diff options
author | Kent Overstreet <kmo@daterainc.com> | 2013-08-10 06:14:13 +0200 |
---|---|---|
committer | Kent Overstreet <kmo@daterainc.com> | 2014-01-08 22:05:07 +0100 |
commit | d56d000a1f424aa77538bd5aad18b43037ed20cc (patch) | |
tree | 77a303f11e2462546f0e621fa9a5a4d840d23dba /drivers/md/bcache/bset.c | |
parent | bcache: Minor btree cache fix (diff) | |
download | linux-d56d000a1f424aa77538bd5aad18b43037ed20cc.tar.xz linux-d56d000a1f424aa77538bd5aad18b43037ed20cc.zip |
bcache: Don't touch bucket gen for dirty ptrs
Unnecessary since a bucket that has dirty pointers pointing to it can
never be invalidated - and skipping it is a measurable performance
boost, since the bucket gen will usually be a cache miss.
Signed-off-by: Kent Overstreet <kmo@daterainc.com>
Diffstat (limited to 'drivers/md/bcache/bset.c')
-rw-r--r-- | drivers/md/bcache/bset.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/drivers/md/bcache/bset.c b/drivers/md/bcache/bset.c index 16958704af3b..e51a739f7514 100644 --- a/drivers/md/bcache/bset.c +++ b/drivers/md/bcache/bset.c @@ -176,10 +176,14 @@ bool bch_ptr_bad(struct btree *b, const struct bkey *k) bch_ptr_invalid(b, k)) return true; - for (i = 0; i < KEY_PTRS(k); i++) { + for (i = 0; i < KEY_PTRS(k); i++) if (!ptr_available(b->c, k, i)) return true; + if (!expensive_debug_checks(b->c) && KEY_DIRTY(k)) + return false; + + for (i = 0; i < KEY_PTRS(k); i++) { g = PTR_BUCKET(b->c, k, i); stale = ptr_stale(b->c, k, i); |