svn commit: r199467 -
user/kmacy/releng_8_fcs_buf/sys/cddl/contrib/opensolaris/uts/common/fs/zfs
Kip Macy
kmacy at FreeBSD.org
Wed Nov 18 04:07:16 UTC 2009
Author: kmacy
Date: Wed Nov 18 04:07:16 2009
New Revision: 199467
URL: http://svn.freebsd.org/changeset/base/199467
Log:
only cache buffers that have been read from or written to disk
Modified:
user/kmacy/releng_8_fcs_buf/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/arc.c
Modified: user/kmacy/releng_8_fcs_buf/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/arc.c
==============================================================================
--- user/kmacy/releng_8_fcs_buf/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/arc.c Wed Nov 18 01:43:11 2009 (r199466)
+++ user/kmacy/releng_8_fcs_buf/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/arc.c Wed Nov 18 04:07:16 2009 (r199467)
@@ -1315,6 +1315,10 @@ arc_bgetvp(arc_buf_t *buf)
return;
newbp = buf->b_bp;
+
+ if ((newbp->b_flags & (B_INVAL|B_CACHE)) != B_CACHE)
+ return;
+
newbp->b_offset = newbp->b_birth = hdr->b_birth;
newbp->b_blkno = newbp->b_lblkno = blkno;
@@ -1341,9 +1345,6 @@ arc_bgetvp(arc_buf_t *buf)
bp->b_birth = 0;
brelse(bp);
- newbp->b_flags |= B_CACHE;
- newbp->b_flags &= ~B_INVAL;
-
BO_LOCK(bo);
bgetvp(vp, newbp);
BO_UNLOCK(bo);
@@ -1423,8 +1424,7 @@ arc_brelse(arc_buf_t *buf, void *data, s
return;
}
- if (hdr->b_datacnt == 1)
- arc_bgetvp(buf);
+ arc_bgetvp(buf);
CTR4(KTR_SPARE2, "arc_brelse() bp=%p flags %X size %ld blkno=%ld",
bp, bp->b_flags, size, bp->b_blkno);
brelse(bp);
@@ -2702,8 +2702,11 @@ arc_read_done(zio_t *zio)
if (HDR_IN_HASH_TABLE(hdr))
buf_hash_remove(hdr);
freeable = refcount_is_zero(&hdr->b_refcnt);
+ } else if (buf->b_bp != NULL) {
+ buf->b_bp->b_flags |= B_CACHE;
+ buf->b_bp->b_flags &= ~B_INVAL;
}
-
+
/*
* Broadcast before we drop the hash_lock to avoid the possibility
* that the hdr (and hence the cv) might be freed before we get to
@@ -3415,7 +3418,10 @@ arc_write_done(zio_t *zio)
arc_hdr_destroy(exists);
exists = buf_hash_insert(hdr, &hash_lock);
ASSERT3P(exists, ==, NULL);
- }
+ } else if (buf->b_bp != NULL) {
+ buf->b_bp->b_flags |= B_CACHE;
+ buf->b_bp->b_flags &= ~B_INVAL;
+ }
hdr->b_flags &= ~ARC_IO_IN_PROGRESS;
/* if it's not anon, we are doing a scrub */
More information about the svn-src-user
mailing list