diff options
Diffstat (limited to 'drivers/md/dm-stripe.c')
-rw-r--r-- | drivers/md/dm-stripe.c | 20 |
1 files changed, 10 insertions, 10 deletions
diff --git a/drivers/md/dm-stripe.c b/drivers/md/dm-stripe.c index e2f876539743..c89cde86d400 100644 --- a/drivers/md/dm-stripe.c +++ b/drivers/md/dm-stripe.c | |||
@@ -162,6 +162,7 @@ static int stripe_ctr(struct dm_target *ti, unsigned int argc, char **argv) | |||
162 | 162 | ||
163 | ti->num_flush_requests = stripes; | 163 | ti->num_flush_requests = stripes; |
164 | ti->num_discard_requests = stripes; | 164 | ti->num_discard_requests = stripes; |
165 | ti->num_write_same_requests = stripes; | ||
165 | 166 | ||
166 | sc->chunk_size = chunk_size; | 167 | sc->chunk_size = chunk_size; |
167 | if (chunk_size & (chunk_size - 1)) | 168 | if (chunk_size & (chunk_size - 1)) |
@@ -251,8 +252,8 @@ static void stripe_map_range_sector(struct stripe_c *sc, sector_t sector, | |||
251 | *result += sc->chunk_size; /* next chunk */ | 252 | *result += sc->chunk_size; /* next chunk */ |
252 | } | 253 | } |
253 | 254 | ||
254 | static int stripe_map_discard(struct stripe_c *sc, struct bio *bio, | 255 | static int stripe_map_range(struct stripe_c *sc, struct bio *bio, |
255 | uint32_t target_stripe) | 256 | uint32_t target_stripe) |
256 | { | 257 | { |
257 | sector_t begin, end; | 258 | sector_t begin, end; |
258 | 259 | ||
@@ -271,23 +272,23 @@ static int stripe_map_discard(struct stripe_c *sc, struct bio *bio, | |||
271 | } | 272 | } |
272 | } | 273 | } |
273 | 274 | ||
274 | static int stripe_map(struct dm_target *ti, struct bio *bio, | 275 | static int stripe_map(struct dm_target *ti, struct bio *bio) |
275 | union map_info *map_context) | ||
276 | { | 276 | { |
277 | struct stripe_c *sc = ti->private; | 277 | struct stripe_c *sc = ti->private; |
278 | uint32_t stripe; | 278 | uint32_t stripe; |
279 | unsigned target_request_nr; | 279 | unsigned target_request_nr; |
280 | 280 | ||
281 | if (bio->bi_rw & REQ_FLUSH) { | 281 | if (bio->bi_rw & REQ_FLUSH) { |
282 | target_request_nr = map_context->target_request_nr; | 282 | target_request_nr = dm_bio_get_target_request_nr(bio); |
283 | BUG_ON(target_request_nr >= sc->stripes); | 283 | BUG_ON(target_request_nr >= sc->stripes); |
284 | bio->bi_bdev = sc->stripe[target_request_nr].dev->bdev; | 284 | bio->bi_bdev = sc->stripe[target_request_nr].dev->bdev; |
285 | return DM_MAPIO_REMAPPED; | 285 | return DM_MAPIO_REMAPPED; |
286 | } | 286 | } |
287 | if (unlikely(bio->bi_rw & REQ_DISCARD)) { | 287 | if (unlikely(bio->bi_rw & REQ_DISCARD) || |
288 | target_request_nr = map_context->target_request_nr; | 288 | unlikely(bio->bi_rw & REQ_WRITE_SAME)) { |
289 | target_request_nr = dm_bio_get_target_request_nr(bio); | ||
289 | BUG_ON(target_request_nr >= sc->stripes); | 290 | BUG_ON(target_request_nr >= sc->stripes); |
290 | return stripe_map_discard(sc, bio, target_request_nr); | 291 | return stripe_map_range(sc, bio, target_request_nr); |
291 | } | 292 | } |
292 | 293 | ||
293 | stripe_map_sector(sc, bio->bi_sector, &stripe, &bio->bi_sector); | 294 | stripe_map_sector(sc, bio->bi_sector, &stripe, &bio->bi_sector); |
@@ -342,8 +343,7 @@ static int stripe_status(struct dm_target *ti, status_type_t type, | |||
342 | return 0; | 343 | return 0; |
343 | } | 344 | } |
344 | 345 | ||
345 | static int stripe_end_io(struct dm_target *ti, struct bio *bio, | 346 | static int stripe_end_io(struct dm_target *ti, struct bio *bio, int error) |
346 | int error, union map_info *map_context) | ||
347 | { | 347 | { |
348 | unsigned i; | 348 | unsigned i; |
349 | char major_minor[16]; | 349 | char major_minor[16]; |