diff options
author | Kent Overstreet <koverstreet@google.com> | 2012-05-25 16:03:11 -0400 |
---|---|---|
committer | Kent Overstreet <koverstreet@google.com> | 2013-03-23 17:26:33 -0400 |
commit | a38352e0ac02dbbd4fa464dc22d1352b5fbd06fd (patch) | |
tree | cae9097633ac86ab3b32ee8db9dc2e847929ad06 | |
parent | a07876064a0b73ab5ef1ebcf14b1cf0231c07858 (diff) |
block: Add an explicit bio flag for bios that own their bvec
This is for the new bio splitting code. When we split a bio, if the
split occured on a bvec boundry we reuse the bvec for the new bio. But
that means bio_free() can't free it, hence the explicit flag.
Signed-off-by: Kent Overstreet <koverstreet@google.com>
CC: Jens Axboe <axboe@kernel.dk>
Acked-by: Tejun Heo <tj@kernel.org>
-rw-r--r-- | fs/bio.c | 4 | ||||
-rw-r--r-- | include/linux/bio.h | 5 | ||||
-rw-r--r-- | include/linux/blk_types.h | 1 |
3 files changed, 4 insertions, 6 deletions
@@ -252,7 +252,7 @@ static void bio_free(struct bio *bio) | |||
252 | __bio_free(bio); | 252 | __bio_free(bio); |
253 | 253 | ||
254 | if (bs) { | 254 | if (bs) { |
255 | if (bio_has_allocated_vec(bio)) | 255 | if (bio_flagged(bio, BIO_OWNS_VEC)) |
256 | bvec_free(bs->bvec_pool, bio->bi_io_vec, BIO_POOL_IDX(bio)); | 256 | bvec_free(bs->bvec_pool, bio->bi_io_vec, BIO_POOL_IDX(bio)); |
257 | 257 | ||
258 | /* | 258 | /* |
@@ -451,6 +451,8 @@ struct bio *bio_alloc_bioset(gfp_t gfp_mask, int nr_iovecs, struct bio_set *bs) | |||
451 | 451 | ||
452 | if (unlikely(!bvl)) | 452 | if (unlikely(!bvl)) |
453 | goto err_free; | 453 | goto err_free; |
454 | |||
455 | bio->bi_flags |= 1 << BIO_OWNS_VEC; | ||
454 | } else if (nr_iovecs) { | 456 | } else if (nr_iovecs) { |
455 | bvl = bio->bi_inline_vecs; | 457 | bvl = bio->bi_inline_vecs; |
456 | } | 458 | } |
diff --git a/include/linux/bio.h b/include/linux/bio.h index e25378f2f408..794bcd0c5039 100644 --- a/include/linux/bio.h +++ b/include/linux/bio.h | |||
@@ -85,11 +85,6 @@ static inline void *bio_data(struct bio *bio) | |||
85 | return NULL; | 85 | return NULL; |
86 | } | 86 | } |
87 | 87 | ||
88 | static inline int bio_has_allocated_vec(struct bio *bio) | ||
89 | { | ||
90 | return bio->bi_io_vec && bio->bi_io_vec != bio->bi_inline_vecs; | ||
91 | } | ||
92 | |||
93 | /* | 88 | /* |
94 | * will die | 89 | * will die |
95 | */ | 90 | */ |
diff --git a/include/linux/blk_types.h b/include/linux/blk_types.h index c178d25e588b..538289ffc704 100644 --- a/include/linux/blk_types.h +++ b/include/linux/blk_types.h | |||
@@ -117,6 +117,7 @@ struct bio { | |||
117 | * BIO_POOL_IDX() | 117 | * BIO_POOL_IDX() |
118 | */ | 118 | */ |
119 | #define BIO_RESET_BITS 12 | 119 | #define BIO_RESET_BITS 12 |
120 | #define BIO_OWNS_VEC 12 /* bio_free() should free bvec */ | ||
120 | 121 | ||
121 | #define bio_flagged(bio, flag) ((bio)->bi_flags & (1 << (flag))) | 122 | #define bio_flagged(bio, flag) ((bio)->bi_flags & (1 << (flag))) |
122 | 123 | ||