From be95bd58fc90c8e861fc5fc7b31fa38053635353 Mon Sep 17 00:00:00 2001 From: mckusick Date: Tue, 24 Sep 2002 05:18:17 +0000 Subject: Add support to fsck_ffs to account for storage for extended attributes. Sponsored by: DARPA & NAI Labs. --- sbin/fsck_ffs/pass1.c | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) (limited to 'sbin/fsck_ffs') diff --git a/sbin/fsck_ffs/pass1.c b/sbin/fsck_ffs/pass1.c index a66690c..87cc464 100644 --- a/sbin/fsck_ffs/pass1.c +++ b/sbin/fsck_ffs/pass1.c @@ -191,7 +191,7 @@ checkinode(ino_t inumber, struct inodesc *idesc) off_t kernmaxfilesize; ufs2_daddr_t ndb; mode_t mode; - int j; + int j, ret, offset; dp = getnextinode(inumber); mode = DIP(dp, di_mode) & IFMT; @@ -331,6 +331,24 @@ checkinode(ino_t inumber, struct inodesc *idesc) else idesc->id_type = ADDR; (void)ckinode(dp, idesc); + if (sblock.fs_magic == FS_UFS2_MAGIC && dp->dp2.di_extsize > 0) { + idesc->id_type = ADDR; + ndb = howmany(dp->dp2.di_extsize, sblock.fs_bsize); + for (j = 0; j < NXADDR; j++) { + if (--ndb == 0 && + (offset = blkoff(&sblock, dp->dp2.di_extsize)) != 0) + idesc->id_numfrags = numfrags(&sblock, + fragroundup(&sblock, offset)); + else + idesc->id_numfrags = sblock.fs_frag; + if (dp->dp2.di_extb[j] == 0) + continue; + idesc->id_blkno = dp->dp2.di_extb[j]; + ret = (*idesc->id_func)(idesc); + if (ret & STOP) + break; + } + } if (sblock.fs_magic == FS_UFS2_MAGIC) eascan(idesc, &dp->dp2); idesc->id_entryno *= btodb(sblock.fs_fsize); -- cgit v1.1