diff options
| author | Kent Overstreet <kmo@daterainc.com> | 2013-10-11 18:44:27 -0400 |
|---|---|---|
| committer | Kent Overstreet <kmo@daterainc.com> | 2013-11-24 01:33:47 -0500 |
| commit | 4f024f3797c43cb4b73cd2c50cec728842d0e49e (patch) | |
| tree | 3aedcab02d2ad723a189d01934d1e94fec7a54e1 /include/linux | |
| parent | ed9c47bebeeea4a468b07cfd745c690190f8014c (diff) | |
block: Abstract out bvec iterator
Immutable biovecs are going to require an explicit iterator. To
implement immutable bvecs, a later patch is going to add a bi_bvec_done
member to this struct; for now, this patch effectively just renames
things.
Signed-off-by: Kent Overstreet <kmo@daterainc.com>
Cc: Jens Axboe <axboe@kernel.dk>
Cc: Geert Uytterhoeven <geert@linux-m68k.org>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Paul Mackerras <paulus@samba.org>
Cc: "Ed L. Cashin" <ecashin@coraid.com>
Cc: Nick Piggin <npiggin@kernel.dk>
Cc: Lars Ellenberg <drbd-dev@lists.linbit.com>
Cc: Jiri Kosina <jkosina@suse.cz>
Cc: Matthew Wilcox <willy@linux.intel.com>
Cc: Geoff Levand <geoff@infradead.org>
Cc: Yehuda Sadeh <yehuda@inktank.com>
Cc: Sage Weil <sage@inktank.com>
Cc: Alex Elder <elder@inktank.com>
Cc: ceph-devel@vger.kernel.org
Cc: Joshua Morris <josh.h.morris@us.ibm.com>
Cc: Philip Kelleher <pjk1939@linux.vnet.ibm.com>
Cc: Rusty Russell <rusty@rustcorp.com.au>
Cc: "Michael S. Tsirkin" <mst@redhat.com>
Cc: Konrad Rzeszutek Wilk <konrad.wilk@oracle.com>
Cc: Jeremy Fitzhardinge <jeremy@goop.org>
Cc: Neil Brown <neilb@suse.de>
Cc: Alasdair Kergon <agk@redhat.com>
Cc: Mike Snitzer <snitzer@redhat.com>
Cc: dm-devel@redhat.com
Cc: Martin Schwidefsky <schwidefsky@de.ibm.com>
Cc: Heiko Carstens <heiko.carstens@de.ibm.com>
Cc: linux390@de.ibm.com
Cc: Boaz Harrosh <bharrosh@panasas.com>
Cc: Benny Halevy <bhalevy@tonian.com>
Cc: "James E.J. Bottomley" <JBottomley@parallels.com>
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Cc: "Nicholas A. Bellinger" <nab@linux-iscsi.org>
Cc: Alexander Viro <viro@zeniv.linux.org.uk>
Cc: Chris Mason <chris.mason@fusionio.com>
Cc: "Theodore Ts'o" <tytso@mit.edu>
Cc: Andreas Dilger <adilger.kernel@dilger.ca>
Cc: Jaegeuk Kim <jaegeuk.kim@samsung.com>
Cc: Steven Whitehouse <swhiteho@redhat.com>
Cc: Dave Kleikamp <shaggy@kernel.org>
Cc: Joern Engel <joern@logfs.org>
Cc: Prasad Joshi <prasadjoshi.linux@gmail.com>
Cc: Trond Myklebust <Trond.Myklebust@netapp.com>
Cc: KONISHI Ryusuke <konishi.ryusuke@lab.ntt.co.jp>
Cc: Mark Fasheh <mfasheh@suse.com>
Cc: Joel Becker <jlbec@evilplan.org>
Cc: Ben Myers <bpm@sgi.com>
Cc: xfs@oss.sgi.com
Cc: Steven Rostedt <rostedt@goodmis.org>
Cc: Frederic Weisbecker <fweisbec@gmail.com>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: Len Brown <len.brown@intel.com>
Cc: Pavel Machek <pavel@ucw.cz>
Cc: "Rafael J. Wysocki" <rjw@sisk.pl>
Cc: Herton Ronaldo Krzesinski <herton.krzesinski@canonical.com>
Cc: Ben Hutchings <ben@decadent.org.uk>
Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: Guo Chao <yan@linux.vnet.ibm.com>
Cc: Tejun Heo <tj@kernel.org>
Cc: Asai Thambi S P <asamymuthupa@micron.com>
Cc: Selvan Mani <smani@micron.com>
Cc: Sam Bradshaw <sbradshaw@micron.com>
Cc: Wei Yongjun <yongjun_wei@trendmicro.com.cn>
Cc: "Roger Pau Monné" <roger.pau@citrix.com>
Cc: Jan Beulich <jbeulich@suse.com>
Cc: Stefano Stabellini <stefano.stabellini@eu.citrix.com>
Cc: Ian Campbell <Ian.Campbell@citrix.com>
Cc: Sebastian Ott <sebott@linux.vnet.ibm.com>
Cc: Christian Borntraeger <borntraeger@de.ibm.com>
Cc: Minchan Kim <minchan@kernel.org>
Cc: Jiang Liu <jiang.liu@huawei.com>
Cc: Nitin Gupta <ngupta@vflare.org>
Cc: Jerome Marchand <jmarchand@redhat.com>
Cc: Joe Perches <joe@perches.com>
Cc: Peng Tao <tao.peng@emc.com>
Cc: Andy Adamson <andros@netapp.com>
Cc: fanchaoting <fanchaoting@cn.fujitsu.com>
Cc: Jie Liu <jeff.liu@oracle.com>
Cc: Sunil Mushran <sunil.mushran@gmail.com>
Cc: "Martin K. Petersen" <martin.petersen@oracle.com>
Cc: Namjae Jeon <namjae.jeon@samsung.com>
Cc: Pankaj Kumar <pankaj.km@samsung.com>
Cc: Dan Magenheimer <dan.magenheimer@oracle.com>
Cc: Mel Gorman <mgorman@suse.de>6
Diffstat (limited to 'include/linux')
| -rw-r--r-- | include/linux/bio.h | 16 | ||||
| -rw-r--r-- | include/linux/blk_types.h | 19 |
2 files changed, 20 insertions, 15 deletions
diff --git a/include/linux/bio.h b/include/linux/bio.h index 060ff695085c..e2e0bc642ed1 100644 --- a/include/linux/bio.h +++ b/include/linux/bio.h | |||
| @@ -62,19 +62,19 @@ | |||
| 62 | * on highmem page vectors | 62 | * on highmem page vectors |
| 63 | */ | 63 | */ |
| 64 | #define bio_iovec_idx(bio, idx) (&((bio)->bi_io_vec[(idx)])) | 64 | #define bio_iovec_idx(bio, idx) (&((bio)->bi_io_vec[(idx)])) |
| 65 | #define bio_iovec(bio) bio_iovec_idx((bio), (bio)->bi_idx) | 65 | #define bio_iovec(bio) bio_iovec_idx((bio), (bio)->bi_iter.bi_idx) |
| 66 | #define bio_page(bio) bio_iovec((bio))->bv_page | 66 | #define bio_page(bio) bio_iovec((bio))->bv_page |
| 67 | #define bio_offset(bio) bio_iovec((bio))->bv_offset | 67 | #define bio_offset(bio) bio_iovec((bio))->bv_offset |
| 68 | #define bio_segments(bio) ((bio)->bi_vcnt - (bio)->bi_idx) | 68 | #define bio_segments(bio) ((bio)->bi_vcnt - (bio)->bi_iter.bi_idx) |
| 69 | #define bio_sectors(bio) ((bio)->bi_size >> 9) | 69 | #define bio_sectors(bio) ((bio)->bi_iter.bi_size >> 9) |
| 70 | #define bio_end_sector(bio) ((bio)->bi_sector + bio_sectors((bio))) | 70 | #define bio_end_sector(bio) ((bio)->bi_iter.bi_sector + bio_sectors((bio))) |
| 71 | 71 | ||
| 72 | static inline unsigned int bio_cur_bytes(struct bio *bio) | 72 | static inline unsigned int bio_cur_bytes(struct bio *bio) |
| 73 | { | 73 | { |
| 74 | if (bio->bi_vcnt) | 74 | if (bio->bi_vcnt) |
| 75 | return bio_iovec(bio)->bv_len; | 75 | return bio_iovec(bio)->bv_len; |
| 76 | else /* dataless requests such as discard */ | 76 | else /* dataless requests such as discard */ |
| 77 | return bio->bi_size; | 77 | return bio->bi_iter.bi_size; |
| 78 | } | 78 | } |
| 79 | 79 | ||
| 80 | static inline void *bio_data(struct bio *bio) | 80 | static inline void *bio_data(struct bio *bio) |
| @@ -108,7 +108,7 @@ static inline void *bio_data(struct bio *bio) | |||
| 108 | */ | 108 | */ |
| 109 | 109 | ||
| 110 | #define __BVEC_END(bio) bio_iovec_idx((bio), (bio)->bi_vcnt - 1) | 110 | #define __BVEC_END(bio) bio_iovec_idx((bio), (bio)->bi_vcnt - 1) |
| 111 | #define __BVEC_START(bio) bio_iovec_idx((bio), (bio)->bi_idx) | 111 | #define __BVEC_START(bio) bio_iovec_idx((bio), (bio)->bi_iter.bi_idx) |
| 112 | 112 | ||
| 113 | /* Default implementation of BIOVEC_PHYS_MERGEABLE */ | 113 | /* Default implementation of BIOVEC_PHYS_MERGEABLE */ |
| 114 | #define __BIOVEC_PHYS_MERGEABLE(vec1, vec2) \ | 114 | #define __BIOVEC_PHYS_MERGEABLE(vec1, vec2) \ |
| @@ -150,7 +150,7 @@ static inline void *bio_data(struct bio *bio) | |||
| 150 | i++) | 150 | i++) |
| 151 | 151 | ||
| 152 | #define bio_for_each_segment(bvl, bio, i) \ | 152 | #define bio_for_each_segment(bvl, bio, i) \ |
| 153 | for (i = (bio)->bi_idx; \ | 153 | for (i = (bio)->bi_iter.bi_idx; \ |
| 154 | bvl = bio_iovec_idx((bio), (i)), i < (bio)->bi_vcnt; \ | 154 | bvl = bio_iovec_idx((bio), (i)), i < (bio)->bi_vcnt; \ |
| 155 | i++) | 155 | i++) |
| 156 | 156 | ||
| @@ -365,7 +365,7 @@ static inline char *__bio_kmap_irq(struct bio *bio, unsigned short idx, | |||
| 365 | #define __bio_kunmap_irq(buf, flags) bvec_kunmap_irq(buf, flags) | 365 | #define __bio_kunmap_irq(buf, flags) bvec_kunmap_irq(buf, flags) |
| 366 | 366 | ||
| 367 | #define bio_kmap_irq(bio, flags) \ | 367 | #define bio_kmap_irq(bio, flags) \ |
| 368 | __bio_kmap_irq((bio), (bio)->bi_idx, (flags)) | 368 | __bio_kmap_irq((bio), (bio)->bi_iter.bi_idx, (flags)) |
| 369 | #define bio_kunmap_irq(buf,flags) __bio_kunmap_irq(buf, flags) | 369 | #define bio_kunmap_irq(buf,flags) __bio_kunmap_irq(buf, flags) |
| 370 | 370 | ||
| 371 | /* | 371 | /* |
diff --git a/include/linux/blk_types.h b/include/linux/blk_types.h index 238ef0ed62f8..29b5b84d8a29 100644 --- a/include/linux/blk_types.h +++ b/include/linux/blk_types.h | |||
| @@ -28,13 +28,19 @@ struct bio_vec { | |||
| 28 | unsigned int bv_offset; | 28 | unsigned int bv_offset; |
| 29 | }; | 29 | }; |
| 30 | 30 | ||
| 31 | struct bvec_iter { | ||
| 32 | sector_t bi_sector; /* device address in 512 byte | ||
| 33 | sectors */ | ||
| 34 | unsigned int bi_size; /* residual I/O count */ | ||
| 35 | |||
| 36 | unsigned int bi_idx; /* current index into bvl_vec */ | ||
| 37 | }; | ||
| 38 | |||
| 31 | /* | 39 | /* |
| 32 | * main unit of I/O for the block layer and lower layers (ie drivers and | 40 | * main unit of I/O for the block layer and lower layers (ie drivers and |
| 33 | * stacking drivers) | 41 | * stacking drivers) |
| 34 | */ | 42 | */ |
| 35 | struct bio { | 43 | struct bio { |
| 36 | sector_t bi_sector; /* device address in 512 byte | ||
| 37 | sectors */ | ||
| 38 | struct bio *bi_next; /* request queue link */ | 44 | struct bio *bi_next; /* request queue link */ |
| 39 | struct block_device *bi_bdev; | 45 | struct block_device *bi_bdev; |
| 40 | unsigned long bi_flags; /* status, command, etc */ | 46 | unsigned long bi_flags; /* status, command, etc */ |
| @@ -42,16 +48,13 @@ struct bio { | |||
| 42 | * top bits priority | 48 | * top bits priority |
| 43 | */ | 49 | */ |
| 44 | 50 | ||
| 45 | unsigned short bi_vcnt; /* how many bio_vec's */ | 51 | struct bvec_iter bi_iter; |
| 46 | unsigned short bi_idx; /* current index into bvl_vec */ | ||
| 47 | 52 | ||
| 48 | /* Number of segments in this BIO after | 53 | /* Number of segments in this BIO after |
| 49 | * physical address coalescing is performed. | 54 | * physical address coalescing is performed. |
| 50 | */ | 55 | */ |
| 51 | unsigned int bi_phys_segments; | 56 | unsigned int bi_phys_segments; |
| 52 | 57 | ||
| 53 | unsigned int bi_size; /* residual I/O count */ | ||
| 54 | |||
| 55 | /* | 58 | /* |
| 56 | * To keep track of the max segment size, we account for the | 59 | * To keep track of the max segment size, we account for the |
| 57 | * sizes of the first and last mergeable segments in this bio. | 60 | * sizes of the first and last mergeable segments in this bio. |
| @@ -74,11 +77,13 @@ struct bio { | |||
| 74 | struct bio_integrity_payload *bi_integrity; /* data integrity */ | 77 | struct bio_integrity_payload *bi_integrity; /* data integrity */ |
| 75 | #endif | 78 | #endif |
| 76 | 79 | ||
| 80 | unsigned short bi_vcnt; /* how many bio_vec's */ | ||
| 81 | |||
| 77 | /* | 82 | /* |
| 78 | * Everything starting with bi_max_vecs will be preserved by bio_reset() | 83 | * Everything starting with bi_max_vecs will be preserved by bio_reset() |
| 79 | */ | 84 | */ |
| 80 | 85 | ||
| 81 | unsigned int bi_max_vecs; /* max bvl_vecs we can hold */ | 86 | unsigned short bi_max_vecs; /* max bvl_vecs we can hold */ |
| 82 | 87 | ||
| 83 | atomic_t bi_cnt; /* pin count */ | 88 | atomic_t bi_cnt; /* pin count */ |
| 84 | 89 | ||
