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 | ||
