summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTed Unangst <tedu@cvs.openbsd.org>2003-04-26 10:23:08 +0000
committerTed Unangst <tedu@cvs.openbsd.org>2003-04-26 10:23:08 +0000
commite5600d6172708982cbc5269223103702e090e413 (patch)
tree353ba9b67e923a2914d1c6dc2158c9eba3b079c9
parent29243b7892baed62fd625ccc9eb630b96622ef79 (diff)
fix handling when renaming directories on fat32. mv a/b . would mess up the
file system. submitted by mpech@ in pr1675
-rw-r--r--sys/msdosfs/msdosfs_vnops.c16
1 files changed, 12 insertions, 4 deletions
diff --git a/sys/msdosfs/msdosfs_vnops.c b/sys/msdosfs/msdosfs_vnops.c
index c71ae50a164..1e2f568d340 100644
--- a/sys/msdosfs/msdosfs_vnops.c
+++ b/sys/msdosfs/msdosfs_vnops.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: msdosfs_vnops.c,v 1.38 2003/04/18 22:12:25 tedu Exp $ */
+/* $OpenBSD: msdosfs_vnops.c,v 1.39 2003/04/26 10:23:07 tedu Exp $ */
/* $NetBSD: msdosfs_vnops.c,v 1.63 1997/10/17 11:24:19 ws Exp $ */
/*-
@@ -877,7 +877,7 @@ msdosfs_rename(v)
u_char to_count;
int doingdirectory = 0, newparent = 0;
int error;
- u_long cn;
+ u_long cn, pcl;
daddr_t bn;
struct msdosfsmount *pmp;
struct direntry *dotdotp;
@@ -1135,8 +1135,16 @@ abortit:
brelse(bp);
goto bad;
}
- dotdotp = (struct direntry *)bp->b_data + 1;
- putushort(dotdotp->deStartCluster, dp->de_StartCluster);
+ dotdotp = (struct direntry *)bp->b_data;
+ putushort(dotdotp[0].deStartCluster, dp->de_StartCluster);
+ pcl = dp->de_StartCluster;
+ if (FAT32(pmp) && pcl == pmp->pm_rootdirblk)
+ pcl = 0;
+ putushort(dotdotp[1].deStartCluster, pcl);
+ if (FAT32(pmp)) {
+ putushort(dotdotp[0].deHighClust, cn >> 16);
+ putushort(dotdotp[1].deHighClust, pcl >> 16);
+ }
if ((error = bwrite(bp)) != 0) {
/* XXX should really panic here, fs is corrupt */
goto bad;