aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/md
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/md')
-rw-r--r--drivers/md/dm-snap.c2
-rw-r--r--drivers/md/dm-stripe.c6
-rw-r--r--drivers/md/dm.c18
3 files changed, 14 insertions, 12 deletions
diff --git a/drivers/md/dm-snap.c b/drivers/md/dm-snap.c
index 96feada5e761..5974d3094d97 100644
--- a/drivers/md/dm-snap.c
+++ b/drivers/md/dm-snap.c
@@ -1692,7 +1692,7 @@ static int snapshot_merge_map(struct dm_target *ti, struct bio *bio,
1692 chunk_t chunk; 1692 chunk_t chunk;
1693 1693
1694 if (unlikely(bio_empty_barrier(bio))) { 1694 if (unlikely(bio_empty_barrier(bio))) {
1695 if (!map_context->flush_request) 1695 if (!map_context->target_request_nr)
1696 bio->bi_bdev = s->origin->bdev; 1696 bio->bi_bdev = s->origin->bdev;
1697 else 1697 else
1698 bio->bi_bdev = s->cow->bdev; 1698 bio->bi_bdev = s->cow->bdev;
diff --git a/drivers/md/dm-stripe.c b/drivers/md/dm-stripe.c
index d6e28d732b4d..22d5e2fdab8b 100644
--- a/drivers/md/dm-stripe.c
+++ b/drivers/md/dm-stripe.c
@@ -213,10 +213,12 @@ static int stripe_map(struct dm_target *ti, struct bio *bio,
213 struct stripe_c *sc = (struct stripe_c *) ti->private; 213 struct stripe_c *sc = (struct stripe_c *) ti->private;
214 sector_t offset, chunk; 214 sector_t offset, chunk;
215 uint32_t stripe; 215 uint32_t stripe;
216 unsigned target_request_nr;
216 217
217 if (unlikely(bio_empty_barrier(bio))) { 218 if (unlikely(bio_empty_barrier(bio))) {
218 BUG_ON(map_context->flush_request >= sc->stripes); 219 target_request_nr = map_context->target_request_nr;
219 bio->bi_bdev = sc->stripe[map_context->flush_request].dev->bdev; 220 BUG_ON(target_request_nr >= sc->stripes);
221 bio->bi_bdev = sc->stripe[target_request_nr].dev->bdev;
220 return DM_MAPIO_REMAPPED; 222 return DM_MAPIO_REMAPPED;
221 } 223 }
222 224
diff --git a/drivers/md/dm.c b/drivers/md/dm.c
index 5ae0a05b4811..0d4710175885 100644
--- a/drivers/md/dm.c
+++ b/drivers/md/dm.c
@@ -1183,12 +1183,12 @@ static struct dm_target_io *alloc_tio(struct clone_info *ci,
1183} 1183}
1184 1184
1185static void __flush_target(struct clone_info *ci, struct dm_target *ti, 1185static void __flush_target(struct clone_info *ci, struct dm_target *ti,
1186 unsigned flush_nr) 1186 unsigned request_nr)
1187{ 1187{
1188 struct dm_target_io *tio = alloc_tio(ci, ti); 1188 struct dm_target_io *tio = alloc_tio(ci, ti);
1189 struct bio *clone; 1189 struct bio *clone;
1190 1190
1191 tio->info.flush_request = flush_nr; 1191 tio->info.target_request_nr = request_nr;
1192 1192
1193 clone = bio_alloc_bioset(GFP_NOIO, 0, ci->md->bs); 1193 clone = bio_alloc_bioset(GFP_NOIO, 0, ci->md->bs);
1194 __bio_clone(clone, ci->bio); 1194 __bio_clone(clone, ci->bio);
@@ -1199,13 +1199,13 @@ static void __flush_target(struct clone_info *ci, struct dm_target *ti,
1199 1199
1200static int __clone_and_map_empty_barrier(struct clone_info *ci) 1200static int __clone_and_map_empty_barrier(struct clone_info *ci)
1201{ 1201{
1202 unsigned target_nr = 0, flush_nr; 1202 unsigned target_nr = 0, request_nr;
1203 struct dm_target *ti; 1203 struct dm_target *ti;
1204 1204
1205 while ((ti = dm_table_get_target(ci->map, target_nr++))) 1205 while ((ti = dm_table_get_target(ci->map, target_nr++)))
1206 for (flush_nr = 0; flush_nr < ti->num_flush_requests; 1206 for (request_nr = 0; request_nr < ti->num_flush_requests;
1207 flush_nr++) 1207 request_nr++)
1208 __flush_target(ci, ti, flush_nr); 1208 __flush_target(ci, ti, request_nr);
1209 1209
1210 ci->sector_count = 0; 1210 ci->sector_count = 0;
1211 1211
@@ -2424,11 +2424,11 @@ static void dm_queue_flush(struct mapped_device *md)
2424 queue_work(md->wq, &md->work); 2424 queue_work(md->wq, &md->work);
2425} 2425}
2426 2426
2427static void dm_rq_set_flush_nr(struct request *clone, unsigned flush_nr) 2427static void dm_rq_set_target_request_nr(struct request *clone, unsigned request_nr)
2428{ 2428{
2429 struct dm_rq_target_io *tio = clone->end_io_data; 2429 struct dm_rq_target_io *tio = clone->end_io_data;
2430 2430
2431 tio->info.flush_request = flush_nr; 2431 tio->info.target_request_nr = request_nr;
2432} 2432}
2433 2433
2434/* Issue barrier requests to targets and wait for their completion. */ 2434/* Issue barrier requests to targets and wait for their completion. */
@@ -2446,7 +2446,7 @@ static int dm_rq_barrier(struct mapped_device *md)
2446 ti = dm_table_get_target(map, i); 2446 ti = dm_table_get_target(map, i);
2447 for (j = 0; j < ti->num_flush_requests; j++) { 2447 for (j = 0; j < ti->num_flush_requests; j++) {
2448 clone = clone_rq(md->flush_request, md, GFP_NOIO); 2448 clone = clone_rq(md->flush_request, md, GFP_NOIO);
2449 dm_rq_set_flush_nr(clone, j); 2449 dm_rq_set_target_request_nr(clone, j);
2450 atomic_inc(&md->pending[rq_data_dir(clone)]); 2450 atomic_inc(&md->pending[rq_data_dir(clone)]);
2451 map_request(ti, clone, md); 2451 map_request(ti, clone, md);
2452 } 2452 }