-----BEGIN PGP SIGNED MESSAGE----- Hash: SHA1 Add a couple of extra helper routines to drivers/md/dm-bio-list.h. This patch is required for the current dm-loop patch. Kind regards, Bryn. -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.6 (GNU/Linux) Comment: Using GnuPG with Fedora - http://enigmail.mozdev.org iD8DBQFFyF+/6YSQoMYUY94RAnB0AJ9CUAbLJhy9sGeAkQuKvjfPOcXFhgCfXqXT td9QjIOQK+ECBVf3H0Wl83g= =NX1z -----END PGP SIGNATURE-----
Add additional bio list helpers to dm-bio-list.h: bio_list_empty bio_list_nr bio_list_join bio_list_join_init bio_list_merge_init bio_list_push These are used by dm-loop for manipulating lists of bios to be resubmitted by the fs I/O code. Signed-off-by: Heinz Mauelshagen <hjm@xxxxxxxxxx> Signed-off-by: Bryn Reeves <breeves@xxxxxxxxxx> =================================================================== diff --git a/drivers/md/dm-bio-list.h b/drivers/md/dm-bio-list.h index da43496..301efae 100644 --- a/drivers/md/dm-bio-list.h +++ b/drivers/md/dm-bio-list.h @@ -14,11 +14,33 @@ struct bio_list { struct bio *tail; }; +static inline int bio_list_empty(struct bio_list *bl) +{ + return bl->head == NULL && bl->tail == NULL; +} + +#define BIO_LIST_HEAD(bl) struct bio_list bl = { NULL, NULL } + static inline void bio_list_init(struct bio_list *bl) { bl->head = bl->tail = NULL; } +#define bio_for_each(bio, bl) \ + for (bio = (bl)->head; bio; bio = bio->bi_next) + +static inline int bio_list_nr(struct bio_list *bl) +{ + int i=0; + struct bio *bio; + + if(bio_list_empty(bl)) + return i; + bio_for_each(bio, bl) + i++; + return i; +} + static inline void bio_list_add(struct bio_list *bl, struct bio *bio) { bio->bi_next = NULL; @@ -33,9 +55,6 @@ static inline void bio_list_add(struct bio_list *bl, struct bio *bio) static inline void bio_list_merge(struct bio_list *bl, struct bio_list *bl2) { - if (!bl2->head) - return; - if (bl->tail) bl->tail->bi_next = bl2->head; else @@ -58,6 +77,40 @@ static inline void bio_list_merge_head(struct bio_list *bl, bl->head = bl2->head; } +static inline void bio_list_join(struct bio_list *bl, struct bio_list *bl2) +{ + if (bio_list_empty(bl2)) + return; + + bl2->tail->bi_next = bl->head; + bl->head = bl2->head; + + if (!bl->tail) + bl->tail = bl2->tail; +} + +static inline void bio_list_join_init(struct bio_list *bl, struct bio_list *bl2) +{ + bio_list_join(bl, bl2); + bio_list_init(bl2); +} + +static inline void bio_list_merge_init(struct bio_list *bl, + struct bio_list *bl2) +{ + bio_list_merge(bl, bl2); + bio_list_init(bl2); +} + +static inline void bio_list_push(struct bio_list *bl, struct bio *bio) +{ + bio->bi_next = bl->head; + bl->head = bio; + + if (!bl->tail) + bl->tail = bio; +} + static inline struct bio *bio_list_pop(struct bio_list *bl) { struct bio *bio = bl->head;
-- dm-devel mailing list dm-devel@xxxxxxxxxx https://www.redhat.com/mailman/listinfo/dm-devel