diff options
26 files changed, 1049 insertions, 1909 deletions
diff --git a/drivers/target/loopback/tcm_loop.h b/drivers/target/loopback/tcm_loop.h index 7b54893db665..dd7a84ee78e1 100644 --- a/drivers/target/loopback/tcm_loop.h +++ b/drivers/target/loopback/tcm_loop.h | |||
@@ -53,7 +53,6 @@ struct tcm_loop_hba { | |||
53 | struct se_hba_s *se_hba; | 53 | struct se_hba_s *se_hba; |
54 | struct se_lun *tl_hba_lun; | 54 | struct se_lun *tl_hba_lun; |
55 | struct se_port *tl_hba_lun_sep; | 55 | struct se_port *tl_hba_lun_sep; |
56 | struct se_device_s *se_dev_hba_ptr; | ||
57 | struct tcm_loop_nexus *tl_nexus; | 56 | struct tcm_loop_nexus *tl_nexus; |
58 | struct device dev; | 57 | struct device dev; |
59 | struct Scsi_Host *sh; | 58 | struct Scsi_Host *sh; |
diff --git a/drivers/target/target_core_alua.c b/drivers/target/target_core_alua.c index 9a5f9a7aecd2..15c127b780d8 100644 --- a/drivers/target/target_core_alua.c +++ b/drivers/target/target_core_alua.c | |||
@@ -61,7 +61,7 @@ struct t10_alua_lu_gp *default_lu_gp; | |||
61 | */ | 61 | */ |
62 | int target_emulate_report_target_port_groups(struct se_cmd *cmd) | 62 | int target_emulate_report_target_port_groups(struct se_cmd *cmd) |
63 | { | 63 | { |
64 | struct se_subsystem_dev *su_dev = cmd->se_dev->se_sub_dev; | 64 | struct se_device *dev = cmd->se_dev; |
65 | struct se_port *port; | 65 | struct se_port *port; |
66 | struct t10_alua_tg_pt_gp *tg_pt_gp; | 66 | struct t10_alua_tg_pt_gp *tg_pt_gp; |
67 | struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem; | 67 | struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem; |
@@ -86,8 +86,8 @@ int target_emulate_report_target_port_groups(struct se_cmd *cmd) | |||
86 | } | 86 | } |
87 | buf = transport_kmap_data_sg(cmd); | 87 | buf = transport_kmap_data_sg(cmd); |
88 | 88 | ||
89 | spin_lock(&su_dev->t10_alua.tg_pt_gps_lock); | 89 | spin_lock(&dev->t10_alua.tg_pt_gps_lock); |
90 | list_for_each_entry(tg_pt_gp, &su_dev->t10_alua.tg_pt_gps_list, | 90 | list_for_each_entry(tg_pt_gp, &dev->t10_alua.tg_pt_gps_list, |
91 | tg_pt_gp_list) { | 91 | tg_pt_gp_list) { |
92 | /* | 92 | /* |
93 | * Check if the Target port group and Target port descriptor list | 93 | * Check if the Target port group and Target port descriptor list |
@@ -160,7 +160,7 @@ int target_emulate_report_target_port_groups(struct se_cmd *cmd) | |||
160 | } | 160 | } |
161 | spin_unlock(&tg_pt_gp->tg_pt_gp_lock); | 161 | spin_unlock(&tg_pt_gp->tg_pt_gp_lock); |
162 | } | 162 | } |
163 | spin_unlock(&su_dev->t10_alua.tg_pt_gps_lock); | 163 | spin_unlock(&dev->t10_alua.tg_pt_gps_lock); |
164 | /* | 164 | /* |
165 | * Set the RETURN DATA LENGTH set in the header of the DataIN Payload | 165 | * Set the RETURN DATA LENGTH set in the header of the DataIN Payload |
166 | */ | 166 | */ |
@@ -203,7 +203,6 @@ int target_emulate_report_target_port_groups(struct se_cmd *cmd) | |||
203 | int target_emulate_set_target_port_groups(struct se_cmd *cmd) | 203 | int target_emulate_set_target_port_groups(struct se_cmd *cmd) |
204 | { | 204 | { |
205 | struct se_device *dev = cmd->se_dev; | 205 | struct se_device *dev = cmd->se_dev; |
206 | struct se_subsystem_dev *su_dev = dev->se_sub_dev; | ||
207 | struct se_port *port, *l_port = cmd->se_lun->lun_sep; | 206 | struct se_port *port, *l_port = cmd->se_lun->lun_sep; |
208 | struct se_node_acl *nacl = cmd->se_sess->se_node_acl; | 207 | struct se_node_acl *nacl = cmd->se_sess->se_node_acl; |
209 | struct t10_alua_tg_pt_gp *tg_pt_gp = NULL, *l_tg_pt_gp; | 208 | struct t10_alua_tg_pt_gp *tg_pt_gp = NULL, *l_tg_pt_gp; |
@@ -303,9 +302,9 @@ int target_emulate_set_target_port_groups(struct se_cmd *cmd) | |||
303 | * Locate the matching target port group ID from | 302 | * Locate the matching target port group ID from |
304 | * the global tg_pt_gp list | 303 | * the global tg_pt_gp list |
305 | */ | 304 | */ |
306 | spin_lock(&su_dev->t10_alua.tg_pt_gps_lock); | 305 | spin_lock(&dev->t10_alua.tg_pt_gps_lock); |
307 | list_for_each_entry(tg_pt_gp, | 306 | list_for_each_entry(tg_pt_gp, |
308 | &su_dev->t10_alua.tg_pt_gps_list, | 307 | &dev->t10_alua.tg_pt_gps_list, |
309 | tg_pt_gp_list) { | 308 | tg_pt_gp_list) { |
310 | if (!tg_pt_gp->tg_pt_gp_valid_id) | 309 | if (!tg_pt_gp->tg_pt_gp_valid_id) |
311 | continue; | 310 | continue; |
@@ -315,18 +314,18 @@ int target_emulate_set_target_port_groups(struct se_cmd *cmd) | |||
315 | 314 | ||
316 | atomic_inc(&tg_pt_gp->tg_pt_gp_ref_cnt); | 315 | atomic_inc(&tg_pt_gp->tg_pt_gp_ref_cnt); |
317 | smp_mb__after_atomic_inc(); | 316 | smp_mb__after_atomic_inc(); |
318 | spin_unlock(&su_dev->t10_alua.tg_pt_gps_lock); | 317 | spin_unlock(&dev->t10_alua.tg_pt_gps_lock); |
319 | 318 | ||
320 | rc = core_alua_do_port_transition(tg_pt_gp, | 319 | rc = core_alua_do_port_transition(tg_pt_gp, |
321 | dev, l_port, nacl, | 320 | dev, l_port, nacl, |
322 | alua_access_state, 1); | 321 | alua_access_state, 1); |
323 | 322 | ||
324 | spin_lock(&su_dev->t10_alua.tg_pt_gps_lock); | 323 | spin_lock(&dev->t10_alua.tg_pt_gps_lock); |
325 | atomic_dec(&tg_pt_gp->tg_pt_gp_ref_cnt); | 324 | atomic_dec(&tg_pt_gp->tg_pt_gp_ref_cnt); |
326 | smp_mb__after_atomic_dec(); | 325 | smp_mb__after_atomic_dec(); |
327 | break; | 326 | break; |
328 | } | 327 | } |
329 | spin_unlock(&su_dev->t10_alua.tg_pt_gps_lock); | 328 | spin_unlock(&dev->t10_alua.tg_pt_gps_lock); |
330 | /* | 329 | /* |
331 | * If not matching target port group ID can be located | 330 | * If not matching target port group ID can be located |
332 | * throw an exception with ASCQ: INVALID_PARAMETER_LIST | 331 | * throw an exception with ASCQ: INVALID_PARAMETER_LIST |
@@ -758,8 +757,7 @@ static int core_alua_update_tpg_primary_metadata( | |||
758 | int primary_state, | 757 | int primary_state, |
759 | unsigned char *md_buf) | 758 | unsigned char *md_buf) |
760 | { | 759 | { |
761 | struct se_subsystem_dev *su_dev = tg_pt_gp->tg_pt_gp_su_dev; | 760 | struct t10_wwn *wwn = &tg_pt_gp->tg_pt_gp_dev->t10_wwn; |
762 | struct t10_wwn *wwn = &su_dev->t10_wwn; | ||
763 | char path[ALUA_METADATA_PATH_LEN]; | 761 | char path[ALUA_METADATA_PATH_LEN]; |
764 | int len; | 762 | int len; |
765 | 763 | ||
@@ -899,7 +897,6 @@ int core_alua_do_port_transition( | |||
899 | { | 897 | { |
900 | struct se_device *dev; | 898 | struct se_device *dev; |
901 | struct se_port *port; | 899 | struct se_port *port; |
902 | struct se_subsystem_dev *su_dev; | ||
903 | struct se_node_acl *nacl; | 900 | struct se_node_acl *nacl; |
904 | struct t10_alua_lu_gp *lu_gp; | 901 | struct t10_alua_lu_gp *lu_gp; |
905 | struct t10_alua_lu_gp_member *lu_gp_mem, *local_lu_gp_mem; | 902 | struct t10_alua_lu_gp_member *lu_gp_mem, *local_lu_gp_mem; |
@@ -949,14 +946,13 @@ int core_alua_do_port_transition( | |||
949 | lu_gp_mem_list) { | 946 | lu_gp_mem_list) { |
950 | 947 | ||
951 | dev = lu_gp_mem->lu_gp_mem_dev; | 948 | dev = lu_gp_mem->lu_gp_mem_dev; |
952 | su_dev = dev->se_sub_dev; | ||
953 | atomic_inc(&lu_gp_mem->lu_gp_mem_ref_cnt); | 949 | atomic_inc(&lu_gp_mem->lu_gp_mem_ref_cnt); |
954 | smp_mb__after_atomic_inc(); | 950 | smp_mb__after_atomic_inc(); |
955 | spin_unlock(&lu_gp->lu_gp_lock); | 951 | spin_unlock(&lu_gp->lu_gp_lock); |
956 | 952 | ||
957 | spin_lock(&su_dev->t10_alua.tg_pt_gps_lock); | 953 | spin_lock(&dev->t10_alua.tg_pt_gps_lock); |
958 | list_for_each_entry(tg_pt_gp, | 954 | list_for_each_entry(tg_pt_gp, |
959 | &su_dev->t10_alua.tg_pt_gps_list, | 955 | &dev->t10_alua.tg_pt_gps_list, |
960 | tg_pt_gp_list) { | 956 | tg_pt_gp_list) { |
961 | 957 | ||
962 | if (!tg_pt_gp->tg_pt_gp_valid_id) | 958 | if (!tg_pt_gp->tg_pt_gp_valid_id) |
@@ -981,7 +977,7 @@ int core_alua_do_port_transition( | |||
981 | } | 977 | } |
982 | atomic_inc(&tg_pt_gp->tg_pt_gp_ref_cnt); | 978 | atomic_inc(&tg_pt_gp->tg_pt_gp_ref_cnt); |
983 | smp_mb__after_atomic_inc(); | 979 | smp_mb__after_atomic_inc(); |
984 | spin_unlock(&su_dev->t10_alua.tg_pt_gps_lock); | 980 | spin_unlock(&dev->t10_alua.tg_pt_gps_lock); |
985 | /* | 981 | /* |
986 | * core_alua_do_transition_tg_pt() will always return | 982 | * core_alua_do_transition_tg_pt() will always return |
987 | * success. | 983 | * success. |
@@ -989,11 +985,11 @@ int core_alua_do_port_transition( | |||
989 | core_alua_do_transition_tg_pt(tg_pt_gp, port, | 985 | core_alua_do_transition_tg_pt(tg_pt_gp, port, |
990 | nacl, md_buf, new_state, explict); | 986 | nacl, md_buf, new_state, explict); |
991 | 987 | ||
992 | spin_lock(&su_dev->t10_alua.tg_pt_gps_lock); | 988 | spin_lock(&dev->t10_alua.tg_pt_gps_lock); |
993 | atomic_dec(&tg_pt_gp->tg_pt_gp_ref_cnt); | 989 | atomic_dec(&tg_pt_gp->tg_pt_gp_ref_cnt); |
994 | smp_mb__after_atomic_dec(); | 990 | smp_mb__after_atomic_dec(); |
995 | } | 991 | } |
996 | spin_unlock(&su_dev->t10_alua.tg_pt_gps_lock); | 992 | spin_unlock(&dev->t10_alua.tg_pt_gps_lock); |
997 | 993 | ||
998 | spin_lock(&lu_gp->lu_gp_lock); | 994 | spin_lock(&lu_gp->lu_gp_lock); |
999 | atomic_dec(&lu_gp_mem->lu_gp_mem_ref_cnt); | 995 | atomic_dec(&lu_gp_mem->lu_gp_mem_ref_cnt); |
@@ -1268,8 +1264,7 @@ void core_alua_free_lu_gp(struct t10_alua_lu_gp *lu_gp) | |||
1268 | 1264 | ||
1269 | void core_alua_free_lu_gp_mem(struct se_device *dev) | 1265 | void core_alua_free_lu_gp_mem(struct se_device *dev) |
1270 | { | 1266 | { |
1271 | struct se_subsystem_dev *su_dev = dev->se_sub_dev; | 1267 | struct t10_alua *alua = &dev->t10_alua; |
1272 | struct t10_alua *alua = &su_dev->t10_alua; | ||
1273 | struct t10_alua_lu_gp *lu_gp; | 1268 | struct t10_alua_lu_gp *lu_gp; |
1274 | struct t10_alua_lu_gp_member *lu_gp_mem; | 1269 | struct t10_alua_lu_gp_member *lu_gp_mem; |
1275 | 1270 | ||
@@ -1358,10 +1353,8 @@ void __core_alua_drop_lu_gp_mem( | |||
1358 | spin_unlock(&lu_gp->lu_gp_lock); | 1353 | spin_unlock(&lu_gp->lu_gp_lock); |
1359 | } | 1354 | } |
1360 | 1355 | ||
1361 | struct t10_alua_tg_pt_gp *core_alua_allocate_tg_pt_gp( | 1356 | struct t10_alua_tg_pt_gp *core_alua_allocate_tg_pt_gp(struct se_device *dev, |
1362 | struct se_subsystem_dev *su_dev, | 1357 | const char *name, int def_group) |
1363 | const char *name, | ||
1364 | int def_group) | ||
1365 | { | 1358 | { |
1366 | struct t10_alua_tg_pt_gp *tg_pt_gp; | 1359 | struct t10_alua_tg_pt_gp *tg_pt_gp; |
1367 | 1360 | ||
@@ -1375,7 +1368,7 @@ struct t10_alua_tg_pt_gp *core_alua_allocate_tg_pt_gp( | |||
1375 | mutex_init(&tg_pt_gp->tg_pt_gp_md_mutex); | 1368 | mutex_init(&tg_pt_gp->tg_pt_gp_md_mutex); |
1376 | spin_lock_init(&tg_pt_gp->tg_pt_gp_lock); | 1369 | spin_lock_init(&tg_pt_gp->tg_pt_gp_lock); |
1377 | atomic_set(&tg_pt_gp->tg_pt_gp_ref_cnt, 0); | 1370 | atomic_set(&tg_pt_gp->tg_pt_gp_ref_cnt, 0); |
1378 | tg_pt_gp->tg_pt_gp_su_dev = su_dev; | 1371 | tg_pt_gp->tg_pt_gp_dev = dev; |
1379 | tg_pt_gp->tg_pt_gp_md_buf_len = ALUA_MD_BUF_LEN; | 1372 | tg_pt_gp->tg_pt_gp_md_buf_len = ALUA_MD_BUF_LEN; |
1380 | atomic_set(&tg_pt_gp->tg_pt_gp_alua_access_state, | 1373 | atomic_set(&tg_pt_gp->tg_pt_gp_alua_access_state, |
1381 | ALUA_ACCESS_STATE_ACTIVE_OPTMIZED); | 1374 | ALUA_ACCESS_STATE_ACTIVE_OPTMIZED); |
@@ -1392,14 +1385,14 @@ struct t10_alua_tg_pt_gp *core_alua_allocate_tg_pt_gp( | |||
1392 | tg_pt_gp->tg_pt_gp_implict_trans_secs = ALUA_DEFAULT_IMPLICT_TRANS_SECS; | 1385 | tg_pt_gp->tg_pt_gp_implict_trans_secs = ALUA_DEFAULT_IMPLICT_TRANS_SECS; |
1393 | 1386 | ||
1394 | if (def_group) { | 1387 | if (def_group) { |
1395 | spin_lock(&su_dev->t10_alua.tg_pt_gps_lock); | 1388 | spin_lock(&dev->t10_alua.tg_pt_gps_lock); |
1396 | tg_pt_gp->tg_pt_gp_id = | 1389 | tg_pt_gp->tg_pt_gp_id = |
1397 | su_dev->t10_alua.alua_tg_pt_gps_counter++; | 1390 | dev->t10_alua.alua_tg_pt_gps_counter++; |
1398 | tg_pt_gp->tg_pt_gp_valid_id = 1; | 1391 | tg_pt_gp->tg_pt_gp_valid_id = 1; |
1399 | su_dev->t10_alua.alua_tg_pt_gps_count++; | 1392 | dev->t10_alua.alua_tg_pt_gps_count++; |
1400 | list_add_tail(&tg_pt_gp->tg_pt_gp_list, | 1393 | list_add_tail(&tg_pt_gp->tg_pt_gp_list, |
1401 | &su_dev->t10_alua.tg_pt_gps_list); | 1394 | &dev->t10_alua.tg_pt_gps_list); |
1402 | spin_unlock(&su_dev->t10_alua.tg_pt_gps_lock); | 1395 | spin_unlock(&dev->t10_alua.tg_pt_gps_lock); |
1403 | } | 1396 | } |
1404 | 1397 | ||
1405 | return tg_pt_gp; | 1398 | return tg_pt_gp; |
@@ -1409,9 +1402,10 @@ int core_alua_set_tg_pt_gp_id( | |||
1409 | struct t10_alua_tg_pt_gp *tg_pt_gp, | 1402 | struct t10_alua_tg_pt_gp *tg_pt_gp, |
1410 | u16 tg_pt_gp_id) | 1403 | u16 tg_pt_gp_id) |
1411 | { | 1404 | { |
1412 | struct se_subsystem_dev *su_dev = tg_pt_gp->tg_pt_gp_su_dev; | 1405 | struct se_device *dev = tg_pt_gp->tg_pt_gp_dev; |
1413 | struct t10_alua_tg_pt_gp *tg_pt_gp_tmp; | 1406 | struct t10_alua_tg_pt_gp *tg_pt_gp_tmp; |
1414 | u16 tg_pt_gp_id_tmp; | 1407 | u16 tg_pt_gp_id_tmp; |
1408 | |||
1415 | /* | 1409 | /* |
1416 | * The tg_pt_gp->tg_pt_gp_id may only be set once.. | 1410 | * The tg_pt_gp->tg_pt_gp_id may only be set once.. |
1417 | */ | 1411 | */ |
@@ -1421,19 +1415,19 @@ int core_alua_set_tg_pt_gp_id( | |||
1421 | return -EINVAL; | 1415 | return -EINVAL; |
1422 | } | 1416 | } |
1423 | 1417 | ||
1424 | spin_lock(&su_dev->t10_alua.tg_pt_gps_lock); | 1418 | spin_lock(&dev->t10_alua.tg_pt_gps_lock); |
1425 | if (su_dev->t10_alua.alua_tg_pt_gps_count == 0x0000ffff) { | 1419 | if (dev->t10_alua.alua_tg_pt_gps_count == 0x0000ffff) { |
1426 | pr_err("Maximum ALUA alua_tg_pt_gps_count:" | 1420 | pr_err("Maximum ALUA alua_tg_pt_gps_count:" |
1427 | " 0x0000ffff reached\n"); | 1421 | " 0x0000ffff reached\n"); |
1428 | spin_unlock(&su_dev->t10_alua.tg_pt_gps_lock); | 1422 | spin_unlock(&dev->t10_alua.tg_pt_gps_lock); |
1429 | kmem_cache_free(t10_alua_tg_pt_gp_cache, tg_pt_gp); | 1423 | kmem_cache_free(t10_alua_tg_pt_gp_cache, tg_pt_gp); |
1430 | return -ENOSPC; | 1424 | return -ENOSPC; |
1431 | } | 1425 | } |
1432 | again: | 1426 | again: |
1433 | tg_pt_gp_id_tmp = (tg_pt_gp_id != 0) ? tg_pt_gp_id : | 1427 | tg_pt_gp_id_tmp = (tg_pt_gp_id != 0) ? tg_pt_gp_id : |
1434 | su_dev->t10_alua.alua_tg_pt_gps_counter++; | 1428 | dev->t10_alua.alua_tg_pt_gps_counter++; |
1435 | 1429 | ||
1436 | list_for_each_entry(tg_pt_gp_tmp, &su_dev->t10_alua.tg_pt_gps_list, | 1430 | list_for_each_entry(tg_pt_gp_tmp, &dev->t10_alua.tg_pt_gps_list, |
1437 | tg_pt_gp_list) { | 1431 | tg_pt_gp_list) { |
1438 | if (tg_pt_gp_tmp->tg_pt_gp_id == tg_pt_gp_id_tmp) { | 1432 | if (tg_pt_gp_tmp->tg_pt_gp_id == tg_pt_gp_id_tmp) { |
1439 | if (!tg_pt_gp_id) | 1433 | if (!tg_pt_gp_id) |
@@ -1441,7 +1435,7 @@ again: | |||
1441 | 1435 | ||
1442 | pr_err("ALUA Target Port Group ID: %hu already" | 1436 | pr_err("ALUA Target Port Group ID: %hu already" |
1443 | " exists, ignoring request\n", tg_pt_gp_id); | 1437 | " exists, ignoring request\n", tg_pt_gp_id); |
1444 | spin_unlock(&su_dev->t10_alua.tg_pt_gps_lock); | 1438 | spin_unlock(&dev->t10_alua.tg_pt_gps_lock); |
1445 | return -EINVAL; | 1439 | return -EINVAL; |
1446 | } | 1440 | } |
1447 | } | 1441 | } |
@@ -1449,9 +1443,9 @@ again: | |||
1449 | tg_pt_gp->tg_pt_gp_id = tg_pt_gp_id_tmp; | 1443 | tg_pt_gp->tg_pt_gp_id = tg_pt_gp_id_tmp; |
1450 | tg_pt_gp->tg_pt_gp_valid_id = 1; | 1444 | tg_pt_gp->tg_pt_gp_valid_id = 1; |
1451 | list_add_tail(&tg_pt_gp->tg_pt_gp_list, | 1445 | list_add_tail(&tg_pt_gp->tg_pt_gp_list, |
1452 | &su_dev->t10_alua.tg_pt_gps_list); | 1446 | &dev->t10_alua.tg_pt_gps_list); |
1453 | su_dev->t10_alua.alua_tg_pt_gps_count++; | 1447 | dev->t10_alua.alua_tg_pt_gps_count++; |
1454 | spin_unlock(&su_dev->t10_alua.tg_pt_gps_lock); | 1448 | spin_unlock(&dev->t10_alua.tg_pt_gps_lock); |
1455 | 1449 | ||
1456 | return 0; | 1450 | return 0; |
1457 | } | 1451 | } |
@@ -1480,8 +1474,9 @@ struct t10_alua_tg_pt_gp_member *core_alua_allocate_tg_pt_gp_mem( | |||
1480 | void core_alua_free_tg_pt_gp( | 1474 | void core_alua_free_tg_pt_gp( |
1481 | struct t10_alua_tg_pt_gp *tg_pt_gp) | 1475 | struct t10_alua_tg_pt_gp *tg_pt_gp) |
1482 | { | 1476 | { |
1483 | struct se_subsystem_dev *su_dev = tg_pt_gp->tg_pt_gp_su_dev; | 1477 | struct se_device *dev = tg_pt_gp->tg_pt_gp_dev; |
1484 | struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem, *tg_pt_gp_mem_tmp; | 1478 | struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem, *tg_pt_gp_mem_tmp; |
1479 | |||
1485 | /* | 1480 | /* |
1486 | * Once we have reached this point, config_item_put() has already | 1481 | * Once we have reached this point, config_item_put() has already |
1487 | * been called from target_core_alua_drop_tg_pt_gp(). | 1482 | * been called from target_core_alua_drop_tg_pt_gp(). |
@@ -1490,10 +1485,11 @@ void core_alua_free_tg_pt_gp( | |||
1490 | * no assications *OR* explict ALUA via SET_TARGET_PORT_GROUPS | 1485 | * no assications *OR* explict ALUA via SET_TARGET_PORT_GROUPS |
1491 | * can be made while we are releasing struct t10_alua_tg_pt_gp. | 1486 | * can be made while we are releasing struct t10_alua_tg_pt_gp. |
1492 | */ | 1487 | */ |
1493 | spin_lock(&su_dev->t10_alua.tg_pt_gps_lock); | 1488 | spin_lock(&dev->t10_alua.tg_pt_gps_lock); |
1494 | list_del(&tg_pt_gp->tg_pt_gp_list); | 1489 | list_del(&tg_pt_gp->tg_pt_gp_list); |
1495 | su_dev->t10_alua.alua_tg_pt_gps_counter--; | 1490 | dev->t10_alua.alua_tg_pt_gps_counter--; |
1496 | spin_unlock(&su_dev->t10_alua.tg_pt_gps_lock); | 1491 | spin_unlock(&dev->t10_alua.tg_pt_gps_lock); |
1492 | |||
1497 | /* | 1493 | /* |
1498 | * Allow a struct t10_alua_tg_pt_gp_member * referenced by | 1494 | * Allow a struct t10_alua_tg_pt_gp_member * referenced by |
1499 | * core_alua_get_tg_pt_gp_by_name() in | 1495 | * core_alua_get_tg_pt_gp_by_name() in |
@@ -1502,6 +1498,7 @@ void core_alua_free_tg_pt_gp( | |||
1502 | */ | 1498 | */ |
1503 | while (atomic_read(&tg_pt_gp->tg_pt_gp_ref_cnt)) | 1499 | while (atomic_read(&tg_pt_gp->tg_pt_gp_ref_cnt)) |
1504 | cpu_relax(); | 1500 | cpu_relax(); |
1501 | |||
1505 | /* | 1502 | /* |
1506 | * Release reference to struct t10_alua_tg_pt_gp from all associated | 1503 | * Release reference to struct t10_alua_tg_pt_gp from all associated |
1507 | * struct se_port. | 1504 | * struct se_port. |
@@ -1525,9 +1522,9 @@ void core_alua_free_tg_pt_gp( | |||
1525 | * default_tg_pt_gp. | 1522 | * default_tg_pt_gp. |
1526 | */ | 1523 | */ |
1527 | spin_lock(&tg_pt_gp_mem->tg_pt_gp_mem_lock); | 1524 | spin_lock(&tg_pt_gp_mem->tg_pt_gp_mem_lock); |
1528 | if (tg_pt_gp != su_dev->t10_alua.default_tg_pt_gp) { | 1525 | if (tg_pt_gp != dev->t10_alua.default_tg_pt_gp) { |
1529 | __core_alua_attach_tg_pt_gp_mem(tg_pt_gp_mem, | 1526 | __core_alua_attach_tg_pt_gp_mem(tg_pt_gp_mem, |
1530 | su_dev->t10_alua.default_tg_pt_gp); | 1527 | dev->t10_alua.default_tg_pt_gp); |
1531 | } else | 1528 | } else |
1532 | tg_pt_gp_mem->tg_pt_gp = NULL; | 1529 | tg_pt_gp_mem->tg_pt_gp = NULL; |
1533 | spin_unlock(&tg_pt_gp_mem->tg_pt_gp_mem_lock); | 1530 | spin_unlock(&tg_pt_gp_mem->tg_pt_gp_mem_lock); |
@@ -1541,8 +1538,7 @@ void core_alua_free_tg_pt_gp( | |||
1541 | 1538 | ||
1542 | void core_alua_free_tg_pt_gp_mem(struct se_port *port) | 1539 | void core_alua_free_tg_pt_gp_mem(struct se_port *port) |
1543 | { | 1540 | { |
1544 | struct se_subsystem_dev *su_dev = port->sep_lun->lun_se_dev->se_sub_dev; | 1541 | struct t10_alua *alua = &port->sep_lun->lun_se_dev->t10_alua; |
1545 | struct t10_alua *alua = &su_dev->t10_alua; | ||
1546 | struct t10_alua_tg_pt_gp *tg_pt_gp; | 1542 | struct t10_alua_tg_pt_gp *tg_pt_gp; |
1547 | struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem; | 1543 | struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem; |
1548 | 1544 | ||
@@ -1574,25 +1570,24 @@ void core_alua_free_tg_pt_gp_mem(struct se_port *port) | |||
1574 | } | 1570 | } |
1575 | 1571 | ||
1576 | static struct t10_alua_tg_pt_gp *core_alua_get_tg_pt_gp_by_name( | 1572 | static struct t10_alua_tg_pt_gp *core_alua_get_tg_pt_gp_by_name( |
1577 | struct se_subsystem_dev *su_dev, | 1573 | struct se_device *dev, const char *name) |
1578 | const char *name) | ||
1579 | { | 1574 | { |
1580 | struct t10_alua_tg_pt_gp *tg_pt_gp; | 1575 | struct t10_alua_tg_pt_gp *tg_pt_gp; |
1581 | struct config_item *ci; | 1576 | struct config_item *ci; |
1582 | 1577 | ||
1583 | spin_lock(&su_dev->t10_alua.tg_pt_gps_lock); | 1578 | spin_lock(&dev->t10_alua.tg_pt_gps_lock); |
1584 | list_for_each_entry(tg_pt_gp, &su_dev->t10_alua.tg_pt_gps_list, | 1579 | list_for_each_entry(tg_pt_gp, &dev->t10_alua.tg_pt_gps_list, |
1585 | tg_pt_gp_list) { | 1580 | tg_pt_gp_list) { |
1586 | if (!tg_pt_gp->tg_pt_gp_valid_id) | 1581 | if (!tg_pt_gp->tg_pt_gp_valid_id) |
1587 | continue; | 1582 | continue; |
1588 | ci = &tg_pt_gp->tg_pt_gp_group.cg_item; | 1583 | ci = &tg_pt_gp->tg_pt_gp_group.cg_item; |
1589 | if (!strcmp(config_item_name(ci), name)) { | 1584 | if (!strcmp(config_item_name(ci), name)) { |
1590 | atomic_inc(&tg_pt_gp->tg_pt_gp_ref_cnt); | 1585 | atomic_inc(&tg_pt_gp->tg_pt_gp_ref_cnt); |
1591 | spin_unlock(&su_dev->t10_alua.tg_pt_gps_lock); | 1586 | spin_unlock(&dev->t10_alua.tg_pt_gps_lock); |
1592 | return tg_pt_gp; | 1587 | return tg_pt_gp; |
1593 | } | 1588 | } |
1594 | } | 1589 | } |
1595 | spin_unlock(&su_dev->t10_alua.tg_pt_gps_lock); | 1590 | spin_unlock(&dev->t10_alua.tg_pt_gps_lock); |
1596 | 1591 | ||
1597 | return NULL; | 1592 | return NULL; |
1598 | } | 1593 | } |
@@ -1600,11 +1595,11 @@ static struct t10_alua_tg_pt_gp *core_alua_get_tg_pt_gp_by_name( | |||
1600 | static void core_alua_put_tg_pt_gp_from_name( | 1595 | static void core_alua_put_tg_pt_gp_from_name( |
1601 | struct t10_alua_tg_pt_gp *tg_pt_gp) | 1596 | struct t10_alua_tg_pt_gp *tg_pt_gp) |
1602 | { | 1597 | { |
1603 | struct se_subsystem_dev *su_dev = tg_pt_gp->tg_pt_gp_su_dev; | 1598 | struct se_device *dev = tg_pt_gp->tg_pt_gp_dev; |
1604 | 1599 | ||
1605 | spin_lock(&su_dev->t10_alua.tg_pt_gps_lock); | 1600 | spin_lock(&dev->t10_alua.tg_pt_gps_lock); |
1606 | atomic_dec(&tg_pt_gp->tg_pt_gp_ref_cnt); | 1601 | atomic_dec(&tg_pt_gp->tg_pt_gp_ref_cnt); |
1607 | spin_unlock(&su_dev->t10_alua.tg_pt_gps_lock); | 1602 | spin_unlock(&dev->t10_alua.tg_pt_gps_lock); |
1608 | } | 1603 | } |
1609 | 1604 | ||
1610 | /* | 1605 | /* |
@@ -1640,9 +1635,8 @@ static void __core_alua_drop_tg_pt_gp_mem( | |||
1640 | 1635 | ||
1641 | ssize_t core_alua_show_tg_pt_gp_info(struct se_port *port, char *page) | 1636 | ssize_t core_alua_show_tg_pt_gp_info(struct se_port *port, char *page) |
1642 | { | 1637 | { |
1643 | struct se_subsystem_dev *su_dev = port->sep_lun->lun_se_dev->se_sub_dev; | ||
1644 | struct config_item *tg_pt_ci; | 1638 | struct config_item *tg_pt_ci; |
1645 | struct t10_alua *alua = &su_dev->t10_alua; | 1639 | struct t10_alua *alua = &port->sep_lun->lun_se_dev->t10_alua; |
1646 | struct t10_alua_tg_pt_gp *tg_pt_gp; | 1640 | struct t10_alua_tg_pt_gp *tg_pt_gp; |
1647 | struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem; | 1641 | struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem; |
1648 | ssize_t len = 0; | 1642 | ssize_t len = 0; |
@@ -1683,7 +1677,7 @@ ssize_t core_alua_store_tg_pt_gp_info( | |||
1683 | { | 1677 | { |
1684 | struct se_portal_group *tpg; | 1678 | struct se_portal_group *tpg; |
1685 | struct se_lun *lun; | 1679 | struct se_lun *lun; |
1686 | struct se_subsystem_dev *su_dev = port->sep_lun->lun_se_dev->se_sub_dev; | 1680 | struct se_device *dev = port->sep_lun->lun_se_dev; |
1687 | struct t10_alua_tg_pt_gp *tg_pt_gp = NULL, *tg_pt_gp_new = NULL; | 1681 | struct t10_alua_tg_pt_gp *tg_pt_gp = NULL, *tg_pt_gp_new = NULL; |
1688 | struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem; | 1682 | struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem; |
1689 | unsigned char buf[TG_PT_GROUP_NAME_BUF]; | 1683 | unsigned char buf[TG_PT_GROUP_NAME_BUF]; |
@@ -1692,7 +1686,7 @@ ssize_t core_alua_store_tg_pt_gp_info( | |||
1692 | tpg = port->sep_tpg; | 1686 | tpg = port->sep_tpg; |
1693 | lun = port->sep_lun; | 1687 | lun = port->sep_lun; |
1694 | 1688 | ||
1695 | if (su_dev->t10_alua.alua_type != SPC3_ALUA_EMULATED) { | 1689 | if (dev->t10_alua.alua_type != SPC3_ALUA_EMULATED) { |
1696 | pr_warn("SPC3_ALUA_EMULATED not enabled for" | 1690 | pr_warn("SPC3_ALUA_EMULATED not enabled for" |
1697 | " %s/tpgt_%hu/%s\n", tpg->se_tpg_tfo->tpg_get_wwn(tpg), | 1691 | " %s/tpgt_%hu/%s\n", tpg->se_tpg_tfo->tpg_get_wwn(tpg), |
1698 | tpg->se_tpg_tfo->tpg_get_tag(tpg), | 1692 | tpg->se_tpg_tfo->tpg_get_tag(tpg), |
@@ -1716,7 +1710,7 @@ ssize_t core_alua_store_tg_pt_gp_info( | |||
1716 | * struct t10_alua_tg_pt_gp. This reference is released with | 1710 | * struct t10_alua_tg_pt_gp. This reference is released with |
1717 | * core_alua_put_tg_pt_gp_from_name() below. | 1711 | * core_alua_put_tg_pt_gp_from_name() below. |
1718 | */ | 1712 | */ |
1719 | tg_pt_gp_new = core_alua_get_tg_pt_gp_by_name(su_dev, | 1713 | tg_pt_gp_new = core_alua_get_tg_pt_gp_by_name(dev, |
1720 | strstrip(buf)); | 1714 | strstrip(buf)); |
1721 | if (!tg_pt_gp_new) | 1715 | if (!tg_pt_gp_new) |
1722 | return -ENODEV; | 1716 | return -ENODEV; |
@@ -1750,7 +1744,7 @@ ssize_t core_alua_store_tg_pt_gp_info( | |||
1750 | 1744 | ||
1751 | __core_alua_drop_tg_pt_gp_mem(tg_pt_gp_mem, tg_pt_gp); | 1745 | __core_alua_drop_tg_pt_gp_mem(tg_pt_gp_mem, tg_pt_gp); |
1752 | __core_alua_attach_tg_pt_gp_mem(tg_pt_gp_mem, | 1746 | __core_alua_attach_tg_pt_gp_mem(tg_pt_gp_mem, |
1753 | su_dev->t10_alua.default_tg_pt_gp); | 1747 | dev->t10_alua.default_tg_pt_gp); |
1754 | spin_unlock(&tg_pt_gp_mem->tg_pt_gp_mem_lock); | 1748 | spin_unlock(&tg_pt_gp_mem->tg_pt_gp_mem_lock); |
1755 | 1749 | ||
1756 | return count; | 1750 | return count; |
@@ -2054,32 +2048,29 @@ ssize_t core_alua_store_secondary_write_metadata( | |||
2054 | return count; | 2048 | return count; |
2055 | } | 2049 | } |
2056 | 2050 | ||
2057 | int core_setup_alua(struct se_device *dev, int force_pt) | 2051 | int core_setup_alua(struct se_device *dev) |
2058 | { | 2052 | { |
2059 | struct se_subsystem_dev *su_dev = dev->se_sub_dev; | 2053 | struct t10_alua *alua = &dev->t10_alua; |
2060 | struct t10_alua *alua = &su_dev->t10_alua; | ||
2061 | struct t10_alua_lu_gp_member *lu_gp_mem; | 2054 | struct t10_alua_lu_gp_member *lu_gp_mem; |
2055 | |||
2062 | /* | 2056 | /* |
2063 | * If this device is from Target_Core_Mod/pSCSI, use the ALUA logic | 2057 | * If this device is from Target_Core_Mod/pSCSI, use the ALUA logic |
2064 | * of the Underlying SCSI hardware. In Linux/SCSI terms, this can | 2058 | * of the Underlying SCSI hardware. In Linux/SCSI terms, this can |
2065 | * cause a problem because libata and some SATA RAID HBAs appear | 2059 | * cause a problem because libata and some SATA RAID HBAs appear |
2066 | * under Linux/SCSI, but emulate SCSI logic themselves. | 2060 | * under Linux/SCSI, but emulate SCSI logic themselves. |
2067 | */ | 2061 | */ |
2068 | if (((dev->transport->transport_type == TRANSPORT_PLUGIN_PHBA_PDEV) && | 2062 | if ((dev->se_hba->hba_flags & HBA_FLAGS_INTERNAL_USE) || |
2069 | !(dev->se_sub_dev->se_dev_attrib.emulate_alua)) || force_pt) { | 2063 | (dev->transport->transport_type == TRANSPORT_PLUGIN_PHBA_PDEV && |
2070 | alua->alua_type = SPC_ALUA_PASSTHROUGH; | 2064 | !dev->dev_attrib.emulate_alua)) { |
2071 | alua->alua_state_check = &core_alua_state_check_nop; | ||
2072 | pr_debug("%s: Using SPC_ALUA_PASSTHROUGH, no ALUA" | 2065 | pr_debug("%s: Using SPC_ALUA_PASSTHROUGH, no ALUA" |
2073 | " emulation\n", dev->transport->name); | 2066 | " emulation\n", dev->transport->name); |
2074 | return 0; | 2067 | |
2075 | } | 2068 | alua->alua_type = SPC_ALUA_PASSTHROUGH; |
2076 | /* | 2069 | alua->alua_state_check = &core_alua_state_check_nop; |
2077 | * If SPC-3 or above is reported by real or emulated struct se_device, | 2070 | } else if (dev->transport->get_device_rev(dev) >= SCSI_3) { |
2078 | * use emulated ALUA. | ||
2079 | */ | ||
2080 | if (dev->transport->get_device_rev(dev) >= SCSI_3) { | ||
2081 | pr_debug("%s: Enabling ALUA Emulation for SPC-3" | 2071 | pr_debug("%s: Enabling ALUA Emulation for SPC-3" |
2082 | " device\n", dev->transport->name); | 2072 | " device\n", dev->transport->name); |
2073 | |||
2083 | /* | 2074 | /* |
2084 | * Associate this struct se_device with the default ALUA | 2075 | * Associate this struct se_device with the default ALUA |
2085 | * LUN Group. | 2076 | * LUN Group. |
@@ -2099,10 +2090,11 @@ int core_setup_alua(struct se_device *dev, int force_pt) | |||
2099 | " core/alua/lu_gps/default_lu_gp\n", | 2090 | " core/alua/lu_gps/default_lu_gp\n", |
2100 | dev->transport->name); | 2091 | dev->transport->name); |
2101 | } else { | 2092 | } else { |
2102 | alua->alua_type = SPC2_ALUA_DISABLED; | ||
2103 | alua->alua_state_check = &core_alua_state_check_nop; | ||
2104 | pr_debug("%s: Disabling ALUA Emulation for SPC-2" | 2093 | pr_debug("%s: Disabling ALUA Emulation for SPC-2" |
2105 | " device\n", dev->transport->name); | 2094 | " device\n", dev->transport->name); |
2095 | |||
2096 | alua->alua_type = SPC2_ALUA_DISABLED; | ||
2097 | alua->alua_state_check = &core_alua_state_check_nop; | ||
2106 | } | 2098 | } |
2107 | 2099 | ||
2108 | return 0; | 2100 | return 0; |
diff --git a/drivers/target/target_core_alua.h b/drivers/target/target_core_alua.h index f920c170d47b..5019157ffe69 100644 --- a/drivers/target/target_core_alua.h +++ b/drivers/target/target_core_alua.h | |||
@@ -91,7 +91,7 @@ extern void __core_alua_drop_lu_gp_mem(struct t10_alua_lu_gp_member *, | |||
91 | struct t10_alua_lu_gp *); | 91 | struct t10_alua_lu_gp *); |
92 | extern void core_alua_drop_lu_gp_dev(struct se_device *); | 92 | extern void core_alua_drop_lu_gp_dev(struct se_device *); |
93 | extern struct t10_alua_tg_pt_gp *core_alua_allocate_tg_pt_gp( | 93 | extern struct t10_alua_tg_pt_gp *core_alua_allocate_tg_pt_gp( |
94 | struct se_subsystem_dev *, const char *, int); | 94 | struct se_device *, const char *, int); |
95 | extern int core_alua_set_tg_pt_gp_id(struct t10_alua_tg_pt_gp *, u16); | 95 | extern int core_alua_set_tg_pt_gp_id(struct t10_alua_tg_pt_gp *, u16); |
96 | extern struct t10_alua_tg_pt_gp_member *core_alua_allocate_tg_pt_gp_mem( | 96 | extern struct t10_alua_tg_pt_gp_member *core_alua_allocate_tg_pt_gp_mem( |
97 | struct se_port *); | 97 | struct se_port *); |
@@ -131,6 +131,6 @@ extern ssize_t core_alua_show_secondary_write_metadata(struct se_lun *, | |||
131 | char *); | 131 | char *); |
132 | extern ssize_t core_alua_store_secondary_write_metadata(struct se_lun *, | 132 | extern ssize_t core_alua_store_secondary_write_metadata(struct se_lun *, |
133 | const char *, size_t); | 133 | const char *, size_t); |
134 | extern int core_setup_alua(struct se_device *, int); | 134 | extern int core_setup_alua(struct se_device *); |
135 | 135 | ||
136 | #endif /* TARGET_CORE_ALUA_H */ | 136 | #endif /* TARGET_CORE_ALUA_H */ |
diff --git a/drivers/target/target_core_configfs.c b/drivers/target/target_core_configfs.c index c123327499a3..7272016ed05f 100644 --- a/drivers/target/target_core_configfs.c +++ b/drivers/target/target_core_configfs.c | |||
@@ -565,21 +565,8 @@ static ssize_t target_core_dev_show_attr_##_name( \ | |||
565 | struct se_dev_attrib *da, \ | 565 | struct se_dev_attrib *da, \ |
566 | char *page) \ | 566 | char *page) \ |
567 | { \ | 567 | { \ |
568 | struct se_device *dev; \ | 568 | return snprintf(page, PAGE_SIZE, "%u\n", \ |
569 | struct se_subsystem_dev *se_dev = da->da_sub_dev; \ | 569 | (u32)da->da_dev->dev_attrib._name); \ |
570 | ssize_t rb; \ | ||
571 | \ | ||
572 | spin_lock(&se_dev->se_dev_lock); \ | ||
573 | dev = se_dev->se_dev_ptr; \ | ||
574 | if (!dev) { \ | ||
575 | spin_unlock(&se_dev->se_dev_lock); \ | ||
576 | return -ENODEV; \ | ||
577 | } \ | ||
578 | rb = snprintf(page, PAGE_SIZE, "%u\n", \ | ||
579 | (u32)dev->se_sub_dev->se_dev_attrib._name); \ | ||
580 | spin_unlock(&se_dev->se_dev_lock); \ | ||
581 | \ | ||
582 | return rb; \ | ||
583 | } | 570 | } |
584 | 571 | ||
585 | #define DEF_DEV_ATTRIB_STORE(_name) \ | 572 | #define DEF_DEV_ATTRIB_STORE(_name) \ |
@@ -588,26 +575,16 @@ static ssize_t target_core_dev_store_attr_##_name( \ | |||
588 | const char *page, \ | 575 | const char *page, \ |
589 | size_t count) \ | 576 | size_t count) \ |
590 | { \ | 577 | { \ |
591 | struct se_device *dev; \ | ||
592 | struct se_subsystem_dev *se_dev = da->da_sub_dev; \ | ||
593 | unsigned long val; \ | 578 | unsigned long val; \ |
594 | int ret; \ | 579 | int ret; \ |
595 | \ | 580 | \ |
596 | spin_lock(&se_dev->se_dev_lock); \ | ||
597 | dev = se_dev->se_dev_ptr; \ | ||
598 | if (!dev) { \ | ||
599 | spin_unlock(&se_dev->se_dev_lock); \ | ||
600 | return -ENODEV; \ | ||
601 | } \ | ||
602 | ret = strict_strtoul(page, 0, &val); \ | 581 | ret = strict_strtoul(page, 0, &val); \ |
603 | if (ret < 0) { \ | 582 | if (ret < 0) { \ |
604 | spin_unlock(&se_dev->se_dev_lock); \ | ||
605 | pr_err("strict_strtoul() failed with" \ | 583 | pr_err("strict_strtoul() failed with" \ |
606 | " ret: %d\n", ret); \ | 584 | " ret: %d\n", ret); \ |
607 | return -EINVAL; \ | 585 | return -EINVAL; \ |
608 | } \ | 586 | } \ |
609 | ret = se_dev_set_##_name(dev, (u32)val); \ | 587 | ret = se_dev_set_##_name(da->da_dev, (u32)val); \ |
610 | spin_unlock(&se_dev->se_dev_lock); \ | ||
611 | \ | 588 | \ |
612 | return (!ret) ? count : -EINVAL; \ | 589 | return (!ret) ? count : -EINVAL; \ |
613 | } | 590 | } |
@@ -764,13 +741,6 @@ static ssize_t target_core_dev_wwn_show_attr_vpd_unit_serial( | |||
764 | struct t10_wwn *t10_wwn, | 741 | struct t10_wwn *t10_wwn, |
765 | char *page) | 742 | char *page) |
766 | { | 743 | { |
767 | struct se_subsystem_dev *se_dev = t10_wwn->t10_sub_dev; | ||
768 | struct se_device *dev; | ||
769 | |||
770 | dev = se_dev->se_dev_ptr; | ||
771 | if (!dev) | ||
772 | return -ENODEV; | ||
773 | |||
774 | return sprintf(page, "T10 VPD Unit Serial Number: %s\n", | 744 | return sprintf(page, "T10 VPD Unit Serial Number: %s\n", |
775 | &t10_wwn->unit_serial[0]); | 745 | &t10_wwn->unit_serial[0]); |
776 | } | 746 | } |
@@ -780,8 +750,7 @@ static ssize_t target_core_dev_wwn_store_attr_vpd_unit_serial( | |||
780 | const char *page, | 750 | const char *page, |
781 | size_t count) | 751 | size_t count) |
782 | { | 752 | { |
783 | struct se_subsystem_dev *su_dev = t10_wwn->t10_sub_dev; | 753 | struct se_device *dev = t10_wwn->t10_dev; |
784 | struct se_device *dev; | ||
785 | unsigned char buf[INQUIRY_VPD_SERIAL_LEN]; | 754 | unsigned char buf[INQUIRY_VPD_SERIAL_LEN]; |
786 | 755 | ||
787 | /* | 756 | /* |
@@ -794,7 +763,7 @@ static ssize_t target_core_dev_wwn_store_attr_vpd_unit_serial( | |||
794 | * it is doing 'the right thing' wrt a world wide unique | 763 | * it is doing 'the right thing' wrt a world wide unique |
795 | * VPD Unit Serial Number that OS dependent multipath can depend on. | 764 | * VPD Unit Serial Number that OS dependent multipath can depend on. |
796 | */ | 765 | */ |
797 | if (su_dev->su_dev_flags & SDF_FIRMWARE_VPD_UNIT_SERIAL) { | 766 | if (dev->dev_flags & DF_FIRMWARE_VPD_UNIT_SERIAL) { |
798 | pr_err("Underlying SCSI device firmware provided VPD" | 767 | pr_err("Underlying SCSI device firmware provided VPD" |
799 | " Unit Serial, ignoring request\n"); | 768 | " Unit Serial, ignoring request\n"); |
800 | return -EOPNOTSUPP; | 769 | return -EOPNOTSUPP; |
@@ -811,15 +780,13 @@ static ssize_t target_core_dev_wwn_store_attr_vpd_unit_serial( | |||
811 | * (underneath the initiator side OS dependent multipath code) | 780 | * (underneath the initiator side OS dependent multipath code) |
812 | * could cause negative effects. | 781 | * could cause negative effects. |
813 | */ | 782 | */ |
814 | dev = su_dev->se_dev_ptr; | 783 | if (dev->export_count) { |
815 | if (dev) { | 784 | pr_err("Unable to set VPD Unit Serial while" |
816 | if (atomic_read(&dev->dev_export_obj.obj_access_count)) { | 785 | " active %d $FABRIC_MOD exports exist\n", |
817 | pr_err("Unable to set VPD Unit Serial while" | 786 | dev->export_count); |
818 | " active %d $FABRIC_MOD exports exist\n", | 787 | return -EINVAL; |
819 | atomic_read(&dev->dev_export_obj.obj_access_count)); | ||
820 | return -EINVAL; | ||
821 | } | ||
822 | } | 788 | } |
789 | |||
823 | /* | 790 | /* |
824 | * This currently assumes ASCII encoding for emulated VPD Unit Serial. | 791 | * This currently assumes ASCII encoding for emulated VPD Unit Serial. |
825 | * | 792 | * |
@@ -828,12 +795,12 @@ static ssize_t target_core_dev_wwn_store_attr_vpd_unit_serial( | |||
828 | */ | 795 | */ |
829 | memset(buf, 0, INQUIRY_VPD_SERIAL_LEN); | 796 | memset(buf, 0, INQUIRY_VPD_SERIAL_LEN); |
830 | snprintf(buf, INQUIRY_VPD_SERIAL_LEN, "%s", page); | 797 | snprintf(buf, INQUIRY_VPD_SERIAL_LEN, "%s", page); |
831 | snprintf(su_dev->t10_wwn.unit_serial, INQUIRY_VPD_SERIAL_LEN, | 798 | snprintf(dev->t10_wwn.unit_serial, INQUIRY_VPD_SERIAL_LEN, |
832 | "%s", strstrip(buf)); | 799 | "%s", strstrip(buf)); |
833 | su_dev->su_dev_flags |= SDF_EMULATED_VPD_UNIT_SERIAL; | 800 | dev->dev_flags |= DF_EMULATED_VPD_UNIT_SERIAL; |
834 | 801 | ||
835 | pr_debug("Target_Core_ConfigFS: Set emulated VPD Unit Serial:" | 802 | pr_debug("Target_Core_ConfigFS: Set emulated VPD Unit Serial:" |
836 | " %s\n", su_dev->t10_wwn.unit_serial); | 803 | " %s\n", dev->t10_wwn.unit_serial); |
837 | 804 | ||
838 | return count; | 805 | return count; |
839 | } | 806 | } |
@@ -847,16 +814,10 @@ static ssize_t target_core_dev_wwn_show_attr_vpd_protocol_identifier( | |||
847 | struct t10_wwn *t10_wwn, | 814 | struct t10_wwn *t10_wwn, |
848 | char *page) | 815 | char *page) |
849 | { | 816 | { |
850 | struct se_subsystem_dev *se_dev = t10_wwn->t10_sub_dev; | ||
851 | struct se_device *dev; | ||
852 | struct t10_vpd *vpd; | 817 | struct t10_vpd *vpd; |
853 | unsigned char buf[VPD_TMP_BUF_SIZE]; | 818 | unsigned char buf[VPD_TMP_BUF_SIZE]; |
854 | ssize_t len = 0; | 819 | ssize_t len = 0; |
855 | 820 | ||
856 | dev = se_dev->se_dev_ptr; | ||
857 | if (!dev) | ||
858 | return -ENODEV; | ||
859 | |||
860 | memset(buf, 0, VPD_TMP_BUF_SIZE); | 821 | memset(buf, 0, VPD_TMP_BUF_SIZE); |
861 | 822 | ||
862 | spin_lock(&t10_wwn->t10_vpd_lock); | 823 | spin_lock(&t10_wwn->t10_vpd_lock); |
@@ -894,16 +855,10 @@ static ssize_t target_core_dev_wwn_show_attr_##_name( \ | |||
894 | struct t10_wwn *t10_wwn, \ | 855 | struct t10_wwn *t10_wwn, \ |
895 | char *page) \ | 856 | char *page) \ |
896 | { \ | 857 | { \ |
897 | struct se_subsystem_dev *se_dev = t10_wwn->t10_sub_dev; \ | ||
898 | struct se_device *dev; \ | ||
899 | struct t10_vpd *vpd; \ | 858 | struct t10_vpd *vpd; \ |
900 | unsigned char buf[VPD_TMP_BUF_SIZE]; \ | 859 | unsigned char buf[VPD_TMP_BUF_SIZE]; \ |
901 | ssize_t len = 0; \ | 860 | ssize_t len = 0; \ |
902 | \ | 861 | \ |
903 | dev = se_dev->se_dev_ptr; \ | ||
904 | if (!dev) \ | ||
905 | return -ENODEV; \ | ||
906 | \ | ||
907 | spin_lock(&t10_wwn->t10_vpd_lock); \ | 862 | spin_lock(&t10_wwn->t10_vpd_lock); \ |
908 | list_for_each_entry(vpd, &t10_wwn->t10_vpd_list, vpd_list) { \ | 863 | list_for_each_entry(vpd, &t10_wwn->t10_vpd_list, vpd_list) { \ |
909 | if (vpd->association != _assoc) \ | 864 | if (vpd->association != _assoc) \ |
@@ -1003,7 +958,7 @@ static struct config_item_type target_core_dev_wwn_cit = { | |||
1003 | 958 | ||
1004 | /* Start functions for struct config_item_type target_core_dev_pr_cit */ | 959 | /* Start functions for struct config_item_type target_core_dev_pr_cit */ |
1005 | 960 | ||
1006 | CONFIGFS_EATTR_STRUCT(target_core_dev_pr, se_subsystem_dev); | 961 | CONFIGFS_EATTR_STRUCT(target_core_dev_pr, se_device); |
1007 | #define SE_DEV_PR_ATTR(_name, _mode) \ | 962 | #define SE_DEV_PR_ATTR(_name, _mode) \ |
1008 | static struct target_core_dev_pr_attribute target_core_dev_pr_##_name = \ | 963 | static struct target_core_dev_pr_attribute target_core_dev_pr_##_name = \ |
1009 | __CONFIGFS_EATTR(_name, _mode, \ | 964 | __CONFIGFS_EATTR(_name, _mode, \ |
@@ -1071,23 +1026,17 @@ static ssize_t target_core_dev_pr_show_spc2_res( | |||
1071 | return *len; | 1026 | return *len; |
1072 | } | 1027 | } |
1073 | 1028 | ||
1074 | static ssize_t target_core_dev_pr_show_attr_res_holder( | 1029 | static ssize_t target_core_dev_pr_show_attr_res_holder(struct se_device *dev, |
1075 | struct se_subsystem_dev *su_dev, | 1030 | char *page) |
1076 | char *page) | ||
1077 | { | 1031 | { |
1078 | ssize_t len = 0; | 1032 | ssize_t len = 0; |
1079 | 1033 | ||
1080 | if (!su_dev->se_dev_ptr) | 1034 | switch (dev->t10_pr.res_type) { |
1081 | return -ENODEV; | ||
1082 | |||
1083 | switch (su_dev->t10_pr.res_type) { | ||
1084 | case SPC3_PERSISTENT_RESERVATIONS: | 1035 | case SPC3_PERSISTENT_RESERVATIONS: |
1085 | target_core_dev_pr_show_spc3_res(su_dev->se_dev_ptr, | 1036 | target_core_dev_pr_show_spc3_res(dev, page, &len); |
1086 | page, &len); | ||
1087 | break; | 1037 | break; |
1088 | case SPC2_RESERVATIONS: | 1038 | case SPC2_RESERVATIONS: |
1089 | target_core_dev_pr_show_spc2_res(su_dev->se_dev_ptr, | 1039 | target_core_dev_pr_show_spc2_res(dev, page, &len); |
1090 | page, &len); | ||
1091 | break; | 1040 | break; |
1092 | case SPC_PASSTHROUGH: | 1041 | case SPC_PASSTHROUGH: |
1093 | len += sprintf(page+len, "Passthrough\n"); | 1042 | len += sprintf(page+len, "Passthrough\n"); |
@@ -1102,22 +1051,13 @@ static ssize_t target_core_dev_pr_show_attr_res_holder( | |||
1102 | 1051 | ||
1103 | SE_DEV_PR_ATTR_RO(res_holder); | 1052 | SE_DEV_PR_ATTR_RO(res_holder); |
1104 | 1053 | ||
1105 | /* | ||
1106 | * res_pr_all_tgt_pts | ||
1107 | */ | ||
1108 | static ssize_t target_core_dev_pr_show_attr_res_pr_all_tgt_pts( | 1054 | static ssize_t target_core_dev_pr_show_attr_res_pr_all_tgt_pts( |
1109 | struct se_subsystem_dev *su_dev, | 1055 | struct se_device *dev, char *page) |
1110 | char *page) | ||
1111 | { | 1056 | { |
1112 | struct se_device *dev; | ||
1113 | struct t10_pr_registration *pr_reg; | 1057 | struct t10_pr_registration *pr_reg; |
1114 | ssize_t len = 0; | 1058 | ssize_t len = 0; |
1115 | 1059 | ||
1116 | dev = su_dev->se_dev_ptr; | 1060 | if (dev->t10_pr.res_type != SPC3_PERSISTENT_RESERVATIONS) |
1117 | if (!dev) | ||
1118 | return -ENODEV; | ||
1119 | |||
1120 | if (su_dev->t10_pr.res_type != SPC3_PERSISTENT_RESERVATIONS) | ||
1121 | return len; | 1061 | return len; |
1122 | 1062 | ||
1123 | spin_lock(&dev->dev_reservation_lock); | 1063 | spin_lock(&dev->dev_reservation_lock); |
@@ -1144,20 +1084,13 @@ static ssize_t target_core_dev_pr_show_attr_res_pr_all_tgt_pts( | |||
1144 | 1084 | ||
1145 | SE_DEV_PR_ATTR_RO(res_pr_all_tgt_pts); | 1085 | SE_DEV_PR_ATTR_RO(res_pr_all_tgt_pts); |
1146 | 1086 | ||
1147 | /* | ||
1148 | * res_pr_generation | ||
1149 | */ | ||
1150 | static ssize_t target_core_dev_pr_show_attr_res_pr_generation( | 1087 | static ssize_t target_core_dev_pr_show_attr_res_pr_generation( |
1151 | struct se_subsystem_dev *su_dev, | 1088 | struct se_device *dev, char *page) |
1152 | char *page) | ||
1153 | { | 1089 | { |
1154 | if (!su_dev->se_dev_ptr) | 1090 | if (dev->t10_pr.res_type != SPC3_PERSISTENT_RESERVATIONS) |
1155 | return -ENODEV; | ||
1156 | |||
1157 | if (su_dev->t10_pr.res_type != SPC3_PERSISTENT_RESERVATIONS) | ||
1158 | return 0; | 1091 | return 0; |
1159 | 1092 | ||
1160 | return sprintf(page, "0x%08x\n", su_dev->t10_pr.pr_generation); | 1093 | return sprintf(page, "0x%08x\n", dev->t10_pr.pr_generation); |
1161 | } | 1094 | } |
1162 | 1095 | ||
1163 | SE_DEV_PR_ATTR_RO(res_pr_generation); | 1096 | SE_DEV_PR_ATTR_RO(res_pr_generation); |
@@ -1166,10 +1099,8 @@ SE_DEV_PR_ATTR_RO(res_pr_generation); | |||
1166 | * res_pr_holder_tg_port | 1099 | * res_pr_holder_tg_port |
1167 | */ | 1100 | */ |
1168 | static ssize_t target_core_dev_pr_show_attr_res_pr_holder_tg_port( | 1101 | static ssize_t target_core_dev_pr_show_attr_res_pr_holder_tg_port( |
1169 | struct se_subsystem_dev *su_dev, | 1102 | struct se_device *dev, char *page) |
1170 | char *page) | ||
1171 | { | 1103 | { |
1172 | struct se_device *dev; | ||
1173 | struct se_node_acl *se_nacl; | 1104 | struct se_node_acl *se_nacl; |
1174 | struct se_lun *lun; | 1105 | struct se_lun *lun; |
1175 | struct se_portal_group *se_tpg; | 1106 | struct se_portal_group *se_tpg; |
@@ -1177,11 +1108,7 @@ static ssize_t target_core_dev_pr_show_attr_res_pr_holder_tg_port( | |||
1177 | struct target_core_fabric_ops *tfo; | 1108 | struct target_core_fabric_ops *tfo; |
1178 | ssize_t len = 0; | 1109 | ssize_t len = 0; |
1179 | 1110 | ||
1180 | dev = su_dev->se_dev_ptr; | 1111 | if (dev->t10_pr.res_type != SPC3_PERSISTENT_RESERVATIONS) |
1181 | if (!dev) | ||
1182 | return -ENODEV; | ||
1183 | |||
1184 | if (su_dev->t10_pr.res_type != SPC3_PERSISTENT_RESERVATIONS) | ||
1185 | return len; | 1112 | return len; |
1186 | 1113 | ||
1187 | spin_lock(&dev->dev_reservation_lock); | 1114 | spin_lock(&dev->dev_reservation_lock); |
@@ -1211,12 +1138,8 @@ static ssize_t target_core_dev_pr_show_attr_res_pr_holder_tg_port( | |||
1211 | 1138 | ||
1212 | SE_DEV_PR_ATTR_RO(res_pr_holder_tg_port); | 1139 | SE_DEV_PR_ATTR_RO(res_pr_holder_tg_port); |
1213 | 1140 | ||
1214 | /* | ||
1215 | * res_pr_registered_i_pts | ||
1216 | */ | ||
1217 | static ssize_t target_core_dev_pr_show_attr_res_pr_registered_i_pts( | 1141 | static ssize_t target_core_dev_pr_show_attr_res_pr_registered_i_pts( |
1218 | struct se_subsystem_dev *su_dev, | 1142 | struct se_device *dev, char *page) |
1219 | char *page) | ||
1220 | { | 1143 | { |
1221 | struct target_core_fabric_ops *tfo; | 1144 | struct target_core_fabric_ops *tfo; |
1222 | struct t10_pr_registration *pr_reg; | 1145 | struct t10_pr_registration *pr_reg; |
@@ -1225,16 +1148,13 @@ static ssize_t target_core_dev_pr_show_attr_res_pr_registered_i_pts( | |||
1225 | ssize_t len = 0; | 1148 | ssize_t len = 0; |
1226 | int reg_count = 0, prf_isid; | 1149 | int reg_count = 0, prf_isid; |
1227 | 1150 | ||
1228 | if (!su_dev->se_dev_ptr) | 1151 | if (dev->t10_pr.res_type != SPC3_PERSISTENT_RESERVATIONS) |
1229 | return -ENODEV; | ||
1230 | |||
1231 | if (su_dev->t10_pr.res_type != SPC3_PERSISTENT_RESERVATIONS) | ||
1232 | return len; | 1152 | return len; |
1233 | 1153 | ||
1234 | len += sprintf(page+len, "SPC-3 PR Registrations:\n"); | 1154 | len += sprintf(page+len, "SPC-3 PR Registrations:\n"); |
1235 | 1155 | ||
1236 | spin_lock(&su_dev->t10_pr.registration_lock); | 1156 | spin_lock(&dev->t10_pr.registration_lock); |
1237 | list_for_each_entry(pr_reg, &su_dev->t10_pr.registration_list, | 1157 | list_for_each_entry(pr_reg, &dev->t10_pr.registration_list, |
1238 | pr_reg_list) { | 1158 | pr_reg_list) { |
1239 | 1159 | ||
1240 | memset(buf, 0, 384); | 1160 | memset(buf, 0, 384); |
@@ -1254,7 +1174,7 @@ static ssize_t target_core_dev_pr_show_attr_res_pr_registered_i_pts( | |||
1254 | len += sprintf(page+len, "%s", buf); | 1174 | len += sprintf(page+len, "%s", buf); |
1255 | reg_count++; | 1175 | reg_count++; |
1256 | } | 1176 | } |
1257 | spin_unlock(&su_dev->t10_pr.registration_lock); | 1177 | spin_unlock(&dev->t10_pr.registration_lock); |
1258 | 1178 | ||
1259 | if (!reg_count) | 1179 | if (!reg_count) |
1260 | len += sprintf(page+len, "None\n"); | 1180 | len += sprintf(page+len, "None\n"); |
@@ -1264,22 +1184,13 @@ static ssize_t target_core_dev_pr_show_attr_res_pr_registered_i_pts( | |||
1264 | 1184 | ||
1265 | SE_DEV_PR_ATTR_RO(res_pr_registered_i_pts); | 1185 | SE_DEV_PR_ATTR_RO(res_pr_registered_i_pts); |
1266 | 1186 | ||
1267 | /* | ||
1268 | * res_pr_type | ||
1269 | */ | ||
1270 | static ssize_t target_core_dev_pr_show_attr_res_pr_type( | 1187 | static ssize_t target_core_dev_pr_show_attr_res_pr_type( |
1271 | struct se_subsystem_dev *su_dev, | 1188 | struct se_device *dev, char *page) |
1272 | char *page) | ||
1273 | { | 1189 | { |
1274 | struct se_device *dev; | ||
1275 | struct t10_pr_registration *pr_reg; | 1190 | struct t10_pr_registration *pr_reg; |
1276 | ssize_t len = 0; | 1191 | ssize_t len = 0; |
1277 | 1192 | ||
1278 | dev = su_dev->se_dev_ptr; | 1193 | if (dev->t10_pr.res_type != SPC3_PERSISTENT_RESERVATIONS) |
1279 | if (!dev) | ||
1280 | return -ENODEV; | ||
1281 | |||
1282 | if (su_dev->t10_pr.res_type != SPC3_PERSISTENT_RESERVATIONS) | ||
1283 | return len; | 1194 | return len; |
1284 | 1195 | ||
1285 | spin_lock(&dev->dev_reservation_lock); | 1196 | spin_lock(&dev->dev_reservation_lock); |
@@ -1298,19 +1209,12 @@ static ssize_t target_core_dev_pr_show_attr_res_pr_type( | |||
1298 | 1209 | ||
1299 | SE_DEV_PR_ATTR_RO(res_pr_type); | 1210 | SE_DEV_PR_ATTR_RO(res_pr_type); |
1300 | 1211 | ||
1301 | /* | ||
1302 | * res_type | ||
1303 | */ | ||
1304 | static ssize_t target_core_dev_pr_show_attr_res_type( | 1212 | static ssize_t target_core_dev_pr_show_attr_res_type( |
1305 | struct se_subsystem_dev *su_dev, | 1213 | struct se_device *dev, char *page) |
1306 | char *page) | ||
1307 | { | 1214 | { |
1308 | ssize_t len = 0; | 1215 | ssize_t len = 0; |
1309 | 1216 | ||
1310 | if (!su_dev->se_dev_ptr) | 1217 | switch (dev->t10_pr.res_type) { |
1311 | return -ENODEV; | ||
1312 | |||
1313 | switch (su_dev->t10_pr.res_type) { | ||
1314 | case SPC3_PERSISTENT_RESERVATIONS: | 1218 | case SPC3_PERSISTENT_RESERVATIONS: |
1315 | len = sprintf(page, "SPC3_PERSISTENT_RESERVATIONS\n"); | 1219 | len = sprintf(page, "SPC3_PERSISTENT_RESERVATIONS\n"); |
1316 | break; | 1220 | break; |
@@ -1330,22 +1234,14 @@ static ssize_t target_core_dev_pr_show_attr_res_type( | |||
1330 | 1234 | ||
1331 | SE_DEV_PR_ATTR_RO(res_type); | 1235 | SE_DEV_PR_ATTR_RO(res_type); |
1332 | 1236 | ||
1333 | /* | ||
1334 | * res_aptpl_active | ||
1335 | */ | ||
1336 | |||
1337 | static ssize_t target_core_dev_pr_show_attr_res_aptpl_active( | 1237 | static ssize_t target_core_dev_pr_show_attr_res_aptpl_active( |
1338 | struct se_subsystem_dev *su_dev, | 1238 | struct se_device *dev, char *page) |
1339 | char *page) | ||
1340 | { | 1239 | { |
1341 | if (!su_dev->se_dev_ptr) | 1240 | if (dev->t10_pr.res_type != SPC3_PERSISTENT_RESERVATIONS) |
1342 | return -ENODEV; | ||
1343 | |||
1344 | if (su_dev->t10_pr.res_type != SPC3_PERSISTENT_RESERVATIONS) | ||
1345 | return 0; | 1241 | return 0; |
1346 | 1242 | ||
1347 | return sprintf(page, "APTPL Bit Status: %s\n", | 1243 | return sprintf(page, "APTPL Bit Status: %s\n", |
1348 | (su_dev->t10_pr.pr_aptpl_active) ? "Activated" : "Disabled"); | 1244 | (dev->t10_pr.pr_aptpl_active) ? "Activated" : "Disabled"); |
1349 | } | 1245 | } |
1350 | 1246 | ||
1351 | SE_DEV_PR_ATTR_RO(res_aptpl_active); | 1247 | SE_DEV_PR_ATTR_RO(res_aptpl_active); |
@@ -1354,13 +1250,9 @@ SE_DEV_PR_ATTR_RO(res_aptpl_active); | |||
1354 | * res_aptpl_metadata | 1250 | * res_aptpl_metadata |
1355 | */ | 1251 | */ |
1356 | static ssize_t target_core_dev_pr_show_attr_res_aptpl_metadata( | 1252 | static ssize_t target_core_dev_pr_show_attr_res_aptpl_metadata( |
1357 | struct se_subsystem_dev *su_dev, | 1253 | struct se_device *dev, char *page) |
1358 | char *page) | ||
1359 | { | 1254 | { |
1360 | if (!su_dev->se_dev_ptr) | 1255 | if (dev->t10_pr.res_type != SPC3_PERSISTENT_RESERVATIONS) |
1361 | return -ENODEV; | ||
1362 | |||
1363 | if (su_dev->t10_pr.res_type != SPC3_PERSISTENT_RESERVATIONS) | ||
1364 | return 0; | 1256 | return 0; |
1365 | 1257 | ||
1366 | return sprintf(page, "Ready to process PR APTPL metadata..\n"); | 1258 | return sprintf(page, "Ready to process PR APTPL metadata..\n"); |
@@ -1392,11 +1284,10 @@ static match_table_t tokens = { | |||
1392 | }; | 1284 | }; |
1393 | 1285 | ||
1394 | static ssize_t target_core_dev_pr_store_attr_res_aptpl_metadata( | 1286 | static ssize_t target_core_dev_pr_store_attr_res_aptpl_metadata( |
1395 | struct se_subsystem_dev *su_dev, | 1287 | struct se_device *dev, |
1396 | const char *page, | 1288 | const char *page, |
1397 | size_t count) | 1289 | size_t count) |
1398 | { | 1290 | { |
1399 | struct se_device *dev; | ||
1400 | unsigned char *i_fabric = NULL, *i_port = NULL, *isid = NULL; | 1291 | unsigned char *i_fabric = NULL, *i_port = NULL, *isid = NULL; |
1401 | unsigned char *t_fabric = NULL, *t_port = NULL; | 1292 | unsigned char *t_fabric = NULL, *t_port = NULL; |
1402 | char *orig, *ptr, *arg_p, *opts; | 1293 | char *orig, *ptr, *arg_p, *opts; |
@@ -1408,14 +1299,10 @@ static ssize_t target_core_dev_pr_store_attr_res_aptpl_metadata( | |||
1408 | u16 port_rpti = 0, tpgt = 0; | 1299 | u16 port_rpti = 0, tpgt = 0; |
1409 | u8 type = 0, scope; | 1300 | u8 type = 0, scope; |
1410 | 1301 | ||
1411 | dev = su_dev->se_dev_ptr; | 1302 | if (dev->t10_pr.res_type != SPC3_PERSISTENT_RESERVATIONS) |
1412 | if (!dev) | ||
1413 | return -ENODEV; | ||
1414 | |||
1415 | if (su_dev->t10_pr.res_type != SPC3_PERSISTENT_RESERVATIONS) | ||
1416 | return 0; | 1303 | return 0; |
1417 | 1304 | ||
1418 | if (atomic_read(&dev->dev_export_obj.obj_access_count)) { | 1305 | if (dev->export_count) { |
1419 | pr_debug("Unable to process APTPL metadata while" | 1306 | pr_debug("Unable to process APTPL metadata while" |
1420 | " active fabric exports exist\n"); | 1307 | " active fabric exports exist\n"); |
1421 | return -EINVAL; | 1308 | return -EINVAL; |
@@ -1558,7 +1445,7 @@ static ssize_t target_core_dev_pr_store_attr_res_aptpl_metadata( | |||
1558 | goto out; | 1445 | goto out; |
1559 | } | 1446 | } |
1560 | 1447 | ||
1561 | ret = core_scsi3_alloc_aptpl_registration(&su_dev->t10_pr, sa_res_key, | 1448 | ret = core_scsi3_alloc_aptpl_registration(&dev->t10_pr, sa_res_key, |
1562 | i_port, isid, mapped_lun, t_port, tpgt, target_lun, | 1449 | i_port, isid, mapped_lun, t_port, tpgt, target_lun, |
1563 | res_holder, all_tg_pt, type); | 1450 | res_holder, all_tg_pt, type); |
1564 | out: | 1451 | out: |
@@ -1573,7 +1460,7 @@ out: | |||
1573 | 1460 | ||
1574 | SE_DEV_PR_ATTR(res_aptpl_metadata, S_IRUGO | S_IWUSR); | 1461 | SE_DEV_PR_ATTR(res_aptpl_metadata, S_IRUGO | S_IWUSR); |
1575 | 1462 | ||
1576 | CONFIGFS_EATTR_OPS(target_core_dev_pr, se_subsystem_dev, se_dev_pr_group); | 1463 | CONFIGFS_EATTR_OPS(target_core_dev_pr, se_device, dev_pr_group); |
1577 | 1464 | ||
1578 | static struct configfs_attribute *target_core_dev_pr_attrs[] = { | 1465 | static struct configfs_attribute *target_core_dev_pr_attrs[] = { |
1579 | &target_core_dev_pr_res_holder.attr, | 1466 | &target_core_dev_pr_res_holder.attr, |
@@ -1605,18 +1492,14 @@ static struct config_item_type target_core_dev_pr_cit = { | |||
1605 | 1492 | ||
1606 | static ssize_t target_core_show_dev_info(void *p, char *page) | 1493 | static ssize_t target_core_show_dev_info(void *p, char *page) |
1607 | { | 1494 | { |
1608 | struct se_subsystem_dev *se_dev = p; | 1495 | struct se_device *dev = p; |
1609 | struct se_hba *hba = se_dev->se_dev_hba; | 1496 | struct se_subsystem_api *t = dev->transport; |
1610 | struct se_subsystem_api *t = hba->transport; | ||
1611 | int bl = 0; | 1497 | int bl = 0; |
1612 | ssize_t read_bytes = 0; | 1498 | ssize_t read_bytes = 0; |
1613 | 1499 | ||
1614 | if (!se_dev->se_dev_ptr) | 1500 | transport_dump_dev_state(dev, page, &bl); |
1615 | return -ENODEV; | ||
1616 | |||
1617 | transport_dump_dev_state(se_dev->se_dev_ptr, page, &bl); | ||
1618 | read_bytes += bl; | 1501 | read_bytes += bl; |
1619 | read_bytes += t->show_configfs_dev_params(hba, se_dev, page+read_bytes); | 1502 | read_bytes += t->show_configfs_dev_params(dev, page+read_bytes); |
1620 | return read_bytes; | 1503 | return read_bytes; |
1621 | } | 1504 | } |
1622 | 1505 | ||
@@ -1633,17 +1516,10 @@ static ssize_t target_core_store_dev_control( | |||
1633 | const char *page, | 1516 | const char *page, |
1634 | size_t count) | 1517 | size_t count) |
1635 | { | 1518 | { |
1636 | struct se_subsystem_dev *se_dev = p; | 1519 | struct se_device *dev = p; |
1637 | struct se_hba *hba = se_dev->se_dev_hba; | 1520 | struct se_subsystem_api *t = dev->transport; |
1638 | struct se_subsystem_api *t = hba->transport; | ||
1639 | 1521 | ||
1640 | if (!se_dev->se_dev_su_ptr) { | 1522 | return t->set_configfs_dev_params(dev, page, count); |
1641 | pr_err("Unable to locate struct se_subsystem_dev>se" | ||
1642 | "_dev_su_ptr\n"); | ||
1643 | return -EINVAL; | ||
1644 | } | ||
1645 | |||
1646 | return t->set_configfs_dev_params(hba, se_dev, page, count); | ||
1647 | } | 1523 | } |
1648 | 1524 | ||
1649 | static struct target_core_configfs_attribute target_core_attr_dev_control = { | 1525 | static struct target_core_configfs_attribute target_core_attr_dev_control = { |
@@ -1656,12 +1532,12 @@ static struct target_core_configfs_attribute target_core_attr_dev_control = { | |||
1656 | 1532 | ||
1657 | static ssize_t target_core_show_dev_alias(void *p, char *page) | 1533 | static ssize_t target_core_show_dev_alias(void *p, char *page) |
1658 | { | 1534 | { |
1659 | struct se_subsystem_dev *se_dev = p; | 1535 | struct se_device *dev = p; |
1660 | 1536 | ||
1661 | if (!(se_dev->su_dev_flags & SDF_USING_ALIAS)) | 1537 | if (!(dev->dev_flags & DF_USING_ALIAS)) |
1662 | return 0; | 1538 | return 0; |
1663 | 1539 | ||
1664 | return snprintf(page, PAGE_SIZE, "%s\n", se_dev->se_dev_alias); | 1540 | return snprintf(page, PAGE_SIZE, "%s\n", dev->dev_alias); |
1665 | } | 1541 | } |
1666 | 1542 | ||
1667 | static ssize_t target_core_store_dev_alias( | 1543 | static ssize_t target_core_store_dev_alias( |
@@ -1669,8 +1545,8 @@ static ssize_t target_core_store_dev_alias( | |||
1669 | const char *page, | 1545 | const char *page, |
1670 | size_t count) | 1546 | size_t count) |
1671 | { | 1547 | { |
1672 | struct se_subsystem_dev *se_dev = p; | 1548 | struct se_device *dev = p; |
1673 | struct se_hba *hba = se_dev->se_dev_hba; | 1549 | struct se_hba *hba = dev->se_hba; |
1674 | ssize_t read_bytes; | 1550 | ssize_t read_bytes; |
1675 | 1551 | ||
1676 | if (count > (SE_DEV_ALIAS_LEN-1)) { | 1552 | if (count > (SE_DEV_ALIAS_LEN-1)) { |
@@ -1680,19 +1556,18 @@ static ssize_t target_core_store_dev_alias( | |||
1680 | return -EINVAL; | 1556 | return -EINVAL; |
1681 | } | 1557 | } |
1682 | 1558 | ||
1683 | read_bytes = snprintf(&se_dev->se_dev_alias[0], SE_DEV_ALIAS_LEN, | 1559 | read_bytes = snprintf(&dev->dev_alias[0], SE_DEV_ALIAS_LEN, "%s", page); |
1684 | "%s", page); | ||
1685 | if (!read_bytes) | 1560 | if (!read_bytes) |
1686 | return -EINVAL; | 1561 | return -EINVAL; |
1687 | if (se_dev->se_dev_alias[read_bytes - 1] == '\n') | 1562 | if (dev->dev_alias[read_bytes - 1] == '\n') |
1688 | se_dev->se_dev_alias[read_bytes - 1] = '\0'; | 1563 | dev->dev_alias[read_bytes - 1] = '\0'; |
1689 | 1564 | ||
1690 | se_dev->su_dev_flags |= SDF_USING_ALIAS; | 1565 | dev->dev_flags |= DF_USING_ALIAS; |
1691 | 1566 | ||
1692 | pr_debug("Target_Core_ConfigFS: %s/%s set alias: %s\n", | 1567 | pr_debug("Target_Core_ConfigFS: %s/%s set alias: %s\n", |
1693 | config_item_name(&hba->hba_group.cg_item), | 1568 | config_item_name(&hba->hba_group.cg_item), |
1694 | config_item_name(&se_dev->se_dev_group.cg_item), | 1569 | config_item_name(&dev->dev_group.cg_item), |
1695 | se_dev->se_dev_alias); | 1570 | dev->dev_alias); |
1696 | 1571 | ||
1697 | return read_bytes; | 1572 | return read_bytes; |
1698 | } | 1573 | } |
@@ -1707,12 +1582,12 @@ static struct target_core_configfs_attribute target_core_attr_dev_alias = { | |||
1707 | 1582 | ||
1708 | static ssize_t target_core_show_dev_udev_path(void *p, char *page) | 1583 | static ssize_t target_core_show_dev_udev_path(void *p, char *page) |
1709 | { | 1584 | { |
1710 | struct se_subsystem_dev *se_dev = p; | 1585 | struct se_device *dev = p; |
1711 | 1586 | ||
1712 | if (!(se_dev->su_dev_flags & SDF_USING_UDEV_PATH)) | 1587 | if (!(dev->dev_flags & DF_USING_UDEV_PATH)) |
1713 | return 0; | 1588 | return 0; |
1714 | 1589 | ||
1715 | return snprintf(page, PAGE_SIZE, "%s\n", se_dev->se_dev_udev_path); | 1590 | return snprintf(page, PAGE_SIZE, "%s\n", dev->udev_path); |
1716 | } | 1591 | } |
1717 | 1592 | ||
1718 | static ssize_t target_core_store_dev_udev_path( | 1593 | static ssize_t target_core_store_dev_udev_path( |
@@ -1720,8 +1595,8 @@ static ssize_t target_core_store_dev_udev_path( | |||
1720 | const char *page, | 1595 | const char *page, |
1721 | size_t count) | 1596 | size_t count) |
1722 | { | 1597 | { |
1723 | struct se_subsystem_dev *se_dev = p; | 1598 | struct se_device *dev = p; |
1724 | struct se_hba *hba = se_dev->se_dev_hba; | 1599 | struct se_hba *hba = dev->se_hba; |
1725 | ssize_t read_bytes; | 1600 | ssize_t read_bytes; |
1726 | 1601 | ||
1727 | if (count > (SE_UDEV_PATH_LEN-1)) { | 1602 | if (count > (SE_UDEV_PATH_LEN-1)) { |
@@ -1731,19 +1606,19 @@ static ssize_t target_core_store_dev_udev_path( | |||
1731 | return -EINVAL; | 1606 | return -EINVAL; |
1732 | } | 1607 | } |
1733 | 1608 | ||
1734 | read_bytes = snprintf(&se_dev->se_dev_udev_path[0], SE_UDEV_PATH_LEN, | 1609 | read_bytes = snprintf(&dev->udev_path[0], SE_UDEV_PATH_LEN, |
1735 | "%s", page); | 1610 | "%s", page); |
1736 | if (!read_bytes) | 1611 | if (!read_bytes) |
1737 | return -EINVAL; | 1612 | return -EINVAL; |
1738 | if (se_dev->se_dev_udev_path[read_bytes - 1] == '\n') | 1613 | if (dev->udev_path[read_bytes - 1] == '\n') |
1739 | se_dev->se_dev_udev_path[read_bytes - 1] = '\0'; | 1614 | dev->udev_path[read_bytes - 1] = '\0'; |
1740 | 1615 | ||
1741 | se_dev->su_dev_flags |= SDF_USING_UDEV_PATH; | 1616 | dev->dev_flags |= DF_USING_UDEV_PATH; |
1742 | 1617 | ||
1743 | pr_debug("Target_Core_ConfigFS: %s/%s set udev_path: %s\n", | 1618 | pr_debug("Target_Core_ConfigFS: %s/%s set udev_path: %s\n", |
1744 | config_item_name(&hba->hba_group.cg_item), | 1619 | config_item_name(&hba->hba_group.cg_item), |
1745 | config_item_name(&se_dev->se_dev_group.cg_item), | 1620 | config_item_name(&dev->dev_group.cg_item), |
1746 | se_dev->se_dev_udev_path); | 1621 | dev->udev_path); |
1747 | 1622 | ||
1748 | return read_bytes; | 1623 | return read_bytes; |
1749 | } | 1624 | } |
@@ -1761,11 +1636,9 @@ static ssize_t target_core_store_dev_enable( | |||
1761 | const char *page, | 1636 | const char *page, |
1762 | size_t count) | 1637 | size_t count) |
1763 | { | 1638 | { |
1764 | struct se_subsystem_dev *se_dev = p; | 1639 | struct se_device *dev = p; |
1765 | struct se_device *dev; | ||
1766 | struct se_hba *hba = se_dev->se_dev_hba; | ||
1767 | struct se_subsystem_api *t = hba->transport; | ||
1768 | char *ptr; | 1640 | char *ptr; |
1641 | int ret; | ||
1769 | 1642 | ||
1770 | ptr = strstr(page, "1"); | 1643 | ptr = strstr(page, "1"); |
1771 | if (!ptr) { | 1644 | if (!ptr) { |
@@ -1773,25 +1646,10 @@ static ssize_t target_core_store_dev_enable( | |||
1773 | " is \"1\"\n"); | 1646 | " is \"1\"\n"); |
1774 | return -EINVAL; | 1647 | return -EINVAL; |
1775 | } | 1648 | } |
1776 | if (se_dev->se_dev_ptr) { | ||
1777 | pr_err("se_dev->se_dev_ptr already set for storage" | ||
1778 | " object\n"); | ||
1779 | return -EEXIST; | ||
1780 | } | ||
1781 | |||
1782 | if (t->check_configfs_dev_params(hba, se_dev) < 0) | ||
1783 | return -EINVAL; | ||
1784 | |||
1785 | dev = t->create_virtdevice(hba, se_dev, se_dev->se_dev_su_ptr); | ||
1786 | if (IS_ERR(dev)) | ||
1787 | return PTR_ERR(dev); | ||
1788 | else if (!dev) | ||
1789 | return -EINVAL; | ||
1790 | |||
1791 | se_dev->se_dev_ptr = dev; | ||
1792 | pr_debug("Target_Core_ConfigFS: Registered se_dev->se_dev_ptr:" | ||
1793 | " %p\n", se_dev->se_dev_ptr); | ||
1794 | 1649 | ||
1650 | ret = target_configure_device(dev); | ||
1651 | if (ret) | ||
1652 | return ret; | ||
1795 | return count; | 1653 | return count; |
1796 | } | 1654 | } |
1797 | 1655 | ||
@@ -1805,18 +1663,13 @@ static struct target_core_configfs_attribute target_core_attr_dev_enable = { | |||
1805 | 1663 | ||
1806 | static ssize_t target_core_show_alua_lu_gp(void *p, char *page) | 1664 | static ssize_t target_core_show_alua_lu_gp(void *p, char *page) |
1807 | { | 1665 | { |
1808 | struct se_device *dev; | 1666 | struct se_device *dev = p; |
1809 | struct se_subsystem_dev *su_dev = p; | ||
1810 | struct config_item *lu_ci; | 1667 | struct config_item *lu_ci; |
1811 | struct t10_alua_lu_gp *lu_gp; | 1668 | struct t10_alua_lu_gp *lu_gp; |
1812 | struct t10_alua_lu_gp_member *lu_gp_mem; | 1669 | struct t10_alua_lu_gp_member *lu_gp_mem; |
1813 | ssize_t len = 0; | 1670 | ssize_t len = 0; |
1814 | 1671 | ||
1815 | dev = su_dev->se_dev_ptr; | 1672 | if (dev->t10_alua.alua_type != SPC3_ALUA_EMULATED) |
1816 | if (!dev) | ||
1817 | return -ENODEV; | ||
1818 | |||
1819 | if (su_dev->t10_alua.alua_type != SPC3_ALUA_EMULATED) | ||
1820 | return len; | 1673 | return len; |
1821 | 1674 | ||
1822 | lu_gp_mem = dev->dev_alua_lu_gp_mem; | 1675 | lu_gp_mem = dev->dev_alua_lu_gp_mem; |
@@ -1843,22 +1696,17 @@ static ssize_t target_core_store_alua_lu_gp( | |||
1843 | const char *page, | 1696 | const char *page, |
1844 | size_t count) | 1697 | size_t count) |
1845 | { | 1698 | { |
1846 | struct se_device *dev; | 1699 | struct se_device *dev = p; |
1847 | struct se_subsystem_dev *su_dev = p; | 1700 | struct se_hba *hba = dev->se_hba; |
1848 | struct se_hba *hba = su_dev->se_dev_hba; | ||
1849 | struct t10_alua_lu_gp *lu_gp = NULL, *lu_gp_new = NULL; | 1701 | struct t10_alua_lu_gp *lu_gp = NULL, *lu_gp_new = NULL; |
1850 | struct t10_alua_lu_gp_member *lu_gp_mem; | 1702 | struct t10_alua_lu_gp_member *lu_gp_mem; |
1851 | unsigned char buf[LU_GROUP_NAME_BUF]; | 1703 | unsigned char buf[LU_GROUP_NAME_BUF]; |
1852 | int move = 0; | 1704 | int move = 0; |
1853 | 1705 | ||
1854 | dev = su_dev->se_dev_ptr; | 1706 | if (dev->t10_alua.alua_type != SPC3_ALUA_EMULATED) { |
1855 | if (!dev) | ||
1856 | return -ENODEV; | ||
1857 | |||
1858 | if (su_dev->t10_alua.alua_type != SPC3_ALUA_EMULATED) { | ||
1859 | pr_warn("SPC3_ALUA_EMULATED not enabled for %s/%s\n", | 1707 | pr_warn("SPC3_ALUA_EMULATED not enabled for %s/%s\n", |
1860 | config_item_name(&hba->hba_group.cg_item), | 1708 | config_item_name(&hba->hba_group.cg_item), |
1861 | config_item_name(&su_dev->se_dev_group.cg_item)); | 1709 | config_item_name(&dev->dev_group.cg_item)); |
1862 | return -EINVAL; | 1710 | return -EINVAL; |
1863 | } | 1711 | } |
1864 | if (count > LU_GROUP_NAME_BUF) { | 1712 | if (count > LU_GROUP_NAME_BUF) { |
@@ -1902,7 +1750,7 @@ static ssize_t target_core_store_alua_lu_gp( | |||
1902 | " from ALUA LU Group: core/alua/lu_gps/%s, ID:" | 1750 | " from ALUA LU Group: core/alua/lu_gps/%s, ID:" |
1903 | " %hu\n", | 1751 | " %hu\n", |
1904 | config_item_name(&hba->hba_group.cg_item), | 1752 | config_item_name(&hba->hba_group.cg_item), |
1905 | config_item_name(&su_dev->se_dev_group.cg_item), | 1753 | config_item_name(&dev->dev_group.cg_item), |
1906 | config_item_name(&lu_gp->lu_gp_group.cg_item), | 1754 | config_item_name(&lu_gp->lu_gp_group.cg_item), |
1907 | lu_gp->lu_gp_id); | 1755 | lu_gp->lu_gp_id); |
1908 | 1756 | ||
@@ -1927,7 +1775,7 @@ static ssize_t target_core_store_alua_lu_gp( | |||
1927 | " core/alua/lu_gps/%s, ID: %hu\n", | 1775 | " core/alua/lu_gps/%s, ID: %hu\n", |
1928 | (move) ? "Moving" : "Adding", | 1776 | (move) ? "Moving" : "Adding", |
1929 | config_item_name(&hba->hba_group.cg_item), | 1777 | config_item_name(&hba->hba_group.cg_item), |
1930 | config_item_name(&su_dev->se_dev_group.cg_item), | 1778 | config_item_name(&dev->dev_group.cg_item), |
1931 | config_item_name(&lu_gp_new->lu_gp_group.cg_item), | 1779 | config_item_name(&lu_gp_new->lu_gp_group.cg_item), |
1932 | lu_gp_new->lu_gp_id); | 1780 | lu_gp_new->lu_gp_id); |
1933 | 1781 | ||
@@ -1955,69 +1803,44 @@ static struct configfs_attribute *lio_core_dev_attrs[] = { | |||
1955 | 1803 | ||
1956 | static void target_core_dev_release(struct config_item *item) | 1804 | static void target_core_dev_release(struct config_item *item) |
1957 | { | 1805 | { |
1958 | struct se_subsystem_dev *se_dev = container_of(to_config_group(item), | 1806 | struct config_group *dev_cg = to_config_group(item); |
1959 | struct se_subsystem_dev, se_dev_group); | 1807 | struct se_device *dev = |
1960 | struct se_hba *hba = item_to_hba(&se_dev->se_dev_hba->hba_group.cg_item); | 1808 | container_of(dev_cg, struct se_device, dev_group); |
1961 | struct se_subsystem_api *t = hba->transport; | ||
1962 | struct config_group *dev_cg = &se_dev->se_dev_group; | ||
1963 | 1809 | ||
1964 | kfree(dev_cg->default_groups); | 1810 | kfree(dev_cg->default_groups); |
1965 | /* | 1811 | target_free_device(dev); |
1966 | * This pointer will set when the storage is enabled with: | ||
1967 | *`echo 1 > $CONFIGFS/core/$HBA/$DEV/dev_enable` | ||
1968 | */ | ||
1969 | if (se_dev->se_dev_ptr) { | ||
1970 | pr_debug("Target_Core_ConfigFS: Calling se_free_" | ||
1971 | "virtual_device() for se_dev_ptr: %p\n", | ||
1972 | se_dev->se_dev_ptr); | ||
1973 | |||
1974 | se_free_virtual_device(se_dev->se_dev_ptr, hba); | ||
1975 | } else { | ||
1976 | /* | ||
1977 | * Release struct se_subsystem_dev->se_dev_su_ptr.. | ||
1978 | */ | ||
1979 | pr_debug("Target_Core_ConfigFS: Calling t->free_" | ||
1980 | "device() for se_dev_su_ptr: %p\n", | ||
1981 | se_dev->se_dev_su_ptr); | ||
1982 | |||
1983 | t->free_device(se_dev->se_dev_su_ptr); | ||
1984 | } | ||
1985 | |||
1986 | pr_debug("Target_Core_ConfigFS: Deallocating se_subsystem" | ||
1987 | "_dev_t: %p\n", se_dev); | ||
1988 | kfree(se_dev); | ||
1989 | } | 1812 | } |
1990 | 1813 | ||
1991 | static ssize_t target_core_dev_show(struct config_item *item, | 1814 | static ssize_t target_core_dev_show(struct config_item *item, |
1992 | struct configfs_attribute *attr, | 1815 | struct configfs_attribute *attr, |
1993 | char *page) | 1816 | char *page) |
1994 | { | 1817 | { |
1995 | struct se_subsystem_dev *se_dev = container_of( | 1818 | struct config_group *dev_cg = to_config_group(item); |
1996 | to_config_group(item), struct se_subsystem_dev, | 1819 | struct se_device *dev = |
1997 | se_dev_group); | 1820 | container_of(dev_cg, struct se_device, dev_group); |
1998 | struct target_core_configfs_attribute *tc_attr = container_of( | 1821 | struct target_core_configfs_attribute *tc_attr = container_of( |
1999 | attr, struct target_core_configfs_attribute, attr); | 1822 | attr, struct target_core_configfs_attribute, attr); |
2000 | 1823 | ||
2001 | if (!tc_attr->show) | 1824 | if (!tc_attr->show) |
2002 | return -EINVAL; | 1825 | return -EINVAL; |
2003 | 1826 | ||
2004 | return tc_attr->show(se_dev, page); | 1827 | return tc_attr->show(dev, page); |
2005 | } | 1828 | } |
2006 | 1829 | ||
2007 | static ssize_t target_core_dev_store(struct config_item *item, | 1830 | static ssize_t target_core_dev_store(struct config_item *item, |
2008 | struct configfs_attribute *attr, | 1831 | struct configfs_attribute *attr, |
2009 | const char *page, size_t count) | 1832 | const char *page, size_t count) |
2010 | { | 1833 | { |
2011 | struct se_subsystem_dev *se_dev = container_of( | 1834 | struct config_group *dev_cg = to_config_group(item); |
2012 | to_config_group(item), struct se_subsystem_dev, | 1835 | struct se_device *dev = |
2013 | se_dev_group); | 1836 | container_of(dev_cg, struct se_device, dev_group); |
2014 | struct target_core_configfs_attribute *tc_attr = container_of( | 1837 | struct target_core_configfs_attribute *tc_attr = container_of( |
2015 | attr, struct target_core_configfs_attribute, attr); | 1838 | attr, struct target_core_configfs_attribute, attr); |
2016 | 1839 | ||
2017 | if (!tc_attr->store) | 1840 | if (!tc_attr->store) |
2018 | return -EINVAL; | 1841 | return -EINVAL; |
2019 | 1842 | ||
2020 | return tc_attr->store(se_dev, page, count); | 1843 | return tc_attr->store(dev, page, count); |
2021 | } | 1844 | } |
2022 | 1845 | ||
2023 | static struct configfs_item_operations target_core_dev_item_ops = { | 1846 | static struct configfs_item_operations target_core_dev_item_ops = { |
@@ -2107,7 +1930,6 @@ static ssize_t target_core_alua_lu_gp_show_attr_members( | |||
2107 | { | 1930 | { |
2108 | struct se_device *dev; | 1931 | struct se_device *dev; |
2109 | struct se_hba *hba; | 1932 | struct se_hba *hba; |
2110 | struct se_subsystem_dev *su_dev; | ||
2111 | struct t10_alua_lu_gp_member *lu_gp_mem; | 1933 | struct t10_alua_lu_gp_member *lu_gp_mem; |
2112 | ssize_t len = 0, cur_len; | 1934 | ssize_t len = 0, cur_len; |
2113 | unsigned char buf[LU_GROUP_NAME_BUF]; | 1935 | unsigned char buf[LU_GROUP_NAME_BUF]; |
@@ -2117,12 +1939,11 @@ static ssize_t target_core_alua_lu_gp_show_attr_members( | |||
2117 | spin_lock(&lu_gp->lu_gp_lock); | 1939 | spin_lock(&lu_gp->lu_gp_lock); |
2118 | list_for_each_entry(lu_gp_mem, &lu_gp->lu_gp_mem_list, lu_gp_mem_list) { | 1940 | list_for_each_entry(lu_gp_mem, &lu_gp->lu_gp_mem_list, lu_gp_mem_list) { |
2119 | dev = lu_gp_mem->lu_gp_mem_dev; | 1941 | dev = lu_gp_mem->lu_gp_mem_dev; |
2120 | su_dev = dev->se_sub_dev; | 1942 | hba = dev->se_hba; |
2121 | hba = su_dev->se_dev_hba; | ||
2122 | 1943 | ||
2123 | cur_len = snprintf(buf, LU_GROUP_NAME_BUF, "%s/%s\n", | 1944 | cur_len = snprintf(buf, LU_GROUP_NAME_BUF, "%s/%s\n", |
2124 | config_item_name(&hba->hba_group.cg_item), | 1945 | config_item_name(&hba->hba_group.cg_item), |
2125 | config_item_name(&su_dev->se_dev_group.cg_item)); | 1946 | config_item_name(&dev->dev_group.cg_item)); |
2126 | cur_len++; /* Extra byte for NULL terminator */ | 1947 | cur_len++; /* Extra byte for NULL terminator */ |
2127 | 1948 | ||
2128 | if ((cur_len + len) > PAGE_SIZE) { | 1949 | if ((cur_len + len) > PAGE_SIZE) { |
@@ -2260,7 +2081,7 @@ static ssize_t target_core_alua_tg_pt_gp_store_attr_alua_access_state( | |||
2260 | const char *page, | 2081 | const char *page, |
2261 | size_t count) | 2082 | size_t count) |
2262 | { | 2083 | { |
2263 | struct se_subsystem_dev *su_dev = tg_pt_gp->tg_pt_gp_su_dev; | 2084 | struct se_device *dev = tg_pt_gp->tg_pt_gp_dev; |
2264 | unsigned long tmp; | 2085 | unsigned long tmp; |
2265 | int new_state, ret; | 2086 | int new_state, ret; |
2266 | 2087 | ||
@@ -2284,7 +2105,7 @@ static ssize_t target_core_alua_tg_pt_gp_store_attr_alua_access_state( | |||
2284 | return -EINVAL; | 2105 | return -EINVAL; |
2285 | } | 2106 | } |
2286 | 2107 | ||
2287 | ret = core_alua_do_port_transition(tg_pt_gp, su_dev->se_dev_ptr, | 2108 | ret = core_alua_do_port_transition(tg_pt_gp, dev, |
2288 | NULL, NULL, new_state, 0); | 2109 | NULL, NULL, new_state, 0); |
2289 | return (!ret) ? count : -EINVAL; | 2110 | return (!ret) ? count : -EINVAL; |
2290 | } | 2111 | } |
@@ -2620,11 +2441,10 @@ static struct config_group *target_core_alua_create_tg_pt_gp( | |||
2620 | struct t10_alua *alua = container_of(group, struct t10_alua, | 2441 | struct t10_alua *alua = container_of(group, struct t10_alua, |
2621 | alua_tg_pt_gps_group); | 2442 | alua_tg_pt_gps_group); |
2622 | struct t10_alua_tg_pt_gp *tg_pt_gp; | 2443 | struct t10_alua_tg_pt_gp *tg_pt_gp; |
2623 | struct se_subsystem_dev *su_dev = alua->t10_sub_dev; | ||
2624 | struct config_group *alua_tg_pt_gp_cg = NULL; | 2444 | struct config_group *alua_tg_pt_gp_cg = NULL; |
2625 | struct config_item *alua_tg_pt_gp_ci = NULL; | 2445 | struct config_item *alua_tg_pt_gp_ci = NULL; |
2626 | 2446 | ||
2627 | tg_pt_gp = core_alua_allocate_tg_pt_gp(su_dev, name, 0); | 2447 | tg_pt_gp = core_alua_allocate_tg_pt_gp(alua->t10_dev, name, 0); |
2628 | if (!tg_pt_gp) | 2448 | if (!tg_pt_gp) |
2629 | return NULL; | 2449 | return NULL; |
2630 | 2450 | ||
@@ -2721,10 +2541,10 @@ static struct config_group *target_core_make_subdev( | |||
2721 | const char *name) | 2541 | const char *name) |
2722 | { | 2542 | { |
2723 | struct t10_alua_tg_pt_gp *tg_pt_gp; | 2543 | struct t10_alua_tg_pt_gp *tg_pt_gp; |
2724 | struct se_subsystem_dev *se_dev; | ||
2725 | struct se_subsystem_api *t; | 2544 | struct se_subsystem_api *t; |
2726 | struct config_item *hba_ci = &group->cg_item; | 2545 | struct config_item *hba_ci = &group->cg_item; |
2727 | struct se_hba *hba = item_to_hba(hba_ci); | 2546 | struct se_hba *hba = item_to_hba(hba_ci); |
2547 | struct se_device *dev; | ||
2728 | struct config_group *dev_cg = NULL, *tg_pt_gp_cg = NULL; | 2548 | struct config_group *dev_cg = NULL, *tg_pt_gp_cg = NULL; |
2729 | struct config_group *dev_stat_grp = NULL; | 2549 | struct config_group *dev_stat_grp = NULL; |
2730 | int errno = -ENOMEM, ret; | 2550 | int errno = -ENOMEM, ret; |
@@ -2737,120 +2557,80 @@ static struct config_group *target_core_make_subdev( | |||
2737 | */ | 2557 | */ |
2738 | t = hba->transport; | 2558 | t = hba->transport; |
2739 | 2559 | ||
2740 | se_dev = kzalloc(sizeof(struct se_subsystem_dev), GFP_KERNEL); | 2560 | dev = target_alloc_device(hba, name); |
2741 | if (!se_dev) { | 2561 | if (!dev) |
2742 | pr_err("Unable to allocate memory for" | 2562 | goto out_unlock; |
2743 | " struct se_subsystem_dev\n"); | 2563 | |
2744 | goto unlock; | 2564 | dev_cg = &dev->dev_group; |
2745 | } | ||
2746 | INIT_LIST_HEAD(&se_dev->t10_wwn.t10_vpd_list); | ||
2747 | spin_lock_init(&se_dev->t10_wwn.t10_vpd_lock); | ||
2748 | INIT_LIST_HEAD(&se_dev->t10_pr.registration_list); | ||
2749 | INIT_LIST_HEAD(&se_dev->t10_pr.aptpl_reg_list); | ||
2750 | spin_lock_init(&se_dev->t10_pr.registration_lock); | ||
2751 | spin_lock_init(&se_dev->t10_pr.aptpl_reg_lock); | ||
2752 | INIT_LIST_HEAD(&se_dev->t10_alua.tg_pt_gps_list); | ||
2753 | spin_lock_init(&se_dev->t10_alua.tg_pt_gps_lock); | ||
2754 | spin_lock_init(&se_dev->se_dev_lock); | ||
2755 | se_dev->t10_pr.pr_aptpl_buf_len = PR_APTPL_BUF_LEN; | ||
2756 | se_dev->t10_wwn.t10_sub_dev = se_dev; | ||
2757 | se_dev->t10_alua.t10_sub_dev = se_dev; | ||
2758 | se_dev->se_dev_attrib.da_sub_dev = se_dev; | ||
2759 | |||
2760 | se_dev->se_dev_hba = hba; | ||
2761 | dev_cg = &se_dev->se_dev_group; | ||
2762 | 2565 | ||
2763 | dev_cg->default_groups = kzalloc(sizeof(struct config_group) * 7, | 2566 | dev_cg->default_groups = kzalloc(sizeof(struct config_group) * 7, |
2764 | GFP_KERNEL); | 2567 | GFP_KERNEL); |
2765 | if (!dev_cg->default_groups) | 2568 | if (!dev_cg->default_groups) |
2766 | goto out; | 2569 | goto out_free_device; |
2767 | /* | ||
2768 | * Set se_dev_su_ptr from struct se_subsystem_api returned void ptr | ||
2769 | * for ->allocate_virtdevice() | ||
2770 | * | ||
2771 | * se_dev->se_dev_ptr will be set after ->create_virtdev() | ||
2772 | * has been called successfully in the next level up in the | ||
2773 | * configfs tree for device object's struct config_group. | ||
2774 | */ | ||
2775 | se_dev->se_dev_su_ptr = t->allocate_virtdevice(hba, name); | ||
2776 | if (!se_dev->se_dev_su_ptr) { | ||
2777 | pr_err("Unable to locate subsystem dependent pointer" | ||
2778 | " from allocate_virtdevice()\n"); | ||
2779 | goto out; | ||
2780 | } | ||
2781 | 2570 | ||
2782 | config_group_init_type_name(&se_dev->se_dev_group, name, | 2571 | config_group_init_type_name(dev_cg, name, &target_core_dev_cit); |
2783 | &target_core_dev_cit); | 2572 | config_group_init_type_name(&dev->dev_attrib.da_group, "attrib", |
2784 | config_group_init_type_name(&se_dev->se_dev_attrib.da_group, "attrib", | ||
2785 | &target_core_dev_attrib_cit); | 2573 | &target_core_dev_attrib_cit); |
2786 | config_group_init_type_name(&se_dev->se_dev_pr_group, "pr", | 2574 | config_group_init_type_name(&dev->dev_pr_group, "pr", |
2787 | &target_core_dev_pr_cit); | 2575 | &target_core_dev_pr_cit); |
2788 | config_group_init_type_name(&se_dev->t10_wwn.t10_wwn_group, "wwn", | 2576 | config_group_init_type_name(&dev->t10_wwn.t10_wwn_group, "wwn", |
2789 | &target_core_dev_wwn_cit); | 2577 | &target_core_dev_wwn_cit); |
2790 | config_group_init_type_name(&se_dev->t10_alua.alua_tg_pt_gps_group, | 2578 | config_group_init_type_name(&dev->t10_alua.alua_tg_pt_gps_group, |
2791 | "alua", &target_core_alua_tg_pt_gps_cit); | 2579 | "alua", &target_core_alua_tg_pt_gps_cit); |
2792 | config_group_init_type_name(&se_dev->dev_stat_grps.stat_group, | 2580 | config_group_init_type_name(&dev->dev_stat_grps.stat_group, |
2793 | "statistics", &target_core_stat_cit); | 2581 | "statistics", &target_core_stat_cit); |
2794 | 2582 | ||
2795 | dev_cg->default_groups[0] = &se_dev->se_dev_attrib.da_group; | 2583 | dev_cg->default_groups[0] = &dev->dev_attrib.da_group; |
2796 | dev_cg->default_groups[1] = &se_dev->se_dev_pr_group; | 2584 | dev_cg->default_groups[1] = &dev->dev_pr_group; |
2797 | dev_cg->default_groups[2] = &se_dev->t10_wwn.t10_wwn_group; | 2585 | dev_cg->default_groups[2] = &dev->t10_wwn.t10_wwn_group; |
2798 | dev_cg->default_groups[3] = &se_dev->t10_alua.alua_tg_pt_gps_group; | 2586 | dev_cg->default_groups[3] = &dev->t10_alua.alua_tg_pt_gps_group; |
2799 | dev_cg->default_groups[4] = &se_dev->dev_stat_grps.stat_group; | 2587 | dev_cg->default_groups[4] = &dev->dev_stat_grps.stat_group; |
2800 | dev_cg->default_groups[5] = NULL; | 2588 | dev_cg->default_groups[5] = NULL; |
2801 | /* | 2589 | /* |
2802 | * Add core/$HBA/$DEV/alua/default_tg_pt_gp | 2590 | * Add core/$HBA/$DEV/alua/default_tg_pt_gp |
2803 | */ | 2591 | */ |
2804 | tg_pt_gp = core_alua_allocate_tg_pt_gp(se_dev, "default_tg_pt_gp", 1); | 2592 | tg_pt_gp = core_alua_allocate_tg_pt_gp(dev, "default_tg_pt_gp", 1); |
2805 | if (!tg_pt_gp) | 2593 | if (!tg_pt_gp) |
2806 | goto out; | 2594 | goto out_free_dev_cg_default_groups; |
2595 | dev->t10_alua.default_tg_pt_gp = tg_pt_gp; | ||
2807 | 2596 | ||
2808 | tg_pt_gp_cg = &se_dev->t10_alua.alua_tg_pt_gps_group; | 2597 | tg_pt_gp_cg = &dev->t10_alua.alua_tg_pt_gps_group; |
2809 | tg_pt_gp_cg->default_groups = kzalloc(sizeof(struct config_group) * 2, | 2598 | tg_pt_gp_cg->default_groups = kzalloc(sizeof(struct config_group) * 2, |
2810 | GFP_KERNEL); | 2599 | GFP_KERNEL); |
2811 | if (!tg_pt_gp_cg->default_groups) { | 2600 | if (!tg_pt_gp_cg->default_groups) { |
2812 | pr_err("Unable to allocate tg_pt_gp_cg->" | 2601 | pr_err("Unable to allocate tg_pt_gp_cg->" |
2813 | "default_groups\n"); | 2602 | "default_groups\n"); |
2814 | goto out; | 2603 | goto out_free_tg_pt_gp; |
2815 | } | 2604 | } |
2816 | 2605 | ||
2817 | config_group_init_type_name(&tg_pt_gp->tg_pt_gp_group, | 2606 | config_group_init_type_name(&tg_pt_gp->tg_pt_gp_group, |
2818 | "default_tg_pt_gp", &target_core_alua_tg_pt_gp_cit); | 2607 | "default_tg_pt_gp", &target_core_alua_tg_pt_gp_cit); |
2819 | tg_pt_gp_cg->default_groups[0] = &tg_pt_gp->tg_pt_gp_group; | 2608 | tg_pt_gp_cg->default_groups[0] = &tg_pt_gp->tg_pt_gp_group; |
2820 | tg_pt_gp_cg->default_groups[1] = NULL; | 2609 | tg_pt_gp_cg->default_groups[1] = NULL; |
2821 | se_dev->t10_alua.default_tg_pt_gp = tg_pt_gp; | ||
2822 | /* | 2610 | /* |
2823 | * Add core/$HBA/$DEV/statistics/ default groups | 2611 | * Add core/$HBA/$DEV/statistics/ default groups |
2824 | */ | 2612 | */ |
2825 | dev_stat_grp = &se_dev->dev_stat_grps.stat_group; | 2613 | dev_stat_grp = &dev->dev_stat_grps.stat_group; |
2826 | dev_stat_grp->default_groups = kzalloc(sizeof(struct config_group) * 4, | 2614 | dev_stat_grp->default_groups = kzalloc(sizeof(struct config_group) * 4, |
2827 | GFP_KERNEL); | 2615 | GFP_KERNEL); |
2828 | if (!dev_stat_grp->default_groups) { | 2616 | if (!dev_stat_grp->default_groups) { |
2829 | pr_err("Unable to allocate dev_stat_grp->default_groups\n"); | 2617 | pr_err("Unable to allocate dev_stat_grp->default_groups\n"); |
2830 | goto out; | 2618 | goto out_free_tg_pt_gp_cg_default_groups; |
2831 | } | 2619 | } |
2832 | target_stat_setup_dev_default_groups(se_dev); | 2620 | target_stat_setup_dev_default_groups(dev); |
2833 | |||
2834 | pr_debug("Target_Core_ConfigFS: Allocated struct se_subsystem_dev:" | ||
2835 | " %p se_dev_su_ptr: %p\n", se_dev, se_dev->se_dev_su_ptr); | ||
2836 | 2621 | ||
2837 | mutex_unlock(&hba->hba_access_mutex); | 2622 | mutex_unlock(&hba->hba_access_mutex); |
2838 | return &se_dev->se_dev_group; | 2623 | return dev_cg; |
2839 | out: | 2624 | |
2840 | if (se_dev->t10_alua.default_tg_pt_gp) { | 2625 | out_free_tg_pt_gp_cg_default_groups: |
2841 | core_alua_free_tg_pt_gp(se_dev->t10_alua.default_tg_pt_gp); | 2626 | kfree(tg_pt_gp_cg->default_groups); |
2842 | se_dev->t10_alua.default_tg_pt_gp = NULL; | 2627 | out_free_tg_pt_gp: |
2843 | } | 2628 | core_alua_free_tg_pt_gp(tg_pt_gp); |
2844 | if (dev_stat_grp) | 2629 | out_free_dev_cg_default_groups: |
2845 | kfree(dev_stat_grp->default_groups); | 2630 | kfree(dev_cg->default_groups); |
2846 | if (tg_pt_gp_cg) | 2631 | out_free_device: |
2847 | kfree(tg_pt_gp_cg->default_groups); | 2632 | target_free_device(dev); |
2848 | if (dev_cg) | 2633 | out_unlock: |
2849 | kfree(dev_cg->default_groups); | ||
2850 | if (se_dev->se_dev_su_ptr) | ||
2851 | t->free_device(se_dev->se_dev_su_ptr); | ||
2852 | kfree(se_dev); | ||
2853 | unlock: | ||
2854 | mutex_unlock(&hba->hba_access_mutex); | 2634 | mutex_unlock(&hba->hba_access_mutex); |
2855 | return ERR_PTR(errno); | 2635 | return ERR_PTR(errno); |
2856 | } | 2636 | } |
@@ -2859,18 +2639,19 @@ static void target_core_drop_subdev( | |||
2859 | struct config_group *group, | 2639 | struct config_group *group, |
2860 | struct config_item *item) | 2640 | struct config_item *item) |
2861 | { | 2641 | { |
2862 | struct se_subsystem_dev *se_dev = container_of(to_config_group(item), | 2642 | struct config_group *dev_cg = to_config_group(item); |
2863 | struct se_subsystem_dev, se_dev_group); | 2643 | struct se_device *dev = |
2644 | container_of(dev_cg, struct se_device, dev_group); | ||
2864 | struct se_hba *hba; | 2645 | struct se_hba *hba; |
2865 | struct config_item *df_item; | 2646 | struct config_item *df_item; |
2866 | struct config_group *dev_cg, *tg_pt_gp_cg, *dev_stat_grp; | 2647 | struct config_group *tg_pt_gp_cg, *dev_stat_grp; |
2867 | int i; | 2648 | int i; |
2868 | 2649 | ||
2869 | hba = item_to_hba(&se_dev->se_dev_hba->hba_group.cg_item); | 2650 | hba = item_to_hba(&dev->se_hba->hba_group.cg_item); |
2870 | 2651 | ||
2871 | mutex_lock(&hba->hba_access_mutex); | 2652 | mutex_lock(&hba->hba_access_mutex); |
2872 | 2653 | ||
2873 | dev_stat_grp = &se_dev->dev_stat_grps.stat_group; | 2654 | dev_stat_grp = &dev->dev_stat_grps.stat_group; |
2874 | for (i = 0; dev_stat_grp->default_groups[i]; i++) { | 2655 | for (i = 0; dev_stat_grp->default_groups[i]; i++) { |
2875 | df_item = &dev_stat_grp->default_groups[i]->cg_item; | 2656 | df_item = &dev_stat_grp->default_groups[i]->cg_item; |
2876 | dev_stat_grp->default_groups[i] = NULL; | 2657 | dev_stat_grp->default_groups[i] = NULL; |
@@ -2878,7 +2659,7 @@ static void target_core_drop_subdev( | |||
2878 | } | 2659 | } |
2879 | kfree(dev_stat_grp->default_groups); | 2660 | kfree(dev_stat_grp->default_groups); |
2880 | 2661 | ||
2881 | tg_pt_gp_cg = &se_dev->t10_alua.alua_tg_pt_gps_group; | 2662 | tg_pt_gp_cg = &dev->t10_alua.alua_tg_pt_gps_group; |
2882 | for (i = 0; tg_pt_gp_cg->default_groups[i]; i++) { | 2663 | for (i = 0; tg_pt_gp_cg->default_groups[i]; i++) { |
2883 | df_item = &tg_pt_gp_cg->default_groups[i]->cg_item; | 2664 | df_item = &tg_pt_gp_cg->default_groups[i]->cg_item; |
2884 | tg_pt_gp_cg->default_groups[i] = NULL; | 2665 | tg_pt_gp_cg->default_groups[i] = NULL; |
@@ -2889,17 +2670,15 @@ static void target_core_drop_subdev( | |||
2889 | * core_alua_free_tg_pt_gp() is called from ->default_tg_pt_gp | 2670 | * core_alua_free_tg_pt_gp() is called from ->default_tg_pt_gp |
2890 | * directly from target_core_alua_tg_pt_gp_release(). | 2671 | * directly from target_core_alua_tg_pt_gp_release(). |
2891 | */ | 2672 | */ |
2892 | se_dev->t10_alua.default_tg_pt_gp = NULL; | 2673 | dev->t10_alua.default_tg_pt_gp = NULL; |
2893 | 2674 | ||
2894 | dev_cg = &se_dev->se_dev_group; | ||
2895 | for (i = 0; dev_cg->default_groups[i]; i++) { | 2675 | for (i = 0; dev_cg->default_groups[i]; i++) { |
2896 | df_item = &dev_cg->default_groups[i]->cg_item; | 2676 | df_item = &dev_cg->default_groups[i]->cg_item; |
2897 | dev_cg->default_groups[i] = NULL; | 2677 | dev_cg->default_groups[i] = NULL; |
2898 | config_item_put(df_item); | 2678 | config_item_put(df_item); |
2899 | } | 2679 | } |
2900 | /* | 2680 | /* |
2901 | * The releasing of se_dev and associated se_dev->se_dev_ptr is done | 2681 | * se_dev is released from target_core_dev_item_ops->release() |
2902 | * from target_core_dev_item_ops->release() ->target_core_dev_release(). | ||
2903 | */ | 2682 | */ |
2904 | config_item_put(item); | 2683 | config_item_put(item); |
2905 | mutex_unlock(&hba->hba_access_mutex); | 2684 | mutex_unlock(&hba->hba_access_mutex); |
@@ -2962,13 +2741,10 @@ static ssize_t target_core_hba_store_attr_hba_mode(struct se_hba *hba, | |||
2962 | return -EINVAL; | 2741 | return -EINVAL; |
2963 | } | 2742 | } |
2964 | 2743 | ||
2965 | spin_lock(&hba->device_lock); | 2744 | if (hba->dev_count) { |
2966 | if (!list_empty(&hba->hba_dev_list)) { | ||
2967 | pr_err("Unable to set hba_mode with active devices\n"); | 2745 | pr_err("Unable to set hba_mode with active devices\n"); |
2968 | spin_unlock(&hba->device_lock); | ||
2969 | return -EINVAL; | 2746 | return -EINVAL; |
2970 | } | 2747 | } |
2971 | spin_unlock(&hba->device_lock); | ||
2972 | 2748 | ||
2973 | ret = transport->pmode_enable_hba(hba, mode_flag); | 2749 | ret = transport->pmode_enable_hba(hba, mode_flag); |
2974 | if (ret < 0) | 2750 | if (ret < 0) |
diff --git a/drivers/target/target_core_device.c b/drivers/target/target_core_device.c index 9abef9f8eb76..b27c75a0e2e2 100644 --- a/drivers/target/target_core_device.c +++ b/drivers/target/target_core_device.c | |||
@@ -50,11 +50,7 @@ | |||
50 | #include "target_core_pr.h" | 50 | #include "target_core_pr.h" |
51 | #include "target_core_ua.h" | 51 | #include "target_core_ua.h" |
52 | 52 | ||
53 | static void se_dev_start(struct se_device *dev); | ||
54 | static void se_dev_stop(struct se_device *dev); | ||
55 | |||
56 | static struct se_hba *lun0_hba; | 53 | static struct se_hba *lun0_hba; |
57 | static struct se_subsystem_dev *lun0_su_dev; | ||
58 | /* not static, needed by tpg.c */ | 54 | /* not static, needed by tpg.c */ |
59 | struct se_device *g_lun0_dev; | 55 | struct se_device *g_lun0_dev; |
60 | 56 | ||
@@ -136,15 +132,6 @@ int transport_lookup_cmd_lun(struct se_cmd *se_cmd, u32 unpacked_lun) | |||
136 | se_cmd->orig_fe_lun = 0; | 132 | se_cmd->orig_fe_lun = 0; |
137 | se_cmd->se_cmd_flags |= SCF_SE_LUN_CMD; | 133 | se_cmd->se_cmd_flags |= SCF_SE_LUN_CMD; |
138 | } | 134 | } |
139 | /* | ||
140 | * Determine if the struct se_lun is online. | ||
141 | * FIXME: Check for LUN_RESET + UNIT Attention | ||
142 | */ | ||
143 | if (se_dev_check_online(se_lun->lun_se_dev) != 0) { | ||
144 | se_cmd->scsi_sense_reason = TCM_NON_EXISTENT_LUN; | ||
145 | se_cmd->se_cmd_flags |= SCF_SCSI_CDB_EXCEPTION; | ||
146 | return -ENODEV; | ||
147 | } | ||
148 | 135 | ||
149 | /* Directly associate cmd with se_dev */ | 136 | /* Directly associate cmd with se_dev */ |
150 | se_cmd->se_dev = se_lun->lun_se_dev; | 137 | se_cmd->se_dev = se_lun->lun_se_dev; |
@@ -202,14 +189,6 @@ int transport_lookup_tmr_lun(struct se_cmd *se_cmd, u32 unpacked_lun) | |||
202 | se_cmd->se_cmd_flags |= SCF_SCSI_CDB_EXCEPTION; | 189 | se_cmd->se_cmd_flags |= SCF_SCSI_CDB_EXCEPTION; |
203 | return -ENODEV; | 190 | return -ENODEV; |
204 | } | 191 | } |
205 | /* | ||
206 | * Determine if the struct se_lun is online. | ||
207 | * FIXME: Check for LUN_RESET + UNIT Attention | ||
208 | */ | ||
209 | if (se_dev_check_online(se_lun->lun_se_dev) != 0) { | ||
210 | se_cmd->se_cmd_flags |= SCF_SCSI_CDB_EXCEPTION; | ||
211 | return -ENODEV; | ||
212 | } | ||
213 | 192 | ||
214 | /* Directly associate cmd with se_dev */ | 193 | /* Directly associate cmd with se_dev */ |
215 | se_cmd->se_dev = se_lun->lun_se_dev; | 194 | se_cmd->se_dev = se_lun->lun_se_dev; |
@@ -565,7 +544,6 @@ static void core_export_port( | |||
565 | struct se_port *port, | 544 | struct se_port *port, |
566 | struct se_lun *lun) | 545 | struct se_lun *lun) |
567 | { | 546 | { |
568 | struct se_subsystem_dev *su_dev = dev->se_sub_dev; | ||
569 | struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem = NULL; | 547 | struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem = NULL; |
570 | 548 | ||
571 | spin_lock(&dev->se_port_lock); | 549 | spin_lock(&dev->se_port_lock); |
@@ -578,7 +556,7 @@ static void core_export_port( | |||
578 | list_add_tail(&port->sep_list, &dev->dev_sep_list); | 556 | list_add_tail(&port->sep_list, &dev->dev_sep_list); |
579 | spin_unlock(&dev->se_port_lock); | 557 | spin_unlock(&dev->se_port_lock); |
580 | 558 | ||
581 | if (su_dev->t10_alua.alua_type == SPC3_ALUA_EMULATED) { | 559 | if (dev->t10_alua.alua_type == SPC3_ALUA_EMULATED) { |
582 | tg_pt_gp_mem = core_alua_allocate_tg_pt_gp_mem(port); | 560 | tg_pt_gp_mem = core_alua_allocate_tg_pt_gp_mem(port); |
583 | if (IS_ERR(tg_pt_gp_mem) || !tg_pt_gp_mem) { | 561 | if (IS_ERR(tg_pt_gp_mem) || !tg_pt_gp_mem) { |
584 | pr_err("Unable to allocate t10_alua_tg_pt" | 562 | pr_err("Unable to allocate t10_alua_tg_pt" |
@@ -587,7 +565,7 @@ static void core_export_port( | |||
587 | } | 565 | } |
588 | spin_lock(&tg_pt_gp_mem->tg_pt_gp_mem_lock); | 566 | spin_lock(&tg_pt_gp_mem->tg_pt_gp_mem_lock); |
589 | __core_alua_attach_tg_pt_gp_mem(tg_pt_gp_mem, | 567 | __core_alua_attach_tg_pt_gp_mem(tg_pt_gp_mem, |
590 | su_dev->t10_alua.default_tg_pt_gp); | 568 | dev->t10_alua.default_tg_pt_gp); |
591 | spin_unlock(&tg_pt_gp_mem->tg_pt_gp_mem_lock); | 569 | spin_unlock(&tg_pt_gp_mem->tg_pt_gp_mem_lock); |
592 | pr_debug("%s/%s: Adding to default ALUA Target Port" | 570 | pr_debug("%s/%s: Adding to default ALUA Target Port" |
593 | " Group: alua/default_tg_pt_gp\n", | 571 | " Group: alua/default_tg_pt_gp\n", |
@@ -625,6 +603,7 @@ int core_dev_export( | |||
625 | struct se_portal_group *tpg, | 603 | struct se_portal_group *tpg, |
626 | struct se_lun *lun) | 604 | struct se_lun *lun) |
627 | { | 605 | { |
606 | struct se_hba *hba = dev->se_hba; | ||
628 | struct se_port *port; | 607 | struct se_port *port; |
629 | 608 | ||
630 | port = core_alloc_port(dev); | 609 | port = core_alloc_port(dev); |
@@ -632,9 +611,11 @@ int core_dev_export( | |||
632 | return PTR_ERR(port); | 611 | return PTR_ERR(port); |
633 | 612 | ||
634 | lun->lun_se_dev = dev; | 613 | lun->lun_se_dev = dev; |
635 | se_dev_start(dev); | ||
636 | 614 | ||
637 | atomic_inc(&dev->dev_export_obj.obj_access_count); | 615 | spin_lock(&hba->device_lock); |
616 | dev->export_count++; | ||
617 | spin_unlock(&hba->device_lock); | ||
618 | |||
638 | core_export_port(dev, tpg, port, lun); | 619 | core_export_port(dev, tpg, port, lun); |
639 | return 0; | 620 | return 0; |
640 | } | 621 | } |
@@ -644,6 +625,7 @@ void core_dev_unexport( | |||
644 | struct se_portal_group *tpg, | 625 | struct se_portal_group *tpg, |
645 | struct se_lun *lun) | 626 | struct se_lun *lun) |
646 | { | 627 | { |
628 | struct se_hba *hba = dev->se_hba; | ||
647 | struct se_port *port = lun->lun_sep; | 629 | struct se_port *port = lun->lun_sep; |
648 | 630 | ||
649 | spin_lock(&lun->lun_sep_lock); | 631 | spin_lock(&lun->lun_sep_lock); |
@@ -654,11 +636,13 @@ void core_dev_unexport( | |||
654 | spin_unlock(&lun->lun_sep_lock); | 636 | spin_unlock(&lun->lun_sep_lock); |
655 | 637 | ||
656 | spin_lock(&dev->se_port_lock); | 638 | spin_lock(&dev->se_port_lock); |
657 | atomic_dec(&dev->dev_export_obj.obj_access_count); | ||
658 | core_release_port(dev, port); | 639 | core_release_port(dev, port); |
659 | spin_unlock(&dev->se_port_lock); | 640 | spin_unlock(&dev->se_port_lock); |
660 | 641 | ||
661 | se_dev_stop(dev); | 642 | spin_lock(&hba->device_lock); |
643 | dev->export_count--; | ||
644 | spin_unlock(&hba->device_lock); | ||
645 | |||
662 | lun->lun_se_dev = NULL; | 646 | lun->lun_se_dev = NULL; |
663 | } | 647 | } |
664 | 648 | ||
@@ -725,127 +709,17 @@ done: | |||
725 | return 0; | 709 | return 0; |
726 | } | 710 | } |
727 | 711 | ||
728 | /* se_release_device_for_hba(): | 712 | static void se_release_vpd_for_dev(struct se_device *dev) |
729 | * | ||
730 | * | ||
731 | */ | ||
732 | void se_release_device_for_hba(struct se_device *dev) | ||
733 | { | ||
734 | struct se_hba *hba = dev->se_hba; | ||
735 | |||
736 | if ((dev->dev_status & TRANSPORT_DEVICE_ACTIVATED) || | ||
737 | (dev->dev_status & TRANSPORT_DEVICE_DEACTIVATED) || | ||
738 | (dev->dev_status & TRANSPORT_DEVICE_SHUTDOWN) || | ||
739 | (dev->dev_status & TRANSPORT_DEVICE_OFFLINE_ACTIVATED) || | ||
740 | (dev->dev_status & TRANSPORT_DEVICE_OFFLINE_DEACTIVATED)) | ||
741 | se_dev_stop(dev); | ||
742 | |||
743 | if (dev->dev_ptr) { | ||
744 | destroy_workqueue(dev->tmr_wq); | ||
745 | if (dev->transport->free_device) | ||
746 | dev->transport->free_device(dev->dev_ptr); | ||
747 | } | ||
748 | |||
749 | spin_lock(&hba->device_lock); | ||
750 | list_del(&dev->dev_list); | ||
751 | hba->dev_count--; | ||
752 | spin_unlock(&hba->device_lock); | ||
753 | |||
754 | core_scsi3_free_all_registrations(dev); | ||
755 | se_release_vpd_for_dev(dev); | ||
756 | |||
757 | kfree(dev); | ||
758 | } | ||
759 | |||
760 | void se_release_vpd_for_dev(struct se_device *dev) | ||
761 | { | 713 | { |
762 | struct t10_vpd *vpd, *vpd_tmp; | 714 | struct t10_vpd *vpd, *vpd_tmp; |
763 | 715 | ||
764 | spin_lock(&dev->se_sub_dev->t10_wwn.t10_vpd_lock); | 716 | spin_lock(&dev->t10_wwn.t10_vpd_lock); |
765 | list_for_each_entry_safe(vpd, vpd_tmp, | 717 | list_for_each_entry_safe(vpd, vpd_tmp, |
766 | &dev->se_sub_dev->t10_wwn.t10_vpd_list, vpd_list) { | 718 | &dev->t10_wwn.t10_vpd_list, vpd_list) { |
767 | list_del(&vpd->vpd_list); | 719 | list_del(&vpd->vpd_list); |
768 | kfree(vpd); | 720 | kfree(vpd); |
769 | } | 721 | } |
770 | spin_unlock(&dev->se_sub_dev->t10_wwn.t10_vpd_lock); | 722 | spin_unlock(&dev->t10_wwn.t10_vpd_lock); |
771 | } | ||
772 | |||
773 | /* se_free_virtual_device(): | ||
774 | * | ||
775 | * Used for IBLOCK, RAMDISK, and FILEIO Transport Drivers. | ||
776 | */ | ||
777 | int se_free_virtual_device(struct se_device *dev, struct se_hba *hba) | ||
778 | { | ||
779 | if (!list_empty(&dev->dev_sep_list)) | ||
780 | dump_stack(); | ||
781 | |||
782 | core_alua_free_lu_gp_mem(dev); | ||
783 | se_release_device_for_hba(dev); | ||
784 | |||
785 | return 0; | ||
786 | } | ||
787 | |||
788 | static void se_dev_start(struct se_device *dev) | ||
789 | { | ||
790 | struct se_hba *hba = dev->se_hba; | ||
791 | |||
792 | spin_lock(&hba->device_lock); | ||
793 | atomic_inc(&dev->dev_obj.obj_access_count); | ||
794 | if (atomic_read(&dev->dev_obj.obj_access_count) == 1) { | ||
795 | if (dev->dev_status & TRANSPORT_DEVICE_DEACTIVATED) { | ||
796 | dev->dev_status &= ~TRANSPORT_DEVICE_DEACTIVATED; | ||
797 | dev->dev_status |= TRANSPORT_DEVICE_ACTIVATED; | ||
798 | } else if (dev->dev_status & | ||
799 | TRANSPORT_DEVICE_OFFLINE_DEACTIVATED) { | ||
800 | dev->dev_status &= | ||
801 | ~TRANSPORT_DEVICE_OFFLINE_DEACTIVATED; | ||
802 | dev->dev_status |= TRANSPORT_DEVICE_OFFLINE_ACTIVATED; | ||
803 | } | ||
804 | } | ||
805 | spin_unlock(&hba->device_lock); | ||
806 | } | ||
807 | |||
808 | static void se_dev_stop(struct se_device *dev) | ||
809 | { | ||
810 | struct se_hba *hba = dev->se_hba; | ||
811 | |||
812 | spin_lock(&hba->device_lock); | ||
813 | atomic_dec(&dev->dev_obj.obj_access_count); | ||
814 | if (atomic_read(&dev->dev_obj.obj_access_count) == 0) { | ||
815 | if (dev->dev_status & TRANSPORT_DEVICE_ACTIVATED) { | ||
816 | dev->dev_status &= ~TRANSPORT_DEVICE_ACTIVATED; | ||
817 | dev->dev_status |= TRANSPORT_DEVICE_DEACTIVATED; | ||
818 | } else if (dev->dev_status & | ||
819 | TRANSPORT_DEVICE_OFFLINE_ACTIVATED) { | ||
820 | dev->dev_status &= ~TRANSPORT_DEVICE_OFFLINE_ACTIVATED; | ||
821 | dev->dev_status |= TRANSPORT_DEVICE_OFFLINE_DEACTIVATED; | ||
822 | } | ||
823 | } | ||
824 | spin_unlock(&hba->device_lock); | ||
825 | } | ||
826 | |||
827 | int se_dev_check_online(struct se_device *dev) | ||
828 | { | ||
829 | unsigned long flags; | ||
830 | int ret; | ||
831 | |||
832 | spin_lock_irqsave(&dev->dev_status_lock, flags); | ||
833 | ret = ((dev->dev_status & TRANSPORT_DEVICE_ACTIVATED) || | ||
834 | (dev->dev_status & TRANSPORT_DEVICE_DEACTIVATED)) ? 0 : 1; | ||
835 | spin_unlock_irqrestore(&dev->dev_status_lock, flags); | ||
836 | |||
837 | return ret; | ||
838 | } | ||
839 | |||
840 | int se_dev_check_shutdown(struct se_device *dev) | ||
841 | { | ||
842 | int ret; | ||
843 | |||
844 | spin_lock_irq(&dev->dev_status_lock); | ||
845 | ret = (dev->dev_status & TRANSPORT_DEVICE_SHUTDOWN); | ||
846 | spin_unlock_irq(&dev->dev_status_lock); | ||
847 | |||
848 | return ret; | ||
849 | } | 723 | } |
850 | 724 | ||
851 | static u32 se_dev_align_max_sectors(u32 max_sectors, u32 block_size) | 725 | static u32 se_dev_align_max_sectors(u32 max_sectors, u32 block_size) |
@@ -866,72 +740,13 @@ static u32 se_dev_align_max_sectors(u32 max_sectors, u32 block_size) | |||
866 | return aligned_max_sectors; | 740 | return aligned_max_sectors; |
867 | } | 741 | } |
868 | 742 | ||
869 | void se_dev_set_default_attribs( | ||
870 | struct se_device *dev, | ||
871 | struct se_dev_limits *dev_limits) | ||
872 | { | ||
873 | struct queue_limits *limits = &dev_limits->limits; | ||
874 | |||
875 | dev->se_sub_dev->se_dev_attrib.emulate_dpo = DA_EMULATE_DPO; | ||
876 | dev->se_sub_dev->se_dev_attrib.emulate_fua_write = DA_EMULATE_FUA_WRITE; | ||
877 | dev->se_sub_dev->se_dev_attrib.emulate_fua_read = DA_EMULATE_FUA_READ; | ||
878 | dev->se_sub_dev->se_dev_attrib.emulate_write_cache = DA_EMULATE_WRITE_CACHE; | ||
879 | dev->se_sub_dev->se_dev_attrib.emulate_ua_intlck_ctrl = DA_EMULATE_UA_INTLLCK_CTRL; | ||
880 | dev->se_sub_dev->se_dev_attrib.emulate_tas = DA_EMULATE_TAS; | ||
881 | dev->se_sub_dev->se_dev_attrib.emulate_tpu = DA_EMULATE_TPU; | ||
882 | dev->se_sub_dev->se_dev_attrib.emulate_tpws = DA_EMULATE_TPWS; | ||
883 | dev->se_sub_dev->se_dev_attrib.emulate_reservations = DA_EMULATE_RESERVATIONS; | ||
884 | dev->se_sub_dev->se_dev_attrib.emulate_alua = DA_EMULATE_ALUA; | ||
885 | dev->se_sub_dev->se_dev_attrib.enforce_pr_isids = DA_ENFORCE_PR_ISIDS; | ||
886 | dev->se_sub_dev->se_dev_attrib.is_nonrot = DA_IS_NONROT; | ||
887 | dev->se_sub_dev->se_dev_attrib.emulate_rest_reord = DA_EMULATE_REST_REORD; | ||
888 | /* | ||
889 | * The TPU=1 and TPWS=1 settings will be set in TCM/IBLOCK | ||
890 | * iblock_create_virtdevice() from struct queue_limits values | ||
891 | * if blk_queue_discard()==1 | ||
892 | */ | ||
893 | dev->se_sub_dev->se_dev_attrib.max_unmap_lba_count = DA_MAX_UNMAP_LBA_COUNT; | ||
894 | dev->se_sub_dev->se_dev_attrib.max_unmap_block_desc_count = | ||
895 | DA_MAX_UNMAP_BLOCK_DESC_COUNT; | ||
896 | dev->se_sub_dev->se_dev_attrib.unmap_granularity = DA_UNMAP_GRANULARITY_DEFAULT; | ||
897 | dev->se_sub_dev->se_dev_attrib.unmap_granularity_alignment = | ||
898 | DA_UNMAP_GRANULARITY_ALIGNMENT_DEFAULT; | ||
899 | /* | ||
900 | * block_size is based on subsystem plugin dependent requirements. | ||
901 | */ | ||
902 | dev->se_sub_dev->se_dev_attrib.hw_block_size = limits->logical_block_size; | ||
903 | dev->se_sub_dev->se_dev_attrib.block_size = limits->logical_block_size; | ||
904 | /* | ||
905 | * Align max_hw_sectors down to PAGE_SIZE I/O transfers | ||
906 | */ | ||
907 | limits->max_hw_sectors = se_dev_align_max_sectors(limits->max_hw_sectors, | ||
908 | limits->logical_block_size); | ||
909 | dev->se_sub_dev->se_dev_attrib.hw_max_sectors = limits->max_hw_sectors; | ||
910 | |||
911 | /* | ||
912 | * Set fabric_max_sectors, which is reported in block limits | ||
913 | * VPD page (B0h). | ||
914 | */ | ||
915 | dev->se_sub_dev->se_dev_attrib.fabric_max_sectors = DA_FABRIC_MAX_SECTORS; | ||
916 | /* | ||
917 | * Set optimal_sectors from fabric_max_sectors, which can be | ||
918 | * lowered via configfs. | ||
919 | */ | ||
920 | dev->se_sub_dev->se_dev_attrib.optimal_sectors = DA_FABRIC_MAX_SECTORS; | ||
921 | /* | ||
922 | * queue_depth is based on subsystem plugin dependent requirements. | ||
923 | */ | ||
924 | dev->se_sub_dev->se_dev_attrib.hw_queue_depth = dev_limits->hw_queue_depth; | ||
925 | dev->se_sub_dev->se_dev_attrib.queue_depth = dev_limits->queue_depth; | ||
926 | } | ||
927 | |||
928 | int se_dev_set_max_unmap_lba_count( | 743 | int se_dev_set_max_unmap_lba_count( |
929 | struct se_device *dev, | 744 | struct se_device *dev, |
930 | u32 max_unmap_lba_count) | 745 | u32 max_unmap_lba_count) |
931 | { | 746 | { |
932 | dev->se_sub_dev->se_dev_attrib.max_unmap_lba_count = max_unmap_lba_count; | 747 | dev->dev_attrib.max_unmap_lba_count = max_unmap_lba_count; |
933 | pr_debug("dev[%p]: Set max_unmap_lba_count: %u\n", | 748 | pr_debug("dev[%p]: Set max_unmap_lba_count: %u\n", |
934 | dev, dev->se_sub_dev->se_dev_attrib.max_unmap_lba_count); | 749 | dev, dev->dev_attrib.max_unmap_lba_count); |
935 | return 0; | 750 | return 0; |
936 | } | 751 | } |
937 | 752 | ||
@@ -939,10 +754,10 @@ int se_dev_set_max_unmap_block_desc_count( | |||
939 | struct se_device *dev, | 754 | struct se_device *dev, |
940 | u32 max_unmap_block_desc_count) | 755 | u32 max_unmap_block_desc_count) |
941 | { | 756 | { |
942 | dev->se_sub_dev->se_dev_attrib.max_unmap_block_desc_count = | 757 | dev->dev_attrib.max_unmap_block_desc_count = |
943 | max_unmap_block_desc_count; | 758 | max_unmap_block_desc_count; |
944 | pr_debug("dev[%p]: Set max_unmap_block_desc_count: %u\n", | 759 | pr_debug("dev[%p]: Set max_unmap_block_desc_count: %u\n", |
945 | dev, dev->se_sub_dev->se_dev_attrib.max_unmap_block_desc_count); | 760 | dev, dev->dev_attrib.max_unmap_block_desc_count); |
946 | return 0; | 761 | return 0; |
947 | } | 762 | } |
948 | 763 | ||
@@ -950,9 +765,9 @@ int se_dev_set_unmap_granularity( | |||
950 | struct se_device *dev, | 765 | struct se_device *dev, |
951 | u32 unmap_granularity) | 766 | u32 unmap_granularity) |
952 | { | 767 | { |
953 | dev->se_sub_dev->se_dev_attrib.unmap_granularity = unmap_granularity; | 768 | dev->dev_attrib.unmap_granularity = unmap_granularity; |
954 | pr_debug("dev[%p]: Set unmap_granularity: %u\n", | 769 | pr_debug("dev[%p]: Set unmap_granularity: %u\n", |
955 | dev, dev->se_sub_dev->se_dev_attrib.unmap_granularity); | 770 | dev, dev->dev_attrib.unmap_granularity); |
956 | return 0; | 771 | return 0; |
957 | } | 772 | } |
958 | 773 | ||
@@ -960,9 +775,9 @@ int se_dev_set_unmap_granularity_alignment( | |||
960 | struct se_device *dev, | 775 | struct se_device *dev, |
961 | u32 unmap_granularity_alignment) | 776 | u32 unmap_granularity_alignment) |
962 | { | 777 | { |
963 | dev->se_sub_dev->se_dev_attrib.unmap_granularity_alignment = unmap_granularity_alignment; | 778 | dev->dev_attrib.unmap_granularity_alignment = unmap_granularity_alignment; |
964 | pr_debug("dev[%p]: Set unmap_granularity_alignment: %u\n", | 779 | pr_debug("dev[%p]: Set unmap_granularity_alignment: %u\n", |
965 | dev, dev->se_sub_dev->se_dev_attrib.unmap_granularity_alignment); | 780 | dev, dev->dev_attrib.unmap_granularity_alignment); |
966 | return 0; | 781 | return 0; |
967 | } | 782 | } |
968 | 783 | ||
@@ -993,9 +808,9 @@ int se_dev_set_emulate_fua_write(struct se_device *dev, int flag) | |||
993 | pr_err("emulate_fua_write not supported for pSCSI\n"); | 808 | pr_err("emulate_fua_write not supported for pSCSI\n"); |
994 | return -EINVAL; | 809 | return -EINVAL; |
995 | } | 810 | } |
996 | dev->se_sub_dev->se_dev_attrib.emulate_fua_write = flag; | 811 | dev->dev_attrib.emulate_fua_write = flag; |
997 | pr_debug("dev[%p]: SE Device Forced Unit Access WRITEs: %d\n", | 812 | pr_debug("dev[%p]: SE Device Forced Unit Access WRITEs: %d\n", |
998 | dev, dev->se_sub_dev->se_dev_attrib.emulate_fua_write); | 813 | dev, dev->dev_attrib.emulate_fua_write); |
999 | return 0; | 814 | return 0; |
1000 | } | 815 | } |
1001 | 816 | ||
@@ -1025,9 +840,9 @@ int se_dev_set_emulate_write_cache(struct se_device *dev, int flag) | |||
1025 | pr_err("emulate_write_cache not supported for pSCSI\n"); | 840 | pr_err("emulate_write_cache not supported for pSCSI\n"); |
1026 | return -EINVAL; | 841 | return -EINVAL; |
1027 | } | 842 | } |
1028 | dev->se_sub_dev->se_dev_attrib.emulate_write_cache = flag; | 843 | dev->dev_attrib.emulate_write_cache = flag; |
1029 | pr_debug("dev[%p]: SE Device WRITE_CACHE_EMULATION flag: %d\n", | 844 | pr_debug("dev[%p]: SE Device WRITE_CACHE_EMULATION flag: %d\n", |
1030 | dev, dev->se_sub_dev->se_dev_attrib.emulate_write_cache); | 845 | dev, dev->dev_attrib.emulate_write_cache); |
1031 | return 0; | 846 | return 0; |
1032 | } | 847 | } |
1033 | 848 | ||
@@ -1038,16 +853,15 @@ int se_dev_set_emulate_ua_intlck_ctrl(struct se_device *dev, int flag) | |||
1038 | return -EINVAL; | 853 | return -EINVAL; |
1039 | } | 854 | } |
1040 | 855 | ||
1041 | if (atomic_read(&dev->dev_export_obj.obj_access_count)) { | 856 | if (dev->export_count) { |
1042 | pr_err("dev[%p]: Unable to change SE Device" | 857 | pr_err("dev[%p]: Unable to change SE Device" |
1043 | " UA_INTRLCK_CTRL while dev_export_obj: %d count" | 858 | " UA_INTRLCK_CTRL while export_count is %d\n", |
1044 | " exists\n", dev, | 859 | dev, dev->export_count); |
1045 | atomic_read(&dev->dev_export_obj.obj_access_count)); | ||
1046 | return -EINVAL; | 860 | return -EINVAL; |
1047 | } | 861 | } |
1048 | dev->se_sub_dev->se_dev_attrib.emulate_ua_intlck_ctrl = flag; | 862 | dev->dev_attrib.emulate_ua_intlck_ctrl = flag; |
1049 | pr_debug("dev[%p]: SE Device UA_INTRLCK_CTRL flag: %d\n", | 863 | pr_debug("dev[%p]: SE Device UA_INTRLCK_CTRL flag: %d\n", |
1050 | dev, dev->se_sub_dev->se_dev_attrib.emulate_ua_intlck_ctrl); | 864 | dev, dev->dev_attrib.emulate_ua_intlck_ctrl); |
1051 | 865 | ||
1052 | return 0; | 866 | return 0; |
1053 | } | 867 | } |
@@ -1059,15 +873,15 @@ int se_dev_set_emulate_tas(struct se_device *dev, int flag) | |||
1059 | return -EINVAL; | 873 | return -EINVAL; |
1060 | } | 874 | } |
1061 | 875 | ||
1062 | if (atomic_read(&dev->dev_export_obj.obj_access_count)) { | 876 | if (dev->export_count) { |
1063 | pr_err("dev[%p]: Unable to change SE Device TAS while" | 877 | pr_err("dev[%p]: Unable to change SE Device TAS while" |
1064 | " dev_export_obj: %d count exists\n", dev, | 878 | " export_count is %d\n", |
1065 | atomic_read(&dev->dev_export_obj.obj_access_count)); | 879 | dev, dev->export_count); |
1066 | return -EINVAL; | 880 | return -EINVAL; |
1067 | } | 881 | } |
1068 | dev->se_sub_dev->se_dev_attrib.emulate_tas = flag; | 882 | dev->dev_attrib.emulate_tas = flag; |
1069 | pr_debug("dev[%p]: SE Device TASK_ABORTED status bit: %s\n", | 883 | pr_debug("dev[%p]: SE Device TASK_ABORTED status bit: %s\n", |
1070 | dev, (dev->se_sub_dev->se_dev_attrib.emulate_tas) ? "Enabled" : "Disabled"); | 884 | dev, (dev->dev_attrib.emulate_tas) ? "Enabled" : "Disabled"); |
1071 | 885 | ||
1072 | return 0; | 886 | return 0; |
1073 | } | 887 | } |
@@ -1082,12 +896,12 @@ int se_dev_set_emulate_tpu(struct se_device *dev, int flag) | |||
1082 | * We expect this value to be non-zero when generic Block Layer | 896 | * We expect this value to be non-zero when generic Block Layer |
1083 | * Discard supported is detected iblock_create_virtdevice(). | 897 | * Discard supported is detected iblock_create_virtdevice(). |
1084 | */ | 898 | */ |
1085 | if (flag && !dev->se_sub_dev->se_dev_attrib.max_unmap_block_desc_count) { | 899 | if (flag && !dev->dev_attrib.max_unmap_block_desc_count) { |
1086 | pr_err("Generic Block Discard not supported\n"); | 900 | pr_err("Generic Block Discard not supported\n"); |
1087 | return -ENOSYS; | 901 | return -ENOSYS; |
1088 | } | 902 | } |
1089 | 903 | ||
1090 | dev->se_sub_dev->se_dev_attrib.emulate_tpu = flag; | 904 | dev->dev_attrib.emulate_tpu = flag; |
1091 | pr_debug("dev[%p]: SE Device Thin Provisioning UNMAP bit: %d\n", | 905 | pr_debug("dev[%p]: SE Device Thin Provisioning UNMAP bit: %d\n", |
1092 | dev, flag); | 906 | dev, flag); |
1093 | return 0; | 907 | return 0; |
@@ -1103,12 +917,12 @@ int se_dev_set_emulate_tpws(struct se_device *dev, int flag) | |||
1103 | * We expect this value to be non-zero when generic Block Layer | 917 | * We expect this value to be non-zero when generic Block Layer |
1104 | * Discard supported is detected iblock_create_virtdevice(). | 918 | * Discard supported is detected iblock_create_virtdevice(). |
1105 | */ | 919 | */ |
1106 | if (flag && !dev->se_sub_dev->se_dev_attrib.max_unmap_block_desc_count) { | 920 | if (flag && !dev->dev_attrib.max_unmap_block_desc_count) { |
1107 | pr_err("Generic Block Discard not supported\n"); | 921 | pr_err("Generic Block Discard not supported\n"); |
1108 | return -ENOSYS; | 922 | return -ENOSYS; |
1109 | } | 923 | } |
1110 | 924 | ||
1111 | dev->se_sub_dev->se_dev_attrib.emulate_tpws = flag; | 925 | dev->dev_attrib.emulate_tpws = flag; |
1112 | pr_debug("dev[%p]: SE Device Thin Provisioning WRITE_SAME: %d\n", | 926 | pr_debug("dev[%p]: SE Device Thin Provisioning WRITE_SAME: %d\n", |
1113 | dev, flag); | 927 | dev, flag); |
1114 | return 0; | 928 | return 0; |
@@ -1120,9 +934,9 @@ int se_dev_set_enforce_pr_isids(struct se_device *dev, int flag) | |||
1120 | pr_err("Illegal value %d\n", flag); | 934 | pr_err("Illegal value %d\n", flag); |
1121 | return -EINVAL; | 935 | return -EINVAL; |
1122 | } | 936 | } |
1123 | dev->se_sub_dev->se_dev_attrib.enforce_pr_isids = flag; | 937 | dev->dev_attrib.enforce_pr_isids = flag; |
1124 | pr_debug("dev[%p]: SE Device enforce_pr_isids bit: %s\n", dev, | 938 | pr_debug("dev[%p]: SE Device enforce_pr_isids bit: %s\n", dev, |
1125 | (dev->se_sub_dev->se_dev_attrib.enforce_pr_isids) ? "Enabled" : "Disabled"); | 939 | (dev->dev_attrib.enforce_pr_isids) ? "Enabled" : "Disabled"); |
1126 | return 0; | 940 | return 0; |
1127 | } | 941 | } |
1128 | 942 | ||
@@ -1132,7 +946,7 @@ int se_dev_set_is_nonrot(struct se_device *dev, int flag) | |||
1132 | printk(KERN_ERR "Illegal value %d\n", flag); | 946 | printk(KERN_ERR "Illegal value %d\n", flag); |
1133 | return -EINVAL; | 947 | return -EINVAL; |
1134 | } | 948 | } |
1135 | dev->se_sub_dev->se_dev_attrib.is_nonrot = flag; | 949 | dev->dev_attrib.is_nonrot = flag; |
1136 | pr_debug("dev[%p]: SE Device is_nonrot bit: %d\n", | 950 | pr_debug("dev[%p]: SE Device is_nonrot bit: %d\n", |
1137 | dev, flag); | 951 | dev, flag); |
1138 | return 0; | 952 | return 0; |
@@ -1145,7 +959,7 @@ int se_dev_set_emulate_rest_reord(struct se_device *dev, int flag) | |||
1145 | " reordering not implemented\n", dev); | 959 | " reordering not implemented\n", dev); |
1146 | return -ENOSYS; | 960 | return -ENOSYS; |
1147 | } | 961 | } |
1148 | dev->se_sub_dev->se_dev_attrib.emulate_rest_reord = flag; | 962 | dev->dev_attrib.emulate_rest_reord = flag; |
1149 | pr_debug("dev[%p]: SE Device emulate_rest_reord: %d\n", dev, flag); | 963 | pr_debug("dev[%p]: SE Device emulate_rest_reord: %d\n", dev, flag); |
1150 | return 0; | 964 | return 0; |
1151 | } | 965 | } |
@@ -1155,10 +969,10 @@ int se_dev_set_emulate_rest_reord(struct se_device *dev, int flag) | |||
1155 | */ | 969 | */ |
1156 | int se_dev_set_queue_depth(struct se_device *dev, u32 queue_depth) | 970 | int se_dev_set_queue_depth(struct se_device *dev, u32 queue_depth) |
1157 | { | 971 | { |
1158 | if (atomic_read(&dev->dev_export_obj.obj_access_count)) { | 972 | if (dev->export_count) { |
1159 | pr_err("dev[%p]: Unable to change SE Device TCQ while" | 973 | pr_err("dev[%p]: Unable to change SE Device TCQ while" |
1160 | " dev_export_obj: %d count exists\n", dev, | 974 | " export_count is %d\n", |
1161 | atomic_read(&dev->dev_export_obj.obj_access_count)); | 975 | dev, dev->export_count); |
1162 | return -EINVAL; | 976 | return -EINVAL; |
1163 | } | 977 | } |
1164 | if (!queue_depth) { | 978 | if (!queue_depth) { |
@@ -1168,26 +982,26 @@ int se_dev_set_queue_depth(struct se_device *dev, u32 queue_depth) | |||
1168 | } | 982 | } |
1169 | 983 | ||
1170 | if (dev->transport->transport_type == TRANSPORT_PLUGIN_PHBA_PDEV) { | 984 | if (dev->transport->transport_type == TRANSPORT_PLUGIN_PHBA_PDEV) { |
1171 | if (queue_depth > dev->se_sub_dev->se_dev_attrib.hw_queue_depth) { | 985 | if (queue_depth > dev->dev_attrib.hw_queue_depth) { |
1172 | pr_err("dev[%p]: Passed queue_depth: %u" | 986 | pr_err("dev[%p]: Passed queue_depth: %u" |
1173 | " exceeds TCM/SE_Device TCQ: %u\n", | 987 | " exceeds TCM/SE_Device TCQ: %u\n", |
1174 | dev, queue_depth, | 988 | dev, queue_depth, |
1175 | dev->se_sub_dev->se_dev_attrib.hw_queue_depth); | 989 | dev->dev_attrib.hw_queue_depth); |
1176 | return -EINVAL; | 990 | return -EINVAL; |
1177 | } | 991 | } |
1178 | } else { | 992 | } else { |
1179 | if (queue_depth > dev->se_sub_dev->se_dev_attrib.queue_depth) { | 993 | if (queue_depth > dev->dev_attrib.queue_depth) { |
1180 | if (queue_depth > dev->se_sub_dev->se_dev_attrib.hw_queue_depth) { | 994 | if (queue_depth > dev->dev_attrib.hw_queue_depth) { |
1181 | pr_err("dev[%p]: Passed queue_depth:" | 995 | pr_err("dev[%p]: Passed queue_depth:" |
1182 | " %u exceeds TCM/SE_Device MAX" | 996 | " %u exceeds TCM/SE_Device MAX" |
1183 | " TCQ: %u\n", dev, queue_depth, | 997 | " TCQ: %u\n", dev, queue_depth, |
1184 | dev->se_sub_dev->se_dev_attrib.hw_queue_depth); | 998 | dev->dev_attrib.hw_queue_depth); |
1185 | return -EINVAL; | 999 | return -EINVAL; |
1186 | } | 1000 | } |
1187 | } | 1001 | } |
1188 | } | 1002 | } |
1189 | 1003 | ||
1190 | dev->se_sub_dev->se_dev_attrib.queue_depth = dev->queue_depth = queue_depth; | 1004 | dev->dev_attrib.queue_depth = dev->queue_depth = queue_depth; |
1191 | pr_debug("dev[%p]: SE Device TCQ Depth changed to: %u\n", | 1005 | pr_debug("dev[%p]: SE Device TCQ Depth changed to: %u\n", |
1192 | dev, queue_depth); | 1006 | dev, queue_depth); |
1193 | return 0; | 1007 | return 0; |
@@ -1195,10 +1009,10 @@ int se_dev_set_queue_depth(struct se_device *dev, u32 queue_depth) | |||
1195 | 1009 | ||
1196 | int se_dev_set_fabric_max_sectors(struct se_device *dev, u32 fabric_max_sectors) | 1010 | int se_dev_set_fabric_max_sectors(struct se_device *dev, u32 fabric_max_sectors) |
1197 | { | 1011 | { |
1198 | if (atomic_read(&dev->dev_export_obj.obj_access_count)) { | 1012 | if (dev->export_count) { |
1199 | pr_err("dev[%p]: Unable to change SE Device" | 1013 | pr_err("dev[%p]: Unable to change SE Device" |
1200 | " fabric_max_sectors while dev_export_obj: %d count exists\n", | 1014 | " fabric_max_sectors while export_count is %d\n", |
1201 | dev, atomic_read(&dev->dev_export_obj.obj_access_count)); | 1015 | dev, dev->export_count); |
1202 | return -EINVAL; | 1016 | return -EINVAL; |
1203 | } | 1017 | } |
1204 | if (!fabric_max_sectors) { | 1018 | if (!fabric_max_sectors) { |
@@ -1213,11 +1027,11 @@ int se_dev_set_fabric_max_sectors(struct se_device *dev, u32 fabric_max_sectors) | |||
1213 | return -EINVAL; | 1027 | return -EINVAL; |
1214 | } | 1028 | } |
1215 | if (dev->transport->transport_type == TRANSPORT_PLUGIN_PHBA_PDEV) { | 1029 | if (dev->transport->transport_type == TRANSPORT_PLUGIN_PHBA_PDEV) { |
1216 | if (fabric_max_sectors > dev->se_sub_dev->se_dev_attrib.hw_max_sectors) { | 1030 | if (fabric_max_sectors > dev->dev_attrib.hw_max_sectors) { |
1217 | pr_err("dev[%p]: Passed fabric_max_sectors: %u" | 1031 | pr_err("dev[%p]: Passed fabric_max_sectors: %u" |
1218 | " greater than TCM/SE_Device max_sectors:" | 1032 | " greater than TCM/SE_Device max_sectors:" |
1219 | " %u\n", dev, fabric_max_sectors, | 1033 | " %u\n", dev, fabric_max_sectors, |
1220 | dev->se_sub_dev->se_dev_attrib.hw_max_sectors); | 1034 | dev->dev_attrib.hw_max_sectors); |
1221 | return -EINVAL; | 1035 | return -EINVAL; |
1222 | } | 1036 | } |
1223 | } else { | 1037 | } else { |
@@ -1233,9 +1047,9 @@ int se_dev_set_fabric_max_sectors(struct se_device *dev, u32 fabric_max_sectors) | |||
1233 | * Align max_sectors down to PAGE_SIZE to follow transport_allocate_data_tasks() | 1047 | * Align max_sectors down to PAGE_SIZE to follow transport_allocate_data_tasks() |
1234 | */ | 1048 | */ |
1235 | fabric_max_sectors = se_dev_align_max_sectors(fabric_max_sectors, | 1049 | fabric_max_sectors = se_dev_align_max_sectors(fabric_max_sectors, |
1236 | dev->se_sub_dev->se_dev_attrib.block_size); | 1050 | dev->dev_attrib.block_size); |
1237 | 1051 | ||
1238 | dev->se_sub_dev->se_dev_attrib.fabric_max_sectors = fabric_max_sectors; | 1052 | dev->dev_attrib.fabric_max_sectors = fabric_max_sectors; |
1239 | pr_debug("dev[%p]: SE Device max_sectors changed to %u\n", | 1053 | pr_debug("dev[%p]: SE Device max_sectors changed to %u\n", |
1240 | dev, fabric_max_sectors); | 1054 | dev, fabric_max_sectors); |
1241 | return 0; | 1055 | return 0; |
@@ -1243,10 +1057,10 @@ int se_dev_set_fabric_max_sectors(struct se_device *dev, u32 fabric_max_sectors) | |||
1243 | 1057 | ||
1244 | int se_dev_set_optimal_sectors(struct se_device *dev, u32 optimal_sectors) | 1058 | int se_dev_set_optimal_sectors(struct se_device *dev, u32 optimal_sectors) |
1245 | { | 1059 | { |
1246 | if (atomic_read(&dev->dev_export_obj.obj_access_count)) { | 1060 | if (dev->export_count) { |
1247 | pr_err("dev[%p]: Unable to change SE Device" | 1061 | pr_err("dev[%p]: Unable to change SE Device" |
1248 | " optimal_sectors while dev_export_obj: %d count exists\n", | 1062 | " optimal_sectors while export_count is %d\n", |
1249 | dev, atomic_read(&dev->dev_export_obj.obj_access_count)); | 1063 | dev, dev->export_count); |
1250 | return -EINVAL; | 1064 | return -EINVAL; |
1251 | } | 1065 | } |
1252 | if (dev->transport->transport_type == TRANSPORT_PLUGIN_PHBA_PDEV) { | 1066 | if (dev->transport->transport_type == TRANSPORT_PLUGIN_PHBA_PDEV) { |
@@ -1254,14 +1068,14 @@ int se_dev_set_optimal_sectors(struct se_device *dev, u32 optimal_sectors) | |||
1254 | " changed for TCM/pSCSI\n", dev); | 1068 | " changed for TCM/pSCSI\n", dev); |
1255 | return -EINVAL; | 1069 | return -EINVAL; |
1256 | } | 1070 | } |
1257 | if (optimal_sectors > dev->se_sub_dev->se_dev_attrib.fabric_max_sectors) { | 1071 | if (optimal_sectors > dev->dev_attrib.fabric_max_sectors) { |
1258 | pr_err("dev[%p]: Passed optimal_sectors %u cannot be" | 1072 | pr_err("dev[%p]: Passed optimal_sectors %u cannot be" |
1259 | " greater than fabric_max_sectors: %u\n", dev, | 1073 | " greater than fabric_max_sectors: %u\n", dev, |
1260 | optimal_sectors, dev->se_sub_dev->se_dev_attrib.fabric_max_sectors); | 1074 | optimal_sectors, dev->dev_attrib.fabric_max_sectors); |
1261 | return -EINVAL; | 1075 | return -EINVAL; |
1262 | } | 1076 | } |
1263 | 1077 | ||
1264 | dev->se_sub_dev->se_dev_attrib.optimal_sectors = optimal_sectors; | 1078 | dev->dev_attrib.optimal_sectors = optimal_sectors; |
1265 | pr_debug("dev[%p]: SE Device optimal_sectors changed to %u\n", | 1079 | pr_debug("dev[%p]: SE Device optimal_sectors changed to %u\n", |
1266 | dev, optimal_sectors); | 1080 | dev, optimal_sectors); |
1267 | return 0; | 1081 | return 0; |
@@ -1269,10 +1083,10 @@ int se_dev_set_optimal_sectors(struct se_device *dev, u32 optimal_sectors) | |||
1269 | 1083 | ||
1270 | int se_dev_set_block_size(struct se_device *dev, u32 block_size) | 1084 | int se_dev_set_block_size(struct se_device *dev, u32 block_size) |
1271 | { | 1085 | { |
1272 | if (atomic_read(&dev->dev_export_obj.obj_access_count)) { | 1086 | if (dev->export_count) { |
1273 | pr_err("dev[%p]: Unable to change SE Device block_size" | 1087 | pr_err("dev[%p]: Unable to change SE Device block_size" |
1274 | " while dev_export_obj: %d count exists\n", dev, | 1088 | " while export_count is %d\n", |
1275 | atomic_read(&dev->dev_export_obj.obj_access_count)); | 1089 | dev, dev->export_count); |
1276 | return -EINVAL; | 1090 | return -EINVAL; |
1277 | } | 1091 | } |
1278 | 1092 | ||
@@ -1293,7 +1107,7 @@ int se_dev_set_block_size(struct se_device *dev, u32 block_size) | |||
1293 | return -EINVAL; | 1107 | return -EINVAL; |
1294 | } | 1108 | } |
1295 | 1109 | ||
1296 | dev->se_sub_dev->se_dev_attrib.block_size = block_size; | 1110 | dev->dev_attrib.block_size = block_size; |
1297 | pr_debug("dev[%p]: SE Device block_size changed to %u\n", | 1111 | pr_debug("dev[%p]: SE Device block_size changed to %u\n", |
1298 | dev, block_size); | 1112 | dev, block_size); |
1299 | return 0; | 1113 | return 0; |
@@ -1307,12 +1121,6 @@ struct se_lun *core_dev_add_lun( | |||
1307 | struct se_lun *lun_p; | 1121 | struct se_lun *lun_p; |
1308 | int rc; | 1122 | int rc; |
1309 | 1123 | ||
1310 | if (atomic_read(&dev->dev_access_obj.obj_access_count) != 0) { | ||
1311 | pr_err("Unable to export struct se_device while dev_access_obj: %d\n", | ||
1312 | atomic_read(&dev->dev_access_obj.obj_access_count)); | ||
1313 | return ERR_PTR(-EACCES); | ||
1314 | } | ||
1315 | |||
1316 | lun_p = core_tpg_pre_addlun(tpg, lun); | 1124 | lun_p = core_tpg_pre_addlun(tpg, lun); |
1317 | if (IS_ERR(lun_p)) | 1125 | if (IS_ERR(lun_p)) |
1318 | return lun_p; | 1126 | return lun_p; |
@@ -1568,12 +1376,220 @@ void core_dev_free_initiator_node_lun_acl( | |||
1568 | kfree(lacl); | 1376 | kfree(lacl); |
1569 | } | 1377 | } |
1570 | 1378 | ||
1379 | static void scsi_dump_inquiry(struct se_device *dev) | ||
1380 | { | ||
1381 | struct t10_wwn *wwn = &dev->t10_wwn; | ||
1382 | char buf[17]; | ||
1383 | int i, device_type; | ||
1384 | /* | ||
1385 | * Print Linux/SCSI style INQUIRY formatting to the kernel ring buffer | ||
1386 | */ | ||
1387 | for (i = 0; i < 8; i++) | ||
1388 | if (wwn->vendor[i] >= 0x20) | ||
1389 | buf[i] = wwn->vendor[i]; | ||
1390 | else | ||
1391 | buf[i] = ' '; | ||
1392 | buf[i] = '\0'; | ||
1393 | pr_debug(" Vendor: %s\n", buf); | ||
1394 | |||
1395 | for (i = 0; i < 16; i++) | ||
1396 | if (wwn->model[i] >= 0x20) | ||
1397 | buf[i] = wwn->model[i]; | ||
1398 | else | ||
1399 | buf[i] = ' '; | ||
1400 | buf[i] = '\0'; | ||
1401 | pr_debug(" Model: %s\n", buf); | ||
1402 | |||
1403 | for (i = 0; i < 4; i++) | ||
1404 | if (wwn->revision[i] >= 0x20) | ||
1405 | buf[i] = wwn->revision[i]; | ||
1406 | else | ||
1407 | buf[i] = ' '; | ||
1408 | buf[i] = '\0'; | ||
1409 | pr_debug(" Revision: %s\n", buf); | ||
1410 | |||
1411 | device_type = dev->transport->get_device_type(dev); | ||
1412 | pr_debug(" Type: %s ", scsi_device_type(device_type)); | ||
1413 | pr_debug(" ANSI SCSI revision: %02x\n", | ||
1414 | dev->transport->get_device_rev(dev)); | ||
1415 | } | ||
1416 | |||
1417 | struct se_device *target_alloc_device(struct se_hba *hba, const char *name) | ||
1418 | { | ||
1419 | struct se_device *dev; | ||
1420 | |||
1421 | dev = hba->transport->alloc_device(hba, name); | ||
1422 | if (!dev) | ||
1423 | return NULL; | ||
1424 | |||
1425 | dev->se_hba = hba; | ||
1426 | dev->transport = hba->transport; | ||
1427 | |||
1428 | INIT_LIST_HEAD(&dev->dev_list); | ||
1429 | INIT_LIST_HEAD(&dev->dev_sep_list); | ||
1430 | INIT_LIST_HEAD(&dev->dev_tmr_list); | ||
1431 | INIT_LIST_HEAD(&dev->delayed_cmd_list); | ||
1432 | INIT_LIST_HEAD(&dev->state_list); | ||
1433 | INIT_LIST_HEAD(&dev->qf_cmd_list); | ||
1434 | spin_lock_init(&dev->stats_lock); | ||
1435 | spin_lock_init(&dev->execute_task_lock); | ||
1436 | spin_lock_init(&dev->delayed_cmd_lock); | ||
1437 | spin_lock_init(&dev->dev_reservation_lock); | ||
1438 | spin_lock_init(&dev->se_port_lock); | ||
1439 | spin_lock_init(&dev->se_tmr_lock); | ||
1440 | spin_lock_init(&dev->qf_cmd_lock); | ||
1441 | atomic_set(&dev->dev_ordered_id, 0); | ||
1442 | INIT_LIST_HEAD(&dev->t10_wwn.t10_vpd_list); | ||
1443 | spin_lock_init(&dev->t10_wwn.t10_vpd_lock); | ||
1444 | INIT_LIST_HEAD(&dev->t10_pr.registration_list); | ||
1445 | INIT_LIST_HEAD(&dev->t10_pr.aptpl_reg_list); | ||
1446 | spin_lock_init(&dev->t10_pr.registration_lock); | ||
1447 | spin_lock_init(&dev->t10_pr.aptpl_reg_lock); | ||
1448 | INIT_LIST_HEAD(&dev->t10_alua.tg_pt_gps_list); | ||
1449 | spin_lock_init(&dev->t10_alua.tg_pt_gps_lock); | ||
1450 | |||
1451 | dev->t10_pr.pr_aptpl_buf_len = PR_APTPL_BUF_LEN; | ||
1452 | dev->t10_wwn.t10_dev = dev; | ||
1453 | dev->t10_alua.t10_dev = dev; | ||
1454 | |||
1455 | dev->dev_attrib.da_dev = dev; | ||
1456 | dev->dev_attrib.emulate_dpo = DA_EMULATE_DPO; | ||
1457 | dev->dev_attrib.emulate_fua_write = DA_EMULATE_FUA_WRITE; | ||
1458 | dev->dev_attrib.emulate_fua_read = DA_EMULATE_FUA_READ; | ||
1459 | dev->dev_attrib.emulate_write_cache = DA_EMULATE_WRITE_CACHE; | ||
1460 | dev->dev_attrib.emulate_ua_intlck_ctrl = DA_EMULATE_UA_INTLLCK_CTRL; | ||
1461 | dev->dev_attrib.emulate_tas = DA_EMULATE_TAS; | ||
1462 | dev->dev_attrib.emulate_tpu = DA_EMULATE_TPU; | ||
1463 | dev->dev_attrib.emulate_tpws = DA_EMULATE_TPWS; | ||
1464 | dev->dev_attrib.emulate_reservations = DA_EMULATE_RESERVATIONS; | ||
1465 | dev->dev_attrib.emulate_alua = DA_EMULATE_ALUA; | ||
1466 | dev->dev_attrib.enforce_pr_isids = DA_ENFORCE_PR_ISIDS; | ||
1467 | dev->dev_attrib.is_nonrot = DA_IS_NONROT; | ||
1468 | dev->dev_attrib.emulate_rest_reord = DA_EMULATE_REST_REORD; | ||
1469 | dev->dev_attrib.max_unmap_lba_count = DA_MAX_UNMAP_LBA_COUNT; | ||
1470 | dev->dev_attrib.max_unmap_block_desc_count = | ||
1471 | DA_MAX_UNMAP_BLOCK_DESC_COUNT; | ||
1472 | dev->dev_attrib.unmap_granularity = DA_UNMAP_GRANULARITY_DEFAULT; | ||
1473 | dev->dev_attrib.unmap_granularity_alignment = | ||
1474 | DA_UNMAP_GRANULARITY_ALIGNMENT_DEFAULT; | ||
1475 | dev->dev_attrib.fabric_max_sectors = DA_FABRIC_MAX_SECTORS; | ||
1476 | dev->dev_attrib.optimal_sectors = DA_FABRIC_MAX_SECTORS; | ||
1477 | |||
1478 | if (dev->transport->transport_type == TRANSPORT_PLUGIN_PHBA_PDEV) | ||
1479 | dev->dev_task_attr_type = SAM_TASK_ATTR_PASSTHROUGH; | ||
1480 | else | ||
1481 | dev->dev_task_attr_type = SAM_TASK_ATTR_EMULATED; | ||
1482 | |||
1483 | return dev; | ||
1484 | } | ||
1485 | |||
1486 | int target_configure_device(struct se_device *dev) | ||
1487 | { | ||
1488 | struct se_hba *hba = dev->se_hba; | ||
1489 | int ret; | ||
1490 | |||
1491 | if (dev->dev_flags & DF_CONFIGURED) { | ||
1492 | pr_err("se_dev->se_dev_ptr already set for storage" | ||
1493 | " object\n"); | ||
1494 | return -EEXIST; | ||
1495 | } | ||
1496 | |||
1497 | ret = dev->transport->configure_device(dev); | ||
1498 | if (ret) | ||
1499 | goto out; | ||
1500 | dev->dev_flags |= DF_CONFIGURED; | ||
1501 | |||
1502 | /* | ||
1503 | * XXX: there is not much point to have two different values here.. | ||
1504 | */ | ||
1505 | dev->dev_attrib.block_size = dev->dev_attrib.hw_block_size; | ||
1506 | dev->dev_attrib.queue_depth = dev->dev_attrib.hw_queue_depth; | ||
1507 | |||
1508 | /* | ||
1509 | * Align max_hw_sectors down to PAGE_SIZE I/O transfers | ||
1510 | */ | ||
1511 | dev->dev_attrib.hw_max_sectors = | ||
1512 | se_dev_align_max_sectors(dev->dev_attrib.hw_max_sectors, | ||
1513 | dev->dev_attrib.hw_block_size); | ||
1514 | |||
1515 | dev->dev_index = scsi_get_new_index(SCSI_DEVICE_INDEX); | ||
1516 | dev->creation_time = get_jiffies_64(); | ||
1517 | |||
1518 | core_setup_reservations(dev); | ||
1519 | |||
1520 | ret = core_setup_alua(dev); | ||
1521 | if (ret) | ||
1522 | goto out; | ||
1523 | |||
1524 | /* | ||
1525 | * Startup the struct se_device processing thread | ||
1526 | */ | ||
1527 | dev->tmr_wq = alloc_workqueue("tmr-%s", WQ_MEM_RECLAIM | WQ_UNBOUND, 1, | ||
1528 | dev->transport->name); | ||
1529 | if (!dev->tmr_wq) { | ||
1530 | pr_err("Unable to create tmr workqueue for %s\n", | ||
1531 | dev->transport->name); | ||
1532 | ret = -ENOMEM; | ||
1533 | goto out_free_alua; | ||
1534 | } | ||
1535 | |||
1536 | /* | ||
1537 | * Setup work_queue for QUEUE_FULL | ||
1538 | */ | ||
1539 | INIT_WORK(&dev->qf_work_queue, target_qf_do_work); | ||
1540 | |||
1541 | /* | ||
1542 | * Preload the initial INQUIRY const values if we are doing | ||
1543 | * anything virtual (IBLOCK, FILEIO, RAMDISK), but not for TCM/pSCSI | ||
1544 | * passthrough because this is being provided by the backend LLD. | ||
1545 | */ | ||
1546 | if (dev->transport->transport_type != TRANSPORT_PLUGIN_PHBA_PDEV) { | ||
1547 | strncpy(&dev->t10_wwn.vendor[0], "LIO-ORG", 8); | ||
1548 | strncpy(&dev->t10_wwn.model[0], | ||
1549 | dev->transport->inquiry_prod, 16); | ||
1550 | strncpy(&dev->t10_wwn.revision[0], | ||
1551 | dev->transport->inquiry_rev, 4); | ||
1552 | } | ||
1553 | |||
1554 | scsi_dump_inquiry(dev); | ||
1555 | |||
1556 | spin_lock(&hba->device_lock); | ||
1557 | hba->dev_count++; | ||
1558 | spin_unlock(&hba->device_lock); | ||
1559 | return 0; | ||
1560 | |||
1561 | out_free_alua: | ||
1562 | core_alua_free_lu_gp_mem(dev); | ||
1563 | out: | ||
1564 | se_release_vpd_for_dev(dev); | ||
1565 | return ret; | ||
1566 | } | ||
1567 | |||
1568 | void target_free_device(struct se_device *dev) | ||
1569 | { | ||
1570 | struct se_hba *hba = dev->se_hba; | ||
1571 | |||
1572 | WARN_ON(!list_empty(&dev->dev_sep_list)); | ||
1573 | |||
1574 | if (dev->dev_flags & DF_CONFIGURED) { | ||
1575 | destroy_workqueue(dev->tmr_wq); | ||
1576 | |||
1577 | spin_lock(&hba->device_lock); | ||
1578 | hba->dev_count--; | ||
1579 | spin_unlock(&hba->device_lock); | ||
1580 | } | ||
1581 | |||
1582 | core_alua_free_lu_gp_mem(dev); | ||
1583 | core_scsi3_free_all_registrations(dev); | ||
1584 | se_release_vpd_for_dev(dev); | ||
1585 | |||
1586 | dev->transport->free_device(dev); | ||
1587 | } | ||
1588 | |||
1571 | int core_dev_setup_virtual_lun0(void) | 1589 | int core_dev_setup_virtual_lun0(void) |
1572 | { | 1590 | { |
1573 | struct se_hba *hba; | 1591 | struct se_hba *hba; |
1574 | struct se_device *dev; | 1592 | struct se_device *dev; |
1575 | struct se_subsystem_dev *se_dev = NULL; | ||
1576 | struct se_subsystem_api *t; | ||
1577 | char buf[16]; | 1593 | char buf[16]; |
1578 | int ret; | 1594 | int ret; |
1579 | 1595 | ||
@@ -1581,60 +1597,28 @@ int core_dev_setup_virtual_lun0(void) | |||
1581 | if (IS_ERR(hba)) | 1597 | if (IS_ERR(hba)) |
1582 | return PTR_ERR(hba); | 1598 | return PTR_ERR(hba); |
1583 | 1599 | ||
1584 | lun0_hba = hba; | 1600 | dev = target_alloc_device(hba, "virt_lun0"); |
1585 | t = hba->transport; | 1601 | if (!dev) { |
1586 | |||
1587 | se_dev = kzalloc(sizeof(struct se_subsystem_dev), GFP_KERNEL); | ||
1588 | if (!se_dev) { | ||
1589 | pr_err("Unable to allocate memory for" | ||
1590 | " struct se_subsystem_dev\n"); | ||
1591 | ret = -ENOMEM; | 1602 | ret = -ENOMEM; |
1592 | goto out; | 1603 | goto out_free_hba; |
1593 | } | 1604 | } |
1594 | INIT_LIST_HEAD(&se_dev->t10_wwn.t10_vpd_list); | ||
1595 | spin_lock_init(&se_dev->t10_wwn.t10_vpd_lock); | ||
1596 | INIT_LIST_HEAD(&se_dev->t10_pr.registration_list); | ||
1597 | INIT_LIST_HEAD(&se_dev->t10_pr.aptpl_reg_list); | ||
1598 | spin_lock_init(&se_dev->t10_pr.registration_lock); | ||
1599 | spin_lock_init(&se_dev->t10_pr.aptpl_reg_lock); | ||
1600 | INIT_LIST_HEAD(&se_dev->t10_alua.tg_pt_gps_list); | ||
1601 | spin_lock_init(&se_dev->t10_alua.tg_pt_gps_lock); | ||
1602 | spin_lock_init(&se_dev->se_dev_lock); | ||
1603 | se_dev->t10_pr.pr_aptpl_buf_len = PR_APTPL_BUF_LEN; | ||
1604 | se_dev->t10_wwn.t10_sub_dev = se_dev; | ||
1605 | se_dev->t10_alua.t10_sub_dev = se_dev; | ||
1606 | se_dev->se_dev_attrib.da_sub_dev = se_dev; | ||
1607 | se_dev->se_dev_hba = hba; | ||
1608 | |||
1609 | se_dev->se_dev_su_ptr = t->allocate_virtdevice(hba, "virt_lun0"); | ||
1610 | if (!se_dev->se_dev_su_ptr) { | ||
1611 | pr_err("Unable to locate subsystem dependent pointer" | ||
1612 | " from allocate_virtdevice()\n"); | ||
1613 | ret = -ENOMEM; | ||
1614 | goto out; | ||
1615 | } | ||
1616 | lun0_su_dev = se_dev; | ||
1617 | 1605 | ||
1618 | memset(buf, 0, 16); | 1606 | memset(buf, 0, 16); |
1619 | sprintf(buf, "rd_pages=8"); | 1607 | sprintf(buf, "rd_pages=8"); |
1620 | t->set_configfs_dev_params(hba, se_dev, buf, sizeof(buf)); | 1608 | hba->transport->set_configfs_dev_params(dev, buf, sizeof(buf)); |
1621 | 1609 | ||
1622 | dev = t->create_virtdevice(hba, se_dev, se_dev->se_dev_su_ptr); | 1610 | ret = target_configure_device(dev); |
1623 | if (IS_ERR(dev)) { | 1611 | if (ret) |
1624 | ret = PTR_ERR(dev); | 1612 | goto out_free_se_dev; |
1625 | goto out; | ||
1626 | } | ||
1627 | se_dev->se_dev_ptr = dev; | ||
1628 | g_lun0_dev = dev; | ||
1629 | 1613 | ||
1614 | lun0_hba = hba; | ||
1615 | g_lun0_dev = dev; | ||
1630 | return 0; | 1616 | return 0; |
1631 | out: | 1617 | |
1632 | lun0_su_dev = NULL; | 1618 | out_free_se_dev: |
1633 | kfree(se_dev); | 1619 | target_free_device(dev); |
1634 | if (lun0_hba) { | 1620 | out_free_hba: |
1635 | core_delete_hba(lun0_hba); | 1621 | core_delete_hba(hba); |
1636 | lun0_hba = NULL; | ||
1637 | } | ||
1638 | return ret; | 1622 | return ret; |
1639 | } | 1623 | } |
1640 | 1624 | ||
@@ -1642,14 +1626,11 @@ out: | |||
1642 | void core_dev_release_virtual_lun0(void) | 1626 | void core_dev_release_virtual_lun0(void) |
1643 | { | 1627 | { |
1644 | struct se_hba *hba = lun0_hba; | 1628 | struct se_hba *hba = lun0_hba; |
1645 | struct se_subsystem_dev *su_dev = lun0_su_dev; | ||
1646 | 1629 | ||
1647 | if (!hba) | 1630 | if (!hba) |
1648 | return; | 1631 | return; |
1649 | 1632 | ||
1650 | if (g_lun0_dev) | 1633 | if (g_lun0_dev) |
1651 | se_free_virtual_device(g_lun0_dev, hba); | 1634 | target_free_device(g_lun0_dev); |
1652 | |||
1653 | kfree(su_dev); | ||
1654 | core_delete_hba(hba); | 1635 | core_delete_hba(hba); |
1655 | } | 1636 | } |
diff --git a/drivers/target/target_core_fabric_configfs.c b/drivers/target/target_core_fabric_configfs.c index bca737bb813d..aa6731337f84 100644 --- a/drivers/target/target_core_fabric_configfs.c +++ b/drivers/target/target_core_fabric_configfs.c | |||
@@ -734,14 +734,12 @@ static int target_fabric_port_link( | |||
734 | struct config_item *se_dev_ci) | 734 | struct config_item *se_dev_ci) |
735 | { | 735 | { |
736 | struct config_item *tpg_ci; | 736 | struct config_item *tpg_ci; |
737 | struct se_device *dev; | ||
738 | struct se_lun *lun = container_of(to_config_group(lun_ci), | 737 | struct se_lun *lun = container_of(to_config_group(lun_ci), |
739 | struct se_lun, lun_group); | 738 | struct se_lun, lun_group); |
740 | struct se_lun *lun_p; | 739 | struct se_lun *lun_p; |
741 | struct se_portal_group *se_tpg; | 740 | struct se_portal_group *se_tpg; |
742 | struct se_subsystem_dev *se_dev = container_of( | 741 | struct se_device *dev = |
743 | to_config_group(se_dev_ci), struct se_subsystem_dev, | 742 | container_of(to_config_group(se_dev_ci), struct se_device, dev_group); |
744 | se_dev_group); | ||
745 | struct target_fabric_configfs *tf; | 743 | struct target_fabric_configfs *tf; |
746 | int ret; | 744 | int ret; |
747 | 745 | ||
@@ -755,14 +753,6 @@ static int target_fabric_port_link( | |||
755 | return -EEXIST; | 753 | return -EEXIST; |
756 | } | 754 | } |
757 | 755 | ||
758 | dev = se_dev->se_dev_ptr; | ||
759 | if (!dev) { | ||
760 | pr_err("Unable to locate struct se_device pointer from" | ||
761 | " %s\n", config_item_name(se_dev_ci)); | ||
762 | ret = -ENODEV; | ||
763 | goto out; | ||
764 | } | ||
765 | |||
766 | lun_p = core_dev_add_lun(se_tpg, dev, lun->unpacked_lun); | 756 | lun_p = core_dev_add_lun(se_tpg, dev, lun->unpacked_lun); |
767 | if (IS_ERR(lun_p)) { | 757 | if (IS_ERR(lun_p)) { |
768 | pr_err("core_dev_add_lun() failed\n"); | 758 | pr_err("core_dev_add_lun() failed\n"); |
diff --git a/drivers/target/target_core_file.c b/drivers/target/target_core_file.c index 0360383dfb94..a89d80dacad2 100644 --- a/drivers/target/target_core_file.c +++ b/drivers/target/target_core_file.c | |||
@@ -41,7 +41,10 @@ | |||
41 | 41 | ||
42 | #include "target_core_file.h" | 42 | #include "target_core_file.h" |
43 | 43 | ||
44 | static struct se_subsystem_api fileio_template; | 44 | static inline struct fd_dev *FD_DEV(struct se_device *dev) |
45 | { | ||
46 | return container_of(dev, struct fd_dev, dev); | ||
47 | } | ||
45 | 48 | ||
46 | /* fd_attach_hba(): (Part of se_subsystem_api_t template) | 49 | /* fd_attach_hba(): (Part of se_subsystem_api_t template) |
47 | * | 50 | * |
@@ -82,7 +85,7 @@ static void fd_detach_hba(struct se_hba *hba) | |||
82 | hba->hba_ptr = NULL; | 85 | hba->hba_ptr = NULL; |
83 | } | 86 | } |
84 | 87 | ||
85 | static void *fd_allocate_virtdevice(struct se_hba *hba, const char *name) | 88 | static struct se_device *fd_alloc_device(struct se_hba *hba, const char *name) |
86 | { | 89 | { |
87 | struct fd_dev *fd_dev; | 90 | struct fd_dev *fd_dev; |
88 | struct fd_host *fd_host = hba->hba_ptr; | 91 | struct fd_host *fd_host = hba->hba_ptr; |
@@ -97,34 +100,28 @@ static void *fd_allocate_virtdevice(struct se_hba *hba, const char *name) | |||
97 | 100 | ||
98 | pr_debug("FILEIO: Allocated fd_dev for %p\n", name); | 101 | pr_debug("FILEIO: Allocated fd_dev for %p\n", name); |
99 | 102 | ||
100 | return fd_dev; | 103 | return &fd_dev->dev; |
101 | } | 104 | } |
102 | 105 | ||
103 | /* fd_create_virtdevice(): (Part of se_subsystem_api_t template) | 106 | static int fd_configure_device(struct se_device *dev) |
104 | * | ||
105 | * | ||
106 | */ | ||
107 | static struct se_device *fd_create_virtdevice( | ||
108 | struct se_hba *hba, | ||
109 | struct se_subsystem_dev *se_dev, | ||
110 | void *p) | ||
111 | { | 107 | { |
112 | struct se_device *dev; | 108 | struct fd_dev *fd_dev = FD_DEV(dev); |
113 | struct se_dev_limits dev_limits; | 109 | struct fd_host *fd_host = dev->se_hba->hba_ptr; |
114 | struct queue_limits *limits; | ||
115 | struct fd_dev *fd_dev = p; | ||
116 | struct fd_host *fd_host = hba->hba_ptr; | ||
117 | struct file *file; | 110 | struct file *file; |
118 | struct inode *inode = NULL; | 111 | struct inode *inode = NULL; |
119 | int dev_flags = 0, flags, ret = -EINVAL; | 112 | int flags, ret = -EINVAL; |
120 | 113 | ||
121 | memset(&dev_limits, 0, sizeof(struct se_dev_limits)); | 114 | if (!(fd_dev->fbd_flags & FBDF_HAS_PATH)) { |
115 | pr_err("Missing fd_dev_name=\n"); | ||
116 | return -EINVAL; | ||
117 | } | ||
122 | 118 | ||
123 | /* | 119 | /* |
124 | * Use O_DSYNC by default instead of O_SYNC to forgo syncing | 120 | * Use O_DSYNC by default instead of O_SYNC to forgo syncing |
125 | * of pure timestamp updates. | 121 | * of pure timestamp updates. |
126 | */ | 122 | */ |
127 | flags = O_RDWR | O_CREAT | O_LARGEFILE | O_DSYNC; | 123 | flags = O_RDWR | O_CREAT | O_LARGEFILE | O_DSYNC; |
124 | |||
128 | /* | 125 | /* |
129 | * Optionally allow fd_buffered_io=1 to be enabled for people | 126 | * Optionally allow fd_buffered_io=1 to be enabled for people |
130 | * who want use the fs buffer cache as an WriteCache mechanism. | 127 | * who want use the fs buffer cache as an WriteCache mechanism. |
@@ -154,22 +151,17 @@ static struct se_device *fd_create_virtdevice( | |||
154 | */ | 151 | */ |
155 | inode = file->f_mapping->host; | 152 | inode = file->f_mapping->host; |
156 | if (S_ISBLK(inode->i_mode)) { | 153 | if (S_ISBLK(inode->i_mode)) { |
157 | struct request_queue *q; | 154 | struct request_queue *q = bdev_get_queue(inode->i_bdev); |
158 | unsigned long long dev_size; | 155 | unsigned long long dev_size; |
159 | /* | 156 | |
160 | * Setup the local scope queue_limits from struct request_queue->limits | 157 | dev->dev_attrib.hw_block_size = |
161 | * to pass into transport_add_device_to_core_hba() as struct se_dev_limits. | 158 | bdev_logical_block_size(inode->i_bdev); |
162 | */ | 159 | dev->dev_attrib.hw_max_sectors = queue_max_hw_sectors(q); |
163 | q = bdev_get_queue(inode->i_bdev); | 160 | |
164 | limits = &dev_limits.limits; | ||
165 | limits->logical_block_size = bdev_logical_block_size(inode->i_bdev); | ||
166 | limits->max_hw_sectors = queue_max_hw_sectors(q); | ||
167 | limits->max_sectors = queue_max_sectors(q); | ||
168 | /* | 161 | /* |
169 | * Determine the number of bytes from i_size_read() minus | 162 | * Determine the number of bytes from i_size_read() minus |
170 | * one (1) logical sector from underlying struct block_device | 163 | * one (1) logical sector from underlying struct block_device |
171 | */ | 164 | */ |
172 | fd_dev->fd_block_size = bdev_logical_block_size(inode->i_bdev); | ||
173 | dev_size = (i_size_read(file->f_mapping->host) - | 165 | dev_size = (i_size_read(file->f_mapping->host) - |
174 | fd_dev->fd_block_size); | 166 | fd_dev->fd_block_size); |
175 | 167 | ||
@@ -185,26 +177,18 @@ static struct se_device *fd_create_virtdevice( | |||
185 | goto fail; | 177 | goto fail; |
186 | } | 178 | } |
187 | 179 | ||
188 | limits = &dev_limits.limits; | 180 | dev->dev_attrib.hw_block_size = FD_BLOCKSIZE; |
189 | limits->logical_block_size = FD_BLOCKSIZE; | 181 | dev->dev_attrib.hw_max_sectors = FD_MAX_SECTORS; |
190 | limits->max_hw_sectors = FD_MAX_SECTORS; | ||
191 | limits->max_sectors = FD_MAX_SECTORS; | ||
192 | fd_dev->fd_block_size = FD_BLOCKSIZE; | ||
193 | } | 182 | } |
194 | 183 | ||
195 | dev_limits.hw_queue_depth = FD_MAX_DEVICE_QUEUE_DEPTH; | 184 | fd_dev->fd_block_size = dev->dev_attrib.hw_block_size; |
196 | dev_limits.queue_depth = FD_DEVICE_QUEUE_DEPTH; | ||
197 | 185 | ||
198 | dev = transport_add_device_to_core_hba(hba, &fileio_template, | 186 | dev->dev_attrib.hw_queue_depth = FD_MAX_DEVICE_QUEUE_DEPTH; |
199 | se_dev, dev_flags, fd_dev, | ||
200 | &dev_limits, "FILEIO", FD_VERSION); | ||
201 | if (!dev) | ||
202 | goto fail; | ||
203 | 187 | ||
204 | if (fd_dev->fbd_flags & FDBD_HAS_BUFFERED_IO_WCE) { | 188 | if (fd_dev->fbd_flags & FDBD_HAS_BUFFERED_IO_WCE) { |
205 | pr_debug("FILEIO: Forcing setting of emulate_write_cache=1" | 189 | pr_debug("FILEIO: Forcing setting of emulate_write_cache=1" |
206 | " with FDBD_HAS_BUFFERED_IO_WCE\n"); | 190 | " with FDBD_HAS_BUFFERED_IO_WCE\n"); |
207 | dev->se_sub_dev->se_dev_attrib.emulate_write_cache = 1; | 191 | dev->dev_attrib.emulate_write_cache = 1; |
208 | } | 192 | } |
209 | 193 | ||
210 | fd_dev->fd_dev_id = fd_host->fd_host_dev_id_count++; | 194 | fd_dev->fd_dev_id = fd_host->fd_host_dev_id_count++; |
@@ -214,22 +198,18 @@ static struct se_device *fd_create_virtdevice( | |||
214 | " %llu total bytes\n", fd_host->fd_host_id, fd_dev->fd_dev_id, | 198 | " %llu total bytes\n", fd_host->fd_host_id, fd_dev->fd_dev_id, |
215 | fd_dev->fd_dev_name, fd_dev->fd_dev_size); | 199 | fd_dev->fd_dev_name, fd_dev->fd_dev_size); |
216 | 200 | ||
217 | return dev; | 201 | return 0; |
218 | fail: | 202 | fail: |
219 | if (fd_dev->fd_file) { | 203 | if (fd_dev->fd_file) { |
220 | filp_close(fd_dev->fd_file, NULL); | 204 | filp_close(fd_dev->fd_file, NULL); |
221 | fd_dev->fd_file = NULL; | 205 | fd_dev->fd_file = NULL; |
222 | } | 206 | } |
223 | return ERR_PTR(ret); | 207 | return ret; |
224 | } | 208 | } |
225 | 209 | ||
226 | /* fd_free_device(): (Part of se_subsystem_api_t template) | 210 | static void fd_free_device(struct se_device *dev) |
227 | * | ||
228 | * | ||
229 | */ | ||
230 | static void fd_free_device(void *p) | ||
231 | { | 211 | { |
232 | struct fd_dev *fd_dev = p; | 212 | struct fd_dev *fd_dev = FD_DEV(dev); |
233 | 213 | ||
234 | if (fd_dev->fd_file) { | 214 | if (fd_dev->fd_file) { |
235 | filp_close(fd_dev->fd_file, NULL); | 215 | filp_close(fd_dev->fd_file, NULL); |
@@ -243,13 +223,12 @@ static int fd_do_readv(struct se_cmd *cmd, struct scatterlist *sgl, | |||
243 | u32 sgl_nents) | 223 | u32 sgl_nents) |
244 | { | 224 | { |
245 | struct se_device *se_dev = cmd->se_dev; | 225 | struct se_device *se_dev = cmd->se_dev; |
246 | struct fd_dev *dev = se_dev->dev_ptr; | 226 | struct fd_dev *dev = FD_DEV(se_dev); |
247 | struct file *fd = dev->fd_file; | 227 | struct file *fd = dev->fd_file; |
248 | struct scatterlist *sg; | 228 | struct scatterlist *sg; |
249 | struct iovec *iov; | 229 | struct iovec *iov; |
250 | mm_segment_t old_fs; | 230 | mm_segment_t old_fs; |
251 | loff_t pos = (cmd->t_task_lba * | 231 | loff_t pos = (cmd->t_task_lba * se_dev->dev_attrib.block_size); |
252 | se_dev->se_sub_dev->se_dev_attrib.block_size); | ||
253 | int ret = 0, i; | 232 | int ret = 0, i; |
254 | 233 | ||
255 | iov = kzalloc(sizeof(struct iovec) * sgl_nents, GFP_KERNEL); | 234 | iov = kzalloc(sizeof(struct iovec) * sgl_nents, GFP_KERNEL); |
@@ -296,13 +275,12 @@ static int fd_do_writev(struct se_cmd *cmd, struct scatterlist *sgl, | |||
296 | u32 sgl_nents) | 275 | u32 sgl_nents) |
297 | { | 276 | { |
298 | struct se_device *se_dev = cmd->se_dev; | 277 | struct se_device *se_dev = cmd->se_dev; |
299 | struct fd_dev *dev = se_dev->dev_ptr; | 278 | struct fd_dev *dev = FD_DEV(se_dev); |
300 | struct file *fd = dev->fd_file; | 279 | struct file *fd = dev->fd_file; |
301 | struct scatterlist *sg; | 280 | struct scatterlist *sg; |
302 | struct iovec *iov; | 281 | struct iovec *iov; |
303 | mm_segment_t old_fs; | 282 | mm_segment_t old_fs; |
304 | loff_t pos = (cmd->t_task_lba * | 283 | loff_t pos = (cmd->t_task_lba * se_dev->dev_attrib.block_size); |
305 | se_dev->se_sub_dev->se_dev_attrib.block_size); | ||
306 | int ret, i = 0; | 284 | int ret, i = 0; |
307 | 285 | ||
308 | iov = kzalloc(sizeof(struct iovec) * sgl_nents, GFP_KERNEL); | 286 | iov = kzalloc(sizeof(struct iovec) * sgl_nents, GFP_KERNEL); |
@@ -334,7 +312,7 @@ static int fd_do_writev(struct se_cmd *cmd, struct scatterlist *sgl, | |||
334 | static int fd_execute_sync_cache(struct se_cmd *cmd) | 312 | static int fd_execute_sync_cache(struct se_cmd *cmd) |
335 | { | 313 | { |
336 | struct se_device *dev = cmd->se_dev; | 314 | struct se_device *dev = cmd->se_dev; |
337 | struct fd_dev *fd_dev = dev->dev_ptr; | 315 | struct fd_dev *fd_dev = FD_DEV(dev); |
338 | int immed = (cmd->t_task_cdb[1] & 0x2); | 316 | int immed = (cmd->t_task_cdb[1] & 0x2); |
339 | loff_t start, end; | 317 | loff_t start, end; |
340 | int ret; | 318 | int ret; |
@@ -353,7 +331,7 @@ static int fd_execute_sync_cache(struct se_cmd *cmd) | |||
353 | start = 0; | 331 | start = 0; |
354 | end = LLONG_MAX; | 332 | end = LLONG_MAX; |
355 | } else { | 333 | } else { |
356 | start = cmd->t_task_lba * dev->se_sub_dev->se_dev_attrib.block_size; | 334 | start = cmd->t_task_lba * dev->dev_attrib.block_size; |
357 | if (cmd->data_length) | 335 | if (cmd->data_length) |
358 | end = start + cmd->data_length; | 336 | end = start + cmd->data_length; |
359 | else | 337 | else |
@@ -399,11 +377,11 @@ static int fd_execute_rw(struct se_cmd *cmd) | |||
399 | * Allow this to happen independent of WCE=0 setting. | 377 | * Allow this to happen independent of WCE=0 setting. |
400 | */ | 378 | */ |
401 | if (ret > 0 && | 379 | if (ret > 0 && |
402 | dev->se_sub_dev->se_dev_attrib.emulate_fua_write > 0 && | 380 | dev->dev_attrib.emulate_fua_write > 0 && |
403 | (cmd->se_cmd_flags & SCF_FUA)) { | 381 | (cmd->se_cmd_flags & SCF_FUA)) { |
404 | struct fd_dev *fd_dev = dev->dev_ptr; | 382 | struct fd_dev *fd_dev = FD_DEV(dev); |
405 | loff_t start = cmd->t_task_lba * | 383 | loff_t start = cmd->t_task_lba * |
406 | dev->se_sub_dev->se_dev_attrib.block_size; | 384 | dev->dev_attrib.block_size; |
407 | loff_t end = start + cmd->data_length; | 385 | loff_t end = start + cmd->data_length; |
408 | 386 | ||
409 | vfs_fsync_range(fd_dev->fd_file, start, end, 1); | 387 | vfs_fsync_range(fd_dev->fd_file, start, end, 1); |
@@ -430,12 +408,10 @@ static match_table_t tokens = { | |||
430 | {Opt_err, NULL} | 408 | {Opt_err, NULL} |
431 | }; | 409 | }; |
432 | 410 | ||
433 | static ssize_t fd_set_configfs_dev_params( | 411 | static ssize_t fd_set_configfs_dev_params(struct se_device *dev, |
434 | struct se_hba *hba, | 412 | const char *page, ssize_t count) |
435 | struct se_subsystem_dev *se_dev, | ||
436 | const char *page, ssize_t count) | ||
437 | { | 413 | { |
438 | struct fd_dev *fd_dev = se_dev->se_dev_su_ptr; | 414 | struct fd_dev *fd_dev = FD_DEV(dev); |
439 | char *orig, *ptr, *arg_p, *opts; | 415 | char *orig, *ptr, *arg_p, *opts; |
440 | substring_t args[MAX_OPT_ARGS]; | 416 | substring_t args[MAX_OPT_ARGS]; |
441 | int ret = 0, arg, token; | 417 | int ret = 0, arg, token; |
@@ -502,24 +478,9 @@ out: | |||
502 | return (!ret) ? count : ret; | 478 | return (!ret) ? count : ret; |
503 | } | 479 | } |
504 | 480 | ||
505 | static ssize_t fd_check_configfs_dev_params(struct se_hba *hba, struct se_subsystem_dev *se_dev) | 481 | static ssize_t fd_show_configfs_dev_params(struct se_device *dev, char *b) |
506 | { | ||
507 | struct fd_dev *fd_dev = se_dev->se_dev_su_ptr; | ||
508 | |||
509 | if (!(fd_dev->fbd_flags & FBDF_HAS_PATH)) { | ||
510 | pr_err("Missing fd_dev_name=\n"); | ||
511 | return -EINVAL; | ||
512 | } | ||
513 | |||
514 | return 0; | ||
515 | } | ||
516 | |||
517 | static ssize_t fd_show_configfs_dev_params( | ||
518 | struct se_hba *hba, | ||
519 | struct se_subsystem_dev *se_dev, | ||
520 | char *b) | ||
521 | { | 482 | { |
522 | struct fd_dev *fd_dev = se_dev->se_dev_su_ptr; | 483 | struct fd_dev *fd_dev = FD_DEV(dev); |
523 | ssize_t bl = 0; | 484 | ssize_t bl = 0; |
524 | 485 | ||
525 | bl = sprintf(b + bl, "TCM FILEIO ID: %u", fd_dev->fd_dev_id); | 486 | bl = sprintf(b + bl, "TCM FILEIO ID: %u", fd_dev->fd_dev_id); |
@@ -550,7 +511,7 @@ static u32 fd_get_device_type(struct se_device *dev) | |||
550 | 511 | ||
551 | static sector_t fd_get_blocks(struct se_device *dev) | 512 | static sector_t fd_get_blocks(struct se_device *dev) |
552 | { | 513 | { |
553 | struct fd_dev *fd_dev = dev->dev_ptr; | 514 | struct fd_dev *fd_dev = FD_DEV(dev); |
554 | struct file *f = fd_dev->fd_file; | 515 | struct file *f = fd_dev->fd_file; |
555 | struct inode *i = f->f_mapping->host; | 516 | struct inode *i = f->f_mapping->host; |
556 | unsigned long long dev_size; | 517 | unsigned long long dev_size; |
@@ -564,7 +525,7 @@ static sector_t fd_get_blocks(struct se_device *dev) | |||
564 | else | 525 | else |
565 | dev_size = fd_dev->fd_dev_size; | 526 | dev_size = fd_dev->fd_dev_size; |
566 | 527 | ||
567 | return div_u64(dev_size, dev->se_sub_dev->se_dev_attrib.block_size); | 528 | return div_u64(dev_size, dev->dev_attrib.block_size); |
568 | } | 529 | } |
569 | 530 | ||
570 | static struct spc_ops fd_spc_ops = { | 531 | static struct spc_ops fd_spc_ops = { |
@@ -579,15 +540,16 @@ static int fd_parse_cdb(struct se_cmd *cmd) | |||
579 | 540 | ||
580 | static struct se_subsystem_api fileio_template = { | 541 | static struct se_subsystem_api fileio_template = { |
581 | .name = "fileio", | 542 | .name = "fileio", |
543 | .inquiry_prod = "FILEIO", | ||
544 | .inquiry_rev = FD_VERSION, | ||
582 | .owner = THIS_MODULE, | 545 | .owner = THIS_MODULE, |
583 | .transport_type = TRANSPORT_PLUGIN_VHBA_PDEV, | 546 | .transport_type = TRANSPORT_PLUGIN_VHBA_PDEV, |
584 | .attach_hba = fd_attach_hba, | 547 | .attach_hba = fd_attach_hba, |
585 | .detach_hba = fd_detach_hba, | 548 | .detach_hba = fd_detach_hba, |
586 | .allocate_virtdevice = fd_allocate_virtdevice, | 549 | .alloc_device = fd_alloc_device, |
587 | .create_virtdevice = fd_create_virtdevice, | 550 | .configure_device = fd_configure_device, |
588 | .free_device = fd_free_device, | 551 | .free_device = fd_free_device, |
589 | .parse_cdb = fd_parse_cdb, | 552 | .parse_cdb = fd_parse_cdb, |
590 | .check_configfs_dev_params = fd_check_configfs_dev_params, | ||
591 | .set_configfs_dev_params = fd_set_configfs_dev_params, | 553 | .set_configfs_dev_params = fd_set_configfs_dev_params, |
592 | .show_configfs_dev_params = fd_show_configfs_dev_params, | 554 | .show_configfs_dev_params = fd_show_configfs_dev_params, |
593 | .get_device_rev = fd_get_device_rev, | 555 | .get_device_rev = fd_get_device_rev, |
diff --git a/drivers/target/target_core_file.h b/drivers/target/target_core_file.h index 876ae53ef5b8..bc02b018ae46 100644 --- a/drivers/target/target_core_file.h +++ b/drivers/target/target_core_file.h | |||
@@ -17,6 +17,8 @@ | |||
17 | #define FDBD_HAS_BUFFERED_IO_WCE 0x04 | 17 | #define FDBD_HAS_BUFFERED_IO_WCE 0x04 |
18 | 18 | ||
19 | struct fd_dev { | 19 | struct fd_dev { |
20 | struct se_device dev; | ||
21 | |||
20 | u32 fbd_flags; | 22 | u32 fbd_flags; |
21 | unsigned char fd_dev_name[FD_MAX_DEV_NAME]; | 23 | unsigned char fd_dev_name[FD_MAX_DEV_NAME]; |
22 | /* Unique Ramdisk Device ID in Ramdisk HBA */ | 24 | /* Unique Ramdisk Device ID in Ramdisk HBA */ |
diff --git a/drivers/target/target_core_hba.c b/drivers/target/target_core_hba.c index 3dd1bd4b6f71..048b7b4b9102 100644 --- a/drivers/target/target_core_hba.c +++ b/drivers/target/target_core_hba.c | |||
@@ -113,7 +113,6 @@ core_alloc_hba(const char *plugin_name, u32 plugin_dep_id, u32 hba_flags) | |||
113 | return ERR_PTR(-ENOMEM); | 113 | return ERR_PTR(-ENOMEM); |
114 | } | 114 | } |
115 | 115 | ||
116 | INIT_LIST_HEAD(&hba->hba_dev_list); | ||
117 | spin_lock_init(&hba->device_lock); | 116 | spin_lock_init(&hba->device_lock); |
118 | mutex_init(&hba->hba_access_mutex); | 117 | mutex_init(&hba->hba_access_mutex); |
119 | 118 | ||
@@ -152,8 +151,7 @@ out_free_hba: | |||
152 | int | 151 | int |
153 | core_delete_hba(struct se_hba *hba) | 152 | core_delete_hba(struct se_hba *hba) |
154 | { | 153 | { |
155 | if (!list_empty(&hba->hba_dev_list)) | 154 | WARN_ON(hba->dev_count); |
156 | dump_stack(); | ||
157 | 155 | ||
158 | hba->transport->detach_hba(hba); | 156 | hba->transport->detach_hba(hba); |
159 | 157 | ||
diff --git a/drivers/target/target_core_iblock.c b/drivers/target/target_core_iblock.c index 57d7674c5013..dd6cd92cd9d8 100644 --- a/drivers/target/target_core_iblock.c +++ b/drivers/target/target_core_iblock.c | |||
@@ -50,6 +50,12 @@ | |||
50 | #define IBLOCK_MAX_BIO_PER_TASK 32 /* max # of bios to submit at a time */ | 50 | #define IBLOCK_MAX_BIO_PER_TASK 32 /* max # of bios to submit at a time */ |
51 | #define IBLOCK_BIO_POOL_SIZE 128 | 51 | #define IBLOCK_BIO_POOL_SIZE 128 |
52 | 52 | ||
53 | static inline struct iblock_dev *IBLOCK_DEV(struct se_device *dev) | ||
54 | { | ||
55 | return container_of(dev, struct iblock_dev, dev); | ||
56 | } | ||
57 | |||
58 | |||
53 | static struct se_subsystem_api iblock_template; | 59 | static struct se_subsystem_api iblock_template; |
54 | 60 | ||
55 | static void iblock_bio_done(struct bio *, int); | 61 | static void iblock_bio_done(struct bio *, int); |
@@ -70,7 +76,7 @@ static void iblock_detach_hba(struct se_hba *hba) | |||
70 | { | 76 | { |
71 | } | 77 | } |
72 | 78 | ||
73 | static void *iblock_allocate_virtdevice(struct se_hba *hba, const char *name) | 79 | static struct se_device *iblock_alloc_device(struct se_hba *hba, const char *name) |
74 | { | 80 | { |
75 | struct iblock_dev *ib_dev = NULL; | 81 | struct iblock_dev *ib_dev = NULL; |
76 | 82 | ||
@@ -82,40 +88,28 @@ static void *iblock_allocate_virtdevice(struct se_hba *hba, const char *name) | |||
82 | 88 | ||
83 | pr_debug( "IBLOCK: Allocated ib_dev for %s\n", name); | 89 | pr_debug( "IBLOCK: Allocated ib_dev for %s\n", name); |
84 | 90 | ||
85 | return ib_dev; | 91 | return &ib_dev->dev; |
86 | } | 92 | } |
87 | 93 | ||
88 | static struct se_device *iblock_create_virtdevice( | 94 | static int iblock_configure_device(struct se_device *dev) |
89 | struct se_hba *hba, | ||
90 | struct se_subsystem_dev *se_dev, | ||
91 | void *p) | ||
92 | { | 95 | { |
93 | struct iblock_dev *ib_dev = p; | 96 | struct iblock_dev *ib_dev = IBLOCK_DEV(dev); |
94 | struct se_device *dev; | ||
95 | struct se_dev_limits dev_limits; | ||
96 | struct block_device *bd = NULL; | ||
97 | struct request_queue *q; | 97 | struct request_queue *q; |
98 | struct queue_limits *limits; | 98 | struct block_device *bd = NULL; |
99 | u32 dev_flags = 0; | ||
100 | fmode_t mode; | 99 | fmode_t mode; |
101 | int ret = -EINVAL; | 100 | int ret = -ENOMEM; |
102 | 101 | ||
103 | if (!ib_dev) { | 102 | if (!(ib_dev->ibd_flags & IBDF_HAS_UDEV_PATH)) { |
104 | pr_err("Unable to locate struct iblock_dev parameter\n"); | 103 | pr_err("Missing udev_path= parameters for IBLOCK\n"); |
105 | return ERR_PTR(ret); | 104 | return -EINVAL; |
106 | } | 105 | } |
107 | memset(&dev_limits, 0, sizeof(struct se_dev_limits)); | ||
108 | 106 | ||
109 | ib_dev->ibd_bio_set = bioset_create(IBLOCK_BIO_POOL_SIZE, 0); | 107 | ib_dev->ibd_bio_set = bioset_create(IBLOCK_BIO_POOL_SIZE, 0); |
110 | if (!ib_dev->ibd_bio_set) { | 108 | if (!ib_dev->ibd_bio_set) { |
111 | pr_err("IBLOCK: Unable to create bioset()\n"); | 109 | pr_err("IBLOCK: Unable to create bioset\n"); |
112 | return ERR_PTR(-ENOMEM); | 110 | goto out; |
113 | } | 111 | } |
114 | pr_debug("IBLOCK: Created bio_set()\n"); | 112 | |
115 | /* | ||
116 | * iblock_check_configfs_dev_params() ensures that ib_dev->ibd_udev_path | ||
117 | * must already have been set in order for echo 1 > $HBA/$DEV/enable to run. | ||
118 | */ | ||
119 | pr_debug( "IBLOCK: Claiming struct block_device: %s\n", | 113 | pr_debug( "IBLOCK: Claiming struct block_device: %s\n", |
120 | ib_dev->ibd_udev_path); | 114 | ib_dev->ibd_udev_path); |
121 | 115 | ||
@@ -126,27 +120,15 @@ static struct se_device *iblock_create_virtdevice( | |||
126 | bd = blkdev_get_by_path(ib_dev->ibd_udev_path, mode, ib_dev); | 120 | bd = blkdev_get_by_path(ib_dev->ibd_udev_path, mode, ib_dev); |
127 | if (IS_ERR(bd)) { | 121 | if (IS_ERR(bd)) { |
128 | ret = PTR_ERR(bd); | 122 | ret = PTR_ERR(bd); |
129 | goto failed; | 123 | goto out_free_bioset; |
130 | } | 124 | } |
131 | /* | ||
132 | * Setup the local scope queue_limits from struct request_queue->limits | ||
133 | * to pass into transport_add_device_to_core_hba() as struct se_dev_limits. | ||
134 | */ | ||
135 | q = bdev_get_queue(bd); | ||
136 | limits = &dev_limits.limits; | ||
137 | limits->logical_block_size = bdev_logical_block_size(bd); | ||
138 | limits->max_hw_sectors = UINT_MAX; | ||
139 | limits->max_sectors = UINT_MAX; | ||
140 | dev_limits.hw_queue_depth = q->nr_requests; | ||
141 | dev_limits.queue_depth = q->nr_requests; | ||
142 | |||
143 | ib_dev->ibd_bd = bd; | 125 | ib_dev->ibd_bd = bd; |
144 | 126 | ||
145 | dev = transport_add_device_to_core_hba(hba, | 127 | q = bdev_get_queue(bd); |
146 | &iblock_template, se_dev, dev_flags, ib_dev, | 128 | |
147 | &dev_limits, "IBLOCK", IBLOCK_VERSION); | 129 | dev->dev_attrib.hw_block_size = bdev_logical_block_size(bd); |
148 | if (!dev) | 130 | dev->dev_attrib.hw_max_sectors = UINT_MAX; |
149 | goto failed; | 131 | dev->dev_attrib.hw_queue_depth = q->nr_requests; |
150 | 132 | ||
151 | /* | 133 | /* |
152 | * Check if the underlying struct block_device request_queue supports | 134 | * Check if the underlying struct block_device request_queue supports |
@@ -154,15 +136,16 @@ static struct se_device *iblock_create_virtdevice( | |||
154 | * in ATA and we need to set TPE=1 | 136 | * in ATA and we need to set TPE=1 |
155 | */ | 137 | */ |
156 | if (blk_queue_discard(q)) { | 138 | if (blk_queue_discard(q)) { |
157 | dev->se_sub_dev->se_dev_attrib.max_unmap_lba_count = | 139 | dev->dev_attrib.max_unmap_lba_count = |
158 | q->limits.max_discard_sectors; | 140 | q->limits.max_discard_sectors; |
141 | |||
159 | /* | 142 | /* |
160 | * Currently hardcoded to 1 in Linux/SCSI code.. | 143 | * Currently hardcoded to 1 in Linux/SCSI code.. |
161 | */ | 144 | */ |
162 | dev->se_sub_dev->se_dev_attrib.max_unmap_block_desc_count = 1; | 145 | dev->dev_attrib.max_unmap_block_desc_count = 1; |
163 | dev->se_sub_dev->se_dev_attrib.unmap_granularity = | 146 | dev->dev_attrib.unmap_granularity = |
164 | q->limits.discard_granularity >> 9; | 147 | q->limits.discard_granularity >> 9; |
165 | dev->se_sub_dev->se_dev_attrib.unmap_granularity_alignment = | 148 | dev->dev_attrib.unmap_granularity_alignment = |
166 | q->limits.discard_alignment; | 149 | q->limits.discard_alignment; |
167 | 150 | ||
168 | pr_debug("IBLOCK: BLOCK Discard support available," | 151 | pr_debug("IBLOCK: BLOCK Discard support available," |
@@ -170,22 +153,19 @@ static struct se_device *iblock_create_virtdevice( | |||
170 | } | 153 | } |
171 | 154 | ||
172 | if (blk_queue_nonrot(q)) | 155 | if (blk_queue_nonrot(q)) |
173 | dev->se_sub_dev->se_dev_attrib.is_nonrot = 1; | 156 | dev->dev_attrib.is_nonrot = 1; |
174 | 157 | return 0; | |
175 | return dev; | ||
176 | 158 | ||
177 | failed: | 159 | out_free_bioset: |
178 | if (ib_dev->ibd_bio_set) { | 160 | bioset_free(ib_dev->ibd_bio_set); |
179 | bioset_free(ib_dev->ibd_bio_set); | 161 | ib_dev->ibd_bio_set = NULL; |
180 | ib_dev->ibd_bio_set = NULL; | 162 | out: |
181 | } | 163 | return ret; |
182 | ib_dev->ibd_bd = NULL; | ||
183 | return ERR_PTR(ret); | ||
184 | } | 164 | } |
185 | 165 | ||
186 | static void iblock_free_device(void *p) | 166 | static void iblock_free_device(struct se_device *dev) |
187 | { | 167 | { |
188 | struct iblock_dev *ib_dev = p; | 168 | struct iblock_dev *ib_dev = IBLOCK_DEV(dev); |
189 | 169 | ||
190 | if (ib_dev->ibd_bd != NULL) | 170 | if (ib_dev->ibd_bd != NULL) |
191 | blkdev_put(ib_dev->ibd_bd, FMODE_WRITE|FMODE_READ|FMODE_EXCL); | 171 | blkdev_put(ib_dev->ibd_bd, FMODE_WRITE|FMODE_READ|FMODE_EXCL); |
@@ -203,12 +183,12 @@ static unsigned long long iblock_emulate_read_cap_with_block_size( | |||
203 | bdev_logical_block_size(bd)) - 1); | 183 | bdev_logical_block_size(bd)) - 1); |
204 | u32 block_size = bdev_logical_block_size(bd); | 184 | u32 block_size = bdev_logical_block_size(bd); |
205 | 185 | ||
206 | if (block_size == dev->se_sub_dev->se_dev_attrib.block_size) | 186 | if (block_size == dev->dev_attrib.block_size) |
207 | return blocks_long; | 187 | return blocks_long; |
208 | 188 | ||
209 | switch (block_size) { | 189 | switch (block_size) { |
210 | case 4096: | 190 | case 4096: |
211 | switch (dev->se_sub_dev->se_dev_attrib.block_size) { | 191 | switch (dev->dev_attrib.block_size) { |
212 | case 2048: | 192 | case 2048: |
213 | blocks_long <<= 1; | 193 | blocks_long <<= 1; |
214 | break; | 194 | break; |
@@ -222,7 +202,7 @@ static unsigned long long iblock_emulate_read_cap_with_block_size( | |||
222 | } | 202 | } |
223 | break; | 203 | break; |
224 | case 2048: | 204 | case 2048: |
225 | switch (dev->se_sub_dev->se_dev_attrib.block_size) { | 205 | switch (dev->dev_attrib.block_size) { |
226 | case 4096: | 206 | case 4096: |
227 | blocks_long >>= 1; | 207 | blocks_long >>= 1; |
228 | break; | 208 | break; |
@@ -237,7 +217,7 @@ static unsigned long long iblock_emulate_read_cap_with_block_size( | |||
237 | } | 217 | } |
238 | break; | 218 | break; |
239 | case 1024: | 219 | case 1024: |
240 | switch (dev->se_sub_dev->se_dev_attrib.block_size) { | 220 | switch (dev->dev_attrib.block_size) { |
241 | case 4096: | 221 | case 4096: |
242 | blocks_long >>= 2; | 222 | blocks_long >>= 2; |
243 | break; | 223 | break; |
@@ -252,7 +232,7 @@ static unsigned long long iblock_emulate_read_cap_with_block_size( | |||
252 | } | 232 | } |
253 | break; | 233 | break; |
254 | case 512: | 234 | case 512: |
255 | switch (dev->se_sub_dev->se_dev_attrib.block_size) { | 235 | switch (dev->dev_attrib.block_size) { |
256 | case 4096: | 236 | case 4096: |
257 | blocks_long >>= 3; | 237 | blocks_long >>= 3; |
258 | break; | 238 | break; |
@@ -299,7 +279,7 @@ static void iblock_end_io_flush(struct bio *bio, int err) | |||
299 | */ | 279 | */ |
300 | static int iblock_execute_sync_cache(struct se_cmd *cmd) | 280 | static int iblock_execute_sync_cache(struct se_cmd *cmd) |
301 | { | 281 | { |
302 | struct iblock_dev *ib_dev = cmd->se_dev->dev_ptr; | 282 | struct iblock_dev *ib_dev = IBLOCK_DEV(cmd->se_dev); |
303 | int immed = (cmd->t_task_cdb[1] & 0x2); | 283 | int immed = (cmd->t_task_cdb[1] & 0x2); |
304 | struct bio *bio; | 284 | struct bio *bio; |
305 | 285 | ||
@@ -322,7 +302,7 @@ static int iblock_execute_sync_cache(struct se_cmd *cmd) | |||
322 | static int iblock_execute_unmap(struct se_cmd *cmd) | 302 | static int iblock_execute_unmap(struct se_cmd *cmd) |
323 | { | 303 | { |
324 | struct se_device *dev = cmd->se_dev; | 304 | struct se_device *dev = cmd->se_dev; |
325 | struct iblock_dev *ibd = dev->dev_ptr; | 305 | struct iblock_dev *ib_dev = IBLOCK_DEV(dev); |
326 | unsigned char *buf, *ptr = NULL; | 306 | unsigned char *buf, *ptr = NULL; |
327 | sector_t lba; | 307 | sector_t lba; |
328 | int size; | 308 | int size; |
@@ -349,7 +329,7 @@ static int iblock_execute_unmap(struct se_cmd *cmd) | |||
349 | else | 329 | else |
350 | size = bd_dl; | 330 | size = bd_dl; |
351 | 331 | ||
352 | if (size / 16 > dev->se_sub_dev->se_dev_attrib.max_unmap_block_desc_count) { | 332 | if (size / 16 > dev->dev_attrib.max_unmap_block_desc_count) { |
353 | cmd->scsi_sense_reason = TCM_INVALID_PARAMETER_LIST; | 333 | cmd->scsi_sense_reason = TCM_INVALID_PARAMETER_LIST; |
354 | ret = -EINVAL; | 334 | ret = -EINVAL; |
355 | goto err; | 335 | goto err; |
@@ -366,7 +346,7 @@ static int iblock_execute_unmap(struct se_cmd *cmd) | |||
366 | pr_debug("UNMAP: Using lba: %llu and range: %u\n", | 346 | pr_debug("UNMAP: Using lba: %llu and range: %u\n", |
367 | (unsigned long long)lba, range); | 347 | (unsigned long long)lba, range); |
368 | 348 | ||
369 | if (range > dev->se_sub_dev->se_dev_attrib.max_unmap_lba_count) { | 349 | if (range > dev->dev_attrib.max_unmap_lba_count) { |
370 | cmd->scsi_sense_reason = TCM_INVALID_PARAMETER_LIST; | 350 | cmd->scsi_sense_reason = TCM_INVALID_PARAMETER_LIST; |
371 | ret = -EINVAL; | 351 | ret = -EINVAL; |
372 | goto err; | 352 | goto err; |
@@ -378,7 +358,7 @@ static int iblock_execute_unmap(struct se_cmd *cmd) | |||
378 | goto err; | 358 | goto err; |
379 | } | 359 | } |
380 | 360 | ||
381 | ret = blkdev_issue_discard(ibd->ibd_bd, lba, range, | 361 | ret = blkdev_issue_discard(ib_dev->ibd_bd, lba, range, |
382 | GFP_KERNEL, 0); | 362 | GFP_KERNEL, 0); |
383 | if (ret < 0) { | 363 | if (ret < 0) { |
384 | pr_err("blkdev_issue_discard() failed: %d\n", | 364 | pr_err("blkdev_issue_discard() failed: %d\n", |
@@ -399,10 +379,10 @@ err: | |||
399 | 379 | ||
400 | static int iblock_execute_write_same(struct se_cmd *cmd) | 380 | static int iblock_execute_write_same(struct se_cmd *cmd) |
401 | { | 381 | { |
402 | struct iblock_dev *ibd = cmd->se_dev->dev_ptr; | 382 | struct iblock_dev *ib_dev = IBLOCK_DEV(cmd->se_dev); |
403 | int ret; | 383 | int ret; |
404 | 384 | ||
405 | ret = blkdev_issue_discard(ibd->ibd_bd, cmd->t_task_lba, | 385 | ret = blkdev_issue_discard(ib_dev->ibd_bd, cmd->t_task_lba, |
406 | spc_get_write_same_sectors(cmd), GFP_KERNEL, | 386 | spc_get_write_same_sectors(cmd), GFP_KERNEL, |
407 | 0); | 387 | 0); |
408 | if (ret < 0) { | 388 | if (ret < 0) { |
@@ -425,11 +405,10 @@ static match_table_t tokens = { | |||
425 | {Opt_err, NULL} | 405 | {Opt_err, NULL} |
426 | }; | 406 | }; |
427 | 407 | ||
428 | static ssize_t iblock_set_configfs_dev_params(struct se_hba *hba, | 408 | static ssize_t iblock_set_configfs_dev_params(struct se_device *dev, |
429 | struct se_subsystem_dev *se_dev, | 409 | const char *page, ssize_t count) |
430 | const char *page, ssize_t count) | ||
431 | { | 410 | { |
432 | struct iblock_dev *ib_dev = se_dev->se_dev_su_ptr; | 411 | struct iblock_dev *ib_dev = IBLOCK_DEV(dev); |
433 | char *orig, *ptr, *arg_p, *opts; | 412 | char *orig, *ptr, *arg_p, *opts; |
434 | substring_t args[MAX_OPT_ARGS]; | 413 | substring_t args[MAX_OPT_ARGS]; |
435 | int ret = 0, token; | 414 | int ret = 0, token; |
@@ -491,43 +470,26 @@ out: | |||
491 | return (!ret) ? count : ret; | 470 | return (!ret) ? count : ret; |
492 | } | 471 | } |
493 | 472 | ||
494 | static ssize_t iblock_check_configfs_dev_params( | 473 | static ssize_t iblock_show_configfs_dev_params(struct se_device *dev, char *b) |
495 | struct se_hba *hba, | ||
496 | struct se_subsystem_dev *se_dev) | ||
497 | { | ||
498 | struct iblock_dev *ibd = se_dev->se_dev_su_ptr; | ||
499 | |||
500 | if (!(ibd->ibd_flags & IBDF_HAS_UDEV_PATH)) { | ||
501 | pr_err("Missing udev_path= parameters for IBLOCK\n"); | ||
502 | return -EINVAL; | ||
503 | } | ||
504 | |||
505 | return 0; | ||
506 | } | ||
507 | |||
508 | static ssize_t iblock_show_configfs_dev_params( | ||
509 | struct se_hba *hba, | ||
510 | struct se_subsystem_dev *se_dev, | ||
511 | char *b) | ||
512 | { | 474 | { |
513 | struct iblock_dev *ibd = se_dev->se_dev_su_ptr; | 475 | struct iblock_dev *ib_dev = IBLOCK_DEV(dev); |
514 | struct block_device *bd = ibd->ibd_bd; | 476 | struct block_device *bd = ib_dev->ibd_bd; |
515 | char buf[BDEVNAME_SIZE]; | 477 | char buf[BDEVNAME_SIZE]; |
516 | ssize_t bl = 0; | 478 | ssize_t bl = 0; |
517 | 479 | ||
518 | if (bd) | 480 | if (bd) |
519 | bl += sprintf(b + bl, "iBlock device: %s", | 481 | bl += sprintf(b + bl, "iBlock device: %s", |
520 | bdevname(bd, buf)); | 482 | bdevname(bd, buf)); |
521 | if (ibd->ibd_flags & IBDF_HAS_UDEV_PATH) | 483 | if (ib_dev->ibd_flags & IBDF_HAS_UDEV_PATH) |
522 | bl += sprintf(b + bl, " UDEV PATH: %s", | 484 | bl += sprintf(b + bl, " UDEV PATH: %s", |
523 | ibd->ibd_udev_path); | 485 | ib_dev->ibd_udev_path); |
524 | bl += sprintf(b + bl, " readonly: %d\n", ibd->ibd_readonly); | 486 | bl += sprintf(b + bl, " readonly: %d\n", ib_dev->ibd_readonly); |
525 | 487 | ||
526 | bl += sprintf(b + bl, " "); | 488 | bl += sprintf(b + bl, " "); |
527 | if (bd) { | 489 | if (bd) { |
528 | bl += sprintf(b + bl, "Major: %d Minor: %d %s\n", | 490 | bl += sprintf(b + bl, "Major: %d Minor: %d %s\n", |
529 | MAJOR(bd->bd_dev), MINOR(bd->bd_dev), (!bd->bd_contains) ? | 491 | MAJOR(bd->bd_dev), MINOR(bd->bd_dev), (!bd->bd_contains) ? |
530 | "" : (bd->bd_holder == ibd) ? | 492 | "" : (bd->bd_holder == ib_dev) ? |
531 | "CLAIMED: IBLOCK" : "CLAIMED: OS"); | 493 | "CLAIMED: IBLOCK" : "CLAIMED: OS"); |
532 | } else { | 494 | } else { |
533 | bl += sprintf(b + bl, "Major: 0 Minor: 0\n"); | 495 | bl += sprintf(b + bl, "Major: 0 Minor: 0\n"); |
@@ -556,7 +518,7 @@ static void iblock_complete_cmd(struct se_cmd *cmd) | |||
556 | static struct bio * | 518 | static struct bio * |
557 | iblock_get_bio(struct se_cmd *cmd, sector_t lba, u32 sg_num) | 519 | iblock_get_bio(struct se_cmd *cmd, sector_t lba, u32 sg_num) |
558 | { | 520 | { |
559 | struct iblock_dev *ib_dev = cmd->se_dev->dev_ptr; | 521 | struct iblock_dev *ib_dev = IBLOCK_DEV(cmd->se_dev); |
560 | struct bio *bio; | 522 | struct bio *bio; |
561 | 523 | ||
562 | /* | 524 | /* |
@@ -611,8 +573,8 @@ static int iblock_execute_rw(struct se_cmd *cmd) | |||
611 | * Force data to disk if we pretend to not have a volatile | 573 | * Force data to disk if we pretend to not have a volatile |
612 | * write cache, or the initiator set the Force Unit Access bit. | 574 | * write cache, or the initiator set the Force Unit Access bit. |
613 | */ | 575 | */ |
614 | if (dev->se_sub_dev->se_dev_attrib.emulate_write_cache == 0 || | 576 | if (dev->dev_attrib.emulate_write_cache == 0 || |
615 | (dev->se_sub_dev->se_dev_attrib.emulate_fua_write > 0 && | 577 | (dev->dev_attrib.emulate_fua_write > 0 && |
616 | (cmd->se_cmd_flags & SCF_FUA))) | 578 | (cmd->se_cmd_flags & SCF_FUA))) |
617 | rw = WRITE_FUA; | 579 | rw = WRITE_FUA; |
618 | else | 580 | else |
@@ -625,17 +587,17 @@ static int iblock_execute_rw(struct se_cmd *cmd) | |||
625 | * Convert the blocksize advertised to the initiator to the 512 byte | 587 | * Convert the blocksize advertised to the initiator to the 512 byte |
626 | * units unconditionally used by the Linux block layer. | 588 | * units unconditionally used by the Linux block layer. |
627 | */ | 589 | */ |
628 | if (dev->se_sub_dev->se_dev_attrib.block_size == 4096) | 590 | if (dev->dev_attrib.block_size == 4096) |
629 | block_lba = (cmd->t_task_lba << 3); | 591 | block_lba = (cmd->t_task_lba << 3); |
630 | else if (dev->se_sub_dev->se_dev_attrib.block_size == 2048) | 592 | else if (dev->dev_attrib.block_size == 2048) |
631 | block_lba = (cmd->t_task_lba << 2); | 593 | block_lba = (cmd->t_task_lba << 2); |
632 | else if (dev->se_sub_dev->se_dev_attrib.block_size == 1024) | 594 | else if (dev->dev_attrib.block_size == 1024) |
633 | block_lba = (cmd->t_task_lba << 1); | 595 | block_lba = (cmd->t_task_lba << 1); |
634 | else if (dev->se_sub_dev->se_dev_attrib.block_size == 512) | 596 | else if (dev->dev_attrib.block_size == 512) |
635 | block_lba = cmd->t_task_lba; | 597 | block_lba = cmd->t_task_lba; |
636 | else { | 598 | else { |
637 | pr_err("Unsupported SCSI -> BLOCK LBA conversion:" | 599 | pr_err("Unsupported SCSI -> BLOCK LBA conversion:" |
638 | " %u\n", dev->se_sub_dev->se_dev_attrib.block_size); | 600 | " %u\n", dev->dev_attrib.block_size); |
639 | cmd->scsi_sense_reason = TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE; | 601 | cmd->scsi_sense_reason = TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE; |
640 | return -ENOSYS; | 602 | return -ENOSYS; |
641 | } | 603 | } |
@@ -714,8 +676,8 @@ static u32 iblock_get_device_type(struct se_device *dev) | |||
714 | 676 | ||
715 | static sector_t iblock_get_blocks(struct se_device *dev) | 677 | static sector_t iblock_get_blocks(struct se_device *dev) |
716 | { | 678 | { |
717 | struct iblock_dev *ibd = dev->dev_ptr; | 679 | struct iblock_dev *ib_dev = IBLOCK_DEV(dev); |
718 | struct block_device *bd = ibd->ibd_bd; | 680 | struct block_device *bd = ib_dev->ibd_bd; |
719 | struct request_queue *q = bdev_get_queue(bd); | 681 | struct request_queue *q = bdev_get_queue(bd); |
720 | 682 | ||
721 | return iblock_emulate_read_cap_with_block_size(dev, bd, q); | 683 | return iblock_emulate_read_cap_with_block_size(dev, bd, q); |
@@ -761,15 +723,16 @@ static int iblock_parse_cdb(struct se_cmd *cmd) | |||
761 | 723 | ||
762 | static struct se_subsystem_api iblock_template = { | 724 | static struct se_subsystem_api iblock_template = { |
763 | .name = "iblock", | 725 | .name = "iblock", |
726 | .inquiry_prod = "IBLOCK", | ||
727 | .inquiry_rev = IBLOCK_VERSION, | ||
764 | .owner = THIS_MODULE, | 728 | .owner = THIS_MODULE, |
765 | .transport_type = TRANSPORT_PLUGIN_VHBA_PDEV, | 729 | .transport_type = TRANSPORT_PLUGIN_VHBA_PDEV, |
766 | .attach_hba = iblock_attach_hba, | 730 | .attach_hba = iblock_attach_hba, |
767 | .detach_hba = iblock_detach_hba, | 731 | .detach_hba = iblock_detach_hba, |
768 | .allocate_virtdevice = iblock_allocate_virtdevice, | 732 | .alloc_device = iblock_alloc_device, |
769 | .create_virtdevice = iblock_create_virtdevice, | 733 | .configure_device = iblock_configure_device, |
770 | .free_device = iblock_free_device, | 734 | .free_device = iblock_free_device, |
771 | .parse_cdb = iblock_parse_cdb, | 735 | .parse_cdb = iblock_parse_cdb, |
772 | .check_configfs_dev_params = iblock_check_configfs_dev_params, | ||
773 | .set_configfs_dev_params = iblock_set_configfs_dev_params, | 736 | .set_configfs_dev_params = iblock_set_configfs_dev_params, |
774 | .show_configfs_dev_params = iblock_show_configfs_dev_params, | 737 | .show_configfs_dev_params = iblock_show_configfs_dev_params, |
775 | .get_device_rev = iblock_get_device_rev, | 738 | .get_device_rev = iblock_get_device_rev, |
diff --git a/drivers/target/target_core_iblock.h b/drivers/target/target_core_iblock.h index 533627ae79ec..01c2afd81500 100644 --- a/drivers/target/target_core_iblock.h +++ b/drivers/target/target_core_iblock.h | |||
@@ -14,6 +14,7 @@ struct iblock_req { | |||
14 | #define IBDF_HAS_UDEV_PATH 0x01 | 14 | #define IBDF_HAS_UDEV_PATH 0x01 |
15 | 15 | ||
16 | struct iblock_dev { | 16 | struct iblock_dev { |
17 | struct se_device dev; | ||
17 | unsigned char ibd_udev_path[SE_UDEV_PATH_LEN]; | 18 | unsigned char ibd_udev_path[SE_UDEV_PATH_LEN]; |
18 | u32 ibd_flags; | 19 | u32 ibd_flags; |
19 | struct bio_set *ibd_bio_set; | 20 | struct bio_set *ibd_bio_set; |
diff --git a/drivers/target/target_core_internal.h b/drivers/target/target_core_internal.h index 0fd428225d11..5854ed67af59 100644 --- a/drivers/target/target_core_internal.h +++ b/drivers/target/target_core_internal.h | |||
@@ -20,12 +20,6 @@ int core_dev_export(struct se_device *, struct se_portal_group *, | |||
20 | void core_dev_unexport(struct se_device *, struct se_portal_group *, | 20 | void core_dev_unexport(struct se_device *, struct se_portal_group *, |
21 | struct se_lun *); | 21 | struct se_lun *); |
22 | int target_report_luns(struct se_cmd *); | 22 | int target_report_luns(struct se_cmd *); |
23 | void se_release_device_for_hba(struct se_device *); | ||
24 | void se_release_vpd_for_dev(struct se_device *); | ||
25 | int se_free_virtual_device(struct se_device *, struct se_hba *); | ||
26 | int se_dev_check_online(struct se_device *); | ||
27 | int se_dev_check_shutdown(struct se_device *); | ||
28 | void se_dev_set_default_attribs(struct se_device *, struct se_dev_limits *); | ||
29 | int se_dev_set_task_timeout(struct se_device *, u32); | 23 | int se_dev_set_task_timeout(struct se_device *, u32); |
30 | int se_dev_set_max_unmap_lba_count(struct se_device *, u32); | 24 | int se_dev_set_max_unmap_lba_count(struct se_device *, u32); |
31 | int se_dev_set_max_unmap_block_desc_count(struct se_device *, u32); | 25 | int se_dev_set_max_unmap_block_desc_count(struct se_device *, u32); |
@@ -60,6 +54,9 @@ void core_dev_free_initiator_node_lun_acl(struct se_portal_group *, | |||
60 | struct se_lun_acl *lacl); | 54 | struct se_lun_acl *lacl); |
61 | int core_dev_setup_virtual_lun0(void); | 55 | int core_dev_setup_virtual_lun0(void); |
62 | void core_dev_release_virtual_lun0(void); | 56 | void core_dev_release_virtual_lun0(void); |
57 | struct se_device *target_alloc_device(struct se_hba *hba, const char *name); | ||
58 | int target_configure_device(struct se_device *dev); | ||
59 | void target_free_device(struct se_device *); | ||
63 | 60 | ||
64 | /* target_core_hba.c */ | 61 | /* target_core_hba.c */ |
65 | struct se_hba *core_alloc_hba(const char *, u32, u32); | 62 | struct se_hba *core_alloc_hba(const char *, u32, u32); |
@@ -106,9 +103,10 @@ bool target_stop_cmd(struct se_cmd *cmd, unsigned long *flags); | |||
106 | int transport_clear_lun_from_sessions(struct se_lun *); | 103 | int transport_clear_lun_from_sessions(struct se_lun *); |
107 | void transport_send_task_abort(struct se_cmd *); | 104 | void transport_send_task_abort(struct se_cmd *); |
108 | int target_cmd_size_check(struct se_cmd *cmd, unsigned int size); | 105 | int target_cmd_size_check(struct se_cmd *cmd, unsigned int size); |
106 | void target_qf_do_work(struct work_struct *work); | ||
109 | 107 | ||
110 | /* target_core_stat.c */ | 108 | /* target_core_stat.c */ |
111 | void target_stat_setup_dev_default_groups(struct se_subsystem_dev *); | 109 | void target_stat_setup_dev_default_groups(struct se_device *); |
112 | void target_stat_setup_port_default_groups(struct se_lun *); | 110 | void target_stat_setup_port_default_groups(struct se_lun *); |
113 | void target_stat_setup_mappedlun_default_groups(struct se_lun_acl *); | 111 | void target_stat_setup_mappedlun_default_groups(struct se_lun_acl *); |
114 | 112 | ||
diff --git a/drivers/target/target_core_pr.c b/drivers/target/target_core_pr.c index 8c323a98c4a0..2b289891672f 100644 --- a/drivers/target/target_core_pr.c +++ b/drivers/target/target_core_pr.c | |||
@@ -103,7 +103,7 @@ static int core_scsi2_reservation_check(struct se_cmd *cmd, u32 *pr_reg_type) | |||
103 | spin_unlock(&dev->dev_reservation_lock); | 103 | spin_unlock(&dev->dev_reservation_lock); |
104 | return -EINVAL; | 104 | return -EINVAL; |
105 | } | 105 | } |
106 | if (!(dev->dev_flags & DF_SPC2_RESERVATIONS_WITH_ISID)) { | 106 | if (!(dev->dev_reservation_flags & DRF_SPC2_RESERVATIONS_WITH_ISID)) { |
107 | spin_unlock(&dev->dev_reservation_lock); | 107 | spin_unlock(&dev->dev_reservation_lock); |
108 | return 0; | 108 | return 0; |
109 | } | 109 | } |
@@ -120,10 +120,10 @@ static void core_scsi3_put_pr_reg(struct t10_pr_registration *); | |||
120 | static int target_check_scsi2_reservation_conflict(struct se_cmd *cmd) | 120 | static int target_check_scsi2_reservation_conflict(struct se_cmd *cmd) |
121 | { | 121 | { |
122 | struct se_session *se_sess = cmd->se_sess; | 122 | struct se_session *se_sess = cmd->se_sess; |
123 | struct se_subsystem_dev *su_dev = cmd->se_dev->se_sub_dev; | 123 | struct se_device *dev = cmd->se_dev; |
124 | struct t10_pr_registration *pr_reg; | 124 | struct t10_pr_registration *pr_reg; |
125 | struct t10_reservation *pr_tmpl = &su_dev->t10_pr; | 125 | struct t10_reservation *pr_tmpl = &dev->t10_pr; |
126 | int crh = (su_dev->t10_pr.res_type == SPC3_PERSISTENT_RESERVATIONS); | 126 | int crh = (dev->t10_pr.res_type == SPC3_PERSISTENT_RESERVATIONS); |
127 | int conflict = 0; | 127 | int conflict = 0; |
128 | 128 | ||
129 | if (!crh) | 129 | if (!crh) |
@@ -223,10 +223,10 @@ int target_scsi2_reservation_release(struct se_cmd *cmd) | |||
223 | goto out_unlock; | 223 | goto out_unlock; |
224 | 224 | ||
225 | dev->dev_reserved_node_acl = NULL; | 225 | dev->dev_reserved_node_acl = NULL; |
226 | dev->dev_flags &= ~DF_SPC2_RESERVATIONS; | 226 | dev->dev_reservation_flags &= ~DRF_SPC2_RESERVATIONS; |
227 | if (dev->dev_flags & DF_SPC2_RESERVATIONS_WITH_ISID) { | 227 | if (dev->dev_reservation_flags & DRF_SPC2_RESERVATIONS_WITH_ISID) { |
228 | dev->dev_res_bin_isid = 0; | 228 | dev->dev_res_bin_isid = 0; |
229 | dev->dev_flags &= ~DF_SPC2_RESERVATIONS_WITH_ISID; | 229 | dev->dev_reservation_flags &= ~DRF_SPC2_RESERVATIONS_WITH_ISID; |
230 | } | 230 | } |
231 | tpg = sess->se_tpg; | 231 | tpg = sess->se_tpg; |
232 | pr_debug("SCSI-2 Released reservation for %s LUN: %u ->" | 232 | pr_debug("SCSI-2 Released reservation for %s LUN: %u ->" |
@@ -292,10 +292,10 @@ int target_scsi2_reservation_reserve(struct se_cmd *cmd) | |||
292 | } | 292 | } |
293 | 293 | ||
294 | dev->dev_reserved_node_acl = sess->se_node_acl; | 294 | dev->dev_reserved_node_acl = sess->se_node_acl; |
295 | dev->dev_flags |= DF_SPC2_RESERVATIONS; | 295 | dev->dev_reservation_flags |= DRF_SPC2_RESERVATIONS; |
296 | if (sess->sess_bin_isid != 0) { | 296 | if (sess->sess_bin_isid != 0) { |
297 | dev->dev_res_bin_isid = sess->sess_bin_isid; | 297 | dev->dev_res_bin_isid = sess->sess_bin_isid; |
298 | dev->dev_flags |= DF_SPC2_RESERVATIONS_WITH_ISID; | 298 | dev->dev_reservation_flags |= DRF_SPC2_RESERVATIONS_WITH_ISID; |
299 | } | 299 | } |
300 | pr_debug("SCSI-2 Reserved %s LUN: %u -> MAPPED LUN: %u" | 300 | pr_debug("SCSI-2 Reserved %s LUN: %u -> MAPPED LUN: %u" |
301 | " for %s\n", tpg->se_tpg_tfo->get_fabric_name(), | 301 | " for %s\n", tpg->se_tpg_tfo->get_fabric_name(), |
@@ -333,7 +333,7 @@ static int core_scsi3_pr_seq_non_holder( | |||
333 | /* | 333 | /* |
334 | * A legacy SPC-2 reservation is being held. | 334 | * A legacy SPC-2 reservation is being held. |
335 | */ | 335 | */ |
336 | if (cmd->se_dev->dev_flags & DF_SPC2_RESERVATIONS) | 336 | if (cmd->se_dev->dev_reservation_flags & DRF_SPC2_RESERVATIONS) |
337 | return core_scsi2_reservation_seq_non_holder(cmd, | 337 | return core_scsi2_reservation_seq_non_holder(cmd, |
338 | cdb, pr_reg_type); | 338 | cdb, pr_reg_type); |
339 | 339 | ||
@@ -565,8 +565,8 @@ static int core_scsi3_pr_seq_non_holder( | |||
565 | 565 | ||
566 | static u32 core_scsi3_pr_generation(struct se_device *dev) | 566 | static u32 core_scsi3_pr_generation(struct se_device *dev) |
567 | { | 567 | { |
568 | struct se_subsystem_dev *su_dev = dev->se_sub_dev; | ||
569 | u32 prg; | 568 | u32 prg; |
569 | |||
570 | /* | 570 | /* |
571 | * PRGeneration field shall contain the value of a 32-bit wrapping | 571 | * PRGeneration field shall contain the value of a 32-bit wrapping |
572 | * counter mainted by the device server. | 572 | * counter mainted by the device server. |
@@ -577,7 +577,7 @@ static u32 core_scsi3_pr_generation(struct se_device *dev) | |||
577 | * See spc4r17 section 6.3.12 READ_KEYS service action | 577 | * See spc4r17 section 6.3.12 READ_KEYS service action |
578 | */ | 578 | */ |
579 | spin_lock(&dev->dev_reservation_lock); | 579 | spin_lock(&dev->dev_reservation_lock); |
580 | prg = su_dev->t10_pr.pr_generation++; | 580 | prg = dev->t10_pr.pr_generation++; |
581 | spin_unlock(&dev->dev_reservation_lock); | 581 | spin_unlock(&dev->dev_reservation_lock); |
582 | 582 | ||
583 | return prg; | 583 | return prg; |
@@ -596,7 +596,7 @@ static int core_scsi3_pr_reservation_check( | |||
596 | /* | 596 | /* |
597 | * A legacy SPC-2 reservation is being held. | 597 | * A legacy SPC-2 reservation is being held. |
598 | */ | 598 | */ |
599 | if (dev->dev_flags & DF_SPC2_RESERVATIONS) | 599 | if (dev->dev_reservation_flags & DRF_SPC2_RESERVATIONS) |
600 | return core_scsi2_reservation_check(cmd, pr_reg_type); | 600 | return core_scsi2_reservation_check(cmd, pr_reg_type); |
601 | 601 | ||
602 | spin_lock(&dev->dev_reservation_lock); | 602 | spin_lock(&dev->dev_reservation_lock); |
@@ -636,7 +636,6 @@ static struct t10_pr_registration *__core_scsi3_do_alloc_registration( | |||
636 | int all_tg_pt, | 636 | int all_tg_pt, |
637 | int aptpl) | 637 | int aptpl) |
638 | { | 638 | { |
639 | struct se_subsystem_dev *su_dev = dev->se_sub_dev; | ||
640 | struct t10_pr_registration *pr_reg; | 639 | struct t10_pr_registration *pr_reg; |
641 | 640 | ||
642 | pr_reg = kmem_cache_zalloc(t10_pr_reg_cache, GFP_ATOMIC); | 641 | pr_reg = kmem_cache_zalloc(t10_pr_reg_cache, GFP_ATOMIC); |
@@ -645,7 +644,7 @@ static struct t10_pr_registration *__core_scsi3_do_alloc_registration( | |||
645 | return NULL; | 644 | return NULL; |
646 | } | 645 | } |
647 | 646 | ||
648 | pr_reg->pr_aptpl_buf = kzalloc(su_dev->t10_pr.pr_aptpl_buf_len, | 647 | pr_reg->pr_aptpl_buf = kzalloc(dev->t10_pr.pr_aptpl_buf_len, |
649 | GFP_ATOMIC); | 648 | GFP_ATOMIC); |
650 | if (!pr_reg->pr_aptpl_buf) { | 649 | if (!pr_reg->pr_aptpl_buf) { |
651 | pr_err("Unable to allocate pr_reg->pr_aptpl_buf\n"); | 650 | pr_err("Unable to allocate pr_reg->pr_aptpl_buf\n"); |
@@ -929,7 +928,7 @@ static int __core_scsi3_check_aptpl_registration( | |||
929 | struct se_dev_entry *deve) | 928 | struct se_dev_entry *deve) |
930 | { | 929 | { |
931 | struct t10_pr_registration *pr_reg, *pr_reg_tmp; | 930 | struct t10_pr_registration *pr_reg, *pr_reg_tmp; |
932 | struct t10_reservation *pr_tmpl = &dev->se_sub_dev->t10_pr; | 931 | struct t10_reservation *pr_tmpl = &dev->t10_pr; |
933 | unsigned char i_port[PR_APTPL_MAX_IPORT_LEN]; | 932 | unsigned char i_port[PR_APTPL_MAX_IPORT_LEN]; |
934 | unsigned char t_port[PR_APTPL_MAX_TPORT_LEN]; | 933 | unsigned char t_port[PR_APTPL_MAX_TPORT_LEN]; |
935 | u16 tpgt; | 934 | u16 tpgt; |
@@ -996,11 +995,10 @@ int core_scsi3_check_aptpl_registration( | |||
996 | struct se_lun *lun, | 995 | struct se_lun *lun, |
997 | struct se_lun_acl *lun_acl) | 996 | struct se_lun_acl *lun_acl) |
998 | { | 997 | { |
999 | struct se_subsystem_dev *su_dev = dev->se_sub_dev; | ||
1000 | struct se_node_acl *nacl = lun_acl->se_lun_nacl; | 998 | struct se_node_acl *nacl = lun_acl->se_lun_nacl; |
1001 | struct se_dev_entry *deve = nacl->device_list[lun_acl->mapped_lun]; | 999 | struct se_dev_entry *deve = nacl->device_list[lun_acl->mapped_lun]; |
1002 | 1000 | ||
1003 | if (su_dev->t10_pr.res_type != SPC3_PERSISTENT_RESERVATIONS) | 1001 | if (dev->t10_pr.res_type != SPC3_PERSISTENT_RESERVATIONS) |
1004 | return 0; | 1002 | return 0; |
1005 | 1003 | ||
1006 | return __core_scsi3_check_aptpl_registration(dev, tpg, lun, | 1004 | return __core_scsi3_check_aptpl_registration(dev, tpg, lun, |
@@ -1051,10 +1049,9 @@ static void __core_scsi3_add_registration( | |||
1051 | int register_type, | 1049 | int register_type, |
1052 | int register_move) | 1050 | int register_move) |
1053 | { | 1051 | { |
1054 | struct se_subsystem_dev *su_dev = dev->se_sub_dev; | ||
1055 | struct target_core_fabric_ops *tfo = nacl->se_tpg->se_tpg_tfo; | 1052 | struct target_core_fabric_ops *tfo = nacl->se_tpg->se_tpg_tfo; |
1056 | struct t10_pr_registration *pr_reg_tmp, *pr_reg_tmp_safe; | 1053 | struct t10_pr_registration *pr_reg_tmp, *pr_reg_tmp_safe; |
1057 | struct t10_reservation *pr_tmpl = &dev->se_sub_dev->t10_pr; | 1054 | struct t10_reservation *pr_tmpl = &dev->t10_pr; |
1058 | 1055 | ||
1059 | /* | 1056 | /* |
1060 | * Increment PRgeneration counter for struct se_device upon a successful | 1057 | * Increment PRgeneration counter for struct se_device upon a successful |
@@ -1066,7 +1063,7 @@ static void __core_scsi3_add_registration( | |||
1066 | * for the REGISTER. | 1063 | * for the REGISTER. |
1067 | */ | 1064 | */ |
1068 | pr_reg->pr_res_generation = (register_move) ? | 1065 | pr_reg->pr_res_generation = (register_move) ? |
1069 | su_dev->t10_pr.pr_generation++ : | 1066 | dev->t10_pr.pr_generation++ : |
1070 | core_scsi3_pr_generation(dev); | 1067 | core_scsi3_pr_generation(dev); |
1071 | 1068 | ||
1072 | spin_lock(&pr_tmpl->registration_lock); | 1069 | spin_lock(&pr_tmpl->registration_lock); |
@@ -1135,7 +1132,7 @@ static struct t10_pr_registration *__core_scsi3_locate_pr_reg( | |||
1135 | struct se_node_acl *nacl, | 1132 | struct se_node_acl *nacl, |
1136 | unsigned char *isid) | 1133 | unsigned char *isid) |
1137 | { | 1134 | { |
1138 | struct t10_reservation *pr_tmpl = &dev->se_sub_dev->t10_pr; | 1135 | struct t10_reservation *pr_tmpl = &dev->t10_pr; |
1139 | struct t10_pr_registration *pr_reg, *pr_reg_tmp; | 1136 | struct t10_pr_registration *pr_reg, *pr_reg_tmp; |
1140 | struct se_portal_group *tpg; | 1137 | struct se_portal_group *tpg; |
1141 | 1138 | ||
@@ -1160,7 +1157,7 @@ static struct t10_pr_registration *__core_scsi3_locate_pr_reg( | |||
1160 | * for fabric modules (iSCSI) requiring them. | 1157 | * for fabric modules (iSCSI) requiring them. |
1161 | */ | 1158 | */ |
1162 | if (tpg->se_tpg_tfo->sess_get_initiator_sid != NULL) { | 1159 | if (tpg->se_tpg_tfo->sess_get_initiator_sid != NULL) { |
1163 | if (dev->se_sub_dev->se_dev_attrib.enforce_pr_isids) | 1160 | if (dev->dev_attrib.enforce_pr_isids) |
1164 | continue; | 1161 | continue; |
1165 | } | 1162 | } |
1166 | atomic_inc(&pr_reg->pr_res_holders); | 1163 | atomic_inc(&pr_reg->pr_res_holders); |
@@ -1274,7 +1271,7 @@ static void __core_scsi3_free_registration( | |||
1274 | { | 1271 | { |
1275 | struct target_core_fabric_ops *tfo = | 1272 | struct target_core_fabric_ops *tfo = |
1276 | pr_reg->pr_reg_nacl->se_tpg->se_tpg_tfo; | 1273 | pr_reg->pr_reg_nacl->se_tpg->se_tpg_tfo; |
1277 | struct t10_reservation *pr_tmpl = &dev->se_sub_dev->t10_pr; | 1274 | struct t10_reservation *pr_tmpl = &dev->t10_pr; |
1278 | char i_buf[PR_REG_ISID_ID_LEN]; | 1275 | char i_buf[PR_REG_ISID_ID_LEN]; |
1279 | int prf_isid; | 1276 | int prf_isid; |
1280 | 1277 | ||
@@ -1335,7 +1332,7 @@ void core_scsi3_free_pr_reg_from_nacl( | |||
1335 | struct se_device *dev, | 1332 | struct se_device *dev, |
1336 | struct se_node_acl *nacl) | 1333 | struct se_node_acl *nacl) |
1337 | { | 1334 | { |
1338 | struct t10_reservation *pr_tmpl = &dev->se_sub_dev->t10_pr; | 1335 | struct t10_reservation *pr_tmpl = &dev->t10_pr; |
1339 | struct t10_pr_registration *pr_reg, *pr_reg_tmp, *pr_res_holder; | 1336 | struct t10_pr_registration *pr_reg, *pr_reg_tmp, *pr_res_holder; |
1340 | /* | 1337 | /* |
1341 | * If the passed se_node_acl matches the reservation holder, | 1338 | * If the passed se_node_acl matches the reservation holder, |
@@ -1365,7 +1362,7 @@ void core_scsi3_free_pr_reg_from_nacl( | |||
1365 | void core_scsi3_free_all_registrations( | 1362 | void core_scsi3_free_all_registrations( |
1366 | struct se_device *dev) | 1363 | struct se_device *dev) |
1367 | { | 1364 | { |
1368 | struct t10_reservation *pr_tmpl = &dev->se_sub_dev->t10_pr; | 1365 | struct t10_reservation *pr_tmpl = &dev->t10_pr; |
1369 | struct t10_pr_registration *pr_reg, *pr_reg_tmp, *pr_res_holder; | 1366 | struct t10_pr_registration *pr_reg, *pr_reg_tmp, *pr_res_holder; |
1370 | 1367 | ||
1371 | spin_lock(&dev->dev_reservation_lock); | 1368 | spin_lock(&dev->dev_reservation_lock); |
@@ -1899,7 +1896,6 @@ static int __core_scsi3_update_aptpl_buf( | |||
1899 | { | 1896 | { |
1900 | struct se_lun *lun; | 1897 | struct se_lun *lun; |
1901 | struct se_portal_group *tpg; | 1898 | struct se_portal_group *tpg; |
1902 | struct se_subsystem_dev *su_dev = dev->se_sub_dev; | ||
1903 | struct t10_pr_registration *pr_reg; | 1899 | struct t10_pr_registration *pr_reg; |
1904 | unsigned char tmp[512], isid_buf[32]; | 1900 | unsigned char tmp[512], isid_buf[32]; |
1905 | ssize_t len = 0; | 1901 | ssize_t len = 0; |
@@ -1917,8 +1913,8 @@ static int __core_scsi3_update_aptpl_buf( | |||
1917 | /* | 1913 | /* |
1918 | * Walk the registration list.. | 1914 | * Walk the registration list.. |
1919 | */ | 1915 | */ |
1920 | spin_lock(&su_dev->t10_pr.registration_lock); | 1916 | spin_lock(&dev->t10_pr.registration_lock); |
1921 | list_for_each_entry(pr_reg, &su_dev->t10_pr.registration_list, | 1917 | list_for_each_entry(pr_reg, &dev->t10_pr.registration_list, |
1922 | pr_reg_list) { | 1918 | pr_reg_list) { |
1923 | 1919 | ||
1924 | tmp[0] = '\0'; | 1920 | tmp[0] = '\0'; |
@@ -1963,7 +1959,7 @@ static int __core_scsi3_update_aptpl_buf( | |||
1963 | if ((len + strlen(tmp) >= pr_aptpl_buf_len)) { | 1959 | if ((len + strlen(tmp) >= pr_aptpl_buf_len)) { |
1964 | pr_err("Unable to update renaming" | 1960 | pr_err("Unable to update renaming" |
1965 | " APTPL metadata\n"); | 1961 | " APTPL metadata\n"); |
1966 | spin_unlock(&su_dev->t10_pr.registration_lock); | 1962 | spin_unlock(&dev->t10_pr.registration_lock); |
1967 | return -EMSGSIZE; | 1963 | return -EMSGSIZE; |
1968 | } | 1964 | } |
1969 | len += sprintf(buf+len, "%s", tmp); | 1965 | len += sprintf(buf+len, "%s", tmp); |
@@ -1981,13 +1977,13 @@ static int __core_scsi3_update_aptpl_buf( | |||
1981 | if ((len + strlen(tmp) >= pr_aptpl_buf_len)) { | 1977 | if ((len + strlen(tmp) >= pr_aptpl_buf_len)) { |
1982 | pr_err("Unable to update renaming" | 1978 | pr_err("Unable to update renaming" |
1983 | " APTPL metadata\n"); | 1979 | " APTPL metadata\n"); |
1984 | spin_unlock(&su_dev->t10_pr.registration_lock); | 1980 | spin_unlock(&dev->t10_pr.registration_lock); |
1985 | return -EMSGSIZE; | 1981 | return -EMSGSIZE; |
1986 | } | 1982 | } |
1987 | len += sprintf(buf+len, "%s", tmp); | 1983 | len += sprintf(buf+len, "%s", tmp); |
1988 | reg_count++; | 1984 | reg_count++; |
1989 | } | 1985 | } |
1990 | spin_unlock(&su_dev->t10_pr.registration_lock); | 1986 | spin_unlock(&dev->t10_pr.registration_lock); |
1991 | 1987 | ||
1992 | if (!reg_count) | 1988 | if (!reg_count) |
1993 | len += sprintf(buf+len, "No Registrations or Reservations"); | 1989 | len += sprintf(buf+len, "No Registrations or Reservations"); |
@@ -2019,7 +2015,7 @@ static int __core_scsi3_write_aptpl_to_file( | |||
2019 | unsigned char *buf, | 2015 | unsigned char *buf, |
2020 | u32 pr_aptpl_buf_len) | 2016 | u32 pr_aptpl_buf_len) |
2021 | { | 2017 | { |
2022 | struct t10_wwn *wwn = &dev->se_sub_dev->t10_wwn; | 2018 | struct t10_wwn *wwn = &dev->t10_wwn; |
2023 | struct file *file; | 2019 | struct file *file; |
2024 | struct iovec iov[1]; | 2020 | struct iovec iov[1]; |
2025 | mm_segment_t old_fs; | 2021 | mm_segment_t old_fs; |
@@ -2120,7 +2116,7 @@ static int core_scsi3_emulate_pro_register( | |||
2120 | struct se_lun *se_lun = cmd->se_lun; | 2116 | struct se_lun *se_lun = cmd->se_lun; |
2121 | struct se_portal_group *se_tpg; | 2117 | struct se_portal_group *se_tpg; |
2122 | struct t10_pr_registration *pr_reg, *pr_reg_p, *pr_reg_tmp, *pr_reg_e; | 2118 | struct t10_pr_registration *pr_reg, *pr_reg_p, *pr_reg_tmp, *pr_reg_e; |
2123 | struct t10_reservation *pr_tmpl = &dev->se_sub_dev->t10_pr; | 2119 | struct t10_reservation *pr_tmpl = &dev->t10_pr; |
2124 | /* Used for APTPL metadata w/ UNREGISTER */ | 2120 | /* Used for APTPL metadata w/ UNREGISTER */ |
2125 | unsigned char *pr_aptpl_buf = NULL; | 2121 | unsigned char *pr_aptpl_buf = NULL; |
2126 | unsigned char isid_buf[PR_REG_ISID_LEN], *isid_ptr = NULL; | 2122 | unsigned char isid_buf[PR_REG_ISID_LEN], *isid_ptr = NULL; |
@@ -2434,7 +2430,7 @@ static int core_scsi3_pro_reserve( | |||
2434 | struct se_session *se_sess = cmd->se_sess; | 2430 | struct se_session *se_sess = cmd->se_sess; |
2435 | struct se_lun *se_lun = cmd->se_lun; | 2431 | struct se_lun *se_lun = cmd->se_lun; |
2436 | struct t10_pr_registration *pr_reg, *pr_res_holder; | 2432 | struct t10_pr_registration *pr_reg, *pr_res_holder; |
2437 | struct t10_reservation *pr_tmpl = &dev->se_sub_dev->t10_pr; | 2433 | struct t10_reservation *pr_tmpl = &dev->t10_pr; |
2438 | char i_buf[PR_REG_ISID_ID_LEN]; | 2434 | char i_buf[PR_REG_ISID_ID_LEN]; |
2439 | int ret, prf_isid; | 2435 | int ret, prf_isid; |
2440 | 2436 | ||
@@ -2667,7 +2663,7 @@ static int core_scsi3_emulate_pro_release( | |||
2667 | struct se_session *se_sess = cmd->se_sess; | 2663 | struct se_session *se_sess = cmd->se_sess; |
2668 | struct se_lun *se_lun = cmd->se_lun; | 2664 | struct se_lun *se_lun = cmd->se_lun; |
2669 | struct t10_pr_registration *pr_reg, *pr_reg_p, *pr_res_holder; | 2665 | struct t10_pr_registration *pr_reg, *pr_reg_p, *pr_res_holder; |
2670 | struct t10_reservation *pr_tmpl = &dev->se_sub_dev->t10_pr; | 2666 | struct t10_reservation *pr_tmpl = &dev->t10_pr; |
2671 | int ret, all_reg = 0; | 2667 | int ret, all_reg = 0; |
2672 | 2668 | ||
2673 | if (!se_sess || !se_lun) { | 2669 | if (!se_sess || !se_lun) { |
@@ -2836,7 +2832,7 @@ static int core_scsi3_emulate_pro_clear( | |||
2836 | struct se_device *dev = cmd->se_dev; | 2832 | struct se_device *dev = cmd->se_dev; |
2837 | struct se_node_acl *pr_reg_nacl; | 2833 | struct se_node_acl *pr_reg_nacl; |
2838 | struct se_session *se_sess = cmd->se_sess; | 2834 | struct se_session *se_sess = cmd->se_sess; |
2839 | struct t10_reservation *pr_tmpl = &dev->se_sub_dev->t10_pr; | 2835 | struct t10_reservation *pr_tmpl = &dev->t10_pr; |
2840 | struct t10_pr_registration *pr_reg, *pr_reg_tmp, *pr_reg_n, *pr_res_holder; | 2836 | struct t10_pr_registration *pr_reg, *pr_reg_tmp, *pr_reg_n, *pr_res_holder; |
2841 | u32 pr_res_mapped_lun = 0; | 2837 | u32 pr_res_mapped_lun = 0; |
2842 | int calling_it_nexus = 0; | 2838 | int calling_it_nexus = 0; |
@@ -3006,7 +3002,7 @@ static int core_scsi3_pro_preempt( | |||
3006 | struct se_session *se_sess = cmd->se_sess; | 3002 | struct se_session *se_sess = cmd->se_sess; |
3007 | LIST_HEAD(preempt_and_abort_list); | 3003 | LIST_HEAD(preempt_and_abort_list); |
3008 | struct t10_pr_registration *pr_reg, *pr_reg_tmp, *pr_reg_n, *pr_res_holder; | 3004 | struct t10_pr_registration *pr_reg, *pr_reg_tmp, *pr_reg_n, *pr_res_holder; |
3009 | struct t10_reservation *pr_tmpl = &dev->se_sub_dev->t10_pr; | 3005 | struct t10_reservation *pr_tmpl = &dev->t10_pr; |
3010 | u32 pr_res_mapped_lun = 0; | 3006 | u32 pr_res_mapped_lun = 0; |
3011 | int all_reg = 0, calling_it_nexus = 0, released_regs = 0; | 3007 | int all_reg = 0, calling_it_nexus = 0, released_regs = 0; |
3012 | int prh_type = 0, prh_scope = 0, ret; | 3008 | int prh_type = 0, prh_scope = 0, ret; |
@@ -3358,7 +3354,7 @@ static int core_scsi3_emulate_pro_register_and_move( | |||
3358 | struct se_portal_group *se_tpg, *dest_se_tpg = NULL; | 3354 | struct se_portal_group *se_tpg, *dest_se_tpg = NULL; |
3359 | struct target_core_fabric_ops *dest_tf_ops = NULL, *tf_ops; | 3355 | struct target_core_fabric_ops *dest_tf_ops = NULL, *tf_ops; |
3360 | struct t10_pr_registration *pr_reg, *pr_res_holder, *dest_pr_reg; | 3356 | struct t10_pr_registration *pr_reg, *pr_res_holder, *dest_pr_reg; |
3361 | struct t10_reservation *pr_tmpl = &dev->se_sub_dev->t10_pr; | 3357 | struct t10_reservation *pr_tmpl = &dev->t10_pr; |
3362 | unsigned char *buf; | 3358 | unsigned char *buf; |
3363 | unsigned char *initiator_str; | 3359 | unsigned char *initiator_str; |
3364 | char *iport_ptr = NULL, dest_iport[64], i_buf[PR_REG_ISID_ID_LEN]; | 3360 | char *iport_ptr = NULL, dest_iport[64], i_buf[PR_REG_ISID_ID_LEN]; |
@@ -3823,7 +3819,7 @@ int target_scsi3_emulate_pr_out(struct se_cmd *cmd) | |||
3823 | * initiator or service action and shall terminate with a RESERVATION | 3819 | * initiator or service action and shall terminate with a RESERVATION |
3824 | * CONFLICT status. | 3820 | * CONFLICT status. |
3825 | */ | 3821 | */ |
3826 | if (cmd->se_dev->dev_flags & DF_SPC2_RESERVATIONS) { | 3822 | if (cmd->se_dev->dev_reservation_flags & DRF_SPC2_RESERVATIONS) { |
3827 | pr_err("Received PERSISTENT_RESERVE CDB while legacy" | 3823 | pr_err("Received PERSISTENT_RESERVE CDB while legacy" |
3828 | " SPC-2 reservation is held, returning" | 3824 | " SPC-2 reservation is held, returning" |
3829 | " RESERVATION_CONFLICT\n"); | 3825 | " RESERVATION_CONFLICT\n"); |
@@ -3959,8 +3955,7 @@ out: | |||
3959 | */ | 3955 | */ |
3960 | static int core_scsi3_pri_read_keys(struct se_cmd *cmd) | 3956 | static int core_scsi3_pri_read_keys(struct se_cmd *cmd) |
3961 | { | 3957 | { |
3962 | struct se_device *se_dev = cmd->se_dev; | 3958 | struct se_device *dev = cmd->se_dev; |
3963 | struct se_subsystem_dev *su_dev = se_dev->se_sub_dev; | ||
3964 | struct t10_pr_registration *pr_reg; | 3959 | struct t10_pr_registration *pr_reg; |
3965 | unsigned char *buf; | 3960 | unsigned char *buf; |
3966 | u32 add_len = 0, off = 8; | 3961 | u32 add_len = 0, off = 8; |
@@ -3973,13 +3968,13 @@ static int core_scsi3_pri_read_keys(struct se_cmd *cmd) | |||
3973 | } | 3968 | } |
3974 | 3969 | ||
3975 | buf = transport_kmap_data_sg(cmd); | 3970 | buf = transport_kmap_data_sg(cmd); |
3976 | buf[0] = ((su_dev->t10_pr.pr_generation >> 24) & 0xff); | 3971 | buf[0] = ((dev->t10_pr.pr_generation >> 24) & 0xff); |
3977 | buf[1] = ((su_dev->t10_pr.pr_generation >> 16) & 0xff); | 3972 | buf[1] = ((dev->t10_pr.pr_generation >> 16) & 0xff); |
3978 | buf[2] = ((su_dev->t10_pr.pr_generation >> 8) & 0xff); | 3973 | buf[2] = ((dev->t10_pr.pr_generation >> 8) & 0xff); |
3979 | buf[3] = (su_dev->t10_pr.pr_generation & 0xff); | 3974 | buf[3] = (dev->t10_pr.pr_generation & 0xff); |
3980 | 3975 | ||
3981 | spin_lock(&su_dev->t10_pr.registration_lock); | 3976 | spin_lock(&dev->t10_pr.registration_lock); |
3982 | list_for_each_entry(pr_reg, &su_dev->t10_pr.registration_list, | 3977 | list_for_each_entry(pr_reg, &dev->t10_pr.registration_list, |
3983 | pr_reg_list) { | 3978 | pr_reg_list) { |
3984 | /* | 3979 | /* |
3985 | * Check for overflow of 8byte PRI READ_KEYS payload and | 3980 | * Check for overflow of 8byte PRI READ_KEYS payload and |
@@ -3999,7 +3994,7 @@ static int core_scsi3_pri_read_keys(struct se_cmd *cmd) | |||
3999 | 3994 | ||
4000 | add_len += 8; | 3995 | add_len += 8; |
4001 | } | 3996 | } |
4002 | spin_unlock(&su_dev->t10_pr.registration_lock); | 3997 | spin_unlock(&dev->t10_pr.registration_lock); |
4003 | 3998 | ||
4004 | buf[4] = ((add_len >> 24) & 0xff); | 3999 | buf[4] = ((add_len >> 24) & 0xff); |
4005 | buf[5] = ((add_len >> 16) & 0xff); | 4000 | buf[5] = ((add_len >> 16) & 0xff); |
@@ -4018,8 +4013,7 @@ static int core_scsi3_pri_read_keys(struct se_cmd *cmd) | |||
4018 | */ | 4013 | */ |
4019 | static int core_scsi3_pri_read_reservation(struct se_cmd *cmd) | 4014 | static int core_scsi3_pri_read_reservation(struct se_cmd *cmd) |
4020 | { | 4015 | { |
4021 | struct se_device *se_dev = cmd->se_dev; | 4016 | struct se_device *dev = cmd->se_dev; |
4022 | struct se_subsystem_dev *su_dev = se_dev->se_sub_dev; | ||
4023 | struct t10_pr_registration *pr_reg; | 4017 | struct t10_pr_registration *pr_reg; |
4024 | unsigned char *buf; | 4018 | unsigned char *buf; |
4025 | u64 pr_res_key; | 4019 | u64 pr_res_key; |
@@ -4033,13 +4027,13 @@ static int core_scsi3_pri_read_reservation(struct se_cmd *cmd) | |||
4033 | } | 4027 | } |
4034 | 4028 | ||
4035 | buf = transport_kmap_data_sg(cmd); | 4029 | buf = transport_kmap_data_sg(cmd); |
4036 | buf[0] = ((su_dev->t10_pr.pr_generation >> 24) & 0xff); | 4030 | buf[0] = ((dev->t10_pr.pr_generation >> 24) & 0xff); |
4037 | buf[1] = ((su_dev->t10_pr.pr_generation >> 16) & 0xff); | 4031 | buf[1] = ((dev->t10_pr.pr_generation >> 16) & 0xff); |
4038 | buf[2] = ((su_dev->t10_pr.pr_generation >> 8) & 0xff); | 4032 | buf[2] = ((dev->t10_pr.pr_generation >> 8) & 0xff); |
4039 | buf[3] = (su_dev->t10_pr.pr_generation & 0xff); | 4033 | buf[3] = (dev->t10_pr.pr_generation & 0xff); |
4040 | 4034 | ||
4041 | spin_lock(&se_dev->dev_reservation_lock); | 4035 | spin_lock(&dev->dev_reservation_lock); |
4042 | pr_reg = se_dev->dev_pr_res_holder; | 4036 | pr_reg = dev->dev_pr_res_holder; |
4043 | if (pr_reg) { | 4037 | if (pr_reg) { |
4044 | /* | 4038 | /* |
4045 | * Set the hardcoded Additional Length | 4039 | * Set the hardcoded Additional Length |
@@ -4090,7 +4084,7 @@ static int core_scsi3_pri_read_reservation(struct se_cmd *cmd) | |||
4090 | } | 4084 | } |
4091 | 4085 | ||
4092 | err: | 4086 | err: |
4093 | spin_unlock(&se_dev->dev_reservation_lock); | 4087 | spin_unlock(&dev->dev_reservation_lock); |
4094 | transport_kunmap_data_sg(cmd); | 4088 | transport_kunmap_data_sg(cmd); |
4095 | 4089 | ||
4096 | return 0; | 4090 | return 0; |
@@ -4104,7 +4098,7 @@ err: | |||
4104 | static int core_scsi3_pri_report_capabilities(struct se_cmd *cmd) | 4098 | static int core_scsi3_pri_report_capabilities(struct se_cmd *cmd) |
4105 | { | 4099 | { |
4106 | struct se_device *dev = cmd->se_dev; | 4100 | struct se_device *dev = cmd->se_dev; |
4107 | struct t10_reservation *pr_tmpl = &dev->se_sub_dev->t10_pr; | 4101 | struct t10_reservation *pr_tmpl = &dev->t10_pr; |
4108 | unsigned char *buf; | 4102 | unsigned char *buf; |
4109 | u16 add_len = 8; /* Hardcoded to 8. */ | 4103 | u16 add_len = 8; /* Hardcoded to 8. */ |
4110 | 4104 | ||
@@ -4159,12 +4153,11 @@ static int core_scsi3_pri_report_capabilities(struct se_cmd *cmd) | |||
4159 | */ | 4153 | */ |
4160 | static int core_scsi3_pri_read_full_status(struct se_cmd *cmd) | 4154 | static int core_scsi3_pri_read_full_status(struct se_cmd *cmd) |
4161 | { | 4155 | { |
4162 | struct se_device *se_dev = cmd->se_dev; | 4156 | struct se_device *dev = cmd->se_dev; |
4163 | struct se_node_acl *se_nacl; | 4157 | struct se_node_acl *se_nacl; |
4164 | struct se_subsystem_dev *su_dev = se_dev->se_sub_dev; | ||
4165 | struct se_portal_group *se_tpg; | 4158 | struct se_portal_group *se_tpg; |
4166 | struct t10_pr_registration *pr_reg, *pr_reg_tmp; | 4159 | struct t10_pr_registration *pr_reg, *pr_reg_tmp; |
4167 | struct t10_reservation *pr_tmpl = &se_dev->se_sub_dev->t10_pr; | 4160 | struct t10_reservation *pr_tmpl = &dev->t10_pr; |
4168 | unsigned char *buf; | 4161 | unsigned char *buf; |
4169 | u32 add_desc_len = 0, add_len = 0, desc_len, exp_desc_len; | 4162 | u32 add_desc_len = 0, add_len = 0, desc_len, exp_desc_len; |
4170 | u32 off = 8; /* off into first Full Status descriptor */ | 4163 | u32 off = 8; /* off into first Full Status descriptor */ |
@@ -4179,10 +4172,10 @@ static int core_scsi3_pri_read_full_status(struct se_cmd *cmd) | |||
4179 | 4172 | ||
4180 | buf = transport_kmap_data_sg(cmd); | 4173 | buf = transport_kmap_data_sg(cmd); |
4181 | 4174 | ||
4182 | buf[0] = ((su_dev->t10_pr.pr_generation >> 24) & 0xff); | 4175 | buf[0] = ((dev->t10_pr.pr_generation >> 24) & 0xff); |
4183 | buf[1] = ((su_dev->t10_pr.pr_generation >> 16) & 0xff); | 4176 | buf[1] = ((dev->t10_pr.pr_generation >> 16) & 0xff); |
4184 | buf[2] = ((su_dev->t10_pr.pr_generation >> 8) & 0xff); | 4177 | buf[2] = ((dev->t10_pr.pr_generation >> 8) & 0xff); |
4185 | buf[3] = (su_dev->t10_pr.pr_generation & 0xff); | 4178 | buf[3] = (dev->t10_pr.pr_generation & 0xff); |
4186 | 4179 | ||
4187 | spin_lock(&pr_tmpl->registration_lock); | 4180 | spin_lock(&pr_tmpl->registration_lock); |
4188 | list_for_each_entry_safe(pr_reg, pr_reg_tmp, | 4181 | list_for_each_entry_safe(pr_reg, pr_reg_tmp, |
@@ -4316,7 +4309,7 @@ int target_scsi3_emulate_pr_in(struct se_cmd *cmd) | |||
4316 | * initiator or service action and shall terminate with a RESERVATION | 4309 | * initiator or service action and shall terminate with a RESERVATION |
4317 | * CONFLICT status. | 4310 | * CONFLICT status. |
4318 | */ | 4311 | */ |
4319 | if (cmd->se_dev->dev_flags & DF_SPC2_RESERVATIONS) { | 4312 | if (cmd->se_dev->dev_reservation_flags & DRF_SPC2_RESERVATIONS) { |
4320 | pr_err("Received PERSISTENT_RESERVE CDB while legacy" | 4313 | pr_err("Received PERSISTENT_RESERVE CDB while legacy" |
4321 | " SPC-2 reservation is held, returning" | 4314 | " SPC-2 reservation is held, returning" |
4322 | " RESERVATION_CONFLICT\n"); | 4315 | " RESERVATION_CONFLICT\n"); |
@@ -4363,30 +4356,25 @@ static int core_pt_seq_non_holder( | |||
4363 | return 0; | 4356 | return 0; |
4364 | } | 4357 | } |
4365 | 4358 | ||
4366 | int core_setup_reservations(struct se_device *dev, int force_pt) | 4359 | void core_setup_reservations(struct se_device *dev) |
4367 | { | 4360 | { |
4368 | struct se_subsystem_dev *su_dev = dev->se_sub_dev; | 4361 | struct t10_reservation *rest = &dev->t10_pr; |
4369 | struct t10_reservation *rest = &su_dev->t10_pr; | 4362 | |
4370 | /* | 4363 | /* |
4371 | * If this device is from Target_Core_Mod/pSCSI, use the reservations | 4364 | * If this device is from Target_Core_Mod/pSCSI, use the reservations |
4372 | * of the Underlying SCSI hardware. In Linux/SCSI terms, this can | 4365 | * of the Underlying SCSI hardware. In Linux/SCSI terms, this can |
4373 | * cause a problem because libata and some SATA RAID HBAs appear | 4366 | * cause a problem because libata and some SATA RAID HBAs appear |
4374 | * under Linux/SCSI, but to emulate reservations themselves. | 4367 | * under Linux/SCSI, but to emulate reservations themselves. |
4375 | */ | 4368 | */ |
4376 | if (((dev->transport->transport_type == TRANSPORT_PLUGIN_PHBA_PDEV) && | 4369 | if ((dev->se_hba->hba_flags & HBA_FLAGS_INTERNAL_USE) || |
4377 | !(dev->se_sub_dev->se_dev_attrib.emulate_reservations)) || force_pt) { | 4370 | (dev->transport->transport_type == TRANSPORT_PLUGIN_PHBA_PDEV && |
4371 | !dev->dev_attrib.emulate_reservations)) { | ||
4378 | rest->res_type = SPC_PASSTHROUGH; | 4372 | rest->res_type = SPC_PASSTHROUGH; |
4379 | rest->pr_ops.t10_reservation_check = &core_pt_reservation_check; | 4373 | rest->pr_ops.t10_reservation_check = &core_pt_reservation_check; |
4380 | rest->pr_ops.t10_seq_non_holder = &core_pt_seq_non_holder; | 4374 | rest->pr_ops.t10_seq_non_holder = &core_pt_seq_non_holder; |
4381 | pr_debug("%s: Using SPC_PASSTHROUGH, no reservation" | 4375 | pr_debug("%s: Using SPC_PASSTHROUGH, no reservation" |
4382 | " emulation\n", dev->transport->name); | 4376 | " emulation\n", dev->transport->name); |
4383 | return 0; | 4377 | } else if (dev->transport->get_device_rev(dev) >= SCSI_3) { |
4384 | } | ||
4385 | /* | ||
4386 | * If SPC-3 or above is reported by real or emulated struct se_device, | ||
4387 | * use emulated Persistent Reservations. | ||
4388 | */ | ||
4389 | if (dev->transport->get_device_rev(dev) >= SCSI_3) { | ||
4390 | rest->res_type = SPC3_PERSISTENT_RESERVATIONS; | 4378 | rest->res_type = SPC3_PERSISTENT_RESERVATIONS; |
4391 | rest->pr_ops.t10_reservation_check = &core_scsi3_pr_reservation_check; | 4379 | rest->pr_ops.t10_reservation_check = &core_scsi3_pr_reservation_check; |
4392 | rest->pr_ops.t10_seq_non_holder = &core_scsi3_pr_seq_non_holder; | 4380 | rest->pr_ops.t10_seq_non_holder = &core_scsi3_pr_seq_non_holder; |
@@ -4400,6 +4388,4 @@ int core_setup_reservations(struct se_device *dev, int force_pt) | |||
4400 | pr_debug("%s: Using SPC2_RESERVATIONS emulation\n", | 4388 | pr_debug("%s: Using SPC2_RESERVATIONS emulation\n", |
4401 | dev->transport->name); | 4389 | dev->transport->name); |
4402 | } | 4390 | } |
4403 | |||
4404 | return 0; | ||
4405 | } | 4391 | } |
diff --git a/drivers/target/target_core_pr.h b/drivers/target/target_core_pr.h index af6c460d886d..78451437d2c2 100644 --- a/drivers/target/target_core_pr.h +++ b/drivers/target/target_core_pr.h | |||
@@ -63,6 +63,6 @@ extern unsigned char *core_scsi3_pr_dump_type(int); | |||
63 | 63 | ||
64 | extern int target_scsi3_emulate_pr_in(struct se_cmd *); | 64 | extern int target_scsi3_emulate_pr_in(struct se_cmd *); |
65 | extern int target_scsi3_emulate_pr_out(struct se_cmd *); | 65 | extern int target_scsi3_emulate_pr_out(struct se_cmd *); |
66 | extern int core_setup_reservations(struct se_device *, int); | 66 | extern void core_setup_reservations(struct se_device *); |
67 | 67 | ||
68 | #endif /* TARGET_CORE_PR_H */ | 68 | #endif /* TARGET_CORE_PR_H */ |
diff --git a/drivers/target/target_core_pscsi.c b/drivers/target/target_core_pscsi.c index 617c086a8a02..b2965084eb4f 100644 --- a/drivers/target/target_core_pscsi.c +++ b/drivers/target/target_core_pscsi.c | |||
@@ -53,6 +53,11 @@ | |||
53 | 53 | ||
54 | #define ISPRINT(a) ((a >= ' ') && (a <= '~')) | 54 | #define ISPRINT(a) ((a >= ' ') && (a <= '~')) |
55 | 55 | ||
56 | static inline struct pscsi_dev_virt *PSCSI_DEV(struct se_device *dev) | ||
57 | { | ||
58 | return container_of(dev, struct pscsi_dev_virt, dev); | ||
59 | } | ||
60 | |||
56 | static struct se_subsystem_api pscsi_template; | 61 | static struct se_subsystem_api pscsi_template; |
57 | 62 | ||
58 | static int pscsi_execute_cmd(struct se_cmd *cmd); | 63 | static int pscsi_execute_cmd(struct se_cmd *cmd); |
@@ -219,7 +224,7 @@ pscsi_get_inquiry_vpd_serial(struct scsi_device *sdev, struct t10_wwn *wwn) | |||
219 | 224 | ||
220 | snprintf(&wwn->unit_serial[0], INQUIRY_VPD_SERIAL_LEN, "%s", &buf[4]); | 225 | snprintf(&wwn->unit_serial[0], INQUIRY_VPD_SERIAL_LEN, "%s", &buf[4]); |
221 | 226 | ||
222 | wwn->t10_sub_dev->su_dev_flags |= SDF_FIRMWARE_VPD_UNIT_SERIAL; | 227 | wwn->t10_dev->dev_flags |= DF_FIRMWARE_VPD_UNIT_SERIAL; |
223 | 228 | ||
224 | kfree(buf); | 229 | kfree(buf); |
225 | return 0; | 230 | return 0; |
@@ -299,23 +304,13 @@ out: | |||
299 | kfree(buf); | 304 | kfree(buf); |
300 | } | 305 | } |
301 | 306 | ||
302 | /* pscsi_add_device_to_list(): | 307 | static int pscsi_add_device_to_list(struct se_device *dev, |
303 | * | 308 | struct scsi_device *sd) |
304 | * | ||
305 | */ | ||
306 | static struct se_device *pscsi_add_device_to_list( | ||
307 | struct se_hba *hba, | ||
308 | struct se_subsystem_dev *se_dev, | ||
309 | struct pscsi_dev_virt *pdv, | ||
310 | struct scsi_device *sd, | ||
311 | int dev_flags) | ||
312 | { | 309 | { |
313 | struct se_device *dev; | 310 | struct pscsi_dev_virt *pdv = PSCSI_DEV(dev); |
314 | struct se_dev_limits dev_limits; | 311 | struct request_queue *q = sd->request_queue; |
315 | struct request_queue *q; | ||
316 | struct queue_limits *limits; | ||
317 | 312 | ||
318 | memset(&dev_limits, 0, sizeof(struct se_dev_limits)); | 313 | pdv->pdv_sd = sd; |
319 | 314 | ||
320 | if (!sd->queue_depth) { | 315 | if (!sd->queue_depth) { |
321 | sd->queue_depth = PSCSI_DEFAULT_QUEUEDEPTH; | 316 | sd->queue_depth = PSCSI_DEFAULT_QUEUEDEPTH; |
@@ -324,54 +319,27 @@ static struct se_device *pscsi_add_device_to_list( | |||
324 | " queue_depth to %d\n", sd->channel, sd->id, | 319 | " queue_depth to %d\n", sd->channel, sd->id, |
325 | sd->lun, sd->queue_depth); | 320 | sd->lun, sd->queue_depth); |
326 | } | 321 | } |
327 | /* | 322 | |
328 | * Setup the local scope queue_limits from struct request_queue->limits | 323 | dev->dev_attrib.hw_block_size = sd->sector_size; |
329 | * to pass into transport_add_device_to_core_hba() as struct se_dev_limits. | 324 | dev->dev_attrib.hw_max_sectors = |
330 | */ | 325 | min_t(int, sd->host->max_sectors, queue_max_hw_sectors(q)); |
331 | q = sd->request_queue; | 326 | dev->dev_attrib.hw_queue_depth = sd->queue_depth; |
332 | limits = &dev_limits.limits; | 327 | |
333 | limits->logical_block_size = sd->sector_size; | ||
334 | limits->max_hw_sectors = min_t(int, sd->host->max_sectors, queue_max_hw_sectors(q)); | ||
335 | limits->max_sectors = min_t(int, sd->host->max_sectors, queue_max_sectors(q)); | ||
336 | dev_limits.hw_queue_depth = sd->queue_depth; | ||
337 | dev_limits.queue_depth = sd->queue_depth; | ||
338 | /* | 328 | /* |
339 | * Setup our standard INQUIRY info into se_dev->t10_wwn | 329 | * Setup our standard INQUIRY info into se_dev->t10_wwn |
340 | */ | 330 | */ |
341 | pscsi_set_inquiry_info(sd, &se_dev->t10_wwn); | 331 | pscsi_set_inquiry_info(sd, &dev->t10_wwn); |
342 | |||
343 | /* | ||
344 | * Set the pointer pdv->pdv_sd to from passed struct scsi_device, | ||
345 | * which has already been referenced with Linux SCSI code with | ||
346 | * scsi_device_get() in this file's pscsi_create_virtdevice(). | ||
347 | * | ||
348 | * The passthrough operations called by the transport_add_device_* | ||
349 | * function below will require this pointer to be set for passthroug | ||
350 | * ops. | ||
351 | * | ||
352 | * For the shutdown case in pscsi_free_device(), this struct | ||
353 | * scsi_device reference is released with Linux SCSI code | ||
354 | * scsi_device_put() and the pdv->pdv_sd cleared. | ||
355 | */ | ||
356 | pdv->pdv_sd = sd; | ||
357 | dev = transport_add_device_to_core_hba(hba, &pscsi_template, | ||
358 | se_dev, dev_flags, pdv, | ||
359 | &dev_limits, NULL, NULL); | ||
360 | if (!dev) { | ||
361 | pdv->pdv_sd = NULL; | ||
362 | return NULL; | ||
363 | } | ||
364 | 332 | ||
365 | /* | 333 | /* |
366 | * Locate VPD WWN Information used for various purposes within | 334 | * Locate VPD WWN Information used for various purposes within |
367 | * the Storage Engine. | 335 | * the Storage Engine. |
368 | */ | 336 | */ |
369 | if (!pscsi_get_inquiry_vpd_serial(sd, &se_dev->t10_wwn)) { | 337 | if (!pscsi_get_inquiry_vpd_serial(sd, &dev->t10_wwn)) { |
370 | /* | 338 | /* |
371 | * If VPD Unit Serial returned GOOD status, try | 339 | * If VPD Unit Serial returned GOOD status, try |
372 | * VPD Device Identification page (0x83). | 340 | * VPD Device Identification page (0x83). |
373 | */ | 341 | */ |
374 | pscsi_get_inquiry_vpd_device_ident(sd, &se_dev->t10_wwn); | 342 | pscsi_get_inquiry_vpd_device_ident(sd, &dev->t10_wwn); |
375 | } | 343 | } |
376 | 344 | ||
377 | /* | 345 | /* |
@@ -379,10 +347,11 @@ static struct se_device *pscsi_add_device_to_list( | |||
379 | */ | 347 | */ |
380 | if (sd->type == TYPE_TAPE) | 348 | if (sd->type == TYPE_TAPE) |
381 | pscsi_tape_read_blocksize(dev, sd); | 349 | pscsi_tape_read_blocksize(dev, sd); |
382 | return dev; | 350 | return 0; |
383 | } | 351 | } |
384 | 352 | ||
385 | static void *pscsi_allocate_virtdevice(struct se_hba *hba, const char *name) | 353 | static struct se_device *pscsi_alloc_device(struct se_hba *hba, |
354 | const char *name) | ||
386 | { | 355 | { |
387 | struct pscsi_dev_virt *pdv; | 356 | struct pscsi_dev_virt *pdv; |
388 | 357 | ||
@@ -391,139 +360,125 @@ static void *pscsi_allocate_virtdevice(struct se_hba *hba, const char *name) | |||
391 | pr_err("Unable to allocate memory for struct pscsi_dev_virt\n"); | 360 | pr_err("Unable to allocate memory for struct pscsi_dev_virt\n"); |
392 | return NULL; | 361 | return NULL; |
393 | } | 362 | } |
394 | pdv->pdv_se_hba = hba; | ||
395 | 363 | ||
396 | pr_debug("PSCSI: Allocated pdv: %p for %s\n", pdv, name); | 364 | pr_debug("PSCSI: Allocated pdv: %p for %s\n", pdv, name); |
397 | return pdv; | 365 | return &pdv->dev; |
398 | } | 366 | } |
399 | 367 | ||
400 | /* | 368 | /* |
401 | * Called with struct Scsi_Host->host_lock called. | 369 | * Called with struct Scsi_Host->host_lock called. |
402 | */ | 370 | */ |
403 | static struct se_device *pscsi_create_type_disk( | 371 | static int pscsi_create_type_disk(struct se_device *dev, struct scsi_device *sd) |
404 | struct scsi_device *sd, | ||
405 | struct pscsi_dev_virt *pdv, | ||
406 | struct se_subsystem_dev *se_dev, | ||
407 | struct se_hba *hba) | ||
408 | __releases(sh->host_lock) | 372 | __releases(sh->host_lock) |
409 | { | 373 | { |
410 | struct se_device *dev; | 374 | struct pscsi_hba_virt *phv = dev->se_hba->hba_ptr; |
411 | struct pscsi_hba_virt *phv = pdv->pdv_se_hba->hba_ptr; | 375 | struct pscsi_dev_virt *pdv = PSCSI_DEV(dev); |
412 | struct Scsi_Host *sh = sd->host; | 376 | struct Scsi_Host *sh = sd->host; |
413 | struct block_device *bd; | 377 | struct block_device *bd; |
414 | u32 dev_flags = 0; | 378 | int ret; |
415 | 379 | ||
416 | if (scsi_device_get(sd)) { | 380 | if (scsi_device_get(sd)) { |
417 | pr_err("scsi_device_get() failed for %d:%d:%d:%d\n", | 381 | pr_err("scsi_device_get() failed for %d:%d:%d:%d\n", |
418 | sh->host_no, sd->channel, sd->id, sd->lun); | 382 | sh->host_no, sd->channel, sd->id, sd->lun); |
419 | spin_unlock_irq(sh->host_lock); | 383 | spin_unlock_irq(sh->host_lock); |
420 | return NULL; | 384 | return -EIO; |
421 | } | 385 | } |
422 | spin_unlock_irq(sh->host_lock); | 386 | spin_unlock_irq(sh->host_lock); |
423 | /* | 387 | /* |
424 | * Claim exclusive struct block_device access to struct scsi_device | 388 | * Claim exclusive struct block_device access to struct scsi_device |
425 | * for TYPE_DISK using supplied udev_path | 389 | * for TYPE_DISK using supplied udev_path |
426 | */ | 390 | */ |
427 | bd = blkdev_get_by_path(se_dev->se_dev_udev_path, | 391 | bd = blkdev_get_by_path(dev->udev_path, |
428 | FMODE_WRITE|FMODE_READ|FMODE_EXCL, pdv); | 392 | FMODE_WRITE|FMODE_READ|FMODE_EXCL, pdv); |
429 | if (IS_ERR(bd)) { | 393 | if (IS_ERR(bd)) { |
430 | pr_err("pSCSI: blkdev_get_by_path() failed\n"); | 394 | pr_err("pSCSI: blkdev_get_by_path() failed\n"); |
431 | scsi_device_put(sd); | 395 | scsi_device_put(sd); |
432 | return NULL; | 396 | return PTR_ERR(bd); |
433 | } | 397 | } |
434 | pdv->pdv_bd = bd; | 398 | pdv->pdv_bd = bd; |
435 | 399 | ||
436 | dev = pscsi_add_device_to_list(hba, se_dev, pdv, sd, dev_flags); | 400 | ret = pscsi_add_device_to_list(dev, sd); |
437 | if (!dev) { | 401 | if (ret) { |
438 | blkdev_put(pdv->pdv_bd, FMODE_WRITE|FMODE_READ|FMODE_EXCL); | 402 | blkdev_put(pdv->pdv_bd, FMODE_WRITE|FMODE_READ|FMODE_EXCL); |
439 | scsi_device_put(sd); | 403 | scsi_device_put(sd); |
440 | return NULL; | 404 | return ret; |
441 | } | 405 | } |
406 | |||
442 | pr_debug("CORE_PSCSI[%d] - Added TYPE_DISK for %d:%d:%d:%d\n", | 407 | pr_debug("CORE_PSCSI[%d] - Added TYPE_DISK for %d:%d:%d:%d\n", |
443 | phv->phv_host_id, sh->host_no, sd->channel, sd->id, sd->lun); | 408 | phv->phv_host_id, sh->host_no, sd->channel, sd->id, sd->lun); |
444 | 409 | return 0; | |
445 | return dev; | ||
446 | } | 410 | } |
447 | 411 | ||
448 | /* | 412 | /* |
449 | * Called with struct Scsi_Host->host_lock called. | 413 | * Called with struct Scsi_Host->host_lock called. |
450 | */ | 414 | */ |
451 | static struct se_device *pscsi_create_type_rom( | 415 | static int pscsi_create_type_rom(struct se_device *dev, struct scsi_device *sd) |
452 | struct scsi_device *sd, | ||
453 | struct pscsi_dev_virt *pdv, | ||
454 | struct se_subsystem_dev *se_dev, | ||
455 | struct se_hba *hba) | ||
456 | __releases(sh->host_lock) | 416 | __releases(sh->host_lock) |
457 | { | 417 | { |
458 | struct se_device *dev; | 418 | struct pscsi_hba_virt *phv = dev->se_hba->hba_ptr; |
459 | struct pscsi_hba_virt *phv = pdv->pdv_se_hba->hba_ptr; | ||
460 | struct Scsi_Host *sh = sd->host; | 419 | struct Scsi_Host *sh = sd->host; |
461 | u32 dev_flags = 0; | 420 | int ret; |
462 | 421 | ||
463 | if (scsi_device_get(sd)) { | 422 | if (scsi_device_get(sd)) { |
464 | pr_err("scsi_device_get() failed for %d:%d:%d:%d\n", | 423 | pr_err("scsi_device_get() failed for %d:%d:%d:%d\n", |
465 | sh->host_no, sd->channel, sd->id, sd->lun); | 424 | sh->host_no, sd->channel, sd->id, sd->lun); |
466 | spin_unlock_irq(sh->host_lock); | 425 | spin_unlock_irq(sh->host_lock); |
467 | return NULL; | 426 | return -EIO; |
468 | } | 427 | } |
469 | spin_unlock_irq(sh->host_lock); | 428 | spin_unlock_irq(sh->host_lock); |
470 | 429 | ||
471 | dev = pscsi_add_device_to_list(hba, se_dev, pdv, sd, dev_flags); | 430 | ret = pscsi_add_device_to_list(dev, sd); |
472 | if (!dev) { | 431 | if (ret) { |
473 | scsi_device_put(sd); | 432 | scsi_device_put(sd); |
474 | return NULL; | 433 | return ret; |
475 | } | 434 | } |
476 | pr_debug("CORE_PSCSI[%d] - Added Type: %s for %d:%d:%d:%d\n", | 435 | pr_debug("CORE_PSCSI[%d] - Added Type: %s for %d:%d:%d:%d\n", |
477 | phv->phv_host_id, scsi_device_type(sd->type), sh->host_no, | 436 | phv->phv_host_id, scsi_device_type(sd->type), sh->host_no, |
478 | sd->channel, sd->id, sd->lun); | 437 | sd->channel, sd->id, sd->lun); |
479 | 438 | ||
480 | return dev; | 439 | return 0; |
481 | } | 440 | } |
482 | 441 | ||
483 | /* | 442 | /* |
484 | *Called with struct Scsi_Host->host_lock called. | 443 | * Called with struct Scsi_Host->host_lock called. |
485 | */ | 444 | */ |
486 | static struct se_device *pscsi_create_type_other( | 445 | static int pscsi_create_type_other(struct se_device *dev, |
487 | struct scsi_device *sd, | 446 | struct scsi_device *sd) |
488 | struct pscsi_dev_virt *pdv, | ||
489 | struct se_subsystem_dev *se_dev, | ||
490 | struct se_hba *hba) | ||
491 | __releases(sh->host_lock) | 447 | __releases(sh->host_lock) |
492 | { | 448 | { |
493 | struct se_device *dev; | 449 | struct pscsi_hba_virt *phv = dev->se_hba->hba_ptr; |
494 | struct pscsi_hba_virt *phv = pdv->pdv_se_hba->hba_ptr; | ||
495 | struct Scsi_Host *sh = sd->host; | 450 | struct Scsi_Host *sh = sd->host; |
496 | u32 dev_flags = 0; | 451 | int ret; |
497 | 452 | ||
498 | spin_unlock_irq(sh->host_lock); | 453 | spin_unlock_irq(sh->host_lock); |
499 | dev = pscsi_add_device_to_list(hba, se_dev, pdv, sd, dev_flags); | 454 | ret = pscsi_add_device_to_list(dev, sd); |
500 | if (!dev) | 455 | if (ret) |
501 | return NULL; | 456 | return ret; |
502 | 457 | ||
503 | pr_debug("CORE_PSCSI[%d] - Added Type: %s for %d:%d:%d:%d\n", | 458 | pr_debug("CORE_PSCSI[%d] - Added Type: %s for %d:%d:%d:%d\n", |
504 | phv->phv_host_id, scsi_device_type(sd->type), sh->host_no, | 459 | phv->phv_host_id, scsi_device_type(sd->type), sh->host_no, |
505 | sd->channel, sd->id, sd->lun); | 460 | sd->channel, sd->id, sd->lun); |
506 | 461 | return 0; | |
507 | return dev; | ||
508 | } | 462 | } |
509 | 463 | ||
510 | static struct se_device *pscsi_create_virtdevice( | 464 | int pscsi_configure_device(struct se_device *dev) |
511 | struct se_hba *hba, | ||
512 | struct se_subsystem_dev *se_dev, | ||
513 | void *p) | ||
514 | { | 465 | { |
515 | struct pscsi_dev_virt *pdv = p; | 466 | struct se_hba *hba = dev->se_hba; |
516 | struct se_device *dev; | 467 | struct pscsi_dev_virt *pdv = PSCSI_DEV(dev); |
517 | struct scsi_device *sd; | 468 | struct scsi_device *sd; |
518 | struct pscsi_hba_virt *phv = hba->hba_ptr; | 469 | struct pscsi_hba_virt *phv = dev->se_hba->hba_ptr; |
519 | struct Scsi_Host *sh = phv->phv_lld_host; | 470 | struct Scsi_Host *sh = phv->phv_lld_host; |
520 | int legacy_mode_enable = 0; | 471 | int legacy_mode_enable = 0; |
472 | int ret; | ||
521 | 473 | ||
522 | if (!pdv) { | 474 | if (!(pdv->pdv_flags & PDF_HAS_CHANNEL_ID) || |
523 | pr_err("Unable to locate struct pscsi_dev_virt" | 475 | !(pdv->pdv_flags & PDF_HAS_TARGET_ID) || |
524 | " parameter\n"); | 476 | !(pdv->pdv_flags & PDF_HAS_LUN_ID)) { |
525 | return ERR_PTR(-EINVAL); | 477 | pr_err("Missing scsi_channel_id=, scsi_target_id= and" |
478 | " scsi_lun_id= parameters\n"); | ||
479 | return -EINVAL; | ||
526 | } | 480 | } |
481 | |||
527 | /* | 482 | /* |
528 | * If not running in PHV_LLD_SCSI_HOST_NO mode, locate the | 483 | * If not running in PHV_LLD_SCSI_HOST_NO mode, locate the |
529 | * struct Scsi_Host we will need to bring the TCM/pSCSI object online | 484 | * struct Scsi_Host we will need to bring the TCM/pSCSI object online |
@@ -532,16 +487,16 @@ static struct se_device *pscsi_create_virtdevice( | |||
532 | if (phv->phv_mode == PHV_LLD_SCSI_HOST_NO) { | 487 | if (phv->phv_mode == PHV_LLD_SCSI_HOST_NO) { |
533 | pr_err("pSCSI: Unable to locate struct" | 488 | pr_err("pSCSI: Unable to locate struct" |
534 | " Scsi_Host for PHV_LLD_SCSI_HOST_NO\n"); | 489 | " Scsi_Host for PHV_LLD_SCSI_HOST_NO\n"); |
535 | return ERR_PTR(-ENODEV); | 490 | return -ENODEV; |
536 | } | 491 | } |
537 | /* | 492 | /* |
538 | * For the newer PHV_VIRTUAL_HOST_ID struct scsi_device | 493 | * For the newer PHV_VIRTUAL_HOST_ID struct scsi_device |
539 | * reference, we enforce that udev_path has been set | 494 | * reference, we enforce that udev_path has been set |
540 | */ | 495 | */ |
541 | if (!(se_dev->su_dev_flags & SDF_USING_UDEV_PATH)) { | 496 | if (!(dev->dev_flags & DF_USING_UDEV_PATH)) { |
542 | pr_err("pSCSI: udev_path attribute has not" | 497 | pr_err("pSCSI: udev_path attribute has not" |
543 | " been set before ENABLE=1\n"); | 498 | " been set before ENABLE=1\n"); |
544 | return ERR_PTR(-EINVAL); | 499 | return -EINVAL; |
545 | } | 500 | } |
546 | /* | 501 | /* |
547 | * If no scsi_host_id= was passed for PHV_VIRTUAL_HOST_ID, | 502 | * If no scsi_host_id= was passed for PHV_VIRTUAL_HOST_ID, |
@@ -549,17 +504,14 @@ static struct se_device *pscsi_create_virtdevice( | |||
549 | * and enable for PHV_LLD_SCSI_HOST_NO mode. | 504 | * and enable for PHV_LLD_SCSI_HOST_NO mode. |
550 | */ | 505 | */ |
551 | if (!(pdv->pdv_flags & PDF_HAS_VIRT_HOST_ID)) { | 506 | if (!(pdv->pdv_flags & PDF_HAS_VIRT_HOST_ID)) { |
552 | spin_lock(&hba->device_lock); | 507 | if (hba->dev_count) { |
553 | if (!list_empty(&hba->hba_dev_list)) { | ||
554 | pr_err("pSCSI: Unable to set hba_mode" | 508 | pr_err("pSCSI: Unable to set hba_mode" |
555 | " with active devices\n"); | 509 | " with active devices\n"); |
556 | spin_unlock(&hba->device_lock); | 510 | return -EEXIST; |
557 | return ERR_PTR(-EEXIST); | ||
558 | } | 511 | } |
559 | spin_unlock(&hba->device_lock); | ||
560 | 512 | ||
561 | if (pscsi_pmode_enable_hba(hba, 1) != 1) | 513 | if (pscsi_pmode_enable_hba(hba, 1) != 1) |
562 | return ERR_PTR(-ENODEV); | 514 | return -ENODEV; |
563 | 515 | ||
564 | legacy_mode_enable = 1; | 516 | legacy_mode_enable = 1; |
565 | hba->hba_flags |= HBA_FLAGS_PSCSI_MODE; | 517 | hba->hba_flags |= HBA_FLAGS_PSCSI_MODE; |
@@ -569,14 +521,14 @@ static struct se_device *pscsi_create_virtdevice( | |||
569 | if (IS_ERR(sh)) { | 521 | if (IS_ERR(sh)) { |
570 | pr_err("pSCSI: Unable to locate" | 522 | pr_err("pSCSI: Unable to locate" |
571 | " pdv_host_id: %d\n", pdv->pdv_host_id); | 523 | " pdv_host_id: %d\n", pdv->pdv_host_id); |
572 | return ERR_CAST(sh); | 524 | return PTR_ERR(sh); |
573 | } | 525 | } |
574 | } | 526 | } |
575 | } else { | 527 | } else { |
576 | if (phv->phv_mode == PHV_VIRTUAL_HOST_ID) { | 528 | if (phv->phv_mode == PHV_VIRTUAL_HOST_ID) { |
577 | pr_err("pSCSI: PHV_VIRTUAL_HOST_ID set while" | 529 | pr_err("pSCSI: PHV_VIRTUAL_HOST_ID set while" |
578 | " struct Scsi_Host exists\n"); | 530 | " struct Scsi_Host exists\n"); |
579 | return ERR_PTR(-EEXIST); | 531 | return -EEXIST; |
580 | } | 532 | } |
581 | } | 533 | } |
582 | 534 | ||
@@ -593,17 +545,17 @@ static struct se_device *pscsi_create_virtdevice( | |||
593 | */ | 545 | */ |
594 | switch (sd->type) { | 546 | switch (sd->type) { |
595 | case TYPE_DISK: | 547 | case TYPE_DISK: |
596 | dev = pscsi_create_type_disk(sd, pdv, se_dev, hba); | 548 | ret = pscsi_create_type_disk(dev, sd); |
597 | break; | 549 | break; |
598 | case TYPE_ROM: | 550 | case TYPE_ROM: |
599 | dev = pscsi_create_type_rom(sd, pdv, se_dev, hba); | 551 | ret = pscsi_create_type_rom(dev, sd); |
600 | break; | 552 | break; |
601 | default: | 553 | default: |
602 | dev = pscsi_create_type_other(sd, pdv, se_dev, hba); | 554 | ret = pscsi_create_type_other(dev, sd); |
603 | break; | 555 | break; |
604 | } | 556 | } |
605 | 557 | ||
606 | if (!dev) { | 558 | if (ret) { |
607 | if (phv->phv_mode == PHV_VIRTUAL_HOST_ID) | 559 | if (phv->phv_mode == PHV_VIRTUAL_HOST_ID) |
608 | scsi_host_put(sh); | 560 | scsi_host_put(sh); |
609 | else if (legacy_mode_enable) { | 561 | else if (legacy_mode_enable) { |
@@ -611,9 +563,9 @@ static struct se_device *pscsi_create_virtdevice( | |||
611 | hba->hba_flags &= ~HBA_FLAGS_PSCSI_MODE; | 563 | hba->hba_flags &= ~HBA_FLAGS_PSCSI_MODE; |
612 | } | 564 | } |
613 | pdv->pdv_sd = NULL; | 565 | pdv->pdv_sd = NULL; |
614 | return ERR_PTR(-ENODEV); | 566 | return ret; |
615 | } | 567 | } |
616 | return dev; | 568 | return 0; |
617 | } | 569 | } |
618 | spin_unlock_irq(sh->host_lock); | 570 | spin_unlock_irq(sh->host_lock); |
619 | 571 | ||
@@ -627,17 +579,13 @@ static struct se_device *pscsi_create_virtdevice( | |||
627 | hba->hba_flags &= ~HBA_FLAGS_PSCSI_MODE; | 579 | hba->hba_flags &= ~HBA_FLAGS_PSCSI_MODE; |
628 | } | 580 | } |
629 | 581 | ||
630 | return ERR_PTR(-ENODEV); | 582 | return -ENODEV; |
631 | } | 583 | } |
632 | 584 | ||
633 | /* pscsi_free_device(): (Part of se_subsystem_api_t template) | 585 | static void pscsi_free_device(struct se_device *dev) |
634 | * | ||
635 | * | ||
636 | */ | ||
637 | static void pscsi_free_device(void *p) | ||
638 | { | 586 | { |
639 | struct pscsi_dev_virt *pdv = p; | 587 | struct pscsi_dev_virt *pdv = PSCSI_DEV(dev); |
640 | struct pscsi_hba_virt *phv = pdv->pdv_se_hba->hba_ptr; | 588 | struct pscsi_hba_virt *phv = dev->se_hba->hba_ptr; |
641 | struct scsi_device *sd = pdv->pdv_sd; | 589 | struct scsi_device *sd = pdv->pdv_sd; |
642 | 590 | ||
643 | if (sd) { | 591 | if (sd) { |
@@ -670,7 +618,7 @@ static void pscsi_free_device(void *p) | |||
670 | static void pscsi_transport_complete(struct se_cmd *cmd, struct scatterlist *sg, | 618 | static void pscsi_transport_complete(struct se_cmd *cmd, struct scatterlist *sg, |
671 | unsigned char *sense_buffer) | 619 | unsigned char *sense_buffer) |
672 | { | 620 | { |
673 | struct pscsi_dev_virt *pdv = cmd->se_dev->dev_ptr; | 621 | struct pscsi_dev_virt *pdv = PSCSI_DEV(cmd->se_dev); |
674 | struct scsi_device *sd = pdv->pdv_sd; | 622 | struct scsi_device *sd = pdv->pdv_sd; |
675 | int result; | 623 | int result; |
676 | struct pscsi_plugin_task *pt = cmd->priv; | 624 | struct pscsi_plugin_task *pt = cmd->priv; |
@@ -770,13 +718,11 @@ static match_table_t tokens = { | |||
770 | {Opt_err, NULL} | 718 | {Opt_err, NULL} |
771 | }; | 719 | }; |
772 | 720 | ||
773 | static ssize_t pscsi_set_configfs_dev_params(struct se_hba *hba, | 721 | static ssize_t pscsi_set_configfs_dev_params(struct se_device *dev, |
774 | struct se_subsystem_dev *se_dev, | 722 | const char *page, ssize_t count) |
775 | const char *page, | ||
776 | ssize_t count) | ||
777 | { | 723 | { |
778 | struct pscsi_dev_virt *pdv = se_dev->se_dev_su_ptr; | 724 | struct pscsi_dev_virt *pdv = PSCSI_DEV(dev); |
779 | struct pscsi_hba_virt *phv = hba->hba_ptr; | 725 | struct pscsi_hba_virt *phv = dev->se_hba->hba_ptr; |
780 | char *orig, *ptr, *opts; | 726 | char *orig, *ptr, *opts; |
781 | substring_t args[MAX_OPT_ARGS]; | 727 | substring_t args[MAX_OPT_ARGS]; |
782 | int ret = 0, arg, token; | 728 | int ret = 0, arg, token; |
@@ -841,29 +787,10 @@ out: | |||
841 | return (!ret) ? count : ret; | 787 | return (!ret) ? count : ret; |
842 | } | 788 | } |
843 | 789 | ||
844 | static ssize_t pscsi_check_configfs_dev_params( | 790 | static ssize_t pscsi_show_configfs_dev_params(struct se_device *dev, char *b) |
845 | struct se_hba *hba, | ||
846 | struct se_subsystem_dev *se_dev) | ||
847 | { | ||
848 | struct pscsi_dev_virt *pdv = se_dev->se_dev_su_ptr; | ||
849 | |||
850 | if (!(pdv->pdv_flags & PDF_HAS_CHANNEL_ID) || | ||
851 | !(pdv->pdv_flags & PDF_HAS_TARGET_ID) || | ||
852 | !(pdv->pdv_flags & PDF_HAS_LUN_ID)) { | ||
853 | pr_err("Missing scsi_channel_id=, scsi_target_id= and" | ||
854 | " scsi_lun_id= parameters\n"); | ||
855 | return -EINVAL; | ||
856 | } | ||
857 | |||
858 | return 0; | ||
859 | } | ||
860 | |||
861 | static ssize_t pscsi_show_configfs_dev_params(struct se_hba *hba, | ||
862 | struct se_subsystem_dev *se_dev, | ||
863 | char *b) | ||
864 | { | 791 | { |
865 | struct pscsi_hba_virt *phv = hba->hba_ptr; | 792 | struct pscsi_hba_virt *phv = dev->se_hba->hba_ptr; |
866 | struct pscsi_dev_virt *pdv = se_dev->se_dev_su_ptr; | 793 | struct pscsi_dev_virt *pdv = PSCSI_DEV(dev); |
867 | struct scsi_device *sd = pdv->pdv_sd; | 794 | struct scsi_device *sd = pdv->pdv_sd; |
868 | unsigned char host_id[16]; | 795 | unsigned char host_id[16]; |
869 | ssize_t bl; | 796 | ssize_t bl; |
@@ -933,7 +860,7 @@ static int pscsi_map_sg(struct se_cmd *cmd, struct scatterlist *sgl, | |||
933 | u32 sgl_nents, enum dma_data_direction data_direction, | 860 | u32 sgl_nents, enum dma_data_direction data_direction, |
934 | struct bio **hbio) | 861 | struct bio **hbio) |
935 | { | 862 | { |
936 | struct pscsi_dev_virt *pdv = cmd->se_dev->dev_ptr; | 863 | struct pscsi_dev_virt *pdv = PSCSI_DEV(cmd->se_dev); |
937 | struct bio *bio = NULL, *tbio = NULL; | 864 | struct bio *bio = NULL, *tbio = NULL; |
938 | struct page *page; | 865 | struct page *page; |
939 | struct scatterlist *sg; | 866 | struct scatterlist *sg; |
@@ -1104,7 +1031,7 @@ static int pscsi_execute_cmd(struct se_cmd *cmd) | |||
1104 | struct scatterlist *sgl = cmd->t_data_sg; | 1031 | struct scatterlist *sgl = cmd->t_data_sg; |
1105 | u32 sgl_nents = cmd->t_data_nents; | 1032 | u32 sgl_nents = cmd->t_data_nents; |
1106 | enum dma_data_direction data_direction = cmd->data_direction; | 1033 | enum dma_data_direction data_direction = cmd->data_direction; |
1107 | struct pscsi_dev_virt *pdv = cmd->se_dev->dev_ptr; | 1034 | struct pscsi_dev_virt *pdv = PSCSI_DEV(cmd->se_dev); |
1108 | struct pscsi_plugin_task *pt; | 1035 | struct pscsi_plugin_task *pt; |
1109 | struct request *req; | 1036 | struct request *req; |
1110 | struct bio *hbio; | 1037 | struct bio *hbio; |
@@ -1191,7 +1118,7 @@ fail: | |||
1191 | */ | 1118 | */ |
1192 | static u32 pscsi_get_device_rev(struct se_device *dev) | 1119 | static u32 pscsi_get_device_rev(struct se_device *dev) |
1193 | { | 1120 | { |
1194 | struct pscsi_dev_virt *pdv = dev->dev_ptr; | 1121 | struct pscsi_dev_virt *pdv = PSCSI_DEV(dev); |
1195 | struct scsi_device *sd = pdv->pdv_sd; | 1122 | struct scsi_device *sd = pdv->pdv_sd; |
1196 | 1123 | ||
1197 | return (sd->scsi_level - 1) ? sd->scsi_level - 1 : 1; | 1124 | return (sd->scsi_level - 1) ? sd->scsi_level - 1 : 1; |
@@ -1203,7 +1130,7 @@ static u32 pscsi_get_device_rev(struct se_device *dev) | |||
1203 | */ | 1130 | */ |
1204 | static u32 pscsi_get_device_type(struct se_device *dev) | 1131 | static u32 pscsi_get_device_type(struct se_device *dev) |
1205 | { | 1132 | { |
1206 | struct pscsi_dev_virt *pdv = dev->dev_ptr; | 1133 | struct pscsi_dev_virt *pdv = PSCSI_DEV(dev); |
1207 | struct scsi_device *sd = pdv->pdv_sd; | 1134 | struct scsi_device *sd = pdv->pdv_sd; |
1208 | 1135 | ||
1209 | return sd->type; | 1136 | return sd->type; |
@@ -1211,7 +1138,7 @@ static u32 pscsi_get_device_type(struct se_device *dev) | |||
1211 | 1138 | ||
1212 | static sector_t pscsi_get_blocks(struct se_device *dev) | 1139 | static sector_t pscsi_get_blocks(struct se_device *dev) |
1213 | { | 1140 | { |
1214 | struct pscsi_dev_virt *pdv = dev->dev_ptr; | 1141 | struct pscsi_dev_virt *pdv = PSCSI_DEV(dev); |
1215 | 1142 | ||
1216 | if (pdv->pdv_bd && pdv->pdv_bd->bd_part) | 1143 | if (pdv->pdv_bd && pdv->pdv_bd->bd_part) |
1217 | return pdv->pdv_bd->bd_part->nr_sects; | 1144 | return pdv->pdv_bd->bd_part->nr_sects; |
@@ -1259,12 +1186,11 @@ static struct se_subsystem_api pscsi_template = { | |||
1259 | .attach_hba = pscsi_attach_hba, | 1186 | .attach_hba = pscsi_attach_hba, |
1260 | .detach_hba = pscsi_detach_hba, | 1187 | .detach_hba = pscsi_detach_hba, |
1261 | .pmode_enable_hba = pscsi_pmode_enable_hba, | 1188 | .pmode_enable_hba = pscsi_pmode_enable_hba, |
1262 | .allocate_virtdevice = pscsi_allocate_virtdevice, | 1189 | .alloc_device = pscsi_alloc_device, |
1263 | .create_virtdevice = pscsi_create_virtdevice, | 1190 | .configure_device = pscsi_configure_device, |
1264 | .free_device = pscsi_free_device, | 1191 | .free_device = pscsi_free_device, |
1265 | .transport_complete = pscsi_transport_complete, | 1192 | .transport_complete = pscsi_transport_complete, |
1266 | .parse_cdb = pscsi_parse_cdb, | 1193 | .parse_cdb = pscsi_parse_cdb, |
1267 | .check_configfs_dev_params = pscsi_check_configfs_dev_params, | ||
1268 | .set_configfs_dev_params = pscsi_set_configfs_dev_params, | 1194 | .set_configfs_dev_params = pscsi_set_configfs_dev_params, |
1269 | .show_configfs_dev_params = pscsi_show_configfs_dev_params, | 1195 | .show_configfs_dev_params = pscsi_show_configfs_dev_params, |
1270 | .get_device_rev = pscsi_get_device_rev, | 1196 | .get_device_rev = pscsi_get_device_rev, |
diff --git a/drivers/target/target_core_pscsi.h b/drivers/target/target_core_pscsi.h index bc1e5e11eca0..1bd757dff8ee 100644 --- a/drivers/target/target_core_pscsi.h +++ b/drivers/target/target_core_pscsi.h | |||
@@ -37,6 +37,7 @@ struct pscsi_plugin_task { | |||
37 | #define PDF_HAS_VIRT_HOST_ID 0x20 | 37 | #define PDF_HAS_VIRT_HOST_ID 0x20 |
38 | 38 | ||
39 | struct pscsi_dev_virt { | 39 | struct pscsi_dev_virt { |
40 | struct se_device dev; | ||
40 | int pdv_flags; | 41 | int pdv_flags; |
41 | int pdv_host_id; | 42 | int pdv_host_id; |
42 | int pdv_channel_id; | 43 | int pdv_channel_id; |
@@ -44,7 +45,6 @@ struct pscsi_dev_virt { | |||
44 | int pdv_lun_id; | 45 | int pdv_lun_id; |
45 | struct block_device *pdv_bd; | 46 | struct block_device *pdv_bd; |
46 | struct scsi_device *pdv_sd; | 47 | struct scsi_device *pdv_sd; |
47 | struct se_hba *pdv_se_hba; | ||
48 | } ____cacheline_aligned; | 48 | } ____cacheline_aligned; |
49 | 49 | ||
50 | typedef enum phv_modes { | 50 | typedef enum phv_modes { |
diff --git a/drivers/target/target_core_rd.c b/drivers/target/target_core_rd.c index d00bbe33ff8b..d083f39c4b67 100644 --- a/drivers/target/target_core_rd.c +++ b/drivers/target/target_core_rd.c | |||
@@ -41,7 +41,10 @@ | |||
41 | 41 | ||
42 | #include "target_core_rd.h" | 42 | #include "target_core_rd.h" |
43 | 43 | ||
44 | static struct se_subsystem_api rd_mcp_template; | 44 | static inline struct rd_dev *RD_DEV(struct se_device *dev) |
45 | { | ||
46 | return container_of(dev, struct rd_dev, dev); | ||
47 | } | ||
45 | 48 | ||
46 | /* rd_attach_hba(): (Part of se_subsystem_api_t template) | 49 | /* rd_attach_hba(): (Part of se_subsystem_api_t template) |
47 | * | 50 | * |
@@ -196,7 +199,7 @@ static int rd_build_device_space(struct rd_dev *rd_dev) | |||
196 | return 0; | 199 | return 0; |
197 | } | 200 | } |
198 | 201 | ||
199 | static void *rd_allocate_virtdevice(struct se_hba *hba, const char *name) | 202 | static struct se_device *rd_alloc_device(struct se_hba *hba, const char *name) |
200 | { | 203 | { |
201 | struct rd_dev *rd_dev; | 204 | struct rd_dev *rd_dev; |
202 | struct rd_host *rd_host = hba->hba_ptr; | 205 | struct rd_host *rd_host = hba->hba_ptr; |
@@ -209,39 +212,27 @@ static void *rd_allocate_virtdevice(struct se_hba *hba, const char *name) | |||
209 | 212 | ||
210 | rd_dev->rd_host = rd_host; | 213 | rd_dev->rd_host = rd_host; |
211 | 214 | ||
212 | return rd_dev; | 215 | return &rd_dev->dev; |
213 | } | 216 | } |
214 | 217 | ||
215 | static struct se_device *rd_create_virtdevice(struct se_hba *hba, | 218 | static int rd_configure_device(struct se_device *dev) |
216 | struct se_subsystem_dev *se_dev, void *p) | ||
217 | { | 219 | { |
218 | struct se_device *dev; | 220 | struct rd_dev *rd_dev = RD_DEV(dev); |
219 | struct se_dev_limits dev_limits; | 221 | struct rd_host *rd_host = dev->se_hba->hba_ptr; |
220 | struct rd_dev *rd_dev = p; | 222 | int ret; |
221 | struct rd_host *rd_host = hba->hba_ptr; | ||
222 | int dev_flags = 0, ret; | ||
223 | char prod[16], rev[4]; | ||
224 | 223 | ||
225 | memset(&dev_limits, 0, sizeof(struct se_dev_limits)); | 224 | if (!(rd_dev->rd_flags & RDF_HAS_PAGE_COUNT)) { |
225 | pr_debug("Missing rd_pages= parameter\n"); | ||
226 | return -EINVAL; | ||
227 | } | ||
226 | 228 | ||
227 | ret = rd_build_device_space(rd_dev); | 229 | ret = rd_build_device_space(rd_dev); |
228 | if (ret < 0) | 230 | if (ret < 0) |
229 | goto fail; | 231 | goto fail; |
230 | 232 | ||
231 | snprintf(prod, 16, "RAMDISK-MCP"); | 233 | dev->dev_attrib.hw_block_size = RD_BLOCKSIZE; |
232 | snprintf(rev, 4, "%s", RD_MCP_VERSION); | 234 | dev->dev_attrib.hw_max_sectors = UINT_MAX; |
233 | 235 | dev->dev_attrib.hw_queue_depth = RD_MAX_DEVICE_QUEUE_DEPTH; | |
234 | dev_limits.limits.logical_block_size = RD_BLOCKSIZE; | ||
235 | dev_limits.limits.max_hw_sectors = UINT_MAX; | ||
236 | dev_limits.limits.max_sectors = UINT_MAX; | ||
237 | dev_limits.hw_queue_depth = RD_MAX_DEVICE_QUEUE_DEPTH; | ||
238 | dev_limits.queue_depth = RD_DEVICE_QUEUE_DEPTH; | ||
239 | |||
240 | dev = transport_add_device_to_core_hba(hba, | ||
241 | &rd_mcp_template, se_dev, dev_flags, rd_dev, | ||
242 | &dev_limits, prod, rev); | ||
243 | if (!dev) | ||
244 | goto fail; | ||
245 | 236 | ||
246 | rd_dev->rd_dev_id = rd_host->rd_host_dev_id_count++; | 237 | rd_dev->rd_dev_id = rd_host->rd_host_dev_id_count++; |
247 | 238 | ||
@@ -251,16 +242,16 @@ static struct se_device *rd_create_virtdevice(struct se_hba *hba, | |||
251 | rd_dev->sg_table_count, | 242 | rd_dev->sg_table_count, |
252 | (unsigned long)(rd_dev->rd_page_count * PAGE_SIZE)); | 243 | (unsigned long)(rd_dev->rd_page_count * PAGE_SIZE)); |
253 | 244 | ||
254 | return dev; | 245 | return 0; |
255 | 246 | ||
256 | fail: | 247 | fail: |
257 | rd_release_device_space(rd_dev); | 248 | rd_release_device_space(rd_dev); |
258 | return ERR_PTR(ret); | 249 | return ret; |
259 | } | 250 | } |
260 | 251 | ||
261 | static void rd_free_device(void *p) | 252 | static void rd_free_device(struct se_device *dev) |
262 | { | 253 | { |
263 | struct rd_dev *rd_dev = p; | 254 | struct rd_dev *rd_dev = RD_DEV(dev); |
264 | 255 | ||
265 | rd_release_device_space(rd_dev); | 256 | rd_release_device_space(rd_dev); |
266 | kfree(rd_dev); | 257 | kfree(rd_dev); |
@@ -290,7 +281,7 @@ static int rd_execute_rw(struct se_cmd *cmd) | |||
290 | u32 sgl_nents = cmd->t_data_nents; | 281 | u32 sgl_nents = cmd->t_data_nents; |
291 | enum dma_data_direction data_direction = cmd->data_direction; | 282 | enum dma_data_direction data_direction = cmd->data_direction; |
292 | struct se_device *se_dev = cmd->se_dev; | 283 | struct se_device *se_dev = cmd->se_dev; |
293 | struct rd_dev *dev = se_dev->dev_ptr; | 284 | struct rd_dev *dev = RD_DEV(se_dev); |
294 | struct rd_dev_sg_table *table; | 285 | struct rd_dev_sg_table *table; |
295 | struct scatterlist *rd_sg; | 286 | struct scatterlist *rd_sg; |
296 | struct sg_mapping_iter m; | 287 | struct sg_mapping_iter m; |
@@ -300,7 +291,7 @@ static int rd_execute_rw(struct se_cmd *cmd) | |||
300 | u32 src_len; | 291 | u32 src_len; |
301 | u64 tmp; | 292 | u64 tmp; |
302 | 293 | ||
303 | tmp = cmd->t_task_lba * se_dev->se_sub_dev->se_dev_attrib.block_size; | 294 | tmp = cmd->t_task_lba * se_dev->dev_attrib.block_size; |
304 | rd_offset = do_div(tmp, PAGE_SIZE); | 295 | rd_offset = do_div(tmp, PAGE_SIZE); |
305 | rd_page = tmp; | 296 | rd_page = tmp; |
306 | rd_size = cmd->data_length; | 297 | rd_size = cmd->data_length; |
@@ -378,13 +369,10 @@ static match_table_t tokens = { | |||
378 | {Opt_err, NULL} | 369 | {Opt_err, NULL} |
379 | }; | 370 | }; |
380 | 371 | ||
381 | static ssize_t rd_set_configfs_dev_params( | 372 | static ssize_t rd_set_configfs_dev_params(struct se_device *dev, |
382 | struct se_hba *hba, | 373 | const char *page, ssize_t count) |
383 | struct se_subsystem_dev *se_dev, | ||
384 | const char *page, | ||
385 | ssize_t count) | ||
386 | { | 374 | { |
387 | struct rd_dev *rd_dev = se_dev->se_dev_su_ptr; | 375 | struct rd_dev *rd_dev = RD_DEV(dev); |
388 | char *orig, *ptr, *opts; | 376 | char *orig, *ptr, *opts; |
389 | substring_t args[MAX_OPT_ARGS]; | 377 | substring_t args[MAX_OPT_ARGS]; |
390 | int ret = 0, arg, token; | 378 | int ret = 0, arg, token; |
@@ -417,24 +405,10 @@ static ssize_t rd_set_configfs_dev_params( | |||
417 | return (!ret) ? count : ret; | 405 | return (!ret) ? count : ret; |
418 | } | 406 | } |
419 | 407 | ||
420 | static ssize_t rd_check_configfs_dev_params(struct se_hba *hba, struct se_subsystem_dev *se_dev) | 408 | static ssize_t rd_show_configfs_dev_params(struct se_device *dev, char *b) |
421 | { | 409 | { |
422 | struct rd_dev *rd_dev = se_dev->se_dev_su_ptr; | 410 | struct rd_dev *rd_dev = RD_DEV(dev); |
423 | |||
424 | if (!(rd_dev->rd_flags & RDF_HAS_PAGE_COUNT)) { | ||
425 | pr_debug("Missing rd_pages= parameter\n"); | ||
426 | return -EINVAL; | ||
427 | } | ||
428 | 411 | ||
429 | return 0; | ||
430 | } | ||
431 | |||
432 | static ssize_t rd_show_configfs_dev_params( | ||
433 | struct se_hba *hba, | ||
434 | struct se_subsystem_dev *se_dev, | ||
435 | char *b) | ||
436 | { | ||
437 | struct rd_dev *rd_dev = se_dev->se_dev_su_ptr; | ||
438 | ssize_t bl = sprintf(b, "TCM RamDisk ID: %u RamDisk Makeup: rd_mcp\n", | 412 | ssize_t bl = sprintf(b, "TCM RamDisk ID: %u RamDisk Makeup: rd_mcp\n", |
439 | rd_dev->rd_dev_id); | 413 | rd_dev->rd_dev_id); |
440 | bl += sprintf(b + bl, " PAGES/PAGE_SIZE: %u*%lu" | 414 | bl += sprintf(b + bl, " PAGES/PAGE_SIZE: %u*%lu" |
@@ -455,9 +429,10 @@ static u32 rd_get_device_type(struct se_device *dev) | |||
455 | 429 | ||
456 | static sector_t rd_get_blocks(struct se_device *dev) | 430 | static sector_t rd_get_blocks(struct se_device *dev) |
457 | { | 431 | { |
458 | struct rd_dev *rd_dev = dev->dev_ptr; | 432 | struct rd_dev *rd_dev = RD_DEV(dev); |
433 | |||
459 | unsigned long long blocks_long = ((rd_dev->rd_page_count * PAGE_SIZE) / | 434 | unsigned long long blocks_long = ((rd_dev->rd_page_count * PAGE_SIZE) / |
460 | dev->se_sub_dev->se_dev_attrib.block_size) - 1; | 435 | dev->dev_attrib.block_size) - 1; |
461 | 436 | ||
462 | return blocks_long; | 437 | return blocks_long; |
463 | } | 438 | } |
@@ -473,14 +448,15 @@ static int rd_parse_cdb(struct se_cmd *cmd) | |||
473 | 448 | ||
474 | static struct se_subsystem_api rd_mcp_template = { | 449 | static struct se_subsystem_api rd_mcp_template = { |
475 | .name = "rd_mcp", | 450 | .name = "rd_mcp", |
451 | .inquiry_prod = "RAMDISK-MCP", | ||
452 | .inquiry_rev = RD_MCP_VERSION, | ||
476 | .transport_type = TRANSPORT_PLUGIN_VHBA_VDEV, | 453 | .transport_type = TRANSPORT_PLUGIN_VHBA_VDEV, |
477 | .attach_hba = rd_attach_hba, | 454 | .attach_hba = rd_attach_hba, |
478 | .detach_hba = rd_detach_hba, | 455 | .detach_hba = rd_detach_hba, |
479 | .allocate_virtdevice = rd_allocate_virtdevice, | 456 | .alloc_device = rd_alloc_device, |
480 | .create_virtdevice = rd_create_virtdevice, | 457 | .configure_device = rd_configure_device, |
481 | .free_device = rd_free_device, | 458 | .free_device = rd_free_device, |
482 | .parse_cdb = rd_parse_cdb, | 459 | .parse_cdb = rd_parse_cdb, |
483 | .check_configfs_dev_params = rd_check_configfs_dev_params, | ||
484 | .set_configfs_dev_params = rd_set_configfs_dev_params, | 460 | .set_configfs_dev_params = rd_set_configfs_dev_params, |
485 | .show_configfs_dev_params = rd_show_configfs_dev_params, | 461 | .show_configfs_dev_params = rd_show_configfs_dev_params, |
486 | .get_device_rev = rd_get_device_rev, | 462 | .get_device_rev = rd_get_device_rev, |
diff --git a/drivers/target/target_core_rd.h b/drivers/target/target_core_rd.h index 21458125fe51..933b38b6e563 100644 --- a/drivers/target/target_core_rd.h +++ b/drivers/target/target_core_rd.h | |||
@@ -24,6 +24,7 @@ struct rd_dev_sg_table { | |||
24 | #define RDF_HAS_PAGE_COUNT 0x01 | 24 | #define RDF_HAS_PAGE_COUNT 0x01 |
25 | 25 | ||
26 | struct rd_dev { | 26 | struct rd_dev { |
27 | struct se_device dev; | ||
27 | u32 rd_flags; | 28 | u32 rd_flags; |
28 | /* Unique Ramdisk Device ID in Ramdisk HBA */ | 29 | /* Unique Ramdisk Device ID in Ramdisk HBA */ |
29 | u32 rd_dev_id; | 30 | u32 rd_dev_id; |
diff --git a/drivers/target/target_core_sbc.c b/drivers/target/target_core_sbc.c index a6e27d967c7b..035193d04fa2 100644 --- a/drivers/target/target_core_sbc.c +++ b/drivers/target/target_core_sbc.c | |||
@@ -54,10 +54,10 @@ static int sbc_emulate_readcapacity(struct se_cmd *cmd) | |||
54 | buf[1] = (blocks >> 16) & 0xff; | 54 | buf[1] = (blocks >> 16) & 0xff; |
55 | buf[2] = (blocks >> 8) & 0xff; | 55 | buf[2] = (blocks >> 8) & 0xff; |
56 | buf[3] = blocks & 0xff; | 56 | buf[3] = blocks & 0xff; |
57 | buf[4] = (dev->se_sub_dev->se_dev_attrib.block_size >> 24) & 0xff; | 57 | buf[4] = (dev->dev_attrib.block_size >> 24) & 0xff; |
58 | buf[5] = (dev->se_sub_dev->se_dev_attrib.block_size >> 16) & 0xff; | 58 | buf[5] = (dev->dev_attrib.block_size >> 16) & 0xff; |
59 | buf[6] = (dev->se_sub_dev->se_dev_attrib.block_size >> 8) & 0xff; | 59 | buf[6] = (dev->dev_attrib.block_size >> 8) & 0xff; |
60 | buf[7] = dev->se_sub_dev->se_dev_attrib.block_size & 0xff; | 60 | buf[7] = dev->dev_attrib.block_size & 0xff; |
61 | 61 | ||
62 | rbuf = transport_kmap_data_sg(cmd); | 62 | rbuf = transport_kmap_data_sg(cmd); |
63 | if (rbuf) { | 63 | if (rbuf) { |
@@ -85,15 +85,15 @@ static int sbc_emulate_readcapacity_16(struct se_cmd *cmd) | |||
85 | buf[5] = (blocks >> 16) & 0xff; | 85 | buf[5] = (blocks >> 16) & 0xff; |
86 | buf[6] = (blocks >> 8) & 0xff; | 86 | buf[6] = (blocks >> 8) & 0xff; |
87 | buf[7] = blocks & 0xff; | 87 | buf[7] = blocks & 0xff; |
88 | buf[8] = (dev->se_sub_dev->se_dev_attrib.block_size >> 24) & 0xff; | 88 | buf[8] = (dev->dev_attrib.block_size >> 24) & 0xff; |
89 | buf[9] = (dev->se_sub_dev->se_dev_attrib.block_size >> 16) & 0xff; | 89 | buf[9] = (dev->dev_attrib.block_size >> 16) & 0xff; |
90 | buf[10] = (dev->se_sub_dev->se_dev_attrib.block_size >> 8) & 0xff; | 90 | buf[10] = (dev->dev_attrib.block_size >> 8) & 0xff; |
91 | buf[11] = dev->se_sub_dev->se_dev_attrib.block_size & 0xff; | 91 | buf[11] = dev->dev_attrib.block_size & 0xff; |
92 | /* | 92 | /* |
93 | * Set Thin Provisioning Enable bit following sbc3r22 in section | 93 | * Set Thin Provisioning Enable bit following sbc3r22 in section |
94 | * READ CAPACITY (16) byte 14 if emulate_tpu or emulate_tpws is enabled. | 94 | * READ CAPACITY (16) byte 14 if emulate_tpu or emulate_tpws is enabled. |
95 | */ | 95 | */ |
96 | if (dev->se_sub_dev->se_dev_attrib.emulate_tpu || dev->se_sub_dev->se_dev_attrib.emulate_tpws) | 96 | if (dev->dev_attrib.emulate_tpu || dev->dev_attrib.emulate_tpws) |
97 | buf[14] = 0x80; | 97 | buf[14] = 0x80; |
98 | 98 | ||
99 | rbuf = transport_kmap_data_sg(cmd); | 99 | rbuf = transport_kmap_data_sg(cmd); |
@@ -143,7 +143,7 @@ static int sbc_emulate_noop(struct se_cmd *cmd) | |||
143 | 143 | ||
144 | static inline u32 sbc_get_size(struct se_cmd *cmd, u32 sectors) | 144 | static inline u32 sbc_get_size(struct se_cmd *cmd, u32 sectors) |
145 | { | 145 | { |
146 | return cmd->se_dev->se_sub_dev->se_dev_attrib.block_size * sectors; | 146 | return cmd->se_dev->dev_attrib.block_size * sectors; |
147 | } | 147 | } |
148 | 148 | ||
149 | static int sbc_check_valid_sectors(struct se_cmd *cmd) | 149 | static int sbc_check_valid_sectors(struct se_cmd *cmd) |
@@ -152,7 +152,7 @@ static int sbc_check_valid_sectors(struct se_cmd *cmd) | |||
152 | unsigned long long end_lba; | 152 | unsigned long long end_lba; |
153 | u32 sectors; | 153 | u32 sectors; |
154 | 154 | ||
155 | sectors = cmd->data_length / dev->se_sub_dev->se_dev_attrib.block_size; | 155 | sectors = cmd->data_length / dev->dev_attrib.block_size; |
156 | end_lba = dev->transport->get_blocks(dev) + 1; | 156 | end_lba = dev->transport->get_blocks(dev) + 1; |
157 | 157 | ||
158 | if (cmd->t_task_lba + sectors > end_lba) { | 158 | if (cmd->t_task_lba + sectors > end_lba) { |
@@ -315,7 +315,6 @@ out: | |||
315 | 315 | ||
316 | int sbc_parse_cdb(struct se_cmd *cmd, struct spc_ops *ops) | 316 | int sbc_parse_cdb(struct se_cmd *cmd, struct spc_ops *ops) |
317 | { | 317 | { |
318 | struct se_subsystem_dev *su_dev = cmd->se_dev->se_sub_dev; | ||
319 | struct se_device *dev = cmd->se_dev; | 318 | struct se_device *dev = cmd->se_dev; |
320 | unsigned char *cdb = cmd->t_task_cdb; | 319 | unsigned char *cdb = cmd->t_task_cdb; |
321 | unsigned int size; | 320 | unsigned int size; |
@@ -562,18 +561,18 @@ int sbc_parse_cdb(struct se_cmd *cmd, struct spc_ops *ops) | |||
562 | if (cmd->se_cmd_flags & SCF_SCSI_DATA_CDB) { | 561 | if (cmd->se_cmd_flags & SCF_SCSI_DATA_CDB) { |
563 | unsigned long long end_lba; | 562 | unsigned long long end_lba; |
564 | 563 | ||
565 | if (sectors > su_dev->se_dev_attrib.fabric_max_sectors) { | 564 | if (sectors > dev->dev_attrib.fabric_max_sectors) { |
566 | printk_ratelimited(KERN_ERR "SCSI OP %02xh with too" | 565 | printk_ratelimited(KERN_ERR "SCSI OP %02xh with too" |
567 | " big sectors %u exceeds fabric_max_sectors:" | 566 | " big sectors %u exceeds fabric_max_sectors:" |
568 | " %u\n", cdb[0], sectors, | 567 | " %u\n", cdb[0], sectors, |
569 | su_dev->se_dev_attrib.fabric_max_sectors); | 568 | dev->dev_attrib.fabric_max_sectors); |
570 | goto out_invalid_cdb_field; | 569 | goto out_invalid_cdb_field; |
571 | } | 570 | } |
572 | if (sectors > su_dev->se_dev_attrib.hw_max_sectors) { | 571 | if (sectors > dev->dev_attrib.hw_max_sectors) { |
573 | printk_ratelimited(KERN_ERR "SCSI OP %02xh with too" | 572 | printk_ratelimited(KERN_ERR "SCSI OP %02xh with too" |
574 | " big sectors %u exceeds backend hw_max_sectors:" | 573 | " big sectors %u exceeds backend hw_max_sectors:" |
575 | " %u\n", cdb[0], sectors, | 574 | " %u\n", cdb[0], sectors, |
576 | su_dev->se_dev_attrib.hw_max_sectors); | 575 | dev->dev_attrib.hw_max_sectors); |
577 | goto out_invalid_cdb_field; | 576 | goto out_invalid_cdb_field; |
578 | } | 577 | } |
579 | 578 | ||
diff --git a/drivers/target/target_core_spc.c b/drivers/target/target_core_spc.c index 6fd434d3d7e4..0af45ae32f8c 100644 --- a/drivers/target/target_core_spc.c +++ b/drivers/target/target_core_spc.c | |||
@@ -95,14 +95,14 @@ static int spc_emulate_inquiry_std(struct se_cmd *cmd, char *buf) | |||
95 | /* | 95 | /* |
96 | * Enable SCCS and TPGS fields for Emulated ALUA | 96 | * Enable SCCS and TPGS fields for Emulated ALUA |
97 | */ | 97 | */ |
98 | if (dev->se_sub_dev->t10_alua.alua_type == SPC3_ALUA_EMULATED) | 98 | if (dev->t10_alua.alua_type == SPC3_ALUA_EMULATED) |
99 | spc_fill_alua_data(lun->lun_sep, buf); | 99 | spc_fill_alua_data(lun->lun_sep, buf); |
100 | 100 | ||
101 | buf[7] = 0x2; /* CmdQue=1 */ | 101 | buf[7] = 0x2; /* CmdQue=1 */ |
102 | 102 | ||
103 | snprintf(&buf[8], 8, "LIO-ORG"); | 103 | snprintf(&buf[8], 8, "LIO-ORG"); |
104 | snprintf(&buf[16], 16, "%s", dev->se_sub_dev->t10_wwn.model); | 104 | snprintf(&buf[16], 16, "%s", dev->t10_wwn.model); |
105 | snprintf(&buf[32], 4, "%s", dev->se_sub_dev->t10_wwn.revision); | 105 | snprintf(&buf[32], 4, "%s", dev->t10_wwn.revision); |
106 | buf[4] = 31; /* Set additional length to 31 */ | 106 | buf[4] = 31; /* Set additional length to 31 */ |
107 | 107 | ||
108 | return 0; | 108 | return 0; |
@@ -114,15 +114,13 @@ static int spc_emulate_evpd_80(struct se_cmd *cmd, unsigned char *buf) | |||
114 | struct se_device *dev = cmd->se_dev; | 114 | struct se_device *dev = cmd->se_dev; |
115 | u16 len = 0; | 115 | u16 len = 0; |
116 | 116 | ||
117 | if (dev->se_sub_dev->su_dev_flags & | 117 | if (dev->dev_flags & DF_EMULATED_VPD_UNIT_SERIAL) { |
118 | SDF_EMULATED_VPD_UNIT_SERIAL) { | ||
119 | u32 unit_serial_len; | 118 | u32 unit_serial_len; |
120 | 119 | ||
121 | unit_serial_len = strlen(dev->se_sub_dev->t10_wwn.unit_serial); | 120 | unit_serial_len = strlen(dev->t10_wwn.unit_serial); |
122 | unit_serial_len++; /* For NULL Terminator */ | 121 | unit_serial_len++; /* For NULL Terminator */ |
123 | 122 | ||
124 | len += sprintf(&buf[4], "%s", | 123 | len += sprintf(&buf[4], "%s", dev->t10_wwn.unit_serial); |
125 | dev->se_sub_dev->t10_wwn.unit_serial); | ||
126 | len++; /* Extra Byte for NULL Terminator */ | 124 | len++; /* Extra Byte for NULL Terminator */ |
127 | buf[3] = len; | 125 | buf[3] = len; |
128 | } | 126 | } |
@@ -132,7 +130,7 @@ static int spc_emulate_evpd_80(struct se_cmd *cmd, unsigned char *buf) | |||
132 | static void spc_parse_naa_6h_vendor_specific(struct se_device *dev, | 130 | static void spc_parse_naa_6h_vendor_specific(struct se_device *dev, |
133 | unsigned char *buf) | 131 | unsigned char *buf) |
134 | { | 132 | { |
135 | unsigned char *p = &dev->se_sub_dev->t10_wwn.unit_serial[0]; | 133 | unsigned char *p = &dev->t10_wwn.unit_serial[0]; |
136 | int cnt; | 134 | int cnt; |
137 | bool next = true; | 135 | bool next = true; |
138 | 136 | ||
@@ -173,7 +171,7 @@ static int spc_emulate_evpd_83(struct se_cmd *cmd, unsigned char *buf) | |||
173 | struct t10_alua_lu_gp_member *lu_gp_mem; | 171 | struct t10_alua_lu_gp_member *lu_gp_mem; |
174 | struct t10_alua_tg_pt_gp *tg_pt_gp; | 172 | struct t10_alua_tg_pt_gp *tg_pt_gp; |
175 | struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem; | 173 | struct t10_alua_tg_pt_gp_member *tg_pt_gp_mem; |
176 | unsigned char *prod = &dev->se_sub_dev->t10_wwn.model[0]; | 174 | unsigned char *prod = &dev->t10_wwn.model[0]; |
177 | u32 prod_len; | 175 | u32 prod_len; |
178 | u32 unit_serial_len, off = 0; | 176 | u32 unit_serial_len, off = 0; |
179 | u16 len = 0, id_len; | 177 | u16 len = 0, id_len; |
@@ -188,7 +186,7 @@ static int spc_emulate_evpd_83(struct se_cmd *cmd, unsigned char *buf) | |||
188 | * /sys/kernel/config/target/core/$HBA/$DEV/wwn/vpd_unit_serial | 186 | * /sys/kernel/config/target/core/$HBA/$DEV/wwn/vpd_unit_serial |
189 | * value in order to return the NAA id. | 187 | * value in order to return the NAA id. |
190 | */ | 188 | */ |
191 | if (!(dev->se_sub_dev->su_dev_flags & SDF_EMULATED_VPD_UNIT_SERIAL)) | 189 | if (!(dev->dev_flags & DF_EMULATED_VPD_UNIT_SERIAL)) |
192 | goto check_t10_vend_desc; | 190 | goto check_t10_vend_desc; |
193 | 191 | ||
194 | /* CODE SET == Binary */ | 192 | /* CODE SET == Binary */ |
@@ -236,14 +234,12 @@ check_t10_vend_desc: | |||
236 | prod_len += strlen(prod); | 234 | prod_len += strlen(prod); |
237 | prod_len++; /* For : */ | 235 | prod_len++; /* For : */ |
238 | 236 | ||
239 | if (dev->se_sub_dev->su_dev_flags & | 237 | if (dev->dev_flags & DF_EMULATED_VPD_UNIT_SERIAL) { |
240 | SDF_EMULATED_VPD_UNIT_SERIAL) { | 238 | unit_serial_len = strlen(&dev->t10_wwn.unit_serial[0]); |
241 | unit_serial_len = | ||
242 | strlen(&dev->se_sub_dev->t10_wwn.unit_serial[0]); | ||
243 | unit_serial_len++; /* For NULL Terminator */ | 239 | unit_serial_len++; /* For NULL Terminator */ |
244 | 240 | ||
245 | id_len += sprintf(&buf[off+12], "%s:%s", prod, | 241 | id_len += sprintf(&buf[off+12], "%s:%s", prod, |
246 | &dev->se_sub_dev->t10_wwn.unit_serial[0]); | 242 | &dev->t10_wwn.unit_serial[0]); |
247 | } | 243 | } |
248 | buf[off] = 0x2; /* ASCII */ | 244 | buf[off] = 0x2; /* ASCII */ |
249 | buf[off+1] = 0x1; /* T10 Vendor ID */ | 245 | buf[off+1] = 0x1; /* T10 Vendor ID */ |
@@ -298,8 +294,7 @@ check_t10_vend_desc: | |||
298 | * Get the PROTOCOL IDENTIFIER as defined by spc4r17 | 294 | * Get the PROTOCOL IDENTIFIER as defined by spc4r17 |
299 | * section 7.5.1 Table 362 | 295 | * section 7.5.1 Table 362 |
300 | */ | 296 | */ |
301 | if (dev->se_sub_dev->t10_alua.alua_type != | 297 | if (dev->t10_alua.alua_type != SPC3_ALUA_EMULATED) |
302 | SPC3_ALUA_EMULATED) | ||
303 | goto check_scsi_name; | 298 | goto check_scsi_name; |
304 | 299 | ||
305 | tg_pt_gp_mem = port->sep_alua_tg_pt_gp_mem; | 300 | tg_pt_gp_mem = port->sep_alua_tg_pt_gp_mem; |
@@ -422,7 +417,7 @@ static int spc_emulate_evpd_86(struct se_cmd *cmd, unsigned char *buf) | |||
422 | buf[5] = 0x07; | 417 | buf[5] = 0x07; |
423 | 418 | ||
424 | /* If WriteCache emulation is enabled, set V_SUP */ | 419 | /* If WriteCache emulation is enabled, set V_SUP */ |
425 | if (cmd->se_dev->se_sub_dev->se_dev_attrib.emulate_write_cache > 0) | 420 | if (cmd->se_dev->dev_attrib.emulate_write_cache > 0) |
426 | buf[6] = 0x01; | 421 | buf[6] = 0x01; |
427 | return 0; | 422 | return 0; |
428 | } | 423 | } |
@@ -439,7 +434,7 @@ static int spc_emulate_evpd_b0(struct se_cmd *cmd, unsigned char *buf) | |||
439 | * emulate_tpu=1 or emulate_tpws=1 we will be expect a | 434 | * emulate_tpu=1 or emulate_tpws=1 we will be expect a |
440 | * different page length for Thin Provisioning. | 435 | * different page length for Thin Provisioning. |
441 | */ | 436 | */ |
442 | if (dev->se_sub_dev->se_dev_attrib.emulate_tpu || dev->se_sub_dev->se_dev_attrib.emulate_tpws) | 437 | if (dev->dev_attrib.emulate_tpu || dev->dev_attrib.emulate_tpws) |
443 | have_tp = 1; | 438 | have_tp = 1; |
444 | 439 | ||
445 | buf[0] = dev->transport->get_device_type(dev); | 440 | buf[0] = dev->transport->get_device_type(dev); |
@@ -456,14 +451,14 @@ static int spc_emulate_evpd_b0(struct se_cmd *cmd, unsigned char *buf) | |||
456 | /* | 451 | /* |
457 | * Set MAXIMUM TRANSFER LENGTH | 452 | * Set MAXIMUM TRANSFER LENGTH |
458 | */ | 453 | */ |
459 | max_sectors = min(dev->se_sub_dev->se_dev_attrib.fabric_max_sectors, | 454 | max_sectors = min(dev->dev_attrib.fabric_max_sectors, |
460 | dev->se_sub_dev->se_dev_attrib.hw_max_sectors); | 455 | dev->dev_attrib.hw_max_sectors); |
461 | put_unaligned_be32(max_sectors, &buf[8]); | 456 | put_unaligned_be32(max_sectors, &buf[8]); |
462 | 457 | ||
463 | /* | 458 | /* |
464 | * Set OPTIMAL TRANSFER LENGTH | 459 | * Set OPTIMAL TRANSFER LENGTH |
465 | */ | 460 | */ |
466 | put_unaligned_be32(dev->se_sub_dev->se_dev_attrib.optimal_sectors, &buf[12]); | 461 | put_unaligned_be32(dev->dev_attrib.optimal_sectors, &buf[12]); |
467 | 462 | ||
468 | /* | 463 | /* |
469 | * Exit now if we don't support TP. | 464 | * Exit now if we don't support TP. |
@@ -474,25 +469,25 @@ static int spc_emulate_evpd_b0(struct se_cmd *cmd, unsigned char *buf) | |||
474 | /* | 469 | /* |
475 | * Set MAXIMUM UNMAP LBA COUNT | 470 | * Set MAXIMUM UNMAP LBA COUNT |
476 | */ | 471 | */ |
477 | put_unaligned_be32(dev->se_sub_dev->se_dev_attrib.max_unmap_lba_count, &buf[20]); | 472 | put_unaligned_be32(dev->dev_attrib.max_unmap_lba_count, &buf[20]); |
478 | 473 | ||
479 | /* | 474 | /* |
480 | * Set MAXIMUM UNMAP BLOCK DESCRIPTOR COUNT | 475 | * Set MAXIMUM UNMAP BLOCK DESCRIPTOR COUNT |
481 | */ | 476 | */ |
482 | put_unaligned_be32(dev->se_sub_dev->se_dev_attrib.max_unmap_block_desc_count, | 477 | put_unaligned_be32(dev->dev_attrib.max_unmap_block_desc_count, |
483 | &buf[24]); | 478 | &buf[24]); |
484 | 479 | ||
485 | /* | 480 | /* |
486 | * Set OPTIMAL UNMAP GRANULARITY | 481 | * Set OPTIMAL UNMAP GRANULARITY |
487 | */ | 482 | */ |
488 | put_unaligned_be32(dev->se_sub_dev->se_dev_attrib.unmap_granularity, &buf[28]); | 483 | put_unaligned_be32(dev->dev_attrib.unmap_granularity, &buf[28]); |
489 | 484 | ||
490 | /* | 485 | /* |
491 | * UNMAP GRANULARITY ALIGNMENT | 486 | * UNMAP GRANULARITY ALIGNMENT |
492 | */ | 487 | */ |
493 | put_unaligned_be32(dev->se_sub_dev->se_dev_attrib.unmap_granularity_alignment, | 488 | put_unaligned_be32(dev->dev_attrib.unmap_granularity_alignment, |
494 | &buf[32]); | 489 | &buf[32]); |
495 | if (dev->se_sub_dev->se_dev_attrib.unmap_granularity_alignment != 0) | 490 | if (dev->dev_attrib.unmap_granularity_alignment != 0) |
496 | buf[32] |= 0x80; /* Set the UGAVALID bit */ | 491 | buf[32] |= 0x80; /* Set the UGAVALID bit */ |
497 | 492 | ||
498 | return 0; | 493 | return 0; |
@@ -505,7 +500,7 @@ static int spc_emulate_evpd_b1(struct se_cmd *cmd, unsigned char *buf) | |||
505 | 500 | ||
506 | buf[0] = dev->transport->get_device_type(dev); | 501 | buf[0] = dev->transport->get_device_type(dev); |
507 | buf[3] = 0x3c; | 502 | buf[3] = 0x3c; |
508 | buf[5] = dev->se_sub_dev->se_dev_attrib.is_nonrot ? 1 : 0; | 503 | buf[5] = dev->dev_attrib.is_nonrot ? 1 : 0; |
509 | 504 | ||
510 | return 0; | 505 | return 0; |
511 | } | 506 | } |
@@ -546,7 +541,7 @@ static int spc_emulate_evpd_b2(struct se_cmd *cmd, unsigned char *buf) | |||
546 | * the UNMAP command (see 5.25). A TPU bit set to zero indicates | 541 | * the UNMAP command (see 5.25). A TPU bit set to zero indicates |
547 | * that the device server does not support the UNMAP command. | 542 | * that the device server does not support the UNMAP command. |
548 | */ | 543 | */ |
549 | if (dev->se_sub_dev->se_dev_attrib.emulate_tpu != 0) | 544 | if (dev->dev_attrib.emulate_tpu != 0) |
550 | buf[5] = 0x80; | 545 | buf[5] = 0x80; |
551 | 546 | ||
552 | /* | 547 | /* |
@@ -555,7 +550,7 @@ static int spc_emulate_evpd_b2(struct se_cmd *cmd, unsigned char *buf) | |||
555 | * A TPWS bit set to zero indicates that the device server does not | 550 | * A TPWS bit set to zero indicates that the device server does not |
556 | * support the use of the WRITE SAME (16) command to unmap LBAs. | 551 | * support the use of the WRITE SAME (16) command to unmap LBAs. |
557 | */ | 552 | */ |
558 | if (dev->se_sub_dev->se_dev_attrib.emulate_tpws != 0) | 553 | if (dev->dev_attrib.emulate_tpws != 0) |
559 | buf[5] |= 0x40; | 554 | buf[5] |= 0x40; |
560 | 555 | ||
561 | return 0; | 556 | return 0; |
@@ -586,8 +581,7 @@ static int spc_emulate_evpd_00(struct se_cmd *cmd, unsigned char *buf) | |||
586 | * Registered Extended LUN WWN has been set via ConfigFS | 581 | * Registered Extended LUN WWN has been set via ConfigFS |
587 | * during device creation/restart. | 582 | * during device creation/restart. |
588 | */ | 583 | */ |
589 | if (cmd->se_dev->se_sub_dev->su_dev_flags & | 584 | if (cmd->se_dev->dev_flags & DF_EMULATED_VPD_UNIT_SERIAL) { |
590 | SDF_EMULATED_VPD_UNIT_SERIAL) { | ||
591 | buf[3] = ARRAY_SIZE(evpd_handlers); | 585 | buf[3] = ARRAY_SIZE(evpd_handlers); |
592 | for (p = 0; p < ARRAY_SIZE(evpd_handlers); ++p) | 586 | for (p = 0; p < ARRAY_SIZE(evpd_handlers); ++p) |
593 | buf[p + 4] = evpd_handlers[p].page; | 587 | buf[p + 4] = evpd_handlers[p].page; |
@@ -690,7 +684,7 @@ static int spc_modesense_control(struct se_device *dev, unsigned char *p) | |||
690 | * command sequence order shall be explicitly handled by the application client | 684 | * command sequence order shall be explicitly handled by the application client |
691 | * through the selection of appropriate ommands and task attributes. | 685 | * through the selection of appropriate ommands and task attributes. |
692 | */ | 686 | */ |
693 | p[3] = (dev->se_sub_dev->se_dev_attrib.emulate_rest_reord == 1) ? 0x00 : 0x10; | 687 | p[3] = (dev->dev_attrib.emulate_rest_reord == 1) ? 0x00 : 0x10; |
694 | /* | 688 | /* |
695 | * From spc4r17, section 7.4.6 Control mode Page | 689 | * From spc4r17, section 7.4.6 Control mode Page |
696 | * | 690 | * |
@@ -720,8 +714,8 @@ static int spc_modesense_control(struct se_device *dev, unsigned char *p) | |||
720 | * for a BUSY, TASK SET FULL, or RESERVATION CONFLICT status regardless | 714 | * for a BUSY, TASK SET FULL, or RESERVATION CONFLICT status regardless |
721 | * to the number of commands completed with one of those status codes. | 715 | * to the number of commands completed with one of those status codes. |
722 | */ | 716 | */ |
723 | p[4] = (dev->se_sub_dev->se_dev_attrib.emulate_ua_intlck_ctrl == 2) ? 0x30 : | 717 | p[4] = (dev->dev_attrib.emulate_ua_intlck_ctrl == 2) ? 0x30 : |
724 | (dev->se_sub_dev->se_dev_attrib.emulate_ua_intlck_ctrl == 1) ? 0x20 : 0x00; | 718 | (dev->dev_attrib.emulate_ua_intlck_ctrl == 1) ? 0x20 : 0x00; |
725 | /* | 719 | /* |
726 | * From spc4r17, section 7.4.6 Control mode Page | 720 | * From spc4r17, section 7.4.6 Control mode Page |
727 | * | 721 | * |
@@ -734,7 +728,7 @@ static int spc_modesense_control(struct se_device *dev, unsigned char *p) | |||
734 | * which the command was received shall be completed with TASK ABORTED | 728 | * which the command was received shall be completed with TASK ABORTED |
735 | * status (see SAM-4). | 729 | * status (see SAM-4). |
736 | */ | 730 | */ |
737 | p[5] = (dev->se_sub_dev->se_dev_attrib.emulate_tas) ? 0x40 : 0x00; | 731 | p[5] = (dev->dev_attrib.emulate_tas) ? 0x40 : 0x00; |
738 | p[8] = 0xff; | 732 | p[8] = 0xff; |
739 | p[9] = 0xff; | 733 | p[9] = 0xff; |
740 | p[11] = 30; | 734 | p[11] = 30; |
@@ -746,7 +740,7 @@ static int spc_modesense_caching(struct se_device *dev, unsigned char *p) | |||
746 | { | 740 | { |
747 | p[0] = 0x08; | 741 | p[0] = 0x08; |
748 | p[1] = 0x12; | 742 | p[1] = 0x12; |
749 | if (dev->se_sub_dev->se_dev_attrib.emulate_write_cache > 0) | 743 | if (dev->dev_attrib.emulate_write_cache > 0) |
750 | p[2] = 0x04; /* Write Cache Enable */ | 744 | p[2] = 0x04; /* Write Cache Enable */ |
751 | p[12] = 0x20; /* Disabled Read Ahead */ | 745 | p[12] = 0x20; /* Disabled Read Ahead */ |
752 | 746 | ||
@@ -826,8 +820,8 @@ static int spc_emulate_modesense(struct se_cmd *cmd) | |||
826 | (cmd->se_deve->lun_flags & TRANSPORT_LUNFLAGS_READ_ONLY))) | 820 | (cmd->se_deve->lun_flags & TRANSPORT_LUNFLAGS_READ_ONLY))) |
827 | spc_modesense_write_protect(&buf[3], type); | 821 | spc_modesense_write_protect(&buf[3], type); |
828 | 822 | ||
829 | if ((dev->se_sub_dev->se_dev_attrib.emulate_write_cache > 0) && | 823 | if ((dev->dev_attrib.emulate_write_cache > 0) && |
830 | (dev->se_sub_dev->se_dev_attrib.emulate_fua_write > 0)) | 824 | (dev->dev_attrib.emulate_fua_write > 0)) |
831 | spc_modesense_dpofua(&buf[3], type); | 825 | spc_modesense_dpofua(&buf[3], type); |
832 | } else { | 826 | } else { |
833 | offset -= 1; | 827 | offset -= 1; |
@@ -839,8 +833,8 @@ static int spc_emulate_modesense(struct se_cmd *cmd) | |||
839 | (cmd->se_deve->lun_flags & TRANSPORT_LUNFLAGS_READ_ONLY))) | 833 | (cmd->se_deve->lun_flags & TRANSPORT_LUNFLAGS_READ_ONLY))) |
840 | spc_modesense_write_protect(&buf[2], type); | 834 | spc_modesense_write_protect(&buf[2], type); |
841 | 835 | ||
842 | if ((dev->se_sub_dev->se_dev_attrib.emulate_write_cache > 0) && | 836 | if ((dev->dev_attrib.emulate_write_cache > 0) && |
843 | (dev->se_sub_dev->se_dev_attrib.emulate_fua_write > 0)) | 837 | (dev->dev_attrib.emulate_fua_write > 0)) |
844 | spc_modesense_dpofua(&buf[2], type); | 838 | spc_modesense_dpofua(&buf[2], type); |
845 | } | 839 | } |
846 | 840 | ||
@@ -923,7 +917,6 @@ static int spc_emulate_testunitready(struct se_cmd *cmd) | |||
923 | int spc_parse_cdb(struct se_cmd *cmd, unsigned int *size) | 917 | int spc_parse_cdb(struct se_cmd *cmd, unsigned int *size) |
924 | { | 918 | { |
925 | struct se_device *dev = cmd->se_dev; | 919 | struct se_device *dev = cmd->se_dev; |
926 | struct se_subsystem_dev *su_dev = dev->se_sub_dev; | ||
927 | unsigned char *cdb = cmd->t_task_cdb; | 920 | unsigned char *cdb = cmd->t_task_cdb; |
928 | 921 | ||
929 | switch (cdb[0]) { | 922 | switch (cdb[0]) { |
@@ -946,12 +939,12 @@ int spc_parse_cdb(struct se_cmd *cmd, unsigned int *size) | |||
946 | *size = (cdb[7] << 8) + cdb[8]; | 939 | *size = (cdb[7] << 8) + cdb[8]; |
947 | break; | 940 | break; |
948 | case PERSISTENT_RESERVE_IN: | 941 | case PERSISTENT_RESERVE_IN: |
949 | if (su_dev->t10_pr.res_type == SPC3_PERSISTENT_RESERVATIONS) | 942 | if (dev->t10_pr.res_type == SPC3_PERSISTENT_RESERVATIONS) |
950 | cmd->execute_cmd = target_scsi3_emulate_pr_in; | 943 | cmd->execute_cmd = target_scsi3_emulate_pr_in; |
951 | *size = (cdb[7] << 8) + cdb[8]; | 944 | *size = (cdb[7] << 8) + cdb[8]; |
952 | break; | 945 | break; |
953 | case PERSISTENT_RESERVE_OUT: | 946 | case PERSISTENT_RESERVE_OUT: |
954 | if (su_dev->t10_pr.res_type == SPC3_PERSISTENT_RESERVATIONS) | 947 | if (dev->t10_pr.res_type == SPC3_PERSISTENT_RESERVATIONS) |
955 | cmd->execute_cmd = target_scsi3_emulate_pr_out; | 948 | cmd->execute_cmd = target_scsi3_emulate_pr_out; |
956 | *size = (cdb[7] << 8) + cdb[8]; | 949 | *size = (cdb[7] << 8) + cdb[8]; |
957 | break; | 950 | break; |
@@ -962,7 +955,7 @@ int spc_parse_cdb(struct se_cmd *cmd, unsigned int *size) | |||
962 | else | 955 | else |
963 | *size = cmd->data_length; | 956 | *size = cmd->data_length; |
964 | 957 | ||
965 | if (su_dev->t10_pr.res_type != SPC_PASSTHROUGH) | 958 | if (dev->t10_pr.res_type != SPC_PASSTHROUGH) |
966 | cmd->execute_cmd = target_scsi2_reservation_release; | 959 | cmd->execute_cmd = target_scsi2_reservation_release; |
967 | break; | 960 | break; |
968 | case RESERVE: | 961 | case RESERVE: |
@@ -983,7 +976,7 @@ int spc_parse_cdb(struct se_cmd *cmd, unsigned int *size) | |||
983 | * is running in SPC_PASSTHROUGH, and wants reservations | 976 | * is running in SPC_PASSTHROUGH, and wants reservations |
984 | * emulation disabled. | 977 | * emulation disabled. |
985 | */ | 978 | */ |
986 | if (su_dev->t10_pr.res_type != SPC_PASSTHROUGH) | 979 | if (dev->t10_pr.res_type != SPC_PASSTHROUGH) |
987 | cmd->execute_cmd = target_scsi2_reservation_reserve; | 980 | cmd->execute_cmd = target_scsi2_reservation_reserve; |
988 | break; | 981 | break; |
989 | case REQUEST_SENSE: | 982 | case REQUEST_SENSE: |
@@ -1040,7 +1033,7 @@ int spc_parse_cdb(struct se_cmd *cmd, unsigned int *size) | |||
1040 | * Check for emulated MI_REPORT_TARGET_PGS | 1033 | * Check for emulated MI_REPORT_TARGET_PGS |
1041 | */ | 1034 | */ |
1042 | if ((cdb[1] & 0x1f) == MI_REPORT_TARGET_PGS && | 1035 | if ((cdb[1] & 0x1f) == MI_REPORT_TARGET_PGS && |
1043 | su_dev->t10_alua.alua_type == SPC3_ALUA_EMULATED) { | 1036 | dev->t10_alua.alua_type == SPC3_ALUA_EMULATED) { |
1044 | cmd->execute_cmd = | 1037 | cmd->execute_cmd = |
1045 | target_emulate_report_target_port_groups; | 1038 | target_emulate_report_target_port_groups; |
1046 | } | 1039 | } |
@@ -1059,7 +1052,7 @@ int spc_parse_cdb(struct se_cmd *cmd, unsigned int *size) | |||
1059 | * Check for emulated MO_SET_TARGET_PGS. | 1052 | * Check for emulated MO_SET_TARGET_PGS. |
1060 | */ | 1053 | */ |
1061 | if (cdb[1] == MO_SET_TARGET_PGS && | 1054 | if (cdb[1] == MO_SET_TARGET_PGS && |
1062 | su_dev->t10_alua.alua_type == SPC3_ALUA_EMULATED) { | 1055 | dev->t10_alua.alua_type == SPC3_ALUA_EMULATED) { |
1063 | cmd->execute_cmd = | 1056 | cmd->execute_cmd = |
1064 | target_emulate_set_target_port_groups; | 1057 | target_emulate_set_target_port_groups; |
1065 | } | 1058 | } |
diff --git a/drivers/target/target_core_stat.c b/drivers/target/target_core_stat.c index cb6b0036ae95..9bbb0170b726 100644 --- a/drivers/target/target_core_stat.c +++ b/drivers/target/target_core_stat.c | |||
@@ -80,13 +80,9 @@ static struct target_stat_scsi_dev_attribute \ | |||
80 | static ssize_t target_stat_scsi_dev_show_attr_inst( | 80 | static ssize_t target_stat_scsi_dev_show_attr_inst( |
81 | struct se_dev_stat_grps *sgrps, char *page) | 81 | struct se_dev_stat_grps *sgrps, char *page) |
82 | { | 82 | { |
83 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | 83 | struct se_device *dev = |
84 | struct se_subsystem_dev, dev_stat_grps); | 84 | container_of(sgrps, struct se_device, dev_stat_grps); |
85 | struct se_hba *hba = se_subdev->se_dev_hba; | 85 | struct se_hba *hba = dev->se_hba; |
86 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
87 | |||
88 | if (!dev) | ||
89 | return -ENODEV; | ||
90 | 86 | ||
91 | return snprintf(page, PAGE_SIZE, "%u\n", hba->hba_index); | 87 | return snprintf(page, PAGE_SIZE, "%u\n", hba->hba_index); |
92 | } | 88 | } |
@@ -95,12 +91,8 @@ DEV_STAT_SCSI_DEV_ATTR_RO(inst); | |||
95 | static ssize_t target_stat_scsi_dev_show_attr_indx( | 91 | static ssize_t target_stat_scsi_dev_show_attr_indx( |
96 | struct se_dev_stat_grps *sgrps, char *page) | 92 | struct se_dev_stat_grps *sgrps, char *page) |
97 | { | 93 | { |
98 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | 94 | struct se_device *dev = |
99 | struct se_subsystem_dev, dev_stat_grps); | 95 | container_of(sgrps, struct se_device, dev_stat_grps); |
100 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
101 | |||
102 | if (!dev) | ||
103 | return -ENODEV; | ||
104 | 96 | ||
105 | return snprintf(page, PAGE_SIZE, "%u\n", dev->dev_index); | 97 | return snprintf(page, PAGE_SIZE, "%u\n", dev->dev_index); |
106 | } | 98 | } |
@@ -109,13 +101,6 @@ DEV_STAT_SCSI_DEV_ATTR_RO(indx); | |||
109 | static ssize_t target_stat_scsi_dev_show_attr_role( | 101 | static ssize_t target_stat_scsi_dev_show_attr_role( |
110 | struct se_dev_stat_grps *sgrps, char *page) | 102 | struct se_dev_stat_grps *sgrps, char *page) |
111 | { | 103 | { |
112 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | ||
113 | struct se_subsystem_dev, dev_stat_grps); | ||
114 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
115 | |||
116 | if (!dev) | ||
117 | return -ENODEV; | ||
118 | |||
119 | return snprintf(page, PAGE_SIZE, "Target\n"); | 104 | return snprintf(page, PAGE_SIZE, "Target\n"); |
120 | } | 105 | } |
121 | DEV_STAT_SCSI_DEV_ATTR_RO(role); | 106 | DEV_STAT_SCSI_DEV_ATTR_RO(role); |
@@ -123,12 +108,8 @@ DEV_STAT_SCSI_DEV_ATTR_RO(role); | |||
123 | static ssize_t target_stat_scsi_dev_show_attr_ports( | 108 | static ssize_t target_stat_scsi_dev_show_attr_ports( |
124 | struct se_dev_stat_grps *sgrps, char *page) | 109 | struct se_dev_stat_grps *sgrps, char *page) |
125 | { | 110 | { |
126 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | 111 | struct se_device *dev = |
127 | struct se_subsystem_dev, dev_stat_grps); | 112 | container_of(sgrps, struct se_device, dev_stat_grps); |
128 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
129 | |||
130 | if (!dev) | ||
131 | return -ENODEV; | ||
132 | 113 | ||
133 | return snprintf(page, PAGE_SIZE, "%u\n", dev->dev_port_count); | 114 | return snprintf(page, PAGE_SIZE, "%u\n", dev->dev_port_count); |
134 | } | 115 | } |
@@ -176,13 +157,9 @@ static struct target_stat_scsi_tgt_dev_attribute \ | |||
176 | static ssize_t target_stat_scsi_tgt_dev_show_attr_inst( | 157 | static ssize_t target_stat_scsi_tgt_dev_show_attr_inst( |
177 | struct se_dev_stat_grps *sgrps, char *page) | 158 | struct se_dev_stat_grps *sgrps, char *page) |
178 | { | 159 | { |
179 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | 160 | struct se_device *dev = |
180 | struct se_subsystem_dev, dev_stat_grps); | 161 | container_of(sgrps, struct se_device, dev_stat_grps); |
181 | struct se_hba *hba = se_subdev->se_dev_hba; | 162 | struct se_hba *hba = dev->se_hba; |
182 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
183 | |||
184 | if (!dev) | ||
185 | return -ENODEV; | ||
186 | 163 | ||
187 | return snprintf(page, PAGE_SIZE, "%u\n", hba->hba_index); | 164 | return snprintf(page, PAGE_SIZE, "%u\n", hba->hba_index); |
188 | } | 165 | } |
@@ -191,12 +168,8 @@ DEV_STAT_SCSI_TGT_DEV_ATTR_RO(inst); | |||
191 | static ssize_t target_stat_scsi_tgt_dev_show_attr_indx( | 168 | static ssize_t target_stat_scsi_tgt_dev_show_attr_indx( |
192 | struct se_dev_stat_grps *sgrps, char *page) | 169 | struct se_dev_stat_grps *sgrps, char *page) |
193 | { | 170 | { |
194 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | 171 | struct se_device *dev = |
195 | struct se_subsystem_dev, dev_stat_grps); | 172 | container_of(sgrps, struct se_device, dev_stat_grps); |
196 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
197 | |||
198 | if (!dev) | ||
199 | return -ENODEV; | ||
200 | 173 | ||
201 | return snprintf(page, PAGE_SIZE, "%u\n", dev->dev_index); | 174 | return snprintf(page, PAGE_SIZE, "%u\n", dev->dev_index); |
202 | } | 175 | } |
@@ -205,13 +178,6 @@ DEV_STAT_SCSI_TGT_DEV_ATTR_RO(indx); | |||
205 | static ssize_t target_stat_scsi_tgt_dev_show_attr_num_lus( | 178 | static ssize_t target_stat_scsi_tgt_dev_show_attr_num_lus( |
206 | struct se_dev_stat_grps *sgrps, char *page) | 179 | struct se_dev_stat_grps *sgrps, char *page) |
207 | { | 180 | { |
208 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | ||
209 | struct se_subsystem_dev, dev_stat_grps); | ||
210 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
211 | |||
212 | if (!dev) | ||
213 | return -ENODEV; | ||
214 | |||
215 | return snprintf(page, PAGE_SIZE, "%u\n", LU_COUNT); | 181 | return snprintf(page, PAGE_SIZE, "%u\n", LU_COUNT); |
216 | } | 182 | } |
217 | DEV_STAT_SCSI_TGT_DEV_ATTR_RO(num_lus); | 183 | DEV_STAT_SCSI_TGT_DEV_ATTR_RO(num_lus); |
@@ -219,60 +185,27 @@ DEV_STAT_SCSI_TGT_DEV_ATTR_RO(num_lus); | |||
219 | static ssize_t target_stat_scsi_tgt_dev_show_attr_status( | 185 | static ssize_t target_stat_scsi_tgt_dev_show_attr_status( |
220 | struct se_dev_stat_grps *sgrps, char *page) | 186 | struct se_dev_stat_grps *sgrps, char *page) |
221 | { | 187 | { |
222 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | 188 | struct se_device *dev = |
223 | struct se_subsystem_dev, dev_stat_grps); | 189 | container_of(sgrps, struct se_device, dev_stat_grps); |
224 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
225 | char status[16]; | ||
226 | 190 | ||
227 | if (!dev) | 191 | if (dev->export_count) |
228 | return -ENODEV; | 192 | return snprintf(page, PAGE_SIZE, "activated"); |
229 | 193 | else | |
230 | switch (dev->dev_status) { | 194 | return snprintf(page, PAGE_SIZE, "deactivated"); |
231 | case TRANSPORT_DEVICE_ACTIVATED: | ||
232 | strcpy(status, "activated"); | ||
233 | break; | ||
234 | case TRANSPORT_DEVICE_DEACTIVATED: | ||
235 | strcpy(status, "deactivated"); | ||
236 | break; | ||
237 | case TRANSPORT_DEVICE_SHUTDOWN: | ||
238 | strcpy(status, "shutdown"); | ||
239 | break; | ||
240 | case TRANSPORT_DEVICE_OFFLINE_ACTIVATED: | ||
241 | case TRANSPORT_DEVICE_OFFLINE_DEACTIVATED: | ||
242 | strcpy(status, "offline"); | ||
243 | break; | ||
244 | default: | ||
245 | sprintf(status, "unknown(%d)", dev->dev_status); | ||
246 | break; | ||
247 | } | ||
248 | |||
249 | return snprintf(page, PAGE_SIZE, "%s\n", status); | ||
250 | } | 195 | } |
251 | DEV_STAT_SCSI_TGT_DEV_ATTR_RO(status); | 196 | DEV_STAT_SCSI_TGT_DEV_ATTR_RO(status); |
252 | 197 | ||
253 | static ssize_t target_stat_scsi_tgt_dev_show_attr_non_access_lus( | 198 | static ssize_t target_stat_scsi_tgt_dev_show_attr_non_access_lus( |
254 | struct se_dev_stat_grps *sgrps, char *page) | 199 | struct se_dev_stat_grps *sgrps, char *page) |
255 | { | 200 | { |
256 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | 201 | struct se_device *dev = |
257 | struct se_subsystem_dev, dev_stat_grps); | 202 | container_of(sgrps, struct se_device, dev_stat_grps); |
258 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
259 | int non_accessible_lus; | 203 | int non_accessible_lus; |
260 | 204 | ||
261 | if (!dev) | 205 | if (dev->export_count) |
262 | return -ENODEV; | ||
263 | |||
264 | switch (dev->dev_status) { | ||
265 | case TRANSPORT_DEVICE_ACTIVATED: | ||
266 | non_accessible_lus = 0; | 206 | non_accessible_lus = 0; |
267 | break; | 207 | else |
268 | case TRANSPORT_DEVICE_DEACTIVATED: | ||
269 | case TRANSPORT_DEVICE_SHUTDOWN: | ||
270 | case TRANSPORT_DEVICE_OFFLINE_ACTIVATED: | ||
271 | case TRANSPORT_DEVICE_OFFLINE_DEACTIVATED: | ||
272 | default: | ||
273 | non_accessible_lus = 1; | 208 | non_accessible_lus = 1; |
274 | break; | ||
275 | } | ||
276 | 209 | ||
277 | return snprintf(page, PAGE_SIZE, "%u\n", non_accessible_lus); | 210 | return snprintf(page, PAGE_SIZE, "%u\n", non_accessible_lus); |
278 | } | 211 | } |
@@ -281,12 +214,8 @@ DEV_STAT_SCSI_TGT_DEV_ATTR_RO(non_access_lus); | |||
281 | static ssize_t target_stat_scsi_tgt_dev_show_attr_resets( | 214 | static ssize_t target_stat_scsi_tgt_dev_show_attr_resets( |
282 | struct se_dev_stat_grps *sgrps, char *page) | 215 | struct se_dev_stat_grps *sgrps, char *page) |
283 | { | 216 | { |
284 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | 217 | struct se_device *dev = |
285 | struct se_subsystem_dev, dev_stat_grps); | 218 | container_of(sgrps, struct se_device, dev_stat_grps); |
286 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
287 | |||
288 | if (!dev) | ||
289 | return -ENODEV; | ||
290 | 219 | ||
291 | return snprintf(page, PAGE_SIZE, "%u\n", dev->num_resets); | 220 | return snprintf(page, PAGE_SIZE, "%u\n", dev->num_resets); |
292 | } | 221 | } |
@@ -335,13 +264,9 @@ static struct target_stat_scsi_lu_attribute target_stat_scsi_lu_##_name = \ | |||
335 | static ssize_t target_stat_scsi_lu_show_attr_inst( | 264 | static ssize_t target_stat_scsi_lu_show_attr_inst( |
336 | struct se_dev_stat_grps *sgrps, char *page) | 265 | struct se_dev_stat_grps *sgrps, char *page) |
337 | { | 266 | { |
338 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | 267 | struct se_device *dev = |
339 | struct se_subsystem_dev, dev_stat_grps); | 268 | container_of(sgrps, struct se_device, dev_stat_grps); |
340 | struct se_hba *hba = se_subdev->se_dev_hba; | 269 | struct se_hba *hba = dev->se_hba; |
341 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
342 | |||
343 | if (!dev) | ||
344 | return -ENODEV; | ||
345 | 270 | ||
346 | return snprintf(page, PAGE_SIZE, "%u\n", hba->hba_index); | 271 | return snprintf(page, PAGE_SIZE, "%u\n", hba->hba_index); |
347 | } | 272 | } |
@@ -350,12 +275,8 @@ DEV_STAT_SCSI_LU_ATTR_RO(inst); | |||
350 | static ssize_t target_stat_scsi_lu_show_attr_dev( | 275 | static ssize_t target_stat_scsi_lu_show_attr_dev( |
351 | struct se_dev_stat_grps *sgrps, char *page) | 276 | struct se_dev_stat_grps *sgrps, char *page) |
352 | { | 277 | { |
353 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | 278 | struct se_device *dev = |
354 | struct se_subsystem_dev, dev_stat_grps); | 279 | container_of(sgrps, struct se_device, dev_stat_grps); |
355 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
356 | |||
357 | if (!dev) | ||
358 | return -ENODEV; | ||
359 | 280 | ||
360 | return snprintf(page, PAGE_SIZE, "%u\n", dev->dev_index); | 281 | return snprintf(page, PAGE_SIZE, "%u\n", dev->dev_index); |
361 | } | 282 | } |
@@ -364,13 +285,6 @@ DEV_STAT_SCSI_LU_ATTR_RO(dev); | |||
364 | static ssize_t target_stat_scsi_lu_show_attr_indx( | 285 | static ssize_t target_stat_scsi_lu_show_attr_indx( |
365 | struct se_dev_stat_grps *sgrps, char *page) | 286 | struct se_dev_stat_grps *sgrps, char *page) |
366 | { | 287 | { |
367 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | ||
368 | struct se_subsystem_dev, dev_stat_grps); | ||
369 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
370 | |||
371 | if (!dev) | ||
372 | return -ENODEV; | ||
373 | |||
374 | return snprintf(page, PAGE_SIZE, "%u\n", SCSI_LU_INDEX); | 288 | return snprintf(page, PAGE_SIZE, "%u\n", SCSI_LU_INDEX); |
375 | } | 289 | } |
376 | DEV_STAT_SCSI_LU_ATTR_RO(indx); | 290 | DEV_STAT_SCSI_LU_ATTR_RO(indx); |
@@ -378,12 +292,6 @@ DEV_STAT_SCSI_LU_ATTR_RO(indx); | |||
378 | static ssize_t target_stat_scsi_lu_show_attr_lun( | 292 | static ssize_t target_stat_scsi_lu_show_attr_lun( |
379 | struct se_dev_stat_grps *sgrps, char *page) | 293 | struct se_dev_stat_grps *sgrps, char *page) |
380 | { | 294 | { |
381 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | ||
382 | struct se_subsystem_dev, dev_stat_grps); | ||
383 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
384 | |||
385 | if (!dev) | ||
386 | return -ENODEV; | ||
387 | /* FIXME: scsiLuDefaultLun */ | 295 | /* FIXME: scsiLuDefaultLun */ |
388 | return snprintf(page, PAGE_SIZE, "%llu\n", (unsigned long long)0); | 296 | return snprintf(page, PAGE_SIZE, "%llu\n", (unsigned long long)0); |
389 | } | 297 | } |
@@ -392,35 +300,28 @@ DEV_STAT_SCSI_LU_ATTR_RO(lun); | |||
392 | static ssize_t target_stat_scsi_lu_show_attr_lu_name( | 300 | static ssize_t target_stat_scsi_lu_show_attr_lu_name( |
393 | struct se_dev_stat_grps *sgrps, char *page) | 301 | struct se_dev_stat_grps *sgrps, char *page) |
394 | { | 302 | { |
395 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | 303 | struct se_device *dev = |
396 | struct se_subsystem_dev, dev_stat_grps); | 304 | container_of(sgrps, struct se_device, dev_stat_grps); |
397 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
398 | 305 | ||
399 | if (!dev) | ||
400 | return -ENODEV; | ||
401 | /* scsiLuWwnName */ | 306 | /* scsiLuWwnName */ |
402 | return snprintf(page, PAGE_SIZE, "%s\n", | 307 | return snprintf(page, PAGE_SIZE, "%s\n", |
403 | (strlen(dev->se_sub_dev->t10_wwn.unit_serial)) ? | 308 | (strlen(dev->t10_wwn.unit_serial)) ? |
404 | dev->se_sub_dev->t10_wwn.unit_serial : "None"); | 309 | dev->t10_wwn.unit_serial : "None"); |
405 | } | 310 | } |
406 | DEV_STAT_SCSI_LU_ATTR_RO(lu_name); | 311 | DEV_STAT_SCSI_LU_ATTR_RO(lu_name); |
407 | 312 | ||
408 | static ssize_t target_stat_scsi_lu_show_attr_vend( | 313 | static ssize_t target_stat_scsi_lu_show_attr_vend( |
409 | struct se_dev_stat_grps *sgrps, char *page) | 314 | struct se_dev_stat_grps *sgrps, char *page) |
410 | { | 315 | { |
411 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | 316 | struct se_device *dev = |
412 | struct se_subsystem_dev, dev_stat_grps); | 317 | container_of(sgrps, struct se_device, dev_stat_grps); |
413 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
414 | int i; | 318 | int i; |
415 | char str[sizeof(dev->se_sub_dev->t10_wwn.vendor)+1]; | 319 | char str[sizeof(dev->t10_wwn.vendor)+1]; |
416 | |||
417 | if (!dev) | ||
418 | return -ENODEV; | ||
419 | 320 | ||
420 | /* scsiLuVendorId */ | 321 | /* scsiLuVendorId */ |
421 | for (i = 0; i < sizeof(dev->se_sub_dev->t10_wwn.vendor); i++) | 322 | for (i = 0; i < sizeof(dev->t10_wwn.vendor); i++) |
422 | str[i] = ISPRINT(dev->se_sub_dev->t10_wwn.vendor[i]) ? | 323 | str[i] = ISPRINT(dev->t10_wwn.vendor[i]) ? |
423 | dev->se_sub_dev->t10_wwn.vendor[i] : ' '; | 324 | dev->t10_wwn.vendor[i] : ' '; |
424 | str[i] = '\0'; | 325 | str[i] = '\0'; |
425 | return snprintf(page, PAGE_SIZE, "%s\n", str); | 326 | return snprintf(page, PAGE_SIZE, "%s\n", str); |
426 | } | 327 | } |
@@ -429,19 +330,15 @@ DEV_STAT_SCSI_LU_ATTR_RO(vend); | |||
429 | static ssize_t target_stat_scsi_lu_show_attr_prod( | 330 | static ssize_t target_stat_scsi_lu_show_attr_prod( |
430 | struct se_dev_stat_grps *sgrps, char *page) | 331 | struct se_dev_stat_grps *sgrps, char *page) |
431 | { | 332 | { |
432 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | 333 | struct se_device *dev = |
433 | struct se_subsystem_dev, dev_stat_grps); | 334 | container_of(sgrps, struct se_device, dev_stat_grps); |
434 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
435 | int i; | 335 | int i; |
436 | char str[sizeof(dev->se_sub_dev->t10_wwn.model)+1]; | 336 | char str[sizeof(dev->t10_wwn.model)+1]; |
437 | |||
438 | if (!dev) | ||
439 | return -ENODEV; | ||
440 | 337 | ||
441 | /* scsiLuProductId */ | 338 | /* scsiLuProductId */ |
442 | for (i = 0; i < sizeof(dev->se_sub_dev->t10_wwn.vendor); i++) | 339 | for (i = 0; i < sizeof(dev->t10_wwn.vendor); i++) |
443 | str[i] = ISPRINT(dev->se_sub_dev->t10_wwn.model[i]) ? | 340 | str[i] = ISPRINT(dev->t10_wwn.model[i]) ? |
444 | dev->se_sub_dev->t10_wwn.model[i] : ' '; | 341 | dev->t10_wwn.model[i] : ' '; |
445 | str[i] = '\0'; | 342 | str[i] = '\0'; |
446 | return snprintf(page, PAGE_SIZE, "%s\n", str); | 343 | return snprintf(page, PAGE_SIZE, "%s\n", str); |
447 | } | 344 | } |
@@ -450,19 +347,15 @@ DEV_STAT_SCSI_LU_ATTR_RO(prod); | |||
450 | static ssize_t target_stat_scsi_lu_show_attr_rev( | 347 | static ssize_t target_stat_scsi_lu_show_attr_rev( |
451 | struct se_dev_stat_grps *sgrps, char *page) | 348 | struct se_dev_stat_grps *sgrps, char *page) |
452 | { | 349 | { |
453 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | 350 | struct se_device *dev = |
454 | struct se_subsystem_dev, dev_stat_grps); | 351 | container_of(sgrps, struct se_device, dev_stat_grps); |
455 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
456 | int i; | 352 | int i; |
457 | char str[sizeof(dev->se_sub_dev->t10_wwn.revision)+1]; | 353 | char str[sizeof(dev->t10_wwn.revision)+1]; |
458 | |||
459 | if (!dev) | ||
460 | return -ENODEV; | ||
461 | 354 | ||
462 | /* scsiLuRevisionId */ | 355 | /* scsiLuRevisionId */ |
463 | for (i = 0; i < sizeof(dev->se_sub_dev->t10_wwn.revision); i++) | 356 | for (i = 0; i < sizeof(dev->t10_wwn.revision); i++) |
464 | str[i] = ISPRINT(dev->se_sub_dev->t10_wwn.revision[i]) ? | 357 | str[i] = ISPRINT(dev->t10_wwn.revision[i]) ? |
465 | dev->se_sub_dev->t10_wwn.revision[i] : ' '; | 358 | dev->t10_wwn.revision[i] : ' '; |
466 | str[i] = '\0'; | 359 | str[i] = '\0'; |
467 | return snprintf(page, PAGE_SIZE, "%s\n", str); | 360 | return snprintf(page, PAGE_SIZE, "%s\n", str); |
468 | } | 361 | } |
@@ -471,12 +364,8 @@ DEV_STAT_SCSI_LU_ATTR_RO(rev); | |||
471 | static ssize_t target_stat_scsi_lu_show_attr_dev_type( | 364 | static ssize_t target_stat_scsi_lu_show_attr_dev_type( |
472 | struct se_dev_stat_grps *sgrps, char *page) | 365 | struct se_dev_stat_grps *sgrps, char *page) |
473 | { | 366 | { |
474 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | 367 | struct se_device *dev = |
475 | struct se_subsystem_dev, dev_stat_grps); | 368 | container_of(sgrps, struct se_device, dev_stat_grps); |
476 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
477 | |||
478 | if (!dev) | ||
479 | return -ENODEV; | ||
480 | 369 | ||
481 | /* scsiLuPeripheralType */ | 370 | /* scsiLuPeripheralType */ |
482 | return snprintf(page, PAGE_SIZE, "%u\n", | 371 | return snprintf(page, PAGE_SIZE, "%u\n", |
@@ -487,30 +376,18 @@ DEV_STAT_SCSI_LU_ATTR_RO(dev_type); | |||
487 | static ssize_t target_stat_scsi_lu_show_attr_status( | 376 | static ssize_t target_stat_scsi_lu_show_attr_status( |
488 | struct se_dev_stat_grps *sgrps, char *page) | 377 | struct se_dev_stat_grps *sgrps, char *page) |
489 | { | 378 | { |
490 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | 379 | struct se_device *dev = |
491 | struct se_subsystem_dev, dev_stat_grps); | 380 | container_of(sgrps, struct se_device, dev_stat_grps); |
492 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
493 | |||
494 | if (!dev) | ||
495 | return -ENODEV; | ||
496 | 381 | ||
497 | /* scsiLuStatus */ | 382 | /* scsiLuStatus */ |
498 | return snprintf(page, PAGE_SIZE, "%s\n", | 383 | return snprintf(page, PAGE_SIZE, "%s\n", |
499 | (dev->dev_status == TRANSPORT_DEVICE_ACTIVATED) ? | 384 | (dev->export_count) ? "available" : "notavailable"); |
500 | "available" : "notavailable"); | ||
501 | } | 385 | } |
502 | DEV_STAT_SCSI_LU_ATTR_RO(status); | 386 | DEV_STAT_SCSI_LU_ATTR_RO(status); |
503 | 387 | ||
504 | static ssize_t target_stat_scsi_lu_show_attr_state_bit( | 388 | static ssize_t target_stat_scsi_lu_show_attr_state_bit( |
505 | struct se_dev_stat_grps *sgrps, char *page) | 389 | struct se_dev_stat_grps *sgrps, char *page) |
506 | { | 390 | { |
507 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | ||
508 | struct se_subsystem_dev, dev_stat_grps); | ||
509 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
510 | |||
511 | if (!dev) | ||
512 | return -ENODEV; | ||
513 | |||
514 | /* scsiLuState */ | 391 | /* scsiLuState */ |
515 | return snprintf(page, PAGE_SIZE, "exposed\n"); | 392 | return snprintf(page, PAGE_SIZE, "exposed\n"); |
516 | } | 393 | } |
@@ -519,12 +396,8 @@ DEV_STAT_SCSI_LU_ATTR_RO(state_bit); | |||
519 | static ssize_t target_stat_scsi_lu_show_attr_num_cmds( | 396 | static ssize_t target_stat_scsi_lu_show_attr_num_cmds( |
520 | struct se_dev_stat_grps *sgrps, char *page) | 397 | struct se_dev_stat_grps *sgrps, char *page) |
521 | { | 398 | { |
522 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | 399 | struct se_device *dev = |
523 | struct se_subsystem_dev, dev_stat_grps); | 400 | container_of(sgrps, struct se_device, dev_stat_grps); |
524 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
525 | |||
526 | if (!dev) | ||
527 | return -ENODEV; | ||
528 | 401 | ||
529 | /* scsiLuNumCommands */ | 402 | /* scsiLuNumCommands */ |
530 | return snprintf(page, PAGE_SIZE, "%llu\n", | 403 | return snprintf(page, PAGE_SIZE, "%llu\n", |
@@ -535,12 +408,8 @@ DEV_STAT_SCSI_LU_ATTR_RO(num_cmds); | |||
535 | static ssize_t target_stat_scsi_lu_show_attr_read_mbytes( | 408 | static ssize_t target_stat_scsi_lu_show_attr_read_mbytes( |
536 | struct se_dev_stat_grps *sgrps, char *page) | 409 | struct se_dev_stat_grps *sgrps, char *page) |
537 | { | 410 | { |
538 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | 411 | struct se_device *dev = |
539 | struct se_subsystem_dev, dev_stat_grps); | 412 | container_of(sgrps, struct se_device, dev_stat_grps); |
540 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
541 | |||
542 | if (!dev) | ||
543 | return -ENODEV; | ||
544 | 413 | ||
545 | /* scsiLuReadMegaBytes */ | 414 | /* scsiLuReadMegaBytes */ |
546 | return snprintf(page, PAGE_SIZE, "%u\n", (u32)(dev->read_bytes >> 20)); | 415 | return snprintf(page, PAGE_SIZE, "%u\n", (u32)(dev->read_bytes >> 20)); |
@@ -550,12 +419,8 @@ DEV_STAT_SCSI_LU_ATTR_RO(read_mbytes); | |||
550 | static ssize_t target_stat_scsi_lu_show_attr_write_mbytes( | 419 | static ssize_t target_stat_scsi_lu_show_attr_write_mbytes( |
551 | struct se_dev_stat_grps *sgrps, char *page) | 420 | struct se_dev_stat_grps *sgrps, char *page) |
552 | { | 421 | { |
553 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | 422 | struct se_device *dev = |
554 | struct se_subsystem_dev, dev_stat_grps); | 423 | container_of(sgrps, struct se_device, dev_stat_grps); |
555 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
556 | |||
557 | if (!dev) | ||
558 | return -ENODEV; | ||
559 | 424 | ||
560 | /* scsiLuWrittenMegaBytes */ | 425 | /* scsiLuWrittenMegaBytes */ |
561 | return snprintf(page, PAGE_SIZE, "%u\n", (u32)(dev->write_bytes >> 20)); | 426 | return snprintf(page, PAGE_SIZE, "%u\n", (u32)(dev->write_bytes >> 20)); |
@@ -565,12 +430,8 @@ DEV_STAT_SCSI_LU_ATTR_RO(write_mbytes); | |||
565 | static ssize_t target_stat_scsi_lu_show_attr_resets( | 430 | static ssize_t target_stat_scsi_lu_show_attr_resets( |
566 | struct se_dev_stat_grps *sgrps, char *page) | 431 | struct se_dev_stat_grps *sgrps, char *page) |
567 | { | 432 | { |
568 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | 433 | struct se_device *dev = |
569 | struct se_subsystem_dev, dev_stat_grps); | 434 | container_of(sgrps, struct se_device, dev_stat_grps); |
570 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
571 | |||
572 | if (!dev) | ||
573 | return -ENODEV; | ||
574 | 435 | ||
575 | /* scsiLuInResets */ | 436 | /* scsiLuInResets */ |
576 | return snprintf(page, PAGE_SIZE, "%u\n", dev->num_resets); | 437 | return snprintf(page, PAGE_SIZE, "%u\n", dev->num_resets); |
@@ -580,13 +441,6 @@ DEV_STAT_SCSI_LU_ATTR_RO(resets); | |||
580 | static ssize_t target_stat_scsi_lu_show_attr_full_stat( | 441 | static ssize_t target_stat_scsi_lu_show_attr_full_stat( |
581 | struct se_dev_stat_grps *sgrps, char *page) | 442 | struct se_dev_stat_grps *sgrps, char *page) |
582 | { | 443 | { |
583 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | ||
584 | struct se_subsystem_dev, dev_stat_grps); | ||
585 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
586 | |||
587 | if (!dev) | ||
588 | return -ENODEV; | ||
589 | |||
590 | /* FIXME: scsiLuOutTaskSetFullStatus */ | 444 | /* FIXME: scsiLuOutTaskSetFullStatus */ |
591 | return snprintf(page, PAGE_SIZE, "%u\n", 0); | 445 | return snprintf(page, PAGE_SIZE, "%u\n", 0); |
592 | } | 446 | } |
@@ -595,13 +449,6 @@ DEV_STAT_SCSI_LU_ATTR_RO(full_stat); | |||
595 | static ssize_t target_stat_scsi_lu_show_attr_hs_num_cmds( | 449 | static ssize_t target_stat_scsi_lu_show_attr_hs_num_cmds( |
596 | struct se_dev_stat_grps *sgrps, char *page) | 450 | struct se_dev_stat_grps *sgrps, char *page) |
597 | { | 451 | { |
598 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | ||
599 | struct se_subsystem_dev, dev_stat_grps); | ||
600 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
601 | |||
602 | if (!dev) | ||
603 | return -ENODEV; | ||
604 | |||
605 | /* FIXME: scsiLuHSInCommands */ | 452 | /* FIXME: scsiLuHSInCommands */ |
606 | return snprintf(page, PAGE_SIZE, "%u\n", 0); | 453 | return snprintf(page, PAGE_SIZE, "%u\n", 0); |
607 | } | 454 | } |
@@ -610,12 +457,8 @@ DEV_STAT_SCSI_LU_ATTR_RO(hs_num_cmds); | |||
610 | static ssize_t target_stat_scsi_lu_show_attr_creation_time( | 457 | static ssize_t target_stat_scsi_lu_show_attr_creation_time( |
611 | struct se_dev_stat_grps *sgrps, char *page) | 458 | struct se_dev_stat_grps *sgrps, char *page) |
612 | { | 459 | { |
613 | struct se_subsystem_dev *se_subdev = container_of(sgrps, | 460 | struct se_device *dev = |
614 | struct se_subsystem_dev, dev_stat_grps); | 461 | container_of(sgrps, struct se_device, dev_stat_grps); |
615 | struct se_device *dev = se_subdev->se_dev_ptr; | ||
616 | |||
617 | if (!dev) | ||
618 | return -ENODEV; | ||
619 | 462 | ||
620 | /* scsiLuCreationTime */ | 463 | /* scsiLuCreationTime */ |
621 | return snprintf(page, PAGE_SIZE, "%u\n", (u32)(((u32)dev->creation_time - | 464 | return snprintf(page, PAGE_SIZE, "%u\n", (u32)(((u32)dev->creation_time - |
@@ -662,20 +505,20 @@ static struct config_item_type target_stat_scsi_lu_cit = { | |||
662 | * Called from target_core_configfs.c:target_core_make_subdev() to setup | 505 | * Called from target_core_configfs.c:target_core_make_subdev() to setup |
663 | * the target statistics groups + configfs CITs located in target_core_stat.c | 506 | * the target statistics groups + configfs CITs located in target_core_stat.c |
664 | */ | 507 | */ |
665 | void target_stat_setup_dev_default_groups(struct se_subsystem_dev *se_subdev) | 508 | void target_stat_setup_dev_default_groups(struct se_device *dev) |
666 | { | 509 | { |
667 | struct config_group *dev_stat_grp = &se_subdev->dev_stat_grps.stat_group; | 510 | struct config_group *dev_stat_grp = &dev->dev_stat_grps.stat_group; |
668 | 511 | ||
669 | config_group_init_type_name(&se_subdev->dev_stat_grps.scsi_dev_group, | 512 | config_group_init_type_name(&dev->dev_stat_grps.scsi_dev_group, |
670 | "scsi_dev", &target_stat_scsi_dev_cit); | 513 | "scsi_dev", &target_stat_scsi_dev_cit); |
671 | config_group_init_type_name(&se_subdev->dev_stat_grps.scsi_tgt_dev_group, | 514 | config_group_init_type_name(&dev->dev_stat_grps.scsi_tgt_dev_group, |
672 | "scsi_tgt_dev", &target_stat_scsi_tgt_dev_cit); | 515 | "scsi_tgt_dev", &target_stat_scsi_tgt_dev_cit); |
673 | config_group_init_type_name(&se_subdev->dev_stat_grps.scsi_lu_group, | 516 | config_group_init_type_name(&dev->dev_stat_grps.scsi_lu_group, |
674 | "scsi_lu", &target_stat_scsi_lu_cit); | 517 | "scsi_lu", &target_stat_scsi_lu_cit); |
675 | 518 | ||
676 | dev_stat_grp->default_groups[0] = &se_subdev->dev_stat_grps.scsi_dev_group; | 519 | dev_stat_grp->default_groups[0] = &dev->dev_stat_grps.scsi_dev_group; |
677 | dev_stat_grp->default_groups[1] = &se_subdev->dev_stat_grps.scsi_tgt_dev_group; | 520 | dev_stat_grp->default_groups[1] = &dev->dev_stat_grps.scsi_tgt_dev_group; |
678 | dev_stat_grp->default_groups[2] = &se_subdev->dev_stat_grps.scsi_lu_group; | 521 | dev_stat_grp->default_groups[2] = &dev->dev_stat_grps.scsi_lu_group; |
679 | dev_stat_grp->default_groups[3] = NULL; | 522 | dev_stat_grp->default_groups[3] = NULL; |
680 | } | 523 | } |
681 | 524 | ||
@@ -1161,7 +1004,7 @@ static ssize_t target_stat_scsi_transport_show_attr_dev_name( | |||
1161 | return -ENODEV; | 1004 | return -ENODEV; |
1162 | } | 1005 | } |
1163 | tpg = sep->sep_tpg; | 1006 | tpg = sep->sep_tpg; |
1164 | wwn = &dev->se_sub_dev->t10_wwn; | 1007 | wwn = &dev->t10_wwn; |
1165 | /* scsiTransportDevName */ | 1008 | /* scsiTransportDevName */ |
1166 | ret = snprintf(page, PAGE_SIZE, "%s+%s\n", | 1009 | ret = snprintf(page, PAGE_SIZE, "%s+%s\n", |
1167 | tpg->se_tpg_tfo->tpg_get_wwn(tpg), | 1010 | tpg->se_tpg_tfo->tpg_get_wwn(tpg), |
diff --git a/drivers/target/target_core_tmr.c b/drivers/target/target_core_tmr.c index be75c4331a92..2aaceae964ee 100644 --- a/drivers/target/target_core_tmr.c +++ b/drivers/target/target_core_tmr.c | |||
@@ -371,7 +371,7 @@ int core_tmr_lun_reset( | |||
371 | * which the command was received shall be completed with TASK ABORTED | 371 | * which the command was received shall be completed with TASK ABORTED |
372 | * status (see SAM-4). | 372 | * status (see SAM-4). |
373 | */ | 373 | */ |
374 | tas = dev->se_sub_dev->se_dev_attrib.emulate_tas; | 374 | tas = dev->dev_attrib.emulate_tas; |
375 | /* | 375 | /* |
376 | * Determine if this se_tmr is coming from a $FABRIC_MOD | 376 | * Determine if this se_tmr is coming from a $FABRIC_MOD |
377 | * or struct se_device passthrough.. | 377 | * or struct se_device passthrough.. |
@@ -399,10 +399,10 @@ int core_tmr_lun_reset( | |||
399 | * LOGICAL UNIT RESET | 399 | * LOGICAL UNIT RESET |
400 | */ | 400 | */ |
401 | if (!preempt_and_abort_list && | 401 | if (!preempt_and_abort_list && |
402 | (dev->dev_flags & DF_SPC2_RESERVATIONS)) { | 402 | (dev->dev_reservation_flags & DRF_SPC2_RESERVATIONS)) { |
403 | spin_lock(&dev->dev_reservation_lock); | 403 | spin_lock(&dev->dev_reservation_lock); |
404 | dev->dev_reserved_node_acl = NULL; | 404 | dev->dev_reserved_node_acl = NULL; |
405 | dev->dev_flags &= ~DF_SPC2_RESERVATIONS; | 405 | dev->dev_reservation_flags &= ~DRF_SPC2_RESERVATIONS; |
406 | spin_unlock(&dev->dev_reservation_lock); | 406 | spin_unlock(&dev->dev_reservation_lock); |
407 | pr_debug("LUN_RESET: SCSI-2 Released reservation\n"); | 407 | pr_debug("LUN_RESET: SCSI-2 Released reservation\n"); |
408 | } | 408 | } |
diff --git a/drivers/target/target_core_transport.c b/drivers/target/target_core_transport.c index 9097155e9ebe..d6d24a47ed66 100644 --- a/drivers/target/target_core_transport.c +++ b/drivers/target/target_core_transport.c | |||
@@ -659,7 +659,7 @@ static void target_add_to_state_list(struct se_cmd *cmd) | |||
659 | static void transport_write_pending_qf(struct se_cmd *cmd); | 659 | static void transport_write_pending_qf(struct se_cmd *cmd); |
660 | static void transport_complete_qf(struct se_cmd *cmd); | 660 | static void transport_complete_qf(struct se_cmd *cmd); |
661 | 661 | ||
662 | static void target_qf_do_work(struct work_struct *work) | 662 | void target_qf_do_work(struct work_struct *work) |
663 | { | 663 | { |
664 | struct se_device *dev = container_of(work, struct se_device, | 664 | struct se_device *dev = container_of(work, struct se_device, |
665 | qf_work_queue); | 665 | qf_work_queue); |
@@ -712,29 +712,15 @@ void transport_dump_dev_state( | |||
712 | int *bl) | 712 | int *bl) |
713 | { | 713 | { |
714 | *bl += sprintf(b + *bl, "Status: "); | 714 | *bl += sprintf(b + *bl, "Status: "); |
715 | switch (dev->dev_status) { | 715 | if (dev->export_count) |
716 | case TRANSPORT_DEVICE_ACTIVATED: | ||
717 | *bl += sprintf(b + *bl, "ACTIVATED"); | 716 | *bl += sprintf(b + *bl, "ACTIVATED"); |
718 | break; | 717 | else |
719 | case TRANSPORT_DEVICE_DEACTIVATED: | ||
720 | *bl += sprintf(b + *bl, "DEACTIVATED"); | 718 | *bl += sprintf(b + *bl, "DEACTIVATED"); |
721 | break; | ||
722 | case TRANSPORT_DEVICE_SHUTDOWN: | ||
723 | *bl += sprintf(b + *bl, "SHUTDOWN"); | ||
724 | break; | ||
725 | case TRANSPORT_DEVICE_OFFLINE_ACTIVATED: | ||
726 | case TRANSPORT_DEVICE_OFFLINE_DEACTIVATED: | ||
727 | *bl += sprintf(b + *bl, "OFFLINE"); | ||
728 | break; | ||
729 | default: | ||
730 | *bl += sprintf(b + *bl, "UNKNOWN=%d", dev->dev_status); | ||
731 | break; | ||
732 | } | ||
733 | 719 | ||
734 | *bl += sprintf(b + *bl, " Max Queue Depth: %d", dev->queue_depth); | 720 | *bl += sprintf(b + *bl, " Max Queue Depth: %d", dev->queue_depth); |
735 | *bl += sprintf(b + *bl, " SectorSize: %u HwMaxSectors: %u\n", | 721 | *bl += sprintf(b + *bl, " SectorSize: %u HwMaxSectors: %u\n", |
736 | dev->se_sub_dev->se_dev_attrib.block_size, | 722 | dev->dev_attrib.block_size, |
737 | dev->se_sub_dev->se_dev_attrib.hw_max_sectors); | 723 | dev->dev_attrib.hw_max_sectors); |
738 | *bl += sprintf(b + *bl, " "); | 724 | *bl += sprintf(b + *bl, " "); |
739 | } | 725 | } |
740 | 726 | ||
@@ -991,185 +977,6 @@ transport_set_vpd_ident(struct t10_vpd *vpd, unsigned char *page_83) | |||
991 | } | 977 | } |
992 | EXPORT_SYMBOL(transport_set_vpd_ident); | 978 | EXPORT_SYMBOL(transport_set_vpd_ident); |
993 | 979 | ||
994 | static void core_setup_task_attr_emulation(struct se_device *dev) | ||
995 | { | ||
996 | /* | ||
997 | * If this device is from Target_Core_Mod/pSCSI, disable the | ||
998 | * SAM Task Attribute emulation. | ||
999 | * | ||
1000 | * This is currently not available in upsream Linux/SCSI Target | ||
1001 | * mode code, and is assumed to be disabled while using TCM/pSCSI. | ||
1002 | */ | ||
1003 | if (dev->transport->transport_type == TRANSPORT_PLUGIN_PHBA_PDEV) { | ||
1004 | dev->dev_task_attr_type = SAM_TASK_ATTR_PASSTHROUGH; | ||
1005 | return; | ||
1006 | } | ||
1007 | |||
1008 | dev->dev_task_attr_type = SAM_TASK_ATTR_EMULATED; | ||
1009 | pr_debug("%s: Using SAM_TASK_ATTR_EMULATED for SPC: 0x%02x" | ||
1010 | " device\n", dev->transport->name, | ||
1011 | dev->transport->get_device_rev(dev)); | ||
1012 | } | ||
1013 | |||
1014 | static void scsi_dump_inquiry(struct se_device *dev) | ||
1015 | { | ||
1016 | struct t10_wwn *wwn = &dev->se_sub_dev->t10_wwn; | ||
1017 | char buf[17]; | ||
1018 | int i, device_type; | ||
1019 | /* | ||
1020 | * Print Linux/SCSI style INQUIRY formatting to the kernel ring buffer | ||
1021 | */ | ||
1022 | for (i = 0; i < 8; i++) | ||
1023 | if (wwn->vendor[i] >= 0x20) | ||
1024 | buf[i] = wwn->vendor[i]; | ||
1025 | else | ||
1026 | buf[i] = ' '; | ||
1027 | buf[i] = '\0'; | ||
1028 | pr_debug(" Vendor: %s\n", buf); | ||
1029 | |||
1030 | for (i = 0; i < 16; i++) | ||
1031 | if (wwn->model[i] >= 0x20) | ||
1032 | buf[i] = wwn->model[i]; | ||
1033 | else | ||
1034 | buf[i] = ' '; | ||
1035 | buf[i] = '\0'; | ||
1036 | pr_debug(" Model: %s\n", buf); | ||
1037 | |||
1038 | for (i = 0; i < 4; i++) | ||
1039 | if (wwn->revision[i] >= 0x20) | ||
1040 | buf[i] = wwn->revision[i]; | ||
1041 | else | ||
1042 | buf[i] = ' '; | ||
1043 | buf[i] = '\0'; | ||
1044 | pr_debug(" Revision: %s\n", buf); | ||
1045 | |||
1046 | device_type = dev->transport->get_device_type(dev); | ||
1047 | pr_debug(" Type: %s ", scsi_device_type(device_type)); | ||
1048 | pr_debug(" ANSI SCSI revision: %02x\n", | ||
1049 | dev->transport->get_device_rev(dev)); | ||
1050 | } | ||
1051 | |||
1052 | struct se_device *transport_add_device_to_core_hba( | ||
1053 | struct se_hba *hba, | ||
1054 | struct se_subsystem_api *transport, | ||
1055 | struct se_subsystem_dev *se_dev, | ||
1056 | u32 device_flags, | ||
1057 | void *transport_dev, | ||
1058 | struct se_dev_limits *dev_limits, | ||
1059 | const char *inquiry_prod, | ||
1060 | const char *inquiry_rev) | ||
1061 | { | ||
1062 | int force_pt; | ||
1063 | struct se_device *dev; | ||
1064 | |||
1065 | dev = kzalloc(sizeof(struct se_device), GFP_KERNEL); | ||
1066 | if (!dev) { | ||
1067 | pr_err("Unable to allocate memory for se_dev_t\n"); | ||
1068 | return NULL; | ||
1069 | } | ||
1070 | |||
1071 | dev->dev_flags = device_flags; | ||
1072 | dev->dev_status |= TRANSPORT_DEVICE_DEACTIVATED; | ||
1073 | dev->dev_ptr = transport_dev; | ||
1074 | dev->se_hba = hba; | ||
1075 | dev->se_sub_dev = se_dev; | ||
1076 | dev->transport = transport; | ||
1077 | INIT_LIST_HEAD(&dev->dev_list); | ||
1078 | INIT_LIST_HEAD(&dev->dev_sep_list); | ||
1079 | INIT_LIST_HEAD(&dev->dev_tmr_list); | ||
1080 | INIT_LIST_HEAD(&dev->delayed_cmd_list); | ||
1081 | INIT_LIST_HEAD(&dev->state_list); | ||
1082 | INIT_LIST_HEAD(&dev->qf_cmd_list); | ||
1083 | spin_lock_init(&dev->execute_task_lock); | ||
1084 | spin_lock_init(&dev->delayed_cmd_lock); | ||
1085 | spin_lock_init(&dev->dev_reservation_lock); | ||
1086 | spin_lock_init(&dev->dev_status_lock); | ||
1087 | spin_lock_init(&dev->se_port_lock); | ||
1088 | spin_lock_init(&dev->se_tmr_lock); | ||
1089 | spin_lock_init(&dev->qf_cmd_lock); | ||
1090 | atomic_set(&dev->dev_ordered_id, 0); | ||
1091 | |||
1092 | se_dev_set_default_attribs(dev, dev_limits); | ||
1093 | |||
1094 | dev->dev_index = scsi_get_new_index(SCSI_DEVICE_INDEX); | ||
1095 | dev->creation_time = get_jiffies_64(); | ||
1096 | spin_lock_init(&dev->stats_lock); | ||
1097 | |||
1098 | spin_lock(&hba->device_lock); | ||
1099 | list_add_tail(&dev->dev_list, &hba->hba_dev_list); | ||
1100 | hba->dev_count++; | ||
1101 | spin_unlock(&hba->device_lock); | ||
1102 | /* | ||
1103 | * Setup the SAM Task Attribute emulation for struct se_device | ||
1104 | */ | ||
1105 | core_setup_task_attr_emulation(dev); | ||
1106 | /* | ||
1107 | * Force PR and ALUA passthrough emulation with internal object use. | ||
1108 | */ | ||
1109 | force_pt = (hba->hba_flags & HBA_FLAGS_INTERNAL_USE); | ||
1110 | /* | ||
1111 | * Setup the Reservations infrastructure for struct se_device | ||
1112 | */ | ||
1113 | core_setup_reservations(dev, force_pt); | ||
1114 | /* | ||
1115 | * Setup the Asymmetric Logical Unit Assignment for struct se_device | ||
1116 | */ | ||
1117 | if (core_setup_alua(dev, force_pt) < 0) | ||
1118 | goto err_dev_list; | ||
1119 | |||
1120 | /* | ||
1121 | * Startup the struct se_device processing thread | ||
1122 | */ | ||
1123 | dev->tmr_wq = alloc_workqueue("tmr-%s", WQ_MEM_RECLAIM | WQ_UNBOUND, 1, | ||
1124 | dev->transport->name); | ||
1125 | if (!dev->tmr_wq) { | ||
1126 | pr_err("Unable to create tmr workqueue for %s\n", | ||
1127 | dev->transport->name); | ||
1128 | goto err_dev_list; | ||
1129 | } | ||
1130 | /* | ||
1131 | * Setup work_queue for QUEUE_FULL | ||
1132 | */ | ||
1133 | INIT_WORK(&dev->qf_work_queue, target_qf_do_work); | ||
1134 | /* | ||
1135 | * Preload the initial INQUIRY const values if we are doing | ||
1136 | * anything virtual (IBLOCK, FILEIO, RAMDISK), but not for TCM/pSCSI | ||
1137 | * passthrough because this is being provided by the backend LLD. | ||
1138 | * This is required so that transport_get_inquiry() copies these | ||
1139 | * originals once back into DEV_T10_WWN(dev) for the virtual device | ||
1140 | * setup. | ||
1141 | */ | ||
1142 | if (dev->transport->transport_type != TRANSPORT_PLUGIN_PHBA_PDEV) { | ||
1143 | if (!inquiry_prod || !inquiry_rev) { | ||
1144 | pr_err("All non TCM/pSCSI plugins require" | ||
1145 | " INQUIRY consts\n"); | ||
1146 | goto err_wq; | ||
1147 | } | ||
1148 | |||
1149 | strncpy(&dev->se_sub_dev->t10_wwn.vendor[0], "LIO-ORG", 8); | ||
1150 | strncpy(&dev->se_sub_dev->t10_wwn.model[0], inquiry_prod, 16); | ||
1151 | strncpy(&dev->se_sub_dev->t10_wwn.revision[0], inquiry_rev, 4); | ||
1152 | } | ||
1153 | scsi_dump_inquiry(dev); | ||
1154 | |||
1155 | return dev; | ||
1156 | |||
1157 | err_wq: | ||
1158 | destroy_workqueue(dev->tmr_wq); | ||
1159 | err_dev_list: | ||
1160 | spin_lock(&hba->device_lock); | ||
1161 | list_del(&dev->dev_list); | ||
1162 | hba->dev_count--; | ||
1163 | spin_unlock(&hba->device_lock); | ||
1164 | |||
1165 | se_release_vpd_for_dev(dev); | ||
1166 | |||
1167 | kfree(dev); | ||
1168 | |||
1169 | return NULL; | ||
1170 | } | ||
1171 | EXPORT_SYMBOL(transport_add_device_to_core_hba); | ||
1172 | |||
1173 | int target_cmd_size_check(struct se_cmd *cmd, unsigned int size) | 980 | int target_cmd_size_check(struct se_cmd *cmd, unsigned int size) |
1174 | { | 981 | { |
1175 | struct se_device *dev = cmd->se_dev; | 982 | struct se_device *dev = cmd->se_dev; |
@@ -1191,7 +998,7 @@ int target_cmd_size_check(struct se_cmd *cmd, unsigned int size) | |||
1191 | * Reject READ_* or WRITE_* with overflow/underflow for | 998 | * Reject READ_* or WRITE_* with overflow/underflow for |
1192 | * type SCF_SCSI_DATA_CDB. | 999 | * type SCF_SCSI_DATA_CDB. |
1193 | */ | 1000 | */ |
1194 | if (dev->se_sub_dev->se_dev_attrib.block_size != 512) { | 1001 | if (dev->dev_attrib.block_size != 512) { |
1195 | pr_err("Failing OVERFLOW/UNDERFLOW for LBA op" | 1002 | pr_err("Failing OVERFLOW/UNDERFLOW for LBA op" |
1196 | " CDB on non 512-byte sector setup subsystem" | 1003 | " CDB on non 512-byte sector setup subsystem" |
1197 | " plugin: %s\n", dev->transport->name); | 1004 | " plugin: %s\n", dev->transport->name); |
@@ -1293,7 +1100,7 @@ int target_setup_cmd_from_cdb( | |||
1293 | struct se_cmd *cmd, | 1100 | struct se_cmd *cmd, |
1294 | unsigned char *cdb) | 1101 | unsigned char *cdb) |
1295 | { | 1102 | { |
1296 | struct se_subsystem_dev *su_dev = cmd->se_dev->se_sub_dev; | 1103 | struct se_device *dev = cmd->se_dev; |
1297 | u32 pr_reg_type = 0; | 1104 | u32 pr_reg_type = 0; |
1298 | u8 alua_ascq = 0; | 1105 | u8 alua_ascq = 0; |
1299 | unsigned long flags; | 1106 | unsigned long flags; |
@@ -1345,7 +1152,7 @@ int target_setup_cmd_from_cdb( | |||
1345 | return -EINVAL; | 1152 | return -EINVAL; |
1346 | } | 1153 | } |
1347 | 1154 | ||
1348 | ret = su_dev->t10_alua.alua_state_check(cmd, cdb, &alua_ascq); | 1155 | ret = dev->t10_alua.alua_state_check(cmd, cdb, &alua_ascq); |
1349 | if (ret != 0) { | 1156 | if (ret != 0) { |
1350 | /* | 1157 | /* |
1351 | * Set SCSI additional sense code (ASC) to 'LUN Not Accessible'; | 1158 | * Set SCSI additional sense code (ASC) to 'LUN Not Accessible'; |
@@ -1371,8 +1178,8 @@ int target_setup_cmd_from_cdb( | |||
1371 | /* | 1178 | /* |
1372 | * Check status for SPC-3 Persistent Reservations | 1179 | * Check status for SPC-3 Persistent Reservations |
1373 | */ | 1180 | */ |
1374 | if (su_dev->t10_pr.pr_ops.t10_reservation_check(cmd, &pr_reg_type)) { | 1181 | if (dev->t10_pr.pr_ops.t10_reservation_check(cmd, &pr_reg_type)) { |
1375 | if (su_dev->t10_pr.pr_ops.t10_seq_non_holder( | 1182 | if (dev->t10_pr.pr_ops.t10_seq_non_holder( |
1376 | cmd, cdb, pr_reg_type) != 0) { | 1183 | cmd, cdb, pr_reg_type) != 0) { |
1377 | cmd->se_cmd_flags |= SCF_SCSI_CDB_EXCEPTION; | 1184 | cmd->se_cmd_flags |= SCF_SCSI_CDB_EXCEPTION; |
1378 | cmd->se_cmd_flags |= SCF_SCSI_RESERVATION_CONFLICT; | 1185 | cmd->se_cmd_flags |= SCF_SCSI_RESERVATION_CONFLICT; |
@@ -1387,7 +1194,7 @@ int target_setup_cmd_from_cdb( | |||
1387 | */ | 1194 | */ |
1388 | } | 1195 | } |
1389 | 1196 | ||
1390 | ret = cmd->se_dev->transport->parse_cdb(cmd); | 1197 | ret = dev->transport->parse_cdb(cmd); |
1391 | if (ret < 0) | 1198 | if (ret < 0) |
1392 | return ret; | 1199 | return ret; |
1393 | 1200 | ||
@@ -1759,7 +1566,7 @@ void transport_generic_request_failure(struct se_cmd *cmd) | |||
1759 | * See spc4r17, section 7.4.6 Control Mode Page, Table 349 | 1566 | * See spc4r17, section 7.4.6 Control Mode Page, Table 349 |
1760 | */ | 1567 | */ |
1761 | if (cmd->se_sess && | 1568 | if (cmd->se_sess && |
1762 | cmd->se_dev->se_sub_dev->se_dev_attrib.emulate_ua_intlck_ctrl == 2) | 1569 | cmd->se_dev->dev_attrib.emulate_ua_intlck_ctrl == 2) |
1763 | core_scsi3_ua_allocate(cmd->se_sess->se_node_acl, | 1570 | core_scsi3_ua_allocate(cmd->se_sess->se_node_acl, |
1764 | cmd->orig_fe_lun, 0x2C, | 1571 | cmd->orig_fe_lun, 0x2C, |
1765 | ASCQ_2CH_PREVIOUS_RESERVATION_CONFLICT_STATUS); | 1572 | ASCQ_2CH_PREVIOUS_RESERVATION_CONFLICT_STATUS); |
diff --git a/drivers/target/target_core_ua.c b/drivers/target/target_core_ua.c index 6666a0c74f60..59c95ee14749 100644 --- a/drivers/target/target_core_ua.c +++ b/drivers/target/target_core_ua.c | |||
@@ -237,7 +237,7 @@ void core_scsi3_ua_for_check_condition( | |||
237 | * highest priority UNIT_ATTENTION and ASC/ASCQ without | 237 | * highest priority UNIT_ATTENTION and ASC/ASCQ without |
238 | * clearing it. | 238 | * clearing it. |
239 | */ | 239 | */ |
240 | if (dev->se_sub_dev->se_dev_attrib.emulate_ua_intlck_ctrl != 0) { | 240 | if (dev->dev_attrib.emulate_ua_intlck_ctrl != 0) { |
241 | *asc = ua->ua_asc; | 241 | *asc = ua->ua_asc; |
242 | *ascq = ua->ua_ascq; | 242 | *ascq = ua->ua_ascq; |
243 | break; | 243 | break; |
@@ -265,8 +265,8 @@ void core_scsi3_ua_for_check_condition( | |||
265 | " INTLCK_CTRL: %d, mapped LUN: %u, got CDB: 0x%02x" | 265 | " INTLCK_CTRL: %d, mapped LUN: %u, got CDB: 0x%02x" |
266 | " reported ASC: 0x%02x, ASCQ: 0x%02x\n", | 266 | " reported ASC: 0x%02x, ASCQ: 0x%02x\n", |
267 | nacl->se_tpg->se_tpg_tfo->get_fabric_name(), | 267 | nacl->se_tpg->se_tpg_tfo->get_fabric_name(), |
268 | (dev->se_sub_dev->se_dev_attrib.emulate_ua_intlck_ctrl != 0) ? "Reporting" : | 268 | (dev->dev_attrib.emulate_ua_intlck_ctrl != 0) ? "Reporting" : |
269 | "Releasing", dev->se_sub_dev->se_dev_attrib.emulate_ua_intlck_ctrl, | 269 | "Releasing", dev->dev_attrib.emulate_ua_intlck_ctrl, |
270 | cmd->orig_fe_lun, cmd->t_task_cdb[0], *asc, *ascq); | 270 | cmd->orig_fe_lun, cmd->t_task_cdb[0], *asc, *ascq); |
271 | } | 271 | } |
272 | 272 | ||
diff --git a/include/target/target_core_backend.h b/include/target/target_core_backend.h index 2acd54018b64..6c5bfb5ac17f 100644 --- a/include/target/target_core_backend.h +++ b/include/target/target_core_backend.h | |||
@@ -9,6 +9,8 @@ struct se_subsystem_api { | |||
9 | struct list_head sub_api_list; | 9 | struct list_head sub_api_list; |
10 | 10 | ||
11 | char name[16]; | 11 | char name[16]; |
12 | char inquiry_prod[16]; | ||
13 | char inquiry_rev[4]; | ||
12 | struct module *owner; | 14 | struct module *owner; |
13 | 15 | ||
14 | u8 transport_type; | 16 | u8 transport_type; |
@@ -16,21 +18,20 @@ struct se_subsystem_api { | |||
16 | int (*attach_hba)(struct se_hba *, u32); | 18 | int (*attach_hba)(struct se_hba *, u32); |
17 | void (*detach_hba)(struct se_hba *); | 19 | void (*detach_hba)(struct se_hba *); |
18 | int (*pmode_enable_hba)(struct se_hba *, unsigned long); | 20 | int (*pmode_enable_hba)(struct se_hba *, unsigned long); |
19 | void *(*allocate_virtdevice)(struct se_hba *, const char *); | 21 | |
20 | struct se_device *(*create_virtdevice)(struct se_hba *, | 22 | struct se_device *(*alloc_device)(struct se_hba *, const char *); |
21 | struct se_subsystem_dev *, void *); | 23 | int (*configure_device)(struct se_device *); |
22 | void (*free_device)(void *); | 24 | void (*free_device)(struct se_device *device); |
25 | |||
26 | ssize_t (*set_configfs_dev_params)(struct se_device *, | ||
27 | const char *, ssize_t); | ||
28 | ssize_t (*show_configfs_dev_params)(struct se_device *, char *); | ||
29 | |||
23 | void (*transport_complete)(struct se_cmd *cmd, | 30 | void (*transport_complete)(struct se_cmd *cmd, |
24 | struct scatterlist *, | 31 | struct scatterlist *, |
25 | unsigned char *); | 32 | unsigned char *); |
26 | 33 | ||
27 | int (*parse_cdb)(struct se_cmd *cmd); | 34 | int (*parse_cdb)(struct se_cmd *cmd); |
28 | ssize_t (*check_configfs_dev_params)(struct se_hba *, | ||
29 | struct se_subsystem_dev *); | ||
30 | ssize_t (*set_configfs_dev_params)(struct se_hba *, | ||
31 | struct se_subsystem_dev *, const char *, ssize_t); | ||
32 | ssize_t (*show_configfs_dev_params)(struct se_hba *, | ||
33 | struct se_subsystem_dev *, char *); | ||
34 | u32 (*get_device_rev)(struct se_device *); | 35 | u32 (*get_device_rev)(struct se_device *); |
35 | u32 (*get_device_type)(struct se_device *); | 36 | u32 (*get_device_type)(struct se_device *); |
36 | sector_t (*get_blocks)(struct se_device *); | 37 | sector_t (*get_blocks)(struct se_device *); |
@@ -47,10 +48,6 @@ struct spc_ops { | |||
47 | int transport_subsystem_register(struct se_subsystem_api *); | 48 | int transport_subsystem_register(struct se_subsystem_api *); |
48 | void transport_subsystem_release(struct se_subsystem_api *); | 49 | void transport_subsystem_release(struct se_subsystem_api *); |
49 | 50 | ||
50 | struct se_device *transport_add_device_to_core_hba(struct se_hba *, | ||
51 | struct se_subsystem_api *, struct se_subsystem_dev *, u32, | ||
52 | void *, struct se_dev_limits *, const char *, const char *); | ||
53 | |||
54 | void target_complete_cmd(struct se_cmd *, u8); | 51 | void target_complete_cmd(struct se_cmd *, u8); |
55 | 52 | ||
56 | int sbc_parse_cdb(struct se_cmd *cmd, struct spc_ops *ops); | 53 | int sbc_parse_cdb(struct se_cmd *cmd, struct spc_ops *ops); |
diff --git a/include/target/target_core_base.h b/include/target/target_core_base.h index 5be89373ceac..f6355fc325a8 100644 --- a/include/target/target_core_base.h +++ b/include/target/target_core_base.h | |||
@@ -62,20 +62,6 @@ | |||
62 | 62 | ||
63 | #define PYX_TRANSPORT_STATUS_INTERVAL 5 /* In seconds */ | 63 | #define PYX_TRANSPORT_STATUS_INTERVAL 5 /* In seconds */ |
64 | 64 | ||
65 | /* | ||
66 | * struct se_subsystem_dev->su_dev_flags | ||
67 | */ | ||
68 | #define SDF_FIRMWARE_VPD_UNIT_SERIAL 0x00000001 | ||
69 | #define SDF_EMULATED_VPD_UNIT_SERIAL 0x00000002 | ||
70 | #define SDF_USING_UDEV_PATH 0x00000004 | ||
71 | #define SDF_USING_ALIAS 0x00000008 | ||
72 | |||
73 | /* | ||
74 | * struct se_device->dev_flags | ||
75 | */ | ||
76 | #define DF_SPC2_RESERVATIONS 0x00000001 | ||
77 | #define DF_SPC2_RESERVATIONS_WITH_ISID 0x00000002 | ||
78 | |||
79 | /* struct se_dev_attrib sanity values */ | 65 | /* struct se_dev_attrib sanity values */ |
80 | /* Default max_unmap_lba_count */ | 66 | /* Default max_unmap_lba_count */ |
81 | #define DA_MAX_UNMAP_LBA_COUNT 0 | 67 | #define DA_MAX_UNMAP_LBA_COUNT 0 |
@@ -182,16 +168,6 @@ enum transport_lunflags_table { | |||
182 | TRANSPORT_LUNFLAGS_READ_WRITE = 0x04, | 168 | TRANSPORT_LUNFLAGS_READ_WRITE = 0x04, |
183 | }; | 169 | }; |
184 | 170 | ||
185 | /* struct se_device->dev_status */ | ||
186 | enum transport_device_status_table { | ||
187 | TRANSPORT_DEVICE_ACTIVATED = 0x01, | ||
188 | TRANSPORT_DEVICE_DEACTIVATED = 0x02, | ||
189 | TRANSPORT_DEVICE_QUEUE_FULL = 0x04, | ||
190 | TRANSPORT_DEVICE_SHUTDOWN = 0x08, | ||
191 | TRANSPORT_DEVICE_OFFLINE_ACTIVATED = 0x10, | ||
192 | TRANSPORT_DEVICE_OFFLINE_DEACTIVATED = 0x20, | ||
193 | }; | ||
194 | |||
195 | /* | 171 | /* |
196 | * Used by transport_send_check_condition_and_sense() and se_cmd->scsi_sense_reason | 172 | * Used by transport_send_check_condition_and_sense() and se_cmd->scsi_sense_reason |
197 | * to signal which ASC/ASCQ sense payload should be built. | 173 | * to signal which ASC/ASCQ sense payload should be built. |
@@ -246,10 +222,6 @@ enum tcm_tmrsp_table { | |||
246 | TMR_FUNCTION_REJECTED = 255, | 222 | TMR_FUNCTION_REJECTED = 255, |
247 | }; | 223 | }; |
248 | 224 | ||
249 | struct se_obj { | ||
250 | atomic_t obj_access_count; | ||
251 | }; | ||
252 | |||
253 | /* | 225 | /* |
254 | * Used by TCM Core internally to signal if ALUA emulation is enabled or | 226 | * Used by TCM Core internally to signal if ALUA emulation is enabled or |
255 | * disabled, or running in with TCM/pSCSI passthrough mode | 227 | * disabled, or running in with TCM/pSCSI passthrough mode |
@@ -288,7 +260,7 @@ struct t10_alua { | |||
288 | u16 alua_tg_pt_gps_counter; | 260 | u16 alua_tg_pt_gps_counter; |
289 | u32 alua_tg_pt_gps_count; | 261 | u32 alua_tg_pt_gps_count; |
290 | spinlock_t tg_pt_gps_lock; | 262 | spinlock_t tg_pt_gps_lock; |
291 | struct se_subsystem_dev *t10_sub_dev; | 263 | struct se_device *t10_dev; |
292 | /* Used for default ALUA Target Port Group */ | 264 | /* Used for default ALUA Target Port Group */ |
293 | struct t10_alua_tg_pt_gp *default_tg_pt_gp; | 265 | struct t10_alua_tg_pt_gp *default_tg_pt_gp; |
294 | /* Used for default ALUA Target Port Group ConfigFS group */ | 266 | /* Used for default ALUA Target Port Group ConfigFS group */ |
@@ -335,7 +307,7 @@ struct t10_alua_tg_pt_gp { | |||
335 | atomic_t tg_pt_gp_ref_cnt; | 307 | atomic_t tg_pt_gp_ref_cnt; |
336 | spinlock_t tg_pt_gp_lock; | 308 | spinlock_t tg_pt_gp_lock; |
337 | struct mutex tg_pt_gp_md_mutex; | 309 | struct mutex tg_pt_gp_md_mutex; |
338 | struct se_subsystem_dev *tg_pt_gp_su_dev; | 310 | struct se_device *tg_pt_gp_dev; |
339 | struct config_group tg_pt_gp_group; | 311 | struct config_group tg_pt_gp_group; |
340 | struct list_head tg_pt_gp_list; | 312 | struct list_head tg_pt_gp_list; |
341 | struct list_head tg_pt_gp_mem_list; | 313 | struct list_head tg_pt_gp_mem_list; |
@@ -366,7 +338,7 @@ struct t10_wwn { | |||
366 | char revision[4]; | 338 | char revision[4]; |
367 | char unit_serial[INQUIRY_VPD_SERIAL_LEN]; | 339 | char unit_serial[INQUIRY_VPD_SERIAL_LEN]; |
368 | spinlock_t t10_vpd_lock; | 340 | spinlock_t t10_vpd_lock; |
369 | struct se_subsystem_dev *t10_sub_dev; | 341 | struct se_device *t10_dev; |
370 | struct config_group t10_wwn_group; | 342 | struct config_group t10_wwn_group; |
371 | struct list_head t10_vpd_list; | 343 | struct list_head t10_vpd_list; |
372 | }; | 344 | }; |
@@ -662,15 +634,6 @@ struct se_dev_entry { | |||
662 | struct list_head ua_list; | 634 | struct list_head ua_list; |
663 | }; | 635 | }; |
664 | 636 | ||
665 | struct se_dev_limits { | ||
666 | /* Max supported HW queue depth */ | ||
667 | u32 hw_queue_depth; | ||
668 | /* Max supported virtual queue depth */ | ||
669 | u32 queue_depth; | ||
670 | /* From include/linux/blkdev.h for the other HW/SW limits. */ | ||
671 | struct queue_limits limits; | ||
672 | }; | ||
673 | |||
674 | struct se_dev_attrib { | 637 | struct se_dev_attrib { |
675 | int emulate_dpo; | 638 | int emulate_dpo; |
676 | int emulate_fua_write; | 639 | int emulate_fua_write; |
@@ -696,7 +659,7 @@ struct se_dev_attrib { | |||
696 | u32 max_unmap_block_desc_count; | 659 | u32 max_unmap_block_desc_count; |
697 | u32 unmap_granularity; | 660 | u32 unmap_granularity; |
698 | u32 unmap_granularity_alignment; | 661 | u32 unmap_granularity_alignment; |
699 | struct se_subsystem_dev *da_sub_dev; | 662 | struct se_device *da_dev; |
700 | struct config_group da_group; | 663 | struct config_group da_group; |
701 | }; | 664 | }; |
702 | 665 | ||
@@ -707,48 +670,24 @@ struct se_dev_stat_grps { | |||
707 | struct config_group scsi_lu_group; | 670 | struct config_group scsi_lu_group; |
708 | }; | 671 | }; |
709 | 672 | ||
710 | struct se_subsystem_dev { | ||
711 | /* Used for struct se_subsystem_dev-->se_dev_alias, must be less than PAGE_SIZE */ | ||
712 | #define SE_DEV_ALIAS_LEN 512 | ||
713 | unsigned char se_dev_alias[SE_DEV_ALIAS_LEN]; | ||
714 | /* Used for struct se_subsystem_dev->se_dev_udev_path[], must be less than PAGE_SIZE */ | ||
715 | #define SE_UDEV_PATH_LEN 512 | ||
716 | unsigned char se_dev_udev_path[SE_UDEV_PATH_LEN]; | ||
717 | u32 su_dev_flags; | ||
718 | struct se_hba *se_dev_hba; | ||
719 | struct se_device *se_dev_ptr; | ||
720 | struct se_dev_attrib se_dev_attrib; | ||
721 | /* T10 Asymmetric Logical Unit Assignment for Target Ports */ | ||
722 | struct t10_alua t10_alua; | ||
723 | /* T10 Inquiry and VPD WWN Information */ | ||
724 | struct t10_wwn t10_wwn; | ||
725 | /* T10 SPC-2 + SPC-3 Reservations */ | ||
726 | struct t10_reservation t10_pr; | ||
727 | spinlock_t se_dev_lock; | ||
728 | void *se_dev_su_ptr; | ||
729 | struct config_group se_dev_group; | ||
730 | /* For T10 Reservations */ | ||
731 | struct config_group se_dev_pr_group; | ||
732 | /* For target_core_stat.c groups */ | ||
733 | struct se_dev_stat_grps dev_stat_grps; | ||
734 | }; | ||
735 | |||
736 | struct se_device { | 673 | struct se_device { |
737 | /* RELATIVE TARGET PORT IDENTIFER Counter */ | 674 | /* RELATIVE TARGET PORT IDENTIFER Counter */ |
738 | u16 dev_rpti_counter; | 675 | u16 dev_rpti_counter; |
739 | /* Used for SAM Task Attribute ordering */ | 676 | /* Used for SAM Task Attribute ordering */ |
740 | u32 dev_cur_ordered_id; | 677 | u32 dev_cur_ordered_id; |
741 | u32 dev_flags; | 678 | u32 dev_flags; |
679 | #define DF_CONFIGURED 0x00000001 | ||
680 | #define DF_FIRMWARE_VPD_UNIT_SERIAL 0x00000002 | ||
681 | #define DF_EMULATED_VPD_UNIT_SERIAL 0x00000004 | ||
682 | #define DF_USING_UDEV_PATH 0x00000008 | ||
683 | #define DF_USING_ALIAS 0x00000010 | ||
742 | u32 dev_port_count; | 684 | u32 dev_port_count; |
743 | /* See transport_device_status_table */ | ||
744 | u32 dev_status; | ||
745 | /* Physical device queue depth */ | 685 | /* Physical device queue depth */ |
746 | u32 queue_depth; | 686 | u32 queue_depth; |
747 | /* Used for SPC-2 reservations enforce of ISIDs */ | 687 | /* Used for SPC-2 reservations enforce of ISIDs */ |
748 | u64 dev_res_bin_isid; | 688 | u64 dev_res_bin_isid; |
749 | t10_task_attr_index_t dev_task_attr_type; | 689 | t10_task_attr_index_t dev_task_attr_type; |
750 | /* Pointer to transport specific device structure */ | 690 | /* Pointer to transport specific device structure */ |
751 | void *dev_ptr; | ||
752 | u32 dev_index; | 691 | u32 dev_index; |
753 | u64 creation_time; | 692 | u64 creation_time; |
754 | u32 num_resets; | 693 | u32 num_resets; |
@@ -761,13 +700,13 @@ struct se_device { | |||
761 | atomic_t dev_ordered_id; | 700 | atomic_t dev_ordered_id; |
762 | atomic_t dev_ordered_sync; | 701 | atomic_t dev_ordered_sync; |
763 | atomic_t dev_qf_count; | 702 | atomic_t dev_qf_count; |
764 | struct se_obj dev_obj; | 703 | int export_count; |
765 | struct se_obj dev_access_obj; | ||
766 | struct se_obj dev_export_obj; | ||
767 | spinlock_t delayed_cmd_lock; | 704 | spinlock_t delayed_cmd_lock; |
768 | spinlock_t execute_task_lock; | 705 | spinlock_t execute_task_lock; |
769 | spinlock_t dev_reservation_lock; | 706 | spinlock_t dev_reservation_lock; |
770 | spinlock_t dev_status_lock; | 707 | unsigned int dev_reservation_flags; |
708 | #define DRF_SPC2_RESERVATIONS 0x00000001 | ||
709 | #define DRF_SPC2_RESERVATIONS_WITH_ISID 0x00000002 | ||
771 | spinlock_t se_port_lock; | 710 | spinlock_t se_port_lock; |
772 | spinlock_t se_tmr_lock; | 711 | spinlock_t se_tmr_lock; |
773 | spinlock_t qf_cmd_lock; | 712 | spinlock_t qf_cmd_lock; |
@@ -786,7 +725,20 @@ struct se_device { | |||
786 | struct list_head qf_cmd_list; | 725 | struct list_head qf_cmd_list; |
787 | /* Pointer to associated SE HBA */ | 726 | /* Pointer to associated SE HBA */ |
788 | struct se_hba *se_hba; | 727 | struct se_hba *se_hba; |
789 | struct se_subsystem_dev *se_sub_dev; | 728 | /* T10 Inquiry and VPD WWN Information */ |
729 | struct t10_wwn t10_wwn; | ||
730 | /* T10 Asymmetric Logical Unit Assignment for Target Ports */ | ||
731 | struct t10_alua t10_alua; | ||
732 | /* T10 SPC-2 + SPC-3 Reservations */ | ||
733 | struct t10_reservation t10_pr; | ||
734 | struct se_dev_attrib dev_attrib; | ||
735 | struct config_group dev_group; | ||
736 | struct config_group dev_pr_group; | ||
737 | struct se_dev_stat_grps dev_stat_grps; | ||
738 | #define SE_DEV_ALIAS_LEN 512 /* must be less than PAGE_SIZE */ | ||
739 | unsigned char dev_alias[SE_DEV_ALIAS_LEN]; | ||
740 | #define SE_UDEV_PATH_LEN 512 /* must be less than PAGE_SIZE */ | ||
741 | unsigned char udev_path[SE_UDEV_PATH_LEN]; | ||
790 | /* Pointer to template of function pointers for transport */ | 742 | /* Pointer to template of function pointers for transport */ |
791 | struct se_subsystem_api *transport; | 743 | struct se_subsystem_api *transport; |
792 | /* Linked list for struct se_hba struct se_device list */ | 744 | /* Linked list for struct se_hba struct se_device list */ |
@@ -803,8 +755,6 @@ struct se_hba { | |||
803 | u32 hba_index; | 755 | u32 hba_index; |
804 | /* Pointer to transport specific host structure. */ | 756 | /* Pointer to transport specific host structure. */ |
805 | void *hba_ptr; | 757 | void *hba_ptr; |
806 | /* Linked list for struct se_device */ | ||
807 | struct list_head hba_dev_list; | ||
808 | struct list_head hba_node; | 758 | struct list_head hba_node; |
809 | spinlock_t device_lock; | 759 | spinlock_t device_lock; |
810 | struct config_group hba_group; | 760 | struct config_group hba_group; |