[Patch 4/10] dm: Maintain ordering when deferring bios

From: Joe Thornber
Date: Tue Feb 10 2004 - 12:09:33 EST


Make sure that we maintain ordering when deferring bios.
--- diff/drivers/md/dm.c 2004-02-10 16:11:30.000000000 +0000
+++ source/drivers/md/dm.c 2004-02-10 16:11:37.000000000 +0000
@@ -5,6 +5,7 @@
*/

#include "dm.h"
+#include "dm-bio-list.h"

#include <linux/init.h>
#include <linux/module.h>
@@ -47,7 +48,7 @@
*/
atomic_t pending;
wait_queue_head_t wait;
- struct bio *deferred;
+ struct bio_list deferred;

/*
* The current mapping.
@@ -195,8 +196,7 @@
return 1;
}

- bio->bi_next = md->deferred;
- md->deferred = bio;
+ bio_list_add(&md->deferred, bio);

up_write(&md->lock);
return 0; /* deferred successfully */
@@ -822,8 +822,7 @@
dm_table_resume_targets(md->map);
clear_bit(DMF_SUSPENDED, &md->flags);
clear_bit(DMF_BLOCK_IO, &md->flags);
- def = md->deferred;
- md->deferred = NULL;
+ def = bio_list_get(&md->deferred);
up_write(&md->lock);

flush_deferred_io(def);
--- diff/drivers/md/dm-bio-list.h 1970-01-01 01:00:00.000000000 +0100
+++ source/drivers/md/dm-bio-list.h 2004-02-10 16:11:37.000000000 +0000
@@ -0,0 +1,68 @@
+/*
+ * Copyright (C) 2004 Red Hat UK Ltd.
+ *
+ * This file is released under the GPL.
+ */
+
+#ifndef DM_BIO_LIST_H
+#define DM_BIO_LIST_H
+
+#include <linux/bio.h>
+
+struct bio_list {
+ struct bio *head;
+ struct bio *tail;
+};
+
+static inline void bio_list_init(struct bio_list *bl)
+{
+ bl->head = bl->tail = NULL;
+}
+
+static inline void bio_list_add(struct bio_list *bl, struct bio *bio)
+{
+ bio->bi_next = NULL;
+
+ if (bl->tail)
+ bl->tail->bi_next = bio;
+ else
+ bl->head = bio;
+
+ bl->tail = bio;
+}
+
+static inline void bio_list_merge(struct bio_list *bl, struct bio_list *bl2)
+{
+ if (bl->tail)
+ bl->tail->bi_next = bl2->head;
+ else
+ bl->head = bl2->head;
+
+ bl->tail = bl2->tail;
+}
+
+static inline struct bio *bio_list_pop(struct bio_list *bl)
+{
+ struct bio *bio = bl->head;
+
+ if (bio) {
+ bl->head = bl->head->bi_next;
+ if (!bl->head)
+ bl->tail = NULL;
+
+ bio->bi_next = NULL;
+ }
+
+ return bio;
+}
+
+static inline struct bio *bio_list_get(struct bio_list *bl)
+{
+ struct bio *bio = bl->head;
+
+ bl->head = bl->tail = NULL;
+
+ return bio;
+}
+
+#endif
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/