Date: Wed, 30 Apr 2003 01:24:50 +0300 From: Alex Popa <razor@ldc.ro> To: Lukas Ertl <l.ertl@univie.ac.at> Cc: freebsd-current@freebsd.org Subject: Re: newfs for UFS2 problems Message-ID: <20030429222450.GA59203@ldc.ro> In-Reply-To: <20030426225533.R743@leelou.in.tern> References: <20030426225533.R743@leelou.in.tern>
next in thread | previous in thread | raw e-mail | index | archive | help
Hello, sorry for the delay in testing and answering. The patch seems to work with a little modification, deduced from this: lib/libufs/block.c, line 80: bwrite(struct uufsd *disk, ufs2_daddr_t blockno, const void *data, size_t size) ... cnt = pwrite(disk->d_fd, data, size, (off_t)(blockno * disk->d_bsize)); ... It look that it multiplies by a block size. However, in sys/ufs/ffs/fs.h, lines 68-69 mention the superblock offset is defined in bytes, not blocks. So it seems we need to change your "SBLOCK_UFS1" to "SBLOCK_UFS1 / disk.d_bsize", to get the expected result (overwriting the old ufs1 superblock). This is all I have changed in your patch (the modified patch is below). I have tested it, and dumpfs and mount from 4.8 now complain about a missing magic number / incorrect superblock. Thanks for your help Alex ---8<--- Index: sbin/newfs/mkfs.c =================================================================== RCS file: /home/ncvs/src/sbin/newfs/mkfs.c,v retrieving revision 1.74 diff -u -r1.74 mkfs.c --- sbin/newfs/mkfs.c 22 Feb 2003 23:26:11 -0000 1.74 +++ sbin/newfs/mkfs.c 29 Apr 2003 21:57:33 -0000 @@ -113,6 +113,7 @@ quad_t sizepb; int width; char tmpbuf[100]; /* XXX this will break in about 2,500 years */ + char dummy[SBLOCKSIZE]; /* * Our blocks == sector size, and the version of UFS we are using is @@ -479,8 +480,13 @@ sblock.fs_old_cstotal.cs_nifree = sblock.fs_cstotal.cs_nifree; sblock.fs_old_cstotal.cs_nffree = sblock.fs_cstotal.cs_nffree; } - if (!Nflag) + if (!Nflag) { + if (Oflag != 1) { + memset(dummy, '\0', SBLOCKSIZE); + bwrite(&disk, SBLOCK_UFS1 / disk.d_bsize, dummy, SBLOCKSIZE); + } sbwrite(&disk, 0); + } for (i = 0; i < sblock.fs_cssize; i += sblock.fs_bsize) wtfs(fsbtodb(&sblock, sblock.fs_csaddr + numfrags(&sblock, i)), sblock.fs_cssize - i < sblock.fs_bsize ? ---8<--- On Sat, Apr 26, 2003 at 11:01:41PM +0200, Lukas Ertl wrote: > Alex Popa wrote: > > > It seems the problem is partly caused by newfs on -current, which does > > not remove the old UFS1 magic when creating an UFS2 superblock at a > > different location. This leftover magic is seen by the -stable kernel > > and therefore used. > > Hi Alex, > > could you try this patch to newfs(8)? It wipes the old UFS1 superblock > at location SBLOCK_UFS1 before writing the new superblock at location > SBLOCK_UFS2. > > > best regards, > le > > -- > Lukas Ertl eMail: l.ertl@univie.ac.at > UNIX-Systemadministrator Tel.: (+43 1) 4277-14073 > Zentraler Informatikdienst (ZID) Fax.: (+43 1) 4277-9140 > der Universit?t Wien http://mailbox.univie.ac.at/~le/ ------------+------------------------------------------------------- Alex Popa, | "Computer science is no more about computers than razor@ldc.ro| astronomy is about telescopes" -- E. W. Dijkstra ------------+------------------------------------------------------
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20030429222450.GA59203>