bio: skip atomic inc/dec of ->bi_cnt for most use cases bio-cnt
authorJens Axboe <axboe@fb.com>
Fri, 17 Apr 2015 22:23:59 +0000 (16:23 -0600)
committerJens Axboe <axboe@fb.com>
Sat, 18 Apr 2015 01:41:24 +0000 (19:41 -0600)
commit7a9dec2ba445ead6b017d89a6cb33143c9a43edf
tree501814676258a618cb9950b9f3561e5431df576e
parent411875b29fc4ef290c6d683af7e0a2ec07a6cb2c
bio: skip atomic inc/dec of ->bi_cnt for most use cases

Struct bio has a reference count that controls when it can be freed.
Most uses cases is allocating the bio, which then returns with a
single reference to it, doing IO, and then dropping that single
reference. We can remove this atomic_dec_and_test() in the completion
path, if nobody else is holding a reference to the bio.

If someone does call bio_get() on the bio, then we flag the bio as
now having valid count and that we must properly honor the reference
count when it's being put.

Tested-by: Robert Elliott <elliott@hp.com>
Signed-off-by: Jens Axboe <axboe@fb.com>
block/bio.c
drivers/md/bcache/request.c
fs/btrfs/volumes.c
fs/xfs/xfs_aops.c
include/linux/bio.h
include/linux/blk_types.h