block: add bio_for_each_bvec_all()
authorOmar Sandoval <osandov@fb.com>
Thu, 16 Apr 2020 21:46:11 +0000 (14:46 -0700)
committerDavid Sterba <dsterba@suse.com>
Mon, 25 May 2020 09:25:24 +0000 (11:25 +0200)
An upcoming Btrfs fix needs to know the original size of a non-cloned
bios. Rather than accessing the bvec table directly, let's add a
bio_for_each_bvec_all() accessor.

Reviewed-by: Johannes Thumshirn <johannes.thumshirn@wdc.com>
Signed-off-by: Omar Sandoval <osandov@fb.com>
Signed-off-by: David Sterba <dsterba@suse.com>
.clang-format
Documentation/block/biovecs.rst
include/linux/bio.h

index e92e6dd..a0a9608 100644 (file)
@@ -80,6 +80,7 @@ ForEachMacros:
   - 'ax25_uid_for_each'
   - '__bio_for_each_bvec'
   - 'bio_for_each_bvec'
+  - 'bio_for_each_bvec_all'
   - 'bio_for_each_integrity_vec'
   - '__bio_for_each_segment'
   - 'bio_for_each_segment'
index ad303a2..36771a1 100644 (file)
@@ -129,6 +129,7 @@ Usage of helpers:
 ::
 
        bio_for_each_segment_all()
+       bio_for_each_bvec_all()
        bio_first_bvec_all()
        bio_first_page_all()
        bio_last_bvec_all()
@@ -143,4 +144,5 @@ Usage of helpers:
   bio_vec' will contain a multi-page IO vector during the iteration::
 
        bio_for_each_bvec()
+       bio_for_each_bvec_all()
        rq_for_each_bvec()
index a0ee494..8e23f51 100644 (file)
@@ -169,6 +169,14 @@ static inline void bio_advance_iter(struct bio *bio, struct bvec_iter *iter,
 #define bio_for_each_bvec(bvl, bio, iter)                      \
        __bio_for_each_bvec(bvl, bio, iter, (bio)->bi_iter)
 
+/*
+ * Iterate over all multi-page bvecs. Drivers shouldn't use this version for the
+ * same reasons as bio_for_each_segment_all().
+ */
+#define bio_for_each_bvec_all(bvl, bio, i)             \
+       for (i = 0, bvl = bio_first_bvec_all(bio);      \
+            i < (bio)->bi_vcnt; i++, bvl++)            \
+
 #define bio_iter_last(bvec, iter) ((iter).bi_size == (bvec).bv_len)
 
 static inline unsigned bio_segments(struct bio *bio)