diff options
-rw-r--r-- | drivers/md/dm-ioctl.c | 14 | ||||
-rw-r--r-- | drivers/md/dm.c | 24 | ||||
-rw-r--r-- | include/linux/device-mapper.h | 2 |
3 files changed, 20 insertions, 20 deletions
diff --git a/drivers/md/dm-ioctl.c b/drivers/md/dm-ioctl.c index 99de0e4ce831..bf3d19a0fb78 100644 --- a/drivers/md/dm-ioctl.c +++ b/drivers/md/dm-ioctl.c | |||
@@ -235,7 +235,7 @@ static void __hash_remove(struct hash_cell *hc) | |||
235 | dm_set_mdptr(hc->md, NULL); | 235 | dm_set_mdptr(hc->md, NULL); |
236 | mutex_unlock(&dm_hash_cells_mutex); | 236 | mutex_unlock(&dm_hash_cells_mutex); |
237 | 237 | ||
238 | table = dm_get_table(hc->md); | 238 | table = dm_get_live_table(hc->md); |
239 | if (table) { | 239 | if (table) { |
240 | dm_table_event(table); | 240 | dm_table_event(table); |
241 | dm_table_put(table); | 241 | dm_table_put(table); |
@@ -338,7 +338,7 @@ static int dm_hash_rename(uint32_t cookie, const char *old, const char *new) | |||
338 | /* | 338 | /* |
339 | * Wake up any dm event waiters. | 339 | * Wake up any dm event waiters. |
340 | */ | 340 | */ |
341 | table = dm_get_table(hc->md); | 341 | table = dm_get_live_table(hc->md); |
342 | if (table) { | 342 | if (table) { |
343 | dm_table_event(table); | 343 | dm_table_event(table); |
344 | dm_table_put(table); | 344 | dm_table_put(table); |
@@ -564,7 +564,7 @@ static int __dev_status(struct mapped_device *md, struct dm_ioctl *param) | |||
564 | 564 | ||
565 | param->event_nr = dm_get_event_nr(md); | 565 | param->event_nr = dm_get_event_nr(md); |
566 | 566 | ||
567 | table = dm_get_table(md); | 567 | table = dm_get_live_table(md); |
568 | if (table) { | 568 | if (table) { |
569 | param->flags |= DM_ACTIVE_PRESENT_FLAG; | 569 | param->flags |= DM_ACTIVE_PRESENT_FLAG; |
570 | param->target_count = dm_table_get_num_targets(table); | 570 | param->target_count = dm_table_get_num_targets(table); |
@@ -993,7 +993,7 @@ static int dev_wait(struct dm_ioctl *param, size_t param_size) | |||
993 | if (r) | 993 | if (r) |
994 | goto out; | 994 | goto out; |
995 | 995 | ||
996 | table = dm_get_table(md); | 996 | table = dm_get_live_table(md); |
997 | if (table) { | 997 | if (table) { |
998 | retrieve_status(table, param, param_size); | 998 | retrieve_status(table, param, param_size); |
999 | dm_table_put(table); | 999 | dm_table_put(table); |
@@ -1226,7 +1226,7 @@ static int table_deps(struct dm_ioctl *param, size_t param_size) | |||
1226 | if (r) | 1226 | if (r) |
1227 | goto out; | 1227 | goto out; |
1228 | 1228 | ||
1229 | table = dm_get_table(md); | 1229 | table = dm_get_live_table(md); |
1230 | if (table) { | 1230 | if (table) { |
1231 | retrieve_deps(table, param, param_size); | 1231 | retrieve_deps(table, param, param_size); |
1232 | dm_table_put(table); | 1232 | dm_table_put(table); |
@@ -1255,7 +1255,7 @@ static int table_status(struct dm_ioctl *param, size_t param_size) | |||
1255 | if (r) | 1255 | if (r) |
1256 | goto out; | 1256 | goto out; |
1257 | 1257 | ||
1258 | table = dm_get_table(md); | 1258 | table = dm_get_live_table(md); |
1259 | if (table) { | 1259 | if (table) { |
1260 | retrieve_status(table, param, param_size); | 1260 | retrieve_status(table, param, param_size); |
1261 | dm_table_put(table); | 1261 | dm_table_put(table); |
@@ -1299,7 +1299,7 @@ static int target_message(struct dm_ioctl *param, size_t param_size) | |||
1299 | goto out; | 1299 | goto out; |
1300 | } | 1300 | } |
1301 | 1301 | ||
1302 | table = dm_get_table(md); | 1302 | table = dm_get_live_table(md); |
1303 | if (!table) | 1303 | if (!table) |
1304 | goto out_argv; | 1304 | goto out_argv; |
1305 | 1305 | ||
diff --git a/drivers/md/dm.c b/drivers/md/dm.c index 3de8d6d5b0b8..233a2e9156a3 100644 --- a/drivers/md/dm.c +++ b/drivers/md/dm.c | |||
@@ -397,7 +397,7 @@ static int dm_blk_ioctl(struct block_device *bdev, fmode_t mode, | |||
397 | unsigned int cmd, unsigned long arg) | 397 | unsigned int cmd, unsigned long arg) |
398 | { | 398 | { |
399 | struct mapped_device *md = bdev->bd_disk->private_data; | 399 | struct mapped_device *md = bdev->bd_disk->private_data; |
400 | struct dm_table *map = dm_get_table(md); | 400 | struct dm_table *map = dm_get_live_table(md); |
401 | struct dm_target *tgt; | 401 | struct dm_target *tgt; |
402 | int r = -ENOTTY; | 402 | int r = -ENOTTY; |
403 | 403 | ||
@@ -528,7 +528,7 @@ static void queue_io(struct mapped_device *md, struct bio *bio) | |||
528 | * function to access the md->map field, and make sure they call | 528 | * function to access the md->map field, and make sure they call |
529 | * dm_table_put() when finished. | 529 | * dm_table_put() when finished. |
530 | */ | 530 | */ |
531 | struct dm_table *dm_get_table(struct mapped_device *md) | 531 | struct dm_table *dm_get_live_table(struct mapped_device *md) |
532 | { | 532 | { |
533 | struct dm_table *t; | 533 | struct dm_table *t; |
534 | unsigned long flags; | 534 | unsigned long flags; |
@@ -1294,7 +1294,7 @@ static void __split_and_process_bio(struct mapped_device *md, struct bio *bio) | |||
1294 | struct clone_info ci; | 1294 | struct clone_info ci; |
1295 | int error = 0; | 1295 | int error = 0; |
1296 | 1296 | ||
1297 | ci.map = dm_get_table(md); | 1297 | ci.map = dm_get_live_table(md); |
1298 | if (unlikely(!ci.map)) { | 1298 | if (unlikely(!ci.map)) { |
1299 | if (!bio_rw_flagged(bio, BIO_RW_BARRIER)) | 1299 | if (!bio_rw_flagged(bio, BIO_RW_BARRIER)) |
1300 | bio_io_error(bio); | 1300 | bio_io_error(bio); |
@@ -1335,7 +1335,7 @@ static int dm_merge_bvec(struct request_queue *q, | |||
1335 | struct bio_vec *biovec) | 1335 | struct bio_vec *biovec) |
1336 | { | 1336 | { |
1337 | struct mapped_device *md = q->queuedata; | 1337 | struct mapped_device *md = q->queuedata; |
1338 | struct dm_table *map = dm_get_table(md); | 1338 | struct dm_table *map = dm_get_live_table(md); |
1339 | struct dm_target *ti; | 1339 | struct dm_target *ti; |
1340 | sector_t max_sectors; | 1340 | sector_t max_sectors; |
1341 | int max_size = 0; | 1341 | int max_size = 0; |
@@ -1638,7 +1638,7 @@ static void map_request(struct dm_target *ti, struct request *clone, | |||
1638 | static void dm_request_fn(struct request_queue *q) | 1638 | static void dm_request_fn(struct request_queue *q) |
1639 | { | 1639 | { |
1640 | struct mapped_device *md = q->queuedata; | 1640 | struct mapped_device *md = q->queuedata; |
1641 | struct dm_table *map = dm_get_table(md); | 1641 | struct dm_table *map = dm_get_live_table(md); |
1642 | struct dm_target *ti; | 1642 | struct dm_target *ti; |
1643 | struct request *rq, *clone; | 1643 | struct request *rq, *clone; |
1644 | 1644 | ||
@@ -1697,7 +1697,7 @@ static int dm_lld_busy(struct request_queue *q) | |||
1697 | { | 1697 | { |
1698 | int r; | 1698 | int r; |
1699 | struct mapped_device *md = q->queuedata; | 1699 | struct mapped_device *md = q->queuedata; |
1700 | struct dm_table *map = dm_get_table(md); | 1700 | struct dm_table *map = dm_get_live_table(md); |
1701 | 1701 | ||
1702 | if (!map || test_bit(DMF_BLOCK_IO_FOR_SUSPEND, &md->flags)) | 1702 | if (!map || test_bit(DMF_BLOCK_IO_FOR_SUSPEND, &md->flags)) |
1703 | r = 1; | 1703 | r = 1; |
@@ -1712,7 +1712,7 @@ static int dm_lld_busy(struct request_queue *q) | |||
1712 | static void dm_unplug_all(struct request_queue *q) | 1712 | static void dm_unplug_all(struct request_queue *q) |
1713 | { | 1713 | { |
1714 | struct mapped_device *md = q->queuedata; | 1714 | struct mapped_device *md = q->queuedata; |
1715 | struct dm_table *map = dm_get_table(md); | 1715 | struct dm_table *map = dm_get_live_table(md); |
1716 | 1716 | ||
1717 | if (map) { | 1717 | if (map) { |
1718 | if (dm_request_based(md)) | 1718 | if (dm_request_based(md)) |
@@ -1730,7 +1730,7 @@ static int dm_any_congested(void *congested_data, int bdi_bits) | |||
1730 | struct dm_table *map; | 1730 | struct dm_table *map; |
1731 | 1731 | ||
1732 | if (!test_bit(DMF_BLOCK_IO_FOR_SUSPEND, &md->flags)) { | 1732 | if (!test_bit(DMF_BLOCK_IO_FOR_SUSPEND, &md->flags)) { |
1733 | map = dm_get_table(md); | 1733 | map = dm_get_live_table(md); |
1734 | if (map) { | 1734 | if (map) { |
1735 | /* | 1735 | /* |
1736 | * Request-based dm cares about only own queue for | 1736 | * Request-based dm cares about only own queue for |
@@ -2166,7 +2166,7 @@ void dm_put(struct mapped_device *md) | |||
2166 | BUG_ON(test_bit(DMF_FREEING, &md->flags)); | 2166 | BUG_ON(test_bit(DMF_FREEING, &md->flags)); |
2167 | 2167 | ||
2168 | if (atomic_dec_and_lock(&md->holders, &_minor_lock)) { | 2168 | if (atomic_dec_and_lock(&md->holders, &_minor_lock)) { |
2169 | map = dm_get_table(md); | 2169 | map = dm_get_live_table(md); |
2170 | idr_replace(&_minor_idr, MINOR_ALLOCED, | 2170 | idr_replace(&_minor_idr, MINOR_ALLOCED, |
2171 | MINOR(disk_devt(dm_disk(md)))); | 2171 | MINOR(disk_devt(dm_disk(md)))); |
2172 | set_bit(DMF_FREEING, &md->flags); | 2172 | set_bit(DMF_FREEING, &md->flags); |
@@ -2302,7 +2302,7 @@ static void dm_rq_set_flush_nr(struct request *clone, unsigned flush_nr) | |||
2302 | static int dm_rq_barrier(struct mapped_device *md) | 2302 | static int dm_rq_barrier(struct mapped_device *md) |
2303 | { | 2303 | { |
2304 | int i, j; | 2304 | int i, j; |
2305 | struct dm_table *map = dm_get_table(md); | 2305 | struct dm_table *map = dm_get_live_table(md); |
2306 | unsigned num_targets = dm_table_get_num_targets(map); | 2306 | unsigned num_targets = dm_table_get_num_targets(map); |
2307 | struct dm_target *ti; | 2307 | struct dm_target *ti; |
2308 | struct request *clone; | 2308 | struct request *clone; |
@@ -2453,7 +2453,7 @@ int dm_suspend(struct mapped_device *md, unsigned suspend_flags) | |||
2453 | goto out_unlock; | 2453 | goto out_unlock; |
2454 | } | 2454 | } |
2455 | 2455 | ||
2456 | map = dm_get_table(md); | 2456 | map = dm_get_live_table(md); |
2457 | 2457 | ||
2458 | /* | 2458 | /* |
2459 | * DMF_NOFLUSH_SUSPENDING must be set before presuspend. | 2459 | * DMF_NOFLUSH_SUSPENDING must be set before presuspend. |
@@ -2558,7 +2558,7 @@ int dm_resume(struct mapped_device *md) | |||
2558 | if (!dm_suspended(md)) | 2558 | if (!dm_suspended(md)) |
2559 | goto out; | 2559 | goto out; |
2560 | 2560 | ||
2561 | map = dm_get_table(md); | 2561 | map = dm_get_live_table(md); |
2562 | if (!map || !dm_table_get_size(map)) | 2562 | if (!map || !dm_table_get_size(map)) |
2563 | goto out; | 2563 | goto out; |
2564 | 2564 | ||
diff --git a/include/linux/device-mapper.h b/include/linux/device-mapper.h index df7607e6dce8..fc16a351ef7a 100644 --- a/include/linux/device-mapper.h +++ b/include/linux/device-mapper.h | |||
@@ -276,7 +276,7 @@ void dm_table_unplug_all(struct dm_table *t); | |||
276 | /* | 276 | /* |
277 | * Table reference counting. | 277 | * Table reference counting. |
278 | */ | 278 | */ |
279 | struct dm_table *dm_get_table(struct mapped_device *md); | 279 | struct dm_table *dm_get_live_table(struct mapped_device *md); |
280 | void dm_table_get(struct dm_table *t); | 280 | void dm_table_get(struct dm_table *t); |
281 | void dm_table_put(struct dm_table *t); | 281 | void dm_table_put(struct dm_table *t); |
282 | 282 | ||