svn commit: r199033 -
user/kmacy/releng_8_fcs_buf/sys/cddl/contrib/opensolaris/uts/common/fs/zfs
Kip Macy
kmacy at FreeBSD.org
Sun Nov 8 00:11:16 UTC 2009
Author: kmacy
Date: Sun Nov 8 00:11:16 2009
New Revision: 199033
URL: http://svn.freebsd.org/changeset/base/199033
Log:
- ensure that bcopy always happens when cloning
- bypass buf infrastructure for blocks less than PAGE_SIZE
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 Sat Nov 7 23:37:29 2009 (r199032)
+++ user/kmacy/releng_8_fcs_buf/sys/cddl/contrib/opensolaris/uts/common/fs/zfs/arc.c Sun Nov 8 00:11:16 2009 (r199033)
@@ -1305,6 +1305,7 @@ arc_getblk(arc_buf_t *buf)
arc_buf_contents_t type = buf->b_hdr->b_type;
spa_t *spa = buf->b_hdr->b_spa;
off_t blkno = buf->b_hdr->b_dva.dva_word[1] & ~(1UL<<63);
+ void *data;
struct buf *newbp, *bp;
arc_buf_t *tbuf;
struct vnode *vp;
@@ -1323,11 +1324,12 @@ arc_getblk(arc_buf_t *buf)
bo = &vp->v_bufobj;
newbp = NULL;
- if ((size < PAGE_SIZE) ||
- (buf->b_hdr->b_flags & ARC_BUF_CLONING) ||
- BUF_EMPTY(buf->b_hdr)) {
-
+ if ((size < PAGE_SIZE)) {
+ data = zio_buf_alloc(size);
+ } else if ((buf->b_hdr->b_flags & ARC_BUF_CLONING) ||
+ BUF_EMPTY(buf->b_hdr)) {
newbp = geteblk(size, flags);
+ data = newbp->b_data;
} else {
/*
* We need to be careful to handle the case where the buffer
@@ -1358,13 +1360,15 @@ arc_getblk(arc_buf_t *buf)
newbp = getblk(vp, blkno, size, 0, 0, flags);
newbp->b_offset = buf->b_hdr->b_birth;
+ data = newbp->b_data;
}
- if ((size >= PAGE_SIZE) && (buf->b_hdr->b_flags & ARC_BUF_CLONING)) {
+ if (buf->b_hdr->b_flags & ARC_BUF_CLONING) {
vp = spa_get_vnode(spa);
bcopy(buf->b_next->b_data, newbp->b_data, size);
- arc_binval(buf, blkno, vp, size, newbp);
+ if (size >= PAGE_SIZE)
+ arc_binval(buf, blkno, vp, size, newbp);
buf->b_hdr->b_flags &= ~ARC_BUF_CLONING;
}
@@ -1379,7 +1383,7 @@ arc_getblk(arc_buf_t *buf)
BUF_KERNPROC(newbp);
buf->b_bp = newbp;
- buf->b_data = newbp->b_data;
+ buf->b_data = data;
}
static void
@@ -1388,6 +1392,11 @@ arc_brelse(arc_buf_t *buf, void *data, s
struct buf *bp;
bp = buf->b_bp;
+ if (bp == NULL) {
+ zio_buf_free(buf->b_data, size);
+ return;
+ }
+
#ifdef INVARIANTS
if (bp->b_vp) {
KASSERT((buf->b_bp->b_xflags & (BX_VNCLEAN|BX_VNDIRTY)) == BX_VNCLEAN, ("brelse() on buffer that is not clean"));
@@ -1717,6 +1726,7 @@ arc_evict(arc_state_t *state, spa_t *spa
if (type == ARC_BUFC_METADATA) {
offset = 0;
+
list_count = ARC_BUFC_NUMMETADATALISTS;
list_start = &state->arcs_lists[0];
evicted_list_start = &evicted_state->arcs_lists[0];
More information about the svn-src-user
mailing list