aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/md
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/md')
-rw-r--r--drivers/md/dm-ioctl.c67
1 files changed, 31 insertions, 36 deletions
diff --git a/drivers/md/dm-ioctl.c b/drivers/md/dm-ioctl.c
index 70f83071e9ab..4bc4c4fca90d 100644
--- a/drivers/md/dm-ioctl.c
+++ b/drivers/md/dm-ioctl.c
@@ -573,7 +573,7 @@ static struct dm_table *dm_get_live_or_inactive_table(struct mapped_device *md,
573 * Fills in a dm_ioctl structure, ready for sending back to 573 * Fills in a dm_ioctl structure, ready for sending back to
574 * userland. 574 * userland.
575 */ 575 */
576static int __dev_status(struct mapped_device *md, struct dm_ioctl *param) 576static void __dev_status(struct mapped_device *md, struct dm_ioctl *param)
577{ 577{
578 struct gendisk *disk = dm_disk(md); 578 struct gendisk *disk = dm_disk(md);
579 struct dm_table *table; 579 struct dm_table *table;
@@ -617,8 +617,6 @@ static int __dev_status(struct mapped_device *md, struct dm_ioctl *param)
617 dm_table_put(table); 617 dm_table_put(table);
618 } 618 }
619 } 619 }
620
621 return 0;
622} 620}
623 621
624static int dev_create(struct dm_ioctl *param, size_t param_size) 622static int dev_create(struct dm_ioctl *param, size_t param_size)
@@ -638,14 +636,14 @@ static int dev_create(struct dm_ioctl *param, size_t param_size)
638 return r; 636 return r;
639 637
640 r = dm_hash_insert(param->name, *param->uuid ? param->uuid : NULL, md); 638 r = dm_hash_insert(param->name, *param->uuid ? param->uuid : NULL, md);
641 if (r) { 639 if (r)
642 dm_put(md); 640 goto out;
643 return r;
644 }
645 641
646 param->flags &= ~DM_INACTIVE_PRESENT_FLAG; 642 param->flags &= ~DM_INACTIVE_PRESENT_FLAG;
647 643
648 r = __dev_status(md, param); 644 __dev_status(md, param);
645
646out:
649 dm_put(md); 647 dm_put(md);
650 648
651 return r; 649 return r;
@@ -841,13 +839,17 @@ static int do_suspend(struct dm_ioctl *param)
841 if (param->flags & DM_NOFLUSH_FLAG) 839 if (param->flags & DM_NOFLUSH_FLAG)
842 suspend_flags |= DM_SUSPEND_NOFLUSH_FLAG; 840 suspend_flags |= DM_SUSPEND_NOFLUSH_FLAG;
843 841
844 if (!dm_suspended_md(md)) 842 if (!dm_suspended_md(md)) {
845 r = dm_suspend(md, suspend_flags); 843 r = dm_suspend(md, suspend_flags);
844 if (r)
845 goto out;
846 }
846 847
847 if (!r) 848 __dev_status(md, param);
848 r = __dev_status(md, param);
849 849
850out:
850 dm_put(md); 851 dm_put(md);
852
851 return r; 853 return r;
852} 854}
853 855
@@ -909,7 +911,7 @@ static int do_resume(struct dm_ioctl *param)
909 dm_table_destroy(old_map); 911 dm_table_destroy(old_map);
910 912
911 if (!r) 913 if (!r)
912 r = __dev_status(md, param); 914 __dev_status(md, param);
913 915
914 dm_put(md); 916 dm_put(md);
915 return r; 917 return r;
@@ -933,16 +935,16 @@ static int dev_suspend(struct dm_ioctl *param, size_t param_size)
933 */ 935 */
934static int dev_status(struct dm_ioctl *param, size_t param_size) 936static int dev_status(struct dm_ioctl *param, size_t param_size)
935{ 937{
936 int r;
937 struct mapped_device *md; 938 struct mapped_device *md;
938 939
939 md = find_device(param); 940 md = find_device(param);
940 if (!md) 941 if (!md)
941 return -ENXIO; 942 return -ENXIO;
942 943
943 r = __dev_status(md, param); 944 __dev_status(md, param);
944 dm_put(md); 945 dm_put(md);
945 return r; 946
947 return 0;
946} 948}
947 949
948/* 950/*
@@ -1017,7 +1019,7 @@ static void retrieve_status(struct dm_table *table,
1017 */ 1019 */
1018static int dev_wait(struct dm_ioctl *param, size_t param_size) 1020static int dev_wait(struct dm_ioctl *param, size_t param_size)
1019{ 1021{
1020 int r; 1022 int r = 0;
1021 struct mapped_device *md; 1023 struct mapped_device *md;
1022 struct dm_table *table; 1024 struct dm_table *table;
1023 1025
@@ -1038,9 +1040,7 @@ static int dev_wait(struct dm_ioctl *param, size_t param_size)
1038 * changed to trigger the event, so we may as well tell 1040 * changed to trigger the event, so we may as well tell
1039 * him and save an ioctl. 1041 * him and save an ioctl.
1040 */ 1042 */
1041 r = __dev_status(md, param); 1043 __dev_status(md, param);
1042 if (r)
1043 goto out;
1044 1044
1045 table = dm_get_live_or_inactive_table(md, param); 1045 table = dm_get_live_or_inactive_table(md, param);
1046 if (table) { 1046 if (table) {
@@ -1048,8 +1048,9 @@ static int dev_wait(struct dm_ioctl *param, size_t param_size)
1048 dm_table_put(table); 1048 dm_table_put(table);
1049 } 1049 }
1050 1050
1051 out: 1051out:
1052 dm_put(md); 1052 dm_put(md);
1053
1053 return r; 1054 return r;
1054} 1055}
1055 1056
@@ -1184,7 +1185,7 @@ static int table_load(struct dm_ioctl *param, size_t param_size)
1184 up_write(&_hash_lock); 1185 up_write(&_hash_lock);
1185 1186
1186 param->flags |= DM_INACTIVE_PRESENT_FLAG; 1187 param->flags |= DM_INACTIVE_PRESENT_FLAG;
1187 r = __dev_status(md, param); 1188 __dev_status(md, param);
1188 1189
1189out: 1190out:
1190 dm_put(md); 1191 dm_put(md);
@@ -1194,7 +1195,6 @@ out:
1194 1195
1195static int table_clear(struct dm_ioctl *param, size_t param_size) 1196static int table_clear(struct dm_ioctl *param, size_t param_size)
1196{ 1197{
1197 int r;
1198 struct hash_cell *hc; 1198 struct hash_cell *hc;
1199 struct mapped_device *md; 1199 struct mapped_device *md;
1200 1200
@@ -1214,11 +1214,12 @@ static int table_clear(struct dm_ioctl *param, size_t param_size)
1214 1214
1215 param->flags &= ~DM_INACTIVE_PRESENT_FLAG; 1215 param->flags &= ~DM_INACTIVE_PRESENT_FLAG;
1216 1216
1217 r = __dev_status(hc->md, param); 1217 __dev_status(hc->md, param);
1218 md = hc->md; 1218 md = hc->md;
1219 up_write(&_hash_lock); 1219 up_write(&_hash_lock);
1220 dm_put(md); 1220 dm_put(md);
1221 return r; 1221
1222 return 0;
1222} 1223}
1223 1224
1224/* 1225/*
@@ -1263,7 +1264,6 @@ static void retrieve_deps(struct dm_table *table,
1263 1264
1264static int table_deps(struct dm_ioctl *param, size_t param_size) 1265static int table_deps(struct dm_ioctl *param, size_t param_size)
1265{ 1266{
1266 int r = 0;
1267 struct mapped_device *md; 1267 struct mapped_device *md;
1268 struct dm_table *table; 1268 struct dm_table *table;
1269 1269
@@ -1271,9 +1271,7 @@ static int table_deps(struct dm_ioctl *param, size_t param_size)
1271 if (!md) 1271 if (!md)
1272 return -ENXIO; 1272 return -ENXIO;
1273 1273
1274 r = __dev_status(md, param); 1274 __dev_status(md, param);
1275 if (r)
1276 goto out;
1277 1275
1278 table = dm_get_live_or_inactive_table(md, param); 1276 table = dm_get_live_or_inactive_table(md, param);
1279 if (table) { 1277 if (table) {
@@ -1281,9 +1279,9 @@ static int table_deps(struct dm_ioctl *param, size_t param_size)
1281 dm_table_put(table); 1279 dm_table_put(table);
1282 } 1280 }
1283 1281
1284 out:
1285 dm_put(md); 1282 dm_put(md);
1286 return r; 1283
1284 return 0;
1287} 1285}
1288 1286
1289/* 1287/*
@@ -1292,7 +1290,6 @@ static int table_deps(struct dm_ioctl *param, size_t param_size)
1292 */ 1290 */
1293static int table_status(struct dm_ioctl *param, size_t param_size) 1291static int table_status(struct dm_ioctl *param, size_t param_size)
1294{ 1292{
1295 int r;
1296 struct mapped_device *md; 1293 struct mapped_device *md;
1297 struct dm_table *table; 1294 struct dm_table *table;
1298 1295
@@ -1300,9 +1297,7 @@ static int table_status(struct dm_ioctl *param, size_t param_size)
1300 if (!md) 1297 if (!md)
1301 return -ENXIO; 1298 return -ENXIO;
1302 1299
1303 r = __dev_status(md, param); 1300 __dev_status(md, param);
1304 if (r)
1305 goto out;
1306 1301
1307 table = dm_get_live_or_inactive_table(md, param); 1302 table = dm_get_live_or_inactive_table(md, param);
1308 if (table) { 1303 if (table) {
@@ -1310,9 +1305,9 @@ static int table_status(struct dm_ioctl *param, size_t param_size)
1310 dm_table_put(table); 1305 dm_table_put(table);
1311 } 1306 }
1312 1307
1313out:
1314 dm_put(md); 1308 dm_put(md);
1315 return r; 1309
1310 return 0;
1316} 1311}
1317 1312
1318/* 1313/*