summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorPedro Martelletto <pedro@cvs.openbsd.org>2006-04-02 17:16:13 +0000
committerPedro Martelletto <pedro@cvs.openbsd.org>2006-04-02 17:16:13 +0000
commitbfd7062d86fa2ab46f3a144bc4e188a682b0fc38 (patch)
treefb646f20e6532db71c09333704bd15992a04481a /sys
parent0014e8ba3edcbb29e01665a71962723c779a89ea (diff)
Cope with FFS2's lazy inode allocation policy, adapted from FreeBSD
Diffstat (limited to 'sys')
-rw-r--r--sys/ufs/ffs/ffs_alloc.c30
1 files changed, 29 insertions, 1 deletions
diff --git a/sys/ufs/ffs/ffs_alloc.c b/sys/ufs/ffs/ffs_alloc.c
index e6162055d68..b42f41d8503 100644
--- a/sys/ufs/ffs/ffs_alloc.c
+++ b/sys/ufs/ffs/ffs_alloc.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ffs_alloc.c,v 1.64 2006/04/02 17:08:14 pedro Exp $ */
+/* $OpenBSD: ffs_alloc.c,v 1.65 2006/04/02 17:16:12 pedro Exp $ */
/* $NetBSD: ffs_alloc.c,v 1.11 1996/05/11 18:27:09 mycroft Exp $ */
/*
@@ -1539,6 +1539,10 @@ ffs_nodealloccg(struct inode *ip, int cg, daddr_t ipref, int mode)
struct cg *cgp;
struct buf *bp;
int error, start, len, loc, map, i;
+#ifdef FFS2
+ struct buf *ibp = NULL;
+ struct ufs2_dinode *dp2;
+#endif
/*
* For efficiency, before looking at the bitmaps for free inodes,
@@ -1627,6 +1631,25 @@ ffs_nodealloccg(struct inode *ip, int cg, daddr_t ipref, int mode)
/* NOTREACHED */
gotit:
+
+#ifdef FFS2
+ /* Check to see if we need to initialize more inodes */
+ if (fs->fs_magic == FS_UFS2_MAGIC &&
+ ipref + INOPB(fs) > cgp->cg_initediblk &&
+ cgp->cg_initediblk < cgp->cg_ffs2_niblk) {
+ ibp = getblk(ip->i_devvp, fsbtodb(fs,
+ ino_to_fsba(fs, cg * fs->fs_ipg + cgp->cg_initediblk)),
+ (int)fs->fs_bsize, 0, 0);
+ bzero(ibp->b_data, (int)fs->fs_bsize);
+ dp2 = (struct ufs2_dinode *)(ibp->b_data);
+ for (i = 0; i < INOPB(fs); i++) {
+ dp2->di_gen = arc4random() / 2 + 1;
+ dp2++;
+ }
+ cgp->cg_initediblk += INOPB(fs);
+ }
+#endif /* FFS2 */
+
if (DOINGSOFTDEP(ITOV(ip)))
softdep_setup_inomapdep(bp, ip, cg * fs->fs_ipg + ipref);
@@ -1647,6 +1670,11 @@ gotit:
bdwrite(bp);
+#ifdef FFS2
+ if (ibp != NULL)
+ bawrite(ibp);
+#endif
+
/* Return the allocated inode number */
return (cg * fs->fs_ipg + ipref);
}