diff options
| author | Kent Overstreet <koverstreet@google.com> | 2012-09-05 18:22:02 -0400 |
|---|---|---|
| committer | Kent Overstreet <koverstreet@google.com> | 2013-03-23 17:26:30 -0400 |
| commit | cb34e057ad22a1c2c6f2cb6cd1cbd05cc2f28f28 (patch) | |
| tree | 4077b8e6e88bc7c5eb4cd738b4203401daba28a9 | |
| parent | d74c6d514fe314b8bdab58b487b25992291577ec (diff) | |
block: Convert some code to bio_for_each_segment_all()
More prep work for immutable bvecs:
A few places in the code were either open coding or using the wrong
version - fix.
After we introduce the bvec iter, it'll no longer be possible to modify
the biovec through bio_for_each_segment_all() - it doesn't increment a
pointer to the current bvec, you pass in a struct bio_vec (not a
pointer) which is updated with what the current biovec would be (taking
into account bi_bvec_done and bi_size).
So because of that it's more worthwhile to be consistent about
bio_for_each_segment()/bio_for_each_segment_all() usage.
Signed-off-by: Kent Overstreet <koverstreet@google.com>
CC: Jens Axboe <axboe@kernel.dk>
CC: NeilBrown <neilb@suse.de>
CC: Alasdair Kergon <agk@redhat.com>
CC: dm-devel@redhat.com
CC: Alexander Viro <viro@zeniv.linux.org.uk>
| -rw-r--r-- | drivers/md/dm-crypt.c | 3 | ||||
| -rw-r--r-- | drivers/md/raid1.c | 10 | ||||
| -rw-r--r-- | fs/bio.c | 20 | ||||
| -rw-r--r-- | fs/direct-io.c | 8 | ||||
| -rw-r--r-- | mm/bounce.c | 2 |
5 files changed, 19 insertions, 24 deletions
diff --git a/drivers/md/dm-crypt.c b/drivers/md/dm-crypt.c index 13c15480d940..6d2d41ae9e32 100644 --- a/drivers/md/dm-crypt.c +++ b/drivers/md/dm-crypt.c | |||
| @@ -858,8 +858,7 @@ static void crypt_free_buffer_pages(struct crypt_config *cc, struct bio *clone) | |||
| 858 | unsigned int i; | 858 | unsigned int i; |
| 859 | struct bio_vec *bv; | 859 | struct bio_vec *bv; |
| 860 | 860 | ||
| 861 | for (i = 0; i < clone->bi_vcnt; i++) { | 861 | bio_for_each_segment_all(bv, clone, i) { |
| 862 | bv = bio_iovec_idx(clone, i); | ||
| 863 | BUG_ON(!bv->bv_page); | 862 | BUG_ON(!bv->bv_page); |
| 864 | mempool_free(bv->bv_page, cc->page_pool); | 863 | mempool_free(bv->bv_page, cc->page_pool); |
| 865 | bv->bv_page = NULL; | 864 | bv->bv_page = NULL; |
diff --git a/drivers/md/raid1.c b/drivers/md/raid1.c index 853482015d3d..a7ea954abe1d 100644 --- a/drivers/md/raid1.c +++ b/drivers/md/raid1.c | |||
| @@ -925,7 +925,7 @@ static void alloc_behind_pages(struct bio *bio, struct r1bio *r1_bio) | |||
| 925 | if (unlikely(!bvecs)) | 925 | if (unlikely(!bvecs)) |
| 926 | return; | 926 | return; |
| 927 | 927 | ||
| 928 | bio_for_each_segment(bvec, bio, i) { | 928 | bio_for_each_segment_all(bvec, bio, i) { |
| 929 | bvecs[i] = *bvec; | 929 | bvecs[i] = *bvec; |
| 930 | bvecs[i].bv_page = alloc_page(GFP_NOIO); | 930 | bvecs[i].bv_page = alloc_page(GFP_NOIO); |
| 931 | if (unlikely(!bvecs[i].bv_page)) | 931 | if (unlikely(!bvecs[i].bv_page)) |
| @@ -1284,12 +1284,8 @@ read_again: | |||
| 1284 | struct bio_vec *bvec; | 1284 | struct bio_vec *bvec; |
| 1285 | int j; | 1285 | int j; |
| 1286 | 1286 | ||
| 1287 | /* Yes, I really want the '__' version so that | 1287 | /* |
| 1288 | * we clear any unused pointer in the io_vec, rather | 1288 | * We trimmed the bio, so _all is legit |
| 1289 | * than leave them unchanged. This is important | ||
| 1290 | * because when we come to free the pages, we won't | ||
| 1291 | * know the original bi_idx, so we just free | ||
| 1292 | * them all | ||
| 1293 | */ | 1289 | */ |
| 1294 | bio_for_each_segment_all(bvec, mbio, j) | 1290 | bio_for_each_segment_all(bvec, mbio, j) |
| 1295 | bvec->bv_page = r1_bio->behind_bvecs[j].bv_page; | 1291 | bvec->bv_page = r1_bio->behind_bvecs[j].bv_page; |
| @@ -1548,11 +1548,11 @@ EXPORT_SYMBOL(bio_copy_kern); | |||
| 1548 | */ | 1548 | */ |
| 1549 | void bio_set_pages_dirty(struct bio *bio) | 1549 | void bio_set_pages_dirty(struct bio *bio) |
| 1550 | { | 1550 | { |
| 1551 | struct bio_vec *bvec = bio->bi_io_vec; | 1551 | struct bio_vec *bvec; |
| 1552 | int i; | 1552 | int i; |
| 1553 | 1553 | ||
| 1554 | for (i = 0; i < bio->bi_vcnt; i++) { | 1554 | bio_for_each_segment_all(bvec, bio, i) { |
| 1555 | struct page *page = bvec[i].bv_page; | 1555 | struct page *page = bvec->bv_page; |
| 1556 | 1556 | ||
| 1557 | if (page && !PageCompound(page)) | 1557 | if (page && !PageCompound(page)) |
| 1558 | set_page_dirty_lock(page); | 1558 | set_page_dirty_lock(page); |
| @@ -1561,11 +1561,11 @@ void bio_set_pages_dirty(struct bio *bio) | |||
| 1561 | 1561 | ||
| 1562 | static void bio_release_pages(struct bio *bio) | 1562 | static void bio_release_pages(struct bio *bio) |
| 1563 | { | 1563 | { |
| 1564 | struct bio_vec *bvec = bio->bi_io_vec; | 1564 | struct bio_vec *bvec; |
| 1565 | int i; | 1565 | int i; |
| 1566 | 1566 | ||
| 1567 | for (i = 0; i < bio->bi_vcnt; i++) { | 1567 | bio_for_each_segment_all(bvec, bio, i) { |
| 1568 | struct page *page = bvec[i].bv_page; | 1568 | struct page *page = bvec->bv_page; |
| 1569 | 1569 | ||
| 1570 | if (page) | 1570 | if (page) |
| 1571 | put_page(page); | 1571 | put_page(page); |
| @@ -1614,16 +1614,16 @@ static void bio_dirty_fn(struct work_struct *work) | |||
| 1614 | 1614 | ||
| 1615 | void bio_check_pages_dirty(struct bio *bio) | 1615 | void bio_check_pages_dirty(struct bio *bio) |
| 1616 | { | 1616 | { |
| 1617 | struct bio_vec *bvec = bio->bi_io_vec; | 1617 | struct bio_vec *bvec; |
| 1618 | int nr_clean_pages = 0; | 1618 | int nr_clean_pages = 0; |
| 1619 | int i; | 1619 | int i; |
| 1620 | 1620 | ||
| 1621 | for (i = 0; i < bio->bi_vcnt; i++) { | 1621 | bio_for_each_segment_all(bvec, bio, i) { |
| 1622 | struct page *page = bvec[i].bv_page; | 1622 | struct page *page = bvec->bv_page; |
| 1623 | 1623 | ||
| 1624 | if (PageDirty(page) || PageCompound(page)) { | 1624 | if (PageDirty(page) || PageCompound(page)) { |
| 1625 | page_cache_release(page); | 1625 | page_cache_release(page); |
| 1626 | bvec[i].bv_page = NULL; | 1626 | bvec->bv_page = NULL; |
| 1627 | } else { | 1627 | } else { |
| 1628 | nr_clean_pages++; | 1628 | nr_clean_pages++; |
| 1629 | } | 1629 | } |
diff --git a/fs/direct-io.c b/fs/direct-io.c index f853263cf74f..38484b08a39a 100644 --- a/fs/direct-io.c +++ b/fs/direct-io.c | |||
| @@ -441,8 +441,8 @@ static struct bio *dio_await_one(struct dio *dio) | |||
| 441 | static int dio_bio_complete(struct dio *dio, struct bio *bio) | 441 | static int dio_bio_complete(struct dio *dio, struct bio *bio) |
| 442 | { | 442 | { |
| 443 | const int uptodate = test_bit(BIO_UPTODATE, &bio->bi_flags); | 443 | const int uptodate = test_bit(BIO_UPTODATE, &bio->bi_flags); |
| 444 | struct bio_vec *bvec = bio->bi_io_vec; | 444 | struct bio_vec *bvec; |
| 445 | int page_no; | 445 | unsigned i; |
| 446 | 446 | ||
| 447 | if (!uptodate) | 447 | if (!uptodate) |
| 448 | dio->io_error = -EIO; | 448 | dio->io_error = -EIO; |
| @@ -450,8 +450,8 @@ static int dio_bio_complete(struct dio *dio, struct bio *bio) | |||
| 450 | if (dio->is_async && dio->rw == READ) { | 450 | if (dio->is_async && dio->rw == READ) { |
| 451 | bio_check_pages_dirty(bio); /* transfers ownership */ | 451 | bio_check_pages_dirty(bio); /* transfers ownership */ |
| 452 | } else { | 452 | } else { |
| 453 | for (page_no = 0; page_no < bio->bi_vcnt; page_no++) { | 453 | bio_for_each_segment_all(bvec, bio, i) { |
| 454 | struct page *page = bvec[page_no].bv_page; | 454 | struct page *page = bvec->bv_page; |
| 455 | 455 | ||
| 456 | if (dio->rw == READ && !PageCompound(page)) | 456 | if (dio->rw == READ && !PageCompound(page)) |
| 457 | set_page_dirty_lock(page); | 457 | set_page_dirty_lock(page); |
diff --git a/mm/bounce.c b/mm/bounce.c index 2ee1b6fef44a..f5326b24d65d 100644 --- a/mm/bounce.c +++ b/mm/bounce.c | |||
| @@ -231,7 +231,7 @@ static void __blk_queue_bounce(struct request_queue *q, struct bio **bio_orig, | |||
| 231 | bounce: | 231 | bounce: |
| 232 | bio = bio_clone_bioset(*bio_orig, GFP_NOIO, fs_bio_set); | 232 | bio = bio_clone_bioset(*bio_orig, GFP_NOIO, fs_bio_set); |
| 233 | 233 | ||
| 234 | bio_for_each_segment(to, bio, i) { | 234 | bio_for_each_segment_all(to, bio, i) { |
| 235 | struct page *page = to->bv_page; | 235 | struct page *page = to->bv_page; |
| 236 | 236 | ||
| 237 | if (page_to_pfn(page) <= queue_bounce_pfn(q) && !force) | 237 | if (page_to_pfn(page) <= queue_bounce_pfn(q) && !force) |
