提交 6708bb27 编写于 作者: A Andy Grover 提交者: Nicholas Bellinger

target: Follow up core updates from AGrover and HCH (round 4)

This patch contains the squashed version of forth round series cleanups
from Andy and Christoph following the post heavy lifting in the preceeding:
'Eliminate usage of struct se_mem' and 'Make all control CDBs scatter-gather'
changes.  This also includes a conversion of target core and the v3.0
mainline fabric modules (loopback and tcm_fc) to use pr_debug and the
CONFIG_DYNAMIC_DEBUG infrastructure!

These have been squashed into this third and final round for v3.1.

target: Remove ifdeffed code in t_g_process_write
target: Remove direct ramdisk code
target: Rename task_sg_num to task_sg_nents
target: Remove custom debug macros for pr_debug. Use pr_err().
target: Remove custom debug macros in mainline fabrics
target: Set WSNZ=1 in block limits VPD. Abort if WRITE_SAME sectors = 0
target: Remove transport do_se_mem_map callback
target: Further simplify transport_free_pages
target: Redo task allocation return value handling
target: Remove extra parentheses
target: change alloc_task call to take *cdb, not *cmd

(nab: Fix bogus struct file assignments in fd_do_readv and fd_do_writev)
Signed-off-by: NAndy Grover <agrover@redhat.com>
Reviewed-by: NChristoph Hellwig <hch@lst.de>
Signed-off-by: NNicholas Bellinger <nab@linux-iscsi.org>
上级 ec98f782
...@@ -3,9 +3,3 @@ config LOOPBACK_TARGET ...@@ -3,9 +3,3 @@ config LOOPBACK_TARGET
help help
Say Y here to enable the TCM Virtual SAS target and Linux/SCSI LLD Say Y here to enable the TCM Virtual SAS target and Linux/SCSI LLD
fabric loopback module. fabric loopback module.
config LOOPBACK_TARGET_CDB_DEBUG
bool "TCM loopback fabric module CDB debug code"
depends on LOOPBACK_TARGET
help
Say Y here to enable the TCM loopback fabric module CDB debug code
...@@ -79,7 +79,7 @@ static struct se_cmd *tcm_loop_allocate_core_cmd( ...@@ -79,7 +79,7 @@ static struct se_cmd *tcm_loop_allocate_core_cmd(
tl_cmd = kmem_cache_zalloc(tcm_loop_cmd_cache, GFP_ATOMIC); tl_cmd = kmem_cache_zalloc(tcm_loop_cmd_cache, GFP_ATOMIC);
if (!tl_cmd) { if (!tl_cmd) {
printk(KERN_ERR "Unable to allocate struct tcm_loop_cmd\n"); pr_err("Unable to allocate struct tcm_loop_cmd\n");
set_host_byte(sc, DID_ERROR); set_host_byte(sc, DID_ERROR);
return NULL; return NULL;
} }
...@@ -281,7 +281,7 @@ static int tcm_loop_queuecommand( ...@@ -281,7 +281,7 @@ static int tcm_loop_queuecommand(
struct tcm_loop_hba *tl_hba; struct tcm_loop_hba *tl_hba;
struct tcm_loop_tpg *tl_tpg; struct tcm_loop_tpg *tl_tpg;
TL_CDB_DEBUG("tcm_loop_queuecommand() %d:%d:%d:%d got CDB: 0x%02x" pr_debug("tcm_loop_queuecommand() %d:%d:%d:%d got CDB: 0x%02x"
" scsi_buf_len: %u\n", sc->device->host->host_no, " scsi_buf_len: %u\n", sc->device->host->host_no,
sc->device->id, sc->device->channel, sc->device->lun, sc->device->id, sc->device->channel, sc->device->lun,
sc->cmnd[0], scsi_bufflen(sc)); sc->cmnd[0], scsi_bufflen(sc));
...@@ -331,7 +331,7 @@ static int tcm_loop_device_reset(struct scsi_cmnd *sc) ...@@ -331,7 +331,7 @@ static int tcm_loop_device_reset(struct scsi_cmnd *sc)
*/ */
tl_nexus = tl_hba->tl_nexus; tl_nexus = tl_hba->tl_nexus;
if (!tl_nexus) { if (!tl_nexus) {
printk(KERN_ERR "Unable to perform device reset without" pr_err("Unable to perform device reset without"
" active I_T Nexus\n"); " active I_T Nexus\n");
return FAILED; return FAILED;
} }
...@@ -344,13 +344,13 @@ static int tcm_loop_device_reset(struct scsi_cmnd *sc) ...@@ -344,13 +344,13 @@ static int tcm_loop_device_reset(struct scsi_cmnd *sc)
tl_cmd = kmem_cache_zalloc(tcm_loop_cmd_cache, GFP_KERNEL); tl_cmd = kmem_cache_zalloc(tcm_loop_cmd_cache, GFP_KERNEL);
if (!tl_cmd) { if (!tl_cmd) {
printk(KERN_ERR "Unable to allocate memory for tl_cmd\n"); pr_err("Unable to allocate memory for tl_cmd\n");
return FAILED; return FAILED;
} }
tl_tmr = kzalloc(sizeof(struct tcm_loop_tmr), GFP_KERNEL); tl_tmr = kzalloc(sizeof(struct tcm_loop_tmr), GFP_KERNEL);
if (!tl_tmr) { if (!tl_tmr) {
printk(KERN_ERR "Unable to allocate memory for tl_tmr\n"); pr_err("Unable to allocate memory for tl_tmr\n");
goto release; goto release;
} }
init_waitqueue_head(&tl_tmr->tl_tmr_wait); init_waitqueue_head(&tl_tmr->tl_tmr_wait);
...@@ -435,7 +435,7 @@ static int tcm_loop_driver_probe(struct device *dev) ...@@ -435,7 +435,7 @@ static int tcm_loop_driver_probe(struct device *dev)
sh = scsi_host_alloc(&tcm_loop_driver_template, sh = scsi_host_alloc(&tcm_loop_driver_template,
sizeof(struct tcm_loop_hba)); sizeof(struct tcm_loop_hba));
if (!sh) { if (!sh) {
printk(KERN_ERR "Unable to allocate struct scsi_host\n"); pr_err("Unable to allocate struct scsi_host\n");
return -ENODEV; return -ENODEV;
} }
tl_hba->sh = sh; tl_hba->sh = sh;
...@@ -454,7 +454,7 @@ static int tcm_loop_driver_probe(struct device *dev) ...@@ -454,7 +454,7 @@ static int tcm_loop_driver_probe(struct device *dev)
error = scsi_add_host(sh, &tl_hba->dev); error = scsi_add_host(sh, &tl_hba->dev);
if (error) { if (error) {
printk(KERN_ERR "%s: scsi_add_host failed\n", __func__); pr_err("%s: scsi_add_host failed\n", __func__);
scsi_host_put(sh); scsi_host_put(sh);
return -ENODEV; return -ENODEV;
} }
...@@ -495,7 +495,7 @@ static int tcm_loop_setup_hba_bus(struct tcm_loop_hba *tl_hba, int tcm_loop_host ...@@ -495,7 +495,7 @@ static int tcm_loop_setup_hba_bus(struct tcm_loop_hba *tl_hba, int tcm_loop_host
ret = device_register(&tl_hba->dev); ret = device_register(&tl_hba->dev);
if (ret) { if (ret) {
printk(KERN_ERR "device_register() failed for" pr_err("device_register() failed for"
" tl_hba->dev: %d\n", ret); " tl_hba->dev: %d\n", ret);
return -ENODEV; return -ENODEV;
} }
...@@ -513,24 +513,24 @@ static int tcm_loop_alloc_core_bus(void) ...@@ -513,24 +513,24 @@ static int tcm_loop_alloc_core_bus(void)
tcm_loop_primary = root_device_register("tcm_loop_0"); tcm_loop_primary = root_device_register("tcm_loop_0");
if (IS_ERR(tcm_loop_primary)) { if (IS_ERR(tcm_loop_primary)) {
printk(KERN_ERR "Unable to allocate tcm_loop_primary\n"); pr_err("Unable to allocate tcm_loop_primary\n");
return PTR_ERR(tcm_loop_primary); return PTR_ERR(tcm_loop_primary);
} }
ret = bus_register(&tcm_loop_lld_bus); ret = bus_register(&tcm_loop_lld_bus);
if (ret) { if (ret) {
printk(KERN_ERR "bus_register() failed for tcm_loop_lld_bus\n"); pr_err("bus_register() failed for tcm_loop_lld_bus\n");
goto dev_unreg; goto dev_unreg;
} }
ret = driver_register(&tcm_loop_driverfs); ret = driver_register(&tcm_loop_driverfs);
if (ret) { if (ret) {
printk(KERN_ERR "driver_register() failed for" pr_err("driver_register() failed for"
"tcm_loop_driverfs\n"); "tcm_loop_driverfs\n");
goto bus_unreg; goto bus_unreg;
} }
printk(KERN_INFO "Initialized TCM Loop Core Bus\n"); pr_debug("Initialized TCM Loop Core Bus\n");
return ret; return ret;
bus_unreg: bus_unreg:
...@@ -546,7 +546,7 @@ static void tcm_loop_release_core_bus(void) ...@@ -546,7 +546,7 @@ static void tcm_loop_release_core_bus(void)
bus_unregister(&tcm_loop_lld_bus); bus_unregister(&tcm_loop_lld_bus);
root_device_unregister(tcm_loop_primary); root_device_unregister(tcm_loop_primary);
printk(KERN_INFO "Releasing TCM Loop Core BUS\n"); pr_debug("Releasing TCM Loop Core BUS\n");
} }
static char *tcm_loop_get_fabric_name(void) static char *tcm_loop_get_fabric_name(void)
...@@ -574,7 +574,7 @@ static u8 tcm_loop_get_fabric_proto_ident(struct se_portal_group *se_tpg) ...@@ -574,7 +574,7 @@ static u8 tcm_loop_get_fabric_proto_ident(struct se_portal_group *se_tpg)
case SCSI_PROTOCOL_ISCSI: case SCSI_PROTOCOL_ISCSI:
return iscsi_get_fabric_proto_ident(se_tpg); return iscsi_get_fabric_proto_ident(se_tpg);
default: default:
printk(KERN_ERR "Unknown tl_proto_id: 0x%02x, using" pr_err("Unknown tl_proto_id: 0x%02x, using"
" SAS emulation\n", tl_hba->tl_proto_id); " SAS emulation\n", tl_hba->tl_proto_id);
break; break;
} }
...@@ -630,7 +630,7 @@ static u32 tcm_loop_get_pr_transport_id( ...@@ -630,7 +630,7 @@ static u32 tcm_loop_get_pr_transport_id(
return iscsi_get_pr_transport_id(se_tpg, se_nacl, pr_reg, return iscsi_get_pr_transport_id(se_tpg, se_nacl, pr_reg,
format_code, buf); format_code, buf);
default: default:
printk(KERN_ERR "Unknown tl_proto_id: 0x%02x, using" pr_err("Unknown tl_proto_id: 0x%02x, using"
" SAS emulation\n", tl_hba->tl_proto_id); " SAS emulation\n", tl_hba->tl_proto_id);
break; break;
} }
...@@ -660,7 +660,7 @@ static u32 tcm_loop_get_pr_transport_id_len( ...@@ -660,7 +660,7 @@ static u32 tcm_loop_get_pr_transport_id_len(
return iscsi_get_pr_transport_id_len(se_tpg, se_nacl, pr_reg, return iscsi_get_pr_transport_id_len(se_tpg, se_nacl, pr_reg,
format_code); format_code);
default: default:
printk(KERN_ERR "Unknown tl_proto_id: 0x%02x, using" pr_err("Unknown tl_proto_id: 0x%02x, using"
" SAS emulation\n", tl_hba->tl_proto_id); " SAS emulation\n", tl_hba->tl_proto_id);
break; break;
} }
...@@ -694,7 +694,7 @@ static char *tcm_loop_parse_pr_out_transport_id( ...@@ -694,7 +694,7 @@ static char *tcm_loop_parse_pr_out_transport_id(
return iscsi_parse_pr_out_transport_id(se_tpg, buf, out_tid_len, return iscsi_parse_pr_out_transport_id(se_tpg, buf, out_tid_len,
port_nexus_ptr); port_nexus_ptr);
default: default:
printk(KERN_ERR "Unknown tl_proto_id: 0x%02x, using" pr_err("Unknown tl_proto_id: 0x%02x, using"
" SAS emulation\n", tl_hba->tl_proto_id); " SAS emulation\n", tl_hba->tl_proto_id);
break; break;
} }
...@@ -743,7 +743,7 @@ static struct se_node_acl *tcm_loop_tpg_alloc_fabric_acl( ...@@ -743,7 +743,7 @@ static struct se_node_acl *tcm_loop_tpg_alloc_fabric_acl(
tl_nacl = kzalloc(sizeof(struct tcm_loop_nacl), GFP_KERNEL); tl_nacl = kzalloc(sizeof(struct tcm_loop_nacl), GFP_KERNEL);
if (!tl_nacl) { if (!tl_nacl) {
printk(KERN_ERR "Unable to allocate struct tcm_loop_nacl\n"); pr_err("Unable to allocate struct tcm_loop_nacl\n");
return NULL; return NULL;
} }
...@@ -853,7 +853,7 @@ static int tcm_loop_queue_data_in(struct se_cmd *se_cmd) ...@@ -853,7 +853,7 @@ static int tcm_loop_queue_data_in(struct se_cmd *se_cmd)
struct tcm_loop_cmd, tl_se_cmd); struct tcm_loop_cmd, tl_se_cmd);
struct scsi_cmnd *sc = tl_cmd->sc; struct scsi_cmnd *sc = tl_cmd->sc;
TL_CDB_DEBUG("tcm_loop_queue_data_in() called for scsi_cmnd: %p" pr_debug("tcm_loop_queue_data_in() called for scsi_cmnd: %p"
" cdb: 0x%02x\n", sc, sc->cmnd[0]); " cdb: 0x%02x\n", sc, sc->cmnd[0]);
sc->result = SAM_STAT_GOOD; sc->result = SAM_STAT_GOOD;
...@@ -868,7 +868,7 @@ static int tcm_loop_queue_status(struct se_cmd *se_cmd) ...@@ -868,7 +868,7 @@ static int tcm_loop_queue_status(struct se_cmd *se_cmd)
struct tcm_loop_cmd, tl_se_cmd); struct tcm_loop_cmd, tl_se_cmd);
struct scsi_cmnd *sc = tl_cmd->sc; struct scsi_cmnd *sc = tl_cmd->sc;
TL_CDB_DEBUG("tcm_loop_queue_status() called for scsi_cmnd: %p" pr_debug("tcm_loop_queue_status() called for scsi_cmnd: %p"
" cdb: 0x%02x\n", sc, sc->cmnd[0]); " cdb: 0x%02x\n", sc, sc->cmnd[0]);
if (se_cmd->sense_buffer && if (se_cmd->sense_buffer &&
...@@ -943,7 +943,7 @@ static int tcm_loop_port_link( ...@@ -943,7 +943,7 @@ static int tcm_loop_port_link(
*/ */
scsi_add_device(tl_hba->sh, 0, tl_tpg->tl_tpgt, lun->unpacked_lun); scsi_add_device(tl_hba->sh, 0, tl_tpg->tl_tpgt, lun->unpacked_lun);
printk(KERN_INFO "TCM_Loop_ConfigFS: Port Link Successful\n"); pr_debug("TCM_Loop_ConfigFS: Port Link Successful\n");
return 0; return 0;
} }
...@@ -961,7 +961,7 @@ static void tcm_loop_port_unlink( ...@@ -961,7 +961,7 @@ static void tcm_loop_port_unlink(
sd = scsi_device_lookup(tl_hba->sh, 0, tl_tpg->tl_tpgt, sd = scsi_device_lookup(tl_hba->sh, 0, tl_tpg->tl_tpgt,
se_lun->unpacked_lun); se_lun->unpacked_lun);
if (!sd) { if (!sd) {
printk(KERN_ERR "Unable to locate struct scsi_device for %d:%d:" pr_err("Unable to locate struct scsi_device for %d:%d:"
"%d\n", 0, tl_tpg->tl_tpgt, se_lun->unpacked_lun); "%d\n", 0, tl_tpg->tl_tpgt, se_lun->unpacked_lun);
return; return;
} }
...@@ -974,7 +974,7 @@ static void tcm_loop_port_unlink( ...@@ -974,7 +974,7 @@ static void tcm_loop_port_unlink(
atomic_dec(&tl_tpg->tl_tpg_port_count); atomic_dec(&tl_tpg->tl_tpg_port_count);
smp_mb__after_atomic_dec(); smp_mb__after_atomic_dec();
printk(KERN_INFO "TCM_Loop_ConfigFS: Port Unlink Successful\n"); pr_debug("TCM_Loop_ConfigFS: Port Unlink Successful\n");
} }
/* End items for tcm_loop_port_cit */ /* End items for tcm_loop_port_cit */
...@@ -991,14 +991,14 @@ static int tcm_loop_make_nexus( ...@@ -991,14 +991,14 @@ static int tcm_loop_make_nexus(
int ret = -ENOMEM; int ret = -ENOMEM;
if (tl_tpg->tl_hba->tl_nexus) { if (tl_tpg->tl_hba->tl_nexus) {
printk(KERN_INFO "tl_tpg->tl_hba->tl_nexus already exists\n"); pr_debug("tl_tpg->tl_hba->tl_nexus already exists\n");
return -EEXIST; return -EEXIST;
} }
se_tpg = &tl_tpg->tl_se_tpg; se_tpg = &tl_tpg->tl_se_tpg;
tl_nexus = kzalloc(sizeof(struct tcm_loop_nexus), GFP_KERNEL); tl_nexus = kzalloc(sizeof(struct tcm_loop_nexus), GFP_KERNEL);
if (!tl_nexus) { if (!tl_nexus) {
printk(KERN_ERR "Unable to allocate struct tcm_loop_nexus\n"); pr_err("Unable to allocate struct tcm_loop_nexus\n");
return -ENOMEM; return -ENOMEM;
} }
/* /*
...@@ -1027,7 +1027,7 @@ static int tcm_loop_make_nexus( ...@@ -1027,7 +1027,7 @@ static int tcm_loop_make_nexus(
__transport_register_session(se_tpg, tl_nexus->se_sess->se_node_acl, __transport_register_session(se_tpg, tl_nexus->se_sess->se_node_acl,
tl_nexus->se_sess, tl_nexus); tl_nexus->se_sess, tl_nexus);
tl_tpg->tl_hba->tl_nexus = tl_nexus; tl_tpg->tl_hba->tl_nexus = tl_nexus;
printk(KERN_INFO "TCM_Loop_ConfigFS: Established I_T Nexus to emulated" pr_debug("TCM_Loop_ConfigFS: Established I_T Nexus to emulated"
" %s Initiator Port: %s\n", tcm_loop_dump_proto_id(tl_hba), " %s Initiator Port: %s\n", tcm_loop_dump_proto_id(tl_hba),
name); name);
return 0; return 0;
...@@ -1053,13 +1053,13 @@ static int tcm_loop_drop_nexus( ...@@ -1053,13 +1053,13 @@ static int tcm_loop_drop_nexus(
return -ENODEV; return -ENODEV;
if (atomic_read(&tpg->tl_tpg_port_count)) { if (atomic_read(&tpg->tl_tpg_port_count)) {
printk(KERN_ERR "Unable to remove TCM_Loop I_T Nexus with" pr_err("Unable to remove TCM_Loop I_T Nexus with"
" active TPG port count: %d\n", " active TPG port count: %d\n",
atomic_read(&tpg->tl_tpg_port_count)); atomic_read(&tpg->tl_tpg_port_count));
return -EPERM; return -EPERM;
} }
printk(KERN_INFO "TCM_Loop_ConfigFS: Removing I_T Nexus to emulated" pr_debug("TCM_Loop_ConfigFS: Removing I_T Nexus to emulated"
" %s Initiator Port: %s\n", tcm_loop_dump_proto_id(tl_hba), " %s Initiator Port: %s\n", tcm_loop_dump_proto_id(tl_hba),
tl_nexus->se_sess->se_node_acl->initiatorname); tl_nexus->se_sess->se_node_acl->initiatorname);
/* /*
...@@ -1115,7 +1115,7 @@ static ssize_t tcm_loop_tpg_store_nexus( ...@@ -1115,7 +1115,7 @@ static ssize_t tcm_loop_tpg_store_nexus(
* tcm_loop_make_nexus() * tcm_loop_make_nexus()
*/ */
if (strlen(page) >= TL_WWN_ADDR_LEN) { if (strlen(page) >= TL_WWN_ADDR_LEN) {
printk(KERN_ERR "Emulated NAA Sas Address: %s, exceeds" pr_err("Emulated NAA Sas Address: %s, exceeds"
" max: %d\n", page, TL_WWN_ADDR_LEN); " max: %d\n", page, TL_WWN_ADDR_LEN);
return -EINVAL; return -EINVAL;
} }
...@@ -1124,7 +1124,7 @@ static ssize_t tcm_loop_tpg_store_nexus( ...@@ -1124,7 +1124,7 @@ static ssize_t tcm_loop_tpg_store_nexus(
ptr = strstr(i_port, "naa."); ptr = strstr(i_port, "naa.");
if (ptr) { if (ptr) {
if (tl_hba->tl_proto_id != SCSI_PROTOCOL_SAS) { if (tl_hba->tl_proto_id != SCSI_PROTOCOL_SAS) {
printk(KERN_ERR "Passed SAS Initiator Port %s does not" pr_err("Passed SAS Initiator Port %s does not"
" match target port protoid: %s\n", i_port, " match target port protoid: %s\n", i_port,
tcm_loop_dump_proto_id(tl_hba)); tcm_loop_dump_proto_id(tl_hba));
return -EINVAL; return -EINVAL;
...@@ -1135,7 +1135,7 @@ static ssize_t tcm_loop_tpg_store_nexus( ...@@ -1135,7 +1135,7 @@ static ssize_t tcm_loop_tpg_store_nexus(
ptr = strstr(i_port, "fc."); ptr = strstr(i_port, "fc.");
if (ptr) { if (ptr) {
if (tl_hba->tl_proto_id != SCSI_PROTOCOL_FCP) { if (tl_hba->tl_proto_id != SCSI_PROTOCOL_FCP) {
printk(KERN_ERR "Passed FCP Initiator Port %s does not" pr_err("Passed FCP Initiator Port %s does not"
" match target port protoid: %s\n", i_port, " match target port protoid: %s\n", i_port,
tcm_loop_dump_proto_id(tl_hba)); tcm_loop_dump_proto_id(tl_hba));
return -EINVAL; return -EINVAL;
...@@ -1146,7 +1146,7 @@ static ssize_t tcm_loop_tpg_store_nexus( ...@@ -1146,7 +1146,7 @@ static ssize_t tcm_loop_tpg_store_nexus(
ptr = strstr(i_port, "iqn."); ptr = strstr(i_port, "iqn.");
if (ptr) { if (ptr) {
if (tl_hba->tl_proto_id != SCSI_PROTOCOL_ISCSI) { if (tl_hba->tl_proto_id != SCSI_PROTOCOL_ISCSI) {
printk(KERN_ERR "Passed iSCSI Initiator Port %s does not" pr_err("Passed iSCSI Initiator Port %s does not"
" match target port protoid: %s\n", i_port, " match target port protoid: %s\n", i_port,
tcm_loop_dump_proto_id(tl_hba)); tcm_loop_dump_proto_id(tl_hba));
return -EINVAL; return -EINVAL;
...@@ -1154,7 +1154,7 @@ static ssize_t tcm_loop_tpg_store_nexus( ...@@ -1154,7 +1154,7 @@ static ssize_t tcm_loop_tpg_store_nexus(
port_ptr = &i_port[0]; port_ptr = &i_port[0];
goto check_newline; goto check_newline;
} }
printk(KERN_ERR "Unable to locate prefix for emulated Initiator Port:" pr_err("Unable to locate prefix for emulated Initiator Port:"
" %s\n", i_port); " %s\n", i_port);
return -EINVAL; return -EINVAL;
/* /*
...@@ -1194,7 +1194,7 @@ struct se_portal_group *tcm_loop_make_naa_tpg( ...@@ -1194,7 +1194,7 @@ struct se_portal_group *tcm_loop_make_naa_tpg(
tpgt_str = strstr(name, "tpgt_"); tpgt_str = strstr(name, "tpgt_");
if (!tpgt_str) { if (!tpgt_str) {
printk(KERN_ERR "Unable to locate \"tpgt_#\" directory" pr_err("Unable to locate \"tpgt_#\" directory"
" group\n"); " group\n");
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);
} }
...@@ -1202,7 +1202,7 @@ struct se_portal_group *tcm_loop_make_naa_tpg( ...@@ -1202,7 +1202,7 @@ struct se_portal_group *tcm_loop_make_naa_tpg(
tpgt = (unsigned short int) simple_strtoul(tpgt_str, &end_ptr, 0); tpgt = (unsigned short int) simple_strtoul(tpgt_str, &end_ptr, 0);
if (tpgt >= TL_TPGS_PER_HBA) { if (tpgt >= TL_TPGS_PER_HBA) {
printk(KERN_ERR "Passed tpgt: %hu exceeds TL_TPGS_PER_HBA:" pr_err("Passed tpgt: %hu exceeds TL_TPGS_PER_HBA:"
" %u\n", tpgt, TL_TPGS_PER_HBA); " %u\n", tpgt, TL_TPGS_PER_HBA);
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);
} }
...@@ -1218,7 +1218,7 @@ struct se_portal_group *tcm_loop_make_naa_tpg( ...@@ -1218,7 +1218,7 @@ struct se_portal_group *tcm_loop_make_naa_tpg(
if (ret < 0) if (ret < 0)
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
printk(KERN_INFO "TCM_Loop_ConfigFS: Allocated Emulated %s" pr_debug("TCM_Loop_ConfigFS: Allocated Emulated %s"
" Target Port %s,t,0x%04x\n", tcm_loop_dump_proto_id(tl_hba), " Target Port %s,t,0x%04x\n", tcm_loop_dump_proto_id(tl_hba),
config_item_name(&wwn->wwn_group.cg_item), tpgt); config_item_name(&wwn->wwn_group.cg_item), tpgt);
...@@ -1245,7 +1245,7 @@ void tcm_loop_drop_naa_tpg( ...@@ -1245,7 +1245,7 @@ void tcm_loop_drop_naa_tpg(
*/ */
core_tpg_deregister(se_tpg); core_tpg_deregister(se_tpg);
printk(KERN_INFO "TCM_Loop_ConfigFS: Deallocated Emulated %s" pr_debug("TCM_Loop_ConfigFS: Deallocated Emulated %s"
" Target Port %s,t,0x%04x\n", tcm_loop_dump_proto_id(tl_hba), " Target Port %s,t,0x%04x\n", tcm_loop_dump_proto_id(tl_hba),
config_item_name(&wwn->wwn_group.cg_item), tpgt); config_item_name(&wwn->wwn_group.cg_item), tpgt);
} }
...@@ -1266,7 +1266,7 @@ struct se_wwn *tcm_loop_make_scsi_hba( ...@@ -1266,7 +1266,7 @@ struct se_wwn *tcm_loop_make_scsi_hba(
tl_hba = kzalloc(sizeof(struct tcm_loop_hba), GFP_KERNEL); tl_hba = kzalloc(sizeof(struct tcm_loop_hba), GFP_KERNEL);
if (!tl_hba) { if (!tl_hba) {
printk(KERN_ERR "Unable to allocate struct tcm_loop_hba\n"); pr_err("Unable to allocate struct tcm_loop_hba\n");
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
} }
/* /*
...@@ -1286,7 +1286,7 @@ struct se_wwn *tcm_loop_make_scsi_hba( ...@@ -1286,7 +1286,7 @@ struct se_wwn *tcm_loop_make_scsi_hba(
} }
ptr = strstr(name, "iqn."); ptr = strstr(name, "iqn.");
if (!ptr) { if (!ptr) {
printk(KERN_ERR "Unable to locate prefix for emulated Target " pr_err("Unable to locate prefix for emulated Target "
"Port: %s\n", name); "Port: %s\n", name);
ret = -EINVAL; ret = -EINVAL;
goto out; goto out;
...@@ -1295,7 +1295,7 @@ struct se_wwn *tcm_loop_make_scsi_hba( ...@@ -1295,7 +1295,7 @@ struct se_wwn *tcm_loop_make_scsi_hba(
check_len: check_len:
if (strlen(name) >= TL_WWN_ADDR_LEN) { if (strlen(name) >= TL_WWN_ADDR_LEN) {
printk(KERN_ERR "Emulated NAA %s Address: %s, exceeds" pr_err("Emulated NAA %s Address: %s, exceeds"
" max: %d\n", name, tcm_loop_dump_proto_id(tl_hba), " max: %d\n", name, tcm_loop_dump_proto_id(tl_hba),
TL_WWN_ADDR_LEN); TL_WWN_ADDR_LEN);
ret = -EINVAL; ret = -EINVAL;
...@@ -1314,7 +1314,7 @@ struct se_wwn *tcm_loop_make_scsi_hba( ...@@ -1314,7 +1314,7 @@ struct se_wwn *tcm_loop_make_scsi_hba(
sh = tl_hba->sh; sh = tl_hba->sh;
tcm_loop_hba_no_cnt++; tcm_loop_hba_no_cnt++;
printk(KERN_INFO "TCM_Loop_ConfigFS: Allocated emulated Target" pr_debug("TCM_Loop_ConfigFS: Allocated emulated Target"
" %s Address: %s at Linux/SCSI Host ID: %d\n", " %s Address: %s at Linux/SCSI Host ID: %d\n",
tcm_loop_dump_proto_id(tl_hba), name, sh->host_no); tcm_loop_dump_proto_id(tl_hba), name, sh->host_no);
...@@ -1337,7 +1337,7 @@ void tcm_loop_drop_scsi_hba( ...@@ -1337,7 +1337,7 @@ void tcm_loop_drop_scsi_hba(
*/ */
device_unregister(&tl_hba->dev); device_unregister(&tl_hba->dev);
printk(KERN_INFO "TCM_Loop_ConfigFS: Deallocated emulated Target" pr_debug("TCM_Loop_ConfigFS: Deallocated emulated Target"
" SAS Address: %s at Linux/SCSI Host ID: %d\n", " SAS Address: %s at Linux/SCSI Host ID: %d\n",
config_item_name(&wwn->wwn_group.cg_item), host_no); config_item_name(&wwn->wwn_group.cg_item), host_no);
} }
...@@ -1373,7 +1373,7 @@ static int tcm_loop_register_configfs(void) ...@@ -1373,7 +1373,7 @@ static int tcm_loop_register_configfs(void)
*/ */
fabric = target_fabric_configfs_init(THIS_MODULE, "loopback"); fabric = target_fabric_configfs_init(THIS_MODULE, "loopback");
if (IS_ERR(fabric)) { if (IS_ERR(fabric)) {
printk(KERN_ERR "tcm_loop_register_configfs() failed!\n"); pr_err("tcm_loop_register_configfs() failed!\n");
return PTR_ERR(fabric); return PTR_ERR(fabric);
} }
/* /*
...@@ -1464,7 +1464,7 @@ static int tcm_loop_register_configfs(void) ...@@ -1464,7 +1464,7 @@ static int tcm_loop_register_configfs(void)
*/ */
ret = target_fabric_configfs_register(fabric); ret = target_fabric_configfs_register(fabric);
if (ret < 0) { if (ret < 0) {
printk(KERN_ERR "target_fabric_configfs_register() for" pr_err("target_fabric_configfs_register() for"
" TCM_Loop failed!\n"); " TCM_Loop failed!\n");
target_fabric_configfs_free(fabric); target_fabric_configfs_free(fabric);
return -1; return -1;
...@@ -1473,7 +1473,7 @@ static int tcm_loop_register_configfs(void) ...@@ -1473,7 +1473,7 @@ static int tcm_loop_register_configfs(void)
* Setup our local pointer to *fabric. * Setup our local pointer to *fabric.
*/ */
tcm_loop_fabric_configfs = fabric; tcm_loop_fabric_configfs = fabric;
printk(KERN_INFO "TCM_LOOP[0] - Set fabric ->" pr_debug("TCM_LOOP[0] - Set fabric ->"
" tcm_loop_fabric_configfs\n"); " tcm_loop_fabric_configfs\n");
return 0; return 0;
} }
...@@ -1485,7 +1485,7 @@ static void tcm_loop_deregister_configfs(void) ...@@ -1485,7 +1485,7 @@ static void tcm_loop_deregister_configfs(void)
target_fabric_configfs_deregister(tcm_loop_fabric_configfs); target_fabric_configfs_deregister(tcm_loop_fabric_configfs);
tcm_loop_fabric_configfs = NULL; tcm_loop_fabric_configfs = NULL;
printk(KERN_INFO "TCM_LOOP[0] - Cleared" pr_debug("TCM_LOOP[0] - Cleared"
" tcm_loop_fabric_configfs\n"); " tcm_loop_fabric_configfs\n");
} }
...@@ -1498,7 +1498,7 @@ static int __init tcm_loop_fabric_init(void) ...@@ -1498,7 +1498,7 @@ static int __init tcm_loop_fabric_init(void)
__alignof__(struct tcm_loop_cmd), __alignof__(struct tcm_loop_cmd),
0, NULL); 0, NULL);
if (!tcm_loop_cmd_cache) { if (!tcm_loop_cmd_cache) {
printk(KERN_ERR "kmem_cache_create() for" pr_debug("kmem_cache_create() for"
" tcm_loop_cmd_cache failed\n"); " tcm_loop_cmd_cache failed\n");
return -ENOMEM; return -ENOMEM;
} }
......
...@@ -16,12 +16,6 @@ ...@@ -16,12 +16,6 @@
*/ */
#define TL_SCSI_MAX_CMD_LEN 32 #define TL_SCSI_MAX_CMD_LEN 32
#ifdef CONFIG_LOOPBACK_TARGET_CDB_DEBUG
# define TL_CDB_DEBUG(x...) printk(KERN_INFO x)
#else
# define TL_CDB_DEBUG(x...)
#endif
struct tcm_loop_cmd { struct tcm_loop_cmd {
/* State of Linux/SCSI CDB+Data descriptor */ /* State of Linux/SCSI CDB+Data descriptor */
u32 sc_cmd_state; u32 sc_cmd_state;
......
此差异已折叠。
...@@ -73,7 +73,7 @@ target_emulate_inquiry_std(struct se_cmd *cmd) ...@@ -73,7 +73,7 @@ target_emulate_inquiry_std(struct se_cmd *cmd)
* payload going back for EVPD=0 * payload going back for EVPD=0
*/ */
if (cmd->data_length < 6) { if (cmd->data_length < 6) {
printk(KERN_ERR "SCSI Inquiry payload length: %u" pr_err("SCSI Inquiry payload length: %u"
" too small for EVPD=0\n", cmd->data_length); " too small for EVPD=0\n", cmd->data_length);
return -EINVAL; return -EINVAL;
} }
...@@ -327,7 +327,7 @@ target_emulate_evpd_83(struct se_cmd *cmd, unsigned char *buf) ...@@ -327,7 +327,7 @@ target_emulate_evpd_83(struct se_cmd *cmd, unsigned char *buf)
spin_lock(&tg_pt_gp_mem->tg_pt_gp_mem_lock); spin_lock(&tg_pt_gp_mem->tg_pt_gp_mem_lock);
tg_pt_gp = tg_pt_gp_mem->tg_pt_gp; tg_pt_gp = tg_pt_gp_mem->tg_pt_gp;
if (!(tg_pt_gp)) { if (!tg_pt_gp) {
spin_unlock(&tg_pt_gp_mem->tg_pt_gp_mem_lock); spin_unlock(&tg_pt_gp_mem->tg_pt_gp_mem_lock);
goto check_lu_gp; goto check_lu_gp;
} }
...@@ -358,12 +358,12 @@ target_emulate_evpd_83(struct se_cmd *cmd, unsigned char *buf) ...@@ -358,12 +358,12 @@ target_emulate_evpd_83(struct se_cmd *cmd, unsigned char *buf)
goto check_scsi_name; goto check_scsi_name;
} }
lu_gp_mem = dev->dev_alua_lu_gp_mem; lu_gp_mem = dev->dev_alua_lu_gp_mem;
if (!(lu_gp_mem)) if (!lu_gp_mem)
goto check_scsi_name; goto check_scsi_name;
spin_lock(&lu_gp_mem->lu_gp_mem_lock); spin_lock(&lu_gp_mem->lu_gp_mem_lock);
lu_gp = lu_gp_mem->lu_gp; lu_gp = lu_gp_mem->lu_gp;
if (!(lu_gp)) { if (!lu_gp) {
spin_unlock(&lu_gp_mem->lu_gp_mem_lock); spin_unlock(&lu_gp_mem->lu_gp_mem_lock);
goto check_scsi_name; goto check_scsi_name;
} }
...@@ -475,14 +475,14 @@ target_emulate_evpd_b0(struct se_cmd *cmd, unsigned char *buf) ...@@ -475,14 +475,14 @@ target_emulate_evpd_b0(struct se_cmd *cmd, unsigned char *buf)
have_tp = 1; have_tp = 1;
if (cmd->data_length < (0x10 + 4)) { if (cmd->data_length < (0x10 + 4)) {
printk(KERN_INFO "Received data_length: %u" pr_debug("Received data_length: %u"
" too small for EVPD 0xb0\n", " too small for EVPD 0xb0\n",
cmd->data_length); cmd->data_length);
return -EINVAL; return -EINVAL;
} }
if (have_tp && cmd->data_length < (0x3c + 4)) { if (have_tp && cmd->data_length < (0x3c + 4)) {
printk(KERN_INFO "Received data_length: %u" pr_debug("Received data_length: %u"
" too small for TPE=1 EVPD 0xb0\n", " too small for TPE=1 EVPD 0xb0\n",
cmd->data_length); cmd->data_length);
have_tp = 0; have_tp = 0;
...@@ -491,6 +491,9 @@ target_emulate_evpd_b0(struct se_cmd *cmd, unsigned char *buf) ...@@ -491,6 +491,9 @@ target_emulate_evpd_b0(struct se_cmd *cmd, unsigned char *buf)
buf[0] = dev->transport->get_device_type(dev); buf[0] = dev->transport->get_device_type(dev);
buf[3] = have_tp ? 0x3c : 0x10; buf[3] = have_tp ? 0x3c : 0x10;
/* Set WSNZ to 1 */
buf[4] = 0x01;
/* /*
* Set OPTIMAL TRANSFER LENGTH GRANULARITY * Set OPTIMAL TRANSFER LENGTH GRANULARITY
*/ */
...@@ -667,7 +670,7 @@ target_emulate_inquiry(struct se_cmd *cmd) ...@@ -667,7 +670,7 @@ target_emulate_inquiry(struct se_cmd *cmd)
* payload length left for the next outgoing EVPD metadata * payload length left for the next outgoing EVPD metadata
*/ */
if (cmd->data_length < 4) { if (cmd->data_length < 4) {
printk(KERN_ERR "SCSI Inquiry payload length: %u" pr_err("SCSI Inquiry payload length: %u"
" too small for EVPD=1\n", cmd->data_length); " too small for EVPD=1\n", cmd->data_length);
return -EINVAL; return -EINVAL;
} }
...@@ -685,7 +688,7 @@ target_emulate_inquiry(struct se_cmd *cmd) ...@@ -685,7 +688,7 @@ target_emulate_inquiry(struct se_cmd *cmd)
} }
transport_kunmap_first_data_page(cmd); transport_kunmap_first_data_page(cmd);
printk(KERN_ERR "Unknown VPD Code: 0x%02x\n", cdb[2]); pr_err("Unknown VPD Code: 0x%02x\n", cdb[2]);
return -EINVAL; return -EINVAL;
} }
...@@ -891,7 +894,7 @@ target_emulate_modesense(struct se_cmd *cmd, int ten) ...@@ -891,7 +894,7 @@ target_emulate_modesense(struct se_cmd *cmd, int ten)
length += target_modesense_control(dev, &buf[offset+length]); length += target_modesense_control(dev, &buf[offset+length]);
break; break;
default: default:
printk(KERN_ERR "Got Unknown Mode Page: 0x%02x\n", pr_err("Got Unknown Mode Page: 0x%02x\n",
cdb[2] & 0x3f); cdb[2] & 0x3f);
return PYX_TRANSPORT_UNKNOWN_MODE_PAGE; return PYX_TRANSPORT_UNKNOWN_MODE_PAGE;
} }
...@@ -947,14 +950,14 @@ target_emulate_request_sense(struct se_cmd *cmd) ...@@ -947,14 +950,14 @@ target_emulate_request_sense(struct se_cmd *cmd)
int err = 0; int err = 0;
if (cdb[1] & 0x01) { if (cdb[1] & 0x01) {
printk(KERN_ERR "REQUEST_SENSE description emulation not" pr_err("REQUEST_SENSE description emulation not"
" supported\n"); " supported\n");
return PYX_TRANSPORT_INVALID_CDB_FIELD; return PYX_TRANSPORT_INVALID_CDB_FIELD;
} }
buf = transport_kmap_first_data_page(cmd); buf = transport_kmap_first_data_page(cmd);
if (!(core_scsi3_ua_clear_for_request_sense(cmd, &ua_asc, &ua_ascq))) { if (!core_scsi3_ua_clear_for_request_sense(cmd, &ua_asc, &ua_ascq)) {
/* /*
* CURRENT ERROR, UNIT ATTENTION * CURRENT ERROR, UNIT ATTENTION
*/ */
...@@ -1028,18 +1031,18 @@ target_emulate_unmap(struct se_task *task) ...@@ -1028,18 +1031,18 @@ target_emulate_unmap(struct se_task *task)
buf = transport_kmap_first_data_page(cmd); buf = transport_kmap_first_data_page(cmd);
ptr = &buf[offset]; ptr = &buf[offset];
printk(KERN_INFO "UNMAP: Sub: %s Using dl: %hu bd_dl: %hu size: %hu" pr_debug("UNMAP: Sub: %s Using dl: %hu bd_dl: %hu size: %hu"
" ptr: %p\n", dev->transport->name, dl, bd_dl, size, ptr); " ptr: %p\n", dev->transport->name, dl, bd_dl, size, ptr);
while (size) { while (size) {
lba = get_unaligned_be64(&ptr[0]); lba = get_unaligned_be64(&ptr[0]);
range = get_unaligned_be32(&ptr[8]); range = get_unaligned_be32(&ptr[8]);
printk(KERN_INFO "UNMAP: Using lba: %llu and range: %u\n", pr_debug("UNMAP: Using lba: %llu and range: %u\n",
(unsigned long long)lba, range); (unsigned long long)lba, range);
ret = dev->transport->do_discard(dev, lba, range); ret = dev->transport->do_discard(dev, lba, range);
if (ret < 0) { if (ret < 0) {
printk(KERN_ERR "blkdev_issue_discard() failed: %d\n", pr_err("blkdev_issue_discard() failed: %d\n",
ret); ret);
goto err; goto err;
} }
...@@ -1084,12 +1087,12 @@ target_emulate_write_same(struct se_task *task, int write_same32) ...@@ -1084,12 +1087,12 @@ target_emulate_write_same(struct se_task *task, int write_same32)
else else
range = (dev->transport->get_blocks(dev) - lba); range = (dev->transport->get_blocks(dev) - lba);
printk(KERN_INFO "WRITE_SAME UNMAP: LBA: %llu Range: %llu\n", pr_debug("WRITE_SAME UNMAP: LBA: %llu Range: %llu\n",
(unsigned long long)lba, (unsigned long long)range); (unsigned long long)lba, (unsigned long long)range);
ret = dev->transport->do_discard(dev, lba, range); ret = dev->transport->do_discard(dev, lba, range);
if (ret < 0) { if (ret < 0) {
printk(KERN_INFO "blkdev_issue_discard() failed for WRITE_SAME\n"); pr_debug("blkdev_issue_discard() failed for WRITE_SAME\n");
return ret; return ret;
} }
...@@ -1125,7 +1128,7 @@ transport_emulate_control_cdb(struct se_task *task) ...@@ -1125,7 +1128,7 @@ transport_emulate_control_cdb(struct se_task *task)
ret = target_emulate_readcapacity_16(cmd); ret = target_emulate_readcapacity_16(cmd);
break; break;
default: default:
printk(KERN_ERR "Unsupported SA: 0x%02x\n", pr_err("Unsupported SA: 0x%02x\n",
cmd->t_task_cdb[1] & 0x1f); cmd->t_task_cdb[1] & 0x1f);
return PYX_TRANSPORT_UNKNOWN_SAM_OPCODE; return PYX_TRANSPORT_UNKNOWN_SAM_OPCODE;
} }
...@@ -1135,7 +1138,7 @@ transport_emulate_control_cdb(struct se_task *task) ...@@ -1135,7 +1138,7 @@ transport_emulate_control_cdb(struct se_task *task)
break; break;
case UNMAP: case UNMAP:
if (!dev->transport->do_discard) { if (!dev->transport->do_discard) {
printk(KERN_ERR "UNMAP emulation not supported for: %s\n", pr_err("UNMAP emulation not supported for: %s\n",
dev->transport->name); dev->transport->name);
return PYX_TRANSPORT_UNKNOWN_SAM_OPCODE; return PYX_TRANSPORT_UNKNOWN_SAM_OPCODE;
} }
...@@ -1143,7 +1146,7 @@ transport_emulate_control_cdb(struct se_task *task) ...@@ -1143,7 +1146,7 @@ transport_emulate_control_cdb(struct se_task *task)
break; break;
case WRITE_SAME_16: case WRITE_SAME_16:
if (!dev->transport->do_discard) { if (!dev->transport->do_discard) {
printk(KERN_ERR "WRITE_SAME_16 emulation not supported" pr_err("WRITE_SAME_16 emulation not supported"
" for: %s\n", dev->transport->name); " for: %s\n", dev->transport->name);
return PYX_TRANSPORT_UNKNOWN_SAM_OPCODE; return PYX_TRANSPORT_UNKNOWN_SAM_OPCODE;
} }
...@@ -1155,7 +1158,7 @@ transport_emulate_control_cdb(struct se_task *task) ...@@ -1155,7 +1158,7 @@ transport_emulate_control_cdb(struct se_task *task)
switch (service_action) { switch (service_action) {
case WRITE_SAME_32: case WRITE_SAME_32:
if (!dev->transport->do_discard) { if (!dev->transport->do_discard) {
printk(KERN_ERR "WRITE_SAME_32 SA emulation not" pr_err("WRITE_SAME_32 SA emulation not"
" supported for: %s\n", " supported for: %s\n",
dev->transport->name); dev->transport->name);
return PYX_TRANSPORT_UNKNOWN_SAM_OPCODE; return PYX_TRANSPORT_UNKNOWN_SAM_OPCODE;
...@@ -1163,7 +1166,7 @@ transport_emulate_control_cdb(struct se_task *task) ...@@ -1163,7 +1166,7 @@ transport_emulate_control_cdb(struct se_task *task)
ret = target_emulate_write_same(task, 1); ret = target_emulate_write_same(task, 1);
break; break;
default: default:
printk(KERN_ERR "Unsupported VARIABLE_LENGTH_CMD SA:" pr_err("Unsupported VARIABLE_LENGTH_CMD SA:"
" 0x%02x\n", service_action); " 0x%02x\n", service_action);
break; break;
} }
...@@ -1171,8 +1174,7 @@ transport_emulate_control_cdb(struct se_task *task) ...@@ -1171,8 +1174,7 @@ transport_emulate_control_cdb(struct se_task *task)
case SYNCHRONIZE_CACHE: case SYNCHRONIZE_CACHE:
case 0x91: /* SYNCHRONIZE_CACHE_16: */ case 0x91: /* SYNCHRONIZE_CACHE_16: */
if (!dev->transport->do_sync_cache) { if (!dev->transport->do_sync_cache) {
printk(KERN_ERR pr_err("SYNCHRONIZE_CACHE emulation not supported"
"SYNCHRONIZE_CACHE emulation not supported"
" for: %s\n", dev->transport->name); " for: %s\n", dev->transport->name);
return PYX_TRANSPORT_UNKNOWN_SAM_OPCODE; return PYX_TRANSPORT_UNKNOWN_SAM_OPCODE;
} }
...@@ -1189,7 +1191,7 @@ transport_emulate_control_cdb(struct se_task *task) ...@@ -1189,7 +1191,7 @@ transport_emulate_control_cdb(struct se_task *task)
case WRITE_FILEMARKS: case WRITE_FILEMARKS:
break; break;
default: default:
printk(KERN_ERR "Unsupported SCSI Opcode: 0x%02x for %s\n", pr_err("Unsupported SCSI Opcode: 0x%02x for %s\n",
cmd->t_task_cdb[0], dev->transport->name); cmd->t_task_cdb[0], dev->transport->name);
return PYX_TRANSPORT_UNKNOWN_SAM_OPCODE; return PYX_TRANSPORT_UNKNOWN_SAM_OPCODE;
} }
......
此差异已折叠。
...@@ -60,7 +60,7 @@ static void target_fabric_setup_##_name##_cit(struct target_fabric_configfs *tf) ...@@ -60,7 +60,7 @@ static void target_fabric_setup_##_name##_cit(struct target_fabric_configfs *tf)
cit->ct_group_ops = _group_ops; \ cit->ct_group_ops = _group_ops; \
cit->ct_attrs = _attrs; \ cit->ct_attrs = _attrs; \
cit->ct_owner = tf->tf_module; \ cit->ct_owner = tf->tf_module; \
printk("Setup generic %s\n", __stringify(_name)); \ pr_debug("Setup generic %s\n", __stringify(_name)); \
} }
/* Start of tfc_tpg_mappedlun_cit */ /* Start of tfc_tpg_mappedlun_cit */
...@@ -80,8 +80,8 @@ static int target_fabric_mappedlun_link( ...@@ -80,8 +80,8 @@ static int target_fabric_mappedlun_link(
/* /*
* Ensure that the source port exists * Ensure that the source port exists
*/ */
if (!(lun->lun_sep) || !(lun->lun_sep->sep_tpg)) { if (!lun->lun_sep || !lun->lun_sep->sep_tpg) {
printk(KERN_ERR "Source se_lun->lun_sep or lun->lun_sep->sep" pr_err("Source se_lun->lun_sep or lun->lun_sep->sep"
"_tpg does not exist\n"); "_tpg does not exist\n");
return -EINVAL; return -EINVAL;
} }
...@@ -96,12 +96,12 @@ static int target_fabric_mappedlun_link( ...@@ -96,12 +96,12 @@ static int target_fabric_mappedlun_link(
* Make sure the SymLink is going to the same $FABRIC/$WWN/tpgt_$TPGT * Make sure the SymLink is going to the same $FABRIC/$WWN/tpgt_$TPGT
*/ */
if (strcmp(config_item_name(wwn_ci), config_item_name(wwn_ci_s))) { if (strcmp(config_item_name(wwn_ci), config_item_name(wwn_ci_s))) {
printk(KERN_ERR "Illegal Initiator ACL SymLink outside of %s\n", pr_err("Illegal Initiator ACL SymLink outside of %s\n",
config_item_name(wwn_ci)); config_item_name(wwn_ci));
return -EINVAL; return -EINVAL;
} }
if (strcmp(config_item_name(tpg_ci), config_item_name(tpg_ci_s))) { if (strcmp(config_item_name(tpg_ci), config_item_name(tpg_ci_s))) {
printk(KERN_ERR "Illegal Initiator ACL Symlink outside of %s" pr_err("Illegal Initiator ACL Symlink outside of %s"
" TPGT: %s\n", config_item_name(wwn_ci), " TPGT: %s\n", config_item_name(wwn_ci),
config_item_name(tpg_ci)); config_item_name(tpg_ci));
return -EINVAL; return -EINVAL;
...@@ -147,7 +147,7 @@ static int target_fabric_mappedlun_unlink( ...@@ -147,7 +147,7 @@ static int target_fabric_mappedlun_unlink(
/* /*
* Determine if the underlying MappedLUN has already been released.. * Determine if the underlying MappedLUN has already been released..
*/ */
if (!(deve->se_lun)) if (!deve->se_lun)
return 0; return 0;
lun = container_of(to_config_group(lun_ci), struct se_lun, lun_group); lun = container_of(to_config_group(lun_ci), struct se_lun, lun_group);
...@@ -202,7 +202,7 @@ static ssize_t target_fabric_mappedlun_store_write_protect( ...@@ -202,7 +202,7 @@ static ssize_t target_fabric_mappedlun_store_write_protect(
TRANSPORT_LUNFLAGS_READ_WRITE, TRANSPORT_LUNFLAGS_READ_WRITE,
lacl->se_lun_nacl); lacl->se_lun_nacl);
printk(KERN_INFO "%s_ConfigFS: Changed Initiator ACL: %s" pr_debug("%s_ConfigFS: Changed Initiator ACL: %s"
" Mapped LUN: %u Write Protect bit to %s\n", " Mapped LUN: %u Write Protect bit to %s\n",
se_tpg->se_tpg_tfo->get_fabric_name(), se_tpg->se_tpg_tfo->get_fabric_name(),
lacl->initiatorname, lacl->mapped_lun, (op) ? "ON" : "OFF"); lacl->initiatorname, lacl->mapped_lun, (op) ? "ON" : "OFF");
...@@ -327,14 +327,14 @@ static struct config_group *target_fabric_make_mappedlun( ...@@ -327,14 +327,14 @@ static struct config_group *target_fabric_make_mappedlun(
int ret = 0; int ret = 0;
acl_ci = &group->cg_item; acl_ci = &group->cg_item;
if (!(acl_ci)) { if (!acl_ci) {
printk(KERN_ERR "Unable to locatel acl_ci\n"); pr_err("Unable to locatel acl_ci\n");
return NULL; return NULL;
} }
buf = kzalloc(strlen(name) + 1, GFP_KERNEL); buf = kzalloc(strlen(name) + 1, GFP_KERNEL);
if (!(buf)) { if (!buf) {
printk(KERN_ERR "Unable to allocate memory for name buf\n"); pr_err("Unable to allocate memory for name buf\n");
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
} }
snprintf(buf, strlen(name) + 1, "%s", name); snprintf(buf, strlen(name) + 1, "%s", name);
...@@ -342,7 +342,7 @@ static struct config_group *target_fabric_make_mappedlun( ...@@ -342,7 +342,7 @@ static struct config_group *target_fabric_make_mappedlun(
* Make sure user is creating iscsi/$IQN/$TPGT/acls/$INITIATOR/lun_$ID. * Make sure user is creating iscsi/$IQN/$TPGT/acls/$INITIATOR/lun_$ID.
*/ */
if (strstr(buf, "lun_") != buf) { if (strstr(buf, "lun_") != buf) {
printk(KERN_ERR "Unable to locate \"lun_\" from buf: %s" pr_err("Unable to locate \"lun_\" from buf: %s"
" name: %s\n", buf, name); " name: %s\n", buf, name);
ret = -EINVAL; ret = -EINVAL;
goto out; goto out;
...@@ -358,7 +358,7 @@ static struct config_group *target_fabric_make_mappedlun( ...@@ -358,7 +358,7 @@ static struct config_group *target_fabric_make_mappedlun(
lacl = core_dev_init_initiator_node_lun_acl(se_tpg, mapped_lun, lacl = core_dev_init_initiator_node_lun_acl(se_tpg, mapped_lun,
config_item_name(acl_ci), &ret); config_item_name(acl_ci), &ret);
if (!(lacl)) { if (!lacl) {
ret = -EINVAL; ret = -EINVAL;
goto out; goto out;
} }
...@@ -367,7 +367,7 @@ static struct config_group *target_fabric_make_mappedlun( ...@@ -367,7 +367,7 @@ static struct config_group *target_fabric_make_mappedlun(
lacl_cg->default_groups = kzalloc(sizeof(struct config_group) * 2, lacl_cg->default_groups = kzalloc(sizeof(struct config_group) * 2,
GFP_KERNEL); GFP_KERNEL);
if (!lacl_cg->default_groups) { if (!lacl_cg->default_groups) {
printk(KERN_ERR "Unable to allocate lacl_cg->default_groups\n"); pr_err("Unable to allocate lacl_cg->default_groups\n");
ret = -ENOMEM; ret = -ENOMEM;
goto out; goto out;
} }
...@@ -383,7 +383,7 @@ static struct config_group *target_fabric_make_mappedlun( ...@@ -383,7 +383,7 @@ static struct config_group *target_fabric_make_mappedlun(
ml_stat_grp->default_groups = kzalloc(sizeof(struct config_group) * 3, ml_stat_grp->default_groups = kzalloc(sizeof(struct config_group) * 3,
GFP_KERNEL); GFP_KERNEL);
if (!ml_stat_grp->default_groups) { if (!ml_stat_grp->default_groups) {
printk(KERN_ERR "Unable to allocate ml_stat_grp->default_groups\n"); pr_err("Unable to allocate ml_stat_grp->default_groups\n");
ret = -ENOMEM; ret = -ENOMEM;
goto out; goto out;
} }
...@@ -474,8 +474,8 @@ static struct config_group *target_fabric_make_nodeacl( ...@@ -474,8 +474,8 @@ static struct config_group *target_fabric_make_nodeacl(
struct se_node_acl *se_nacl; struct se_node_acl *se_nacl;
struct config_group *nacl_cg; struct config_group *nacl_cg;
if (!(tf->tf_ops.fabric_make_nodeacl)) { if (!tf->tf_ops.fabric_make_nodeacl) {
printk(KERN_ERR "tf->tf_ops.fabric_make_nodeacl is NULL\n"); pr_err("tf->tf_ops.fabric_make_nodeacl is NULL\n");
return ERR_PTR(-ENOSYS); return ERR_PTR(-ENOSYS);
} }
...@@ -572,13 +572,13 @@ static struct config_group *target_fabric_make_np( ...@@ -572,13 +572,13 @@ static struct config_group *target_fabric_make_np(
struct target_fabric_configfs *tf = se_tpg->se_tpg_wwn->wwn_tf; struct target_fabric_configfs *tf = se_tpg->se_tpg_wwn->wwn_tf;
struct se_tpg_np *se_tpg_np; struct se_tpg_np *se_tpg_np;
if (!(tf->tf_ops.fabric_make_np)) { if (!tf->tf_ops.fabric_make_np) {
printk(KERN_ERR "tf->tf_ops.fabric_make_np is NULL\n"); pr_err("tf->tf_ops.fabric_make_np is NULL\n");
return ERR_PTR(-ENOSYS); return ERR_PTR(-ENOSYS);
} }
se_tpg_np = tf->tf_ops.fabric_make_np(se_tpg, group, name); se_tpg_np = tf->tf_ops.fabric_make_np(se_tpg, group, name);
if (!(se_tpg_np) || IS_ERR(se_tpg_np)) if (!se_tpg_np || IS_ERR(se_tpg_np))
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);
se_tpg_np->tpg_np_parent = se_tpg; se_tpg_np->tpg_np_parent = se_tpg;
...@@ -627,10 +627,7 @@ static ssize_t target_fabric_port_show_attr_alua_tg_pt_gp( ...@@ -627,10 +627,7 @@ static ssize_t target_fabric_port_show_attr_alua_tg_pt_gp(
struct se_lun *lun, struct se_lun *lun,
char *page) char *page)
{ {
if (!(lun)) if (!lun || !lun->lun_sep)
return -ENODEV;
if (!(lun->lun_sep))
return -ENODEV; return -ENODEV;
return core_alua_show_tg_pt_gp_info(lun->lun_sep, page); return core_alua_show_tg_pt_gp_info(lun->lun_sep, page);
...@@ -641,10 +638,7 @@ static ssize_t target_fabric_port_store_attr_alua_tg_pt_gp( ...@@ -641,10 +638,7 @@ static ssize_t target_fabric_port_store_attr_alua_tg_pt_gp(
const char *page, const char *page,
size_t count) size_t count)
{ {
if (!(lun)) if (!lun || !lun->lun_sep)
return -ENODEV;
if (!(lun->lun_sep))
return -ENODEV; return -ENODEV;
return core_alua_store_tg_pt_gp_info(lun->lun_sep, page, count); return core_alua_store_tg_pt_gp_info(lun->lun_sep, page, count);
...@@ -659,10 +653,7 @@ static ssize_t target_fabric_port_show_attr_alua_tg_pt_offline( ...@@ -659,10 +653,7 @@ static ssize_t target_fabric_port_show_attr_alua_tg_pt_offline(
struct se_lun *lun, struct se_lun *lun,
char *page) char *page)
{ {
if (!(lun)) if (!lun || !lun->lun_sep)
return -ENODEV;
if (!(lun->lun_sep))
return -ENODEV; return -ENODEV;
return core_alua_show_offline_bit(lun, page); return core_alua_show_offline_bit(lun, page);
...@@ -673,10 +664,7 @@ static ssize_t target_fabric_port_store_attr_alua_tg_pt_offline( ...@@ -673,10 +664,7 @@ static ssize_t target_fabric_port_store_attr_alua_tg_pt_offline(
const char *page, const char *page,
size_t count) size_t count)
{ {
if (!(lun)) if (!lun || !lun->lun_sep)
return -ENODEV;
if (!(lun->lun_sep))
return -ENODEV; return -ENODEV;
return core_alua_store_offline_bit(lun, page, count); return core_alua_store_offline_bit(lun, page, count);
...@@ -691,10 +679,7 @@ static ssize_t target_fabric_port_show_attr_alua_tg_pt_status( ...@@ -691,10 +679,7 @@ static ssize_t target_fabric_port_show_attr_alua_tg_pt_status(
struct se_lun *lun, struct se_lun *lun,
char *page) char *page)
{ {
if (!(lun)) if (!lun || !lun->lun_sep)
return -ENODEV;
if (!(lun->lun_sep))
return -ENODEV; return -ENODEV;
return core_alua_show_secondary_status(lun, page); return core_alua_show_secondary_status(lun, page);
...@@ -705,10 +690,7 @@ static ssize_t target_fabric_port_store_attr_alua_tg_pt_status( ...@@ -705,10 +690,7 @@ static ssize_t target_fabric_port_store_attr_alua_tg_pt_status(
const char *page, const char *page,
size_t count) size_t count)
{ {
if (!(lun)) if (!lun || !lun->lun_sep)
return -ENODEV;
if (!(lun->lun_sep))
return -ENODEV; return -ENODEV;
return core_alua_store_secondary_status(lun, page, count); return core_alua_store_secondary_status(lun, page, count);
...@@ -723,10 +705,7 @@ static ssize_t target_fabric_port_show_attr_alua_tg_pt_write_md( ...@@ -723,10 +705,7 @@ static ssize_t target_fabric_port_show_attr_alua_tg_pt_write_md(
struct se_lun *lun, struct se_lun *lun,
char *page) char *page)
{ {
if (!(lun)) if (!lun || !lun->lun_sep)
return -ENODEV;
if (!(lun->lun_sep))
return -ENODEV; return -ENODEV;
return core_alua_show_secondary_write_metadata(lun, page); return core_alua_show_secondary_write_metadata(lun, page);
...@@ -737,10 +716,7 @@ static ssize_t target_fabric_port_store_attr_alua_tg_pt_write_md( ...@@ -737,10 +716,7 @@ static ssize_t target_fabric_port_store_attr_alua_tg_pt_write_md(
const char *page, const char *page,
size_t count) size_t count)
{ {
if (!(lun)) if (!lun || !lun->lun_sep)
return -ENODEV;
if (!(lun->lun_sep))
return -ENODEV; return -ENODEV;
return core_alua_store_secondary_write_metadata(lun, page, count); return core_alua_store_secondary_write_metadata(lun, page, count);
...@@ -781,13 +757,13 @@ static int target_fabric_port_link( ...@@ -781,13 +757,13 @@ static int target_fabric_port_link(
tf = se_tpg->se_tpg_wwn->wwn_tf; tf = se_tpg->se_tpg_wwn->wwn_tf;
if (lun->lun_se_dev != NULL) { if (lun->lun_se_dev != NULL) {
printk(KERN_ERR "Port Symlink already exists\n"); pr_err("Port Symlink already exists\n");
return -EEXIST; return -EEXIST;
} }
dev = se_dev->se_dev_ptr; dev = se_dev->se_dev_ptr;
if (!(dev)) { if (!dev) {
printk(KERN_ERR "Unable to locate struct se_device pointer from" pr_err("Unable to locate struct se_device pointer from"
" %s\n", config_item_name(se_dev_ci)); " %s\n", config_item_name(se_dev_ci));
ret = -ENODEV; ret = -ENODEV;
goto out; goto out;
...@@ -795,8 +771,8 @@ static int target_fabric_port_link( ...@@ -795,8 +771,8 @@ static int target_fabric_port_link(
lun_p = core_dev_add_lun(se_tpg, dev->se_hba, dev, lun_p = core_dev_add_lun(se_tpg, dev->se_hba, dev,
lun->unpacked_lun); lun->unpacked_lun);
if ((IS_ERR(lun_p)) || !(lun_p)) { if (IS_ERR(lun_p) || !lun_p) {
printk(KERN_ERR "core_dev_add_lun() failed\n"); pr_err("core_dev_add_lun() failed\n");
ret = -EINVAL; ret = -EINVAL;
goto out; goto out;
} }
...@@ -888,7 +864,7 @@ static struct config_group *target_fabric_make_lun( ...@@ -888,7 +864,7 @@ static struct config_group *target_fabric_make_lun(
int errno; int errno;
if (strstr(name, "lun_") != name) { if (strstr(name, "lun_") != name) {
printk(KERN_ERR "Unable to locate \'_\" in" pr_err("Unable to locate \'_\" in"
" \"lun_$LUN_NUMBER\"\n"); " \"lun_$LUN_NUMBER\"\n");
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);
} }
...@@ -896,14 +872,14 @@ static struct config_group *target_fabric_make_lun( ...@@ -896,14 +872,14 @@ static struct config_group *target_fabric_make_lun(
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);
lun = core_get_lun_from_tpg(se_tpg, unpacked_lun); lun = core_get_lun_from_tpg(se_tpg, unpacked_lun);
if (!(lun)) if (!lun)
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);
lun_cg = &lun->lun_group; lun_cg = &lun->lun_group;
lun_cg->default_groups = kzalloc(sizeof(struct config_group) * 2, lun_cg->default_groups = kzalloc(sizeof(struct config_group) * 2,
GFP_KERNEL); GFP_KERNEL);
if (!lun_cg->default_groups) { if (!lun_cg->default_groups) {
printk(KERN_ERR "Unable to allocate lun_cg->default_groups\n"); pr_err("Unable to allocate lun_cg->default_groups\n");
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
} }
...@@ -918,7 +894,7 @@ static struct config_group *target_fabric_make_lun( ...@@ -918,7 +894,7 @@ static struct config_group *target_fabric_make_lun(
port_stat_grp->default_groups = kzalloc(sizeof(struct config_group) * 3, port_stat_grp->default_groups = kzalloc(sizeof(struct config_group) * 3,
GFP_KERNEL); GFP_KERNEL);
if (!port_stat_grp->default_groups) { if (!port_stat_grp->default_groups) {
printk(KERN_ERR "Unable to allocate port_stat_grp->default_groups\n"); pr_err("Unable to allocate port_stat_grp->default_groups\n");
errno = -ENOMEM; errno = -ENOMEM;
goto out; goto out;
} }
...@@ -1031,13 +1007,13 @@ static struct config_group *target_fabric_make_tpg( ...@@ -1031,13 +1007,13 @@ static struct config_group *target_fabric_make_tpg(
struct target_fabric_configfs *tf = wwn->wwn_tf; struct target_fabric_configfs *tf = wwn->wwn_tf;
struct se_portal_group *se_tpg; struct se_portal_group *se_tpg;
if (!(tf->tf_ops.fabric_make_tpg)) { if (!tf->tf_ops.fabric_make_tpg) {
printk(KERN_ERR "tf->tf_ops.fabric_make_tpg is NULL\n"); pr_err("tf->tf_ops.fabric_make_tpg is NULL\n");
return ERR_PTR(-ENOSYS); return ERR_PTR(-ENOSYS);
} }
se_tpg = tf->tf_ops.fabric_make_tpg(wwn, group, name); se_tpg = tf->tf_ops.fabric_make_tpg(wwn, group, name);
if (!(se_tpg) || IS_ERR(se_tpg)) if (!se_tpg || IS_ERR(se_tpg))
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);
/* /*
* Setup default groups from pre-allocated se_tpg->tpg_default_groups * Setup default groups from pre-allocated se_tpg->tpg_default_groups
...@@ -1130,13 +1106,13 @@ static struct config_group *target_fabric_make_wwn( ...@@ -1130,13 +1106,13 @@ static struct config_group *target_fabric_make_wwn(
struct target_fabric_configfs, tf_group); struct target_fabric_configfs, tf_group);
struct se_wwn *wwn; struct se_wwn *wwn;
if (!(tf->tf_ops.fabric_make_wwn)) { if (!tf->tf_ops.fabric_make_wwn) {
printk(KERN_ERR "tf->tf_ops.fabric_make_wwn is NULL\n"); pr_err("tf->tf_ops.fabric_make_wwn is NULL\n");
return ERR_PTR(-ENOSYS); return ERR_PTR(-ENOSYS);
} }
wwn = tf->tf_ops.fabric_make_wwn(tf, group, name); wwn = tf->tf_ops.fabric_make_wwn(tf, group, name);
if (!(wwn) || IS_ERR(wwn)) if (!wwn || IS_ERR(wwn))
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);
wwn->wwn_tf = tf; wwn->wwn_tf = tf;
......
...@@ -172,7 +172,7 @@ u32 fc_get_pr_transport_id( ...@@ -172,7 +172,7 @@ u32 fc_get_pr_transport_id(
ptr = &se_nacl->initiatorname[0]; ptr = &se_nacl->initiatorname[0];
for (i = 0; i < 24; ) { for (i = 0; i < 24; ) {
if (!(strncmp(&ptr[i], ":", 1))) { if (!strncmp(&ptr[i], ":", 1)) {
i++; i++;
continue; continue;
} }
...@@ -386,7 +386,7 @@ char *iscsi_parse_pr_out_transport_id( ...@@ -386,7 +386,7 @@ char *iscsi_parse_pr_out_transport_id(
* Reserved * Reserved
*/ */
if ((format_code != 0x00) && (format_code != 0x40)) { if ((format_code != 0x00) && (format_code != 0x40)) {
printk(KERN_ERR "Illegal format code: 0x%02x for iSCSI" pr_err("Illegal format code: 0x%02x for iSCSI"
" Initiator Transport ID\n", format_code); " Initiator Transport ID\n", format_code);
return NULL; return NULL;
} }
...@@ -406,7 +406,7 @@ char *iscsi_parse_pr_out_transport_id( ...@@ -406,7 +406,7 @@ char *iscsi_parse_pr_out_transport_id(
tid_len += padding; tid_len += padding;
if ((add_len + 4) != tid_len) { if ((add_len + 4) != tid_len) {
printk(KERN_INFO "LIO-Target Extracted add_len: %hu " pr_debug("LIO-Target Extracted add_len: %hu "
"does not match calculated tid_len: %u," "does not match calculated tid_len: %u,"
" using tid_len instead\n", add_len+4, tid_len); " using tid_len instead\n", add_len+4, tid_len);
*out_tid_len = tid_len; *out_tid_len = tid_len;
...@@ -420,8 +420,8 @@ char *iscsi_parse_pr_out_transport_id( ...@@ -420,8 +420,8 @@ char *iscsi_parse_pr_out_transport_id(
*/ */
if (format_code == 0x40) { if (format_code == 0x40) {
p = strstr((char *)&buf[4], ",i,0x"); p = strstr((char *)&buf[4], ",i,0x");
if (!(p)) { if (!p) {
printk(KERN_ERR "Unable to locate \",i,0x\" seperator" pr_err("Unable to locate \",i,0x\" seperator"
" for Initiator port identifier: %s\n", " for Initiator port identifier: %s\n",
(char *)&buf[4]); (char *)&buf[4]);
return NULL; return NULL;
......
...@@ -42,18 +42,6 @@ ...@@ -42,18 +42,6 @@
#include "target_core_file.h" #include "target_core_file.h"
#if 1
#define DEBUG_FD_CACHE(x...) printk(x)
#else
#define DEBUG_FD_CACHE(x...)
#endif
#if 1
#define DEBUG_FD_FUA(x...) printk(x)
#else
#define DEBUG_FD_FUA(x...)
#endif
static struct se_subsystem_api fileio_template; static struct se_subsystem_api fileio_template;
/* fd_attach_hba(): (Part of se_subsystem_api_t template) /* fd_attach_hba(): (Part of se_subsystem_api_t template)
...@@ -65,8 +53,8 @@ static int fd_attach_hba(struct se_hba *hba, u32 host_id) ...@@ -65,8 +53,8 @@ static int fd_attach_hba(struct se_hba *hba, u32 host_id)
struct fd_host *fd_host; struct fd_host *fd_host;
fd_host = kzalloc(sizeof(struct fd_host), GFP_KERNEL); fd_host = kzalloc(sizeof(struct fd_host), GFP_KERNEL);
if (!(fd_host)) { if (!fd_host) {
printk(KERN_ERR "Unable to allocate memory for struct fd_host\n"); pr_err("Unable to allocate memory for struct fd_host\n");
return -ENOMEM; return -ENOMEM;
} }
...@@ -74,10 +62,10 @@ static int fd_attach_hba(struct se_hba *hba, u32 host_id) ...@@ -74,10 +62,10 @@ static int fd_attach_hba(struct se_hba *hba, u32 host_id)
hba->hba_ptr = fd_host; hba->hba_ptr = fd_host;
printk(KERN_INFO "CORE_HBA[%d] - TCM FILEIO HBA Driver %s on Generic" pr_debug("CORE_HBA[%d] - TCM FILEIO HBA Driver %s on Generic"
" Target Core Stack %s\n", hba->hba_id, FD_VERSION, " Target Core Stack %s\n", hba->hba_id, FD_VERSION,
TARGET_CORE_MOD_VERSION); TARGET_CORE_MOD_VERSION);
printk(KERN_INFO "CORE_HBA[%d] - Attached FILEIO HBA: %u to Generic" pr_debug("CORE_HBA[%d] - Attached FILEIO HBA: %u to Generic"
" MaxSectors: %u\n", " MaxSectors: %u\n",
hba->hba_id, fd_host->fd_host_id, FD_MAX_SECTORS); hba->hba_id, fd_host->fd_host_id, FD_MAX_SECTORS);
...@@ -88,7 +76,7 @@ static void fd_detach_hba(struct se_hba *hba) ...@@ -88,7 +76,7 @@ static void fd_detach_hba(struct se_hba *hba)
{ {
struct fd_host *fd_host = hba->hba_ptr; struct fd_host *fd_host = hba->hba_ptr;
printk(KERN_INFO "CORE_HBA[%d] - Detached FILEIO HBA: %u from Generic" pr_debug("CORE_HBA[%d] - Detached FILEIO HBA: %u from Generic"
" Target Core\n", hba->hba_id, fd_host->fd_host_id); " Target Core\n", hba->hba_id, fd_host->fd_host_id);
kfree(fd_host); kfree(fd_host);
...@@ -101,14 +89,14 @@ static void *fd_allocate_virtdevice(struct se_hba *hba, const char *name) ...@@ -101,14 +89,14 @@ static void *fd_allocate_virtdevice(struct se_hba *hba, const char *name)
struct fd_host *fd_host = (struct fd_host *) hba->hba_ptr; struct fd_host *fd_host = (struct fd_host *) hba->hba_ptr;
fd_dev = kzalloc(sizeof(struct fd_dev), GFP_KERNEL); fd_dev = kzalloc(sizeof(struct fd_dev), GFP_KERNEL);
if (!(fd_dev)) { if (!fd_dev) {
printk(KERN_ERR "Unable to allocate memory for struct fd_dev\n"); pr_err("Unable to allocate memory for struct fd_dev\n");
return NULL; return NULL;
} }
fd_dev->fd_host = fd_host; fd_dev->fd_host = fd_host;
printk(KERN_INFO "FILEIO: Allocated fd_dev for %p\n", name); pr_debug("FILEIO: Allocated fd_dev for %p\n", name);
return fd_dev; return fd_dev;
} }
...@@ -141,7 +129,7 @@ static struct se_device *fd_create_virtdevice( ...@@ -141,7 +129,7 @@ static struct se_device *fd_create_virtdevice(
set_fs(old_fs); set_fs(old_fs);
if (IS_ERR(dev_p)) { if (IS_ERR(dev_p)) {
printk(KERN_ERR "getname(%s) failed: %lu\n", pr_err("getname(%s) failed: %lu\n",
fd_dev->fd_dev_name, IS_ERR(dev_p)); fd_dev->fd_dev_name, IS_ERR(dev_p));
ret = PTR_ERR(dev_p); ret = PTR_ERR(dev_p);
goto fail; goto fail;
...@@ -164,12 +152,12 @@ static struct se_device *fd_create_virtdevice( ...@@ -164,12 +152,12 @@ static struct se_device *fd_create_virtdevice(
file = filp_open(dev_p, flags, 0600); file = filp_open(dev_p, flags, 0600);
if (IS_ERR(file)) { if (IS_ERR(file)) {
printk(KERN_ERR "filp_open(%s) failed\n", dev_p); pr_err("filp_open(%s) failed\n", dev_p);
ret = PTR_ERR(file); ret = PTR_ERR(file);
goto fail; goto fail;
} }
if (!file || !file->f_dentry) { if (!file || !file->f_dentry) {
printk(KERN_ERR "filp_open(%s) failed\n", dev_p); pr_err("filp_open(%s) failed\n", dev_p);
goto fail; goto fail;
} }
fd_dev->fd_file = file; fd_dev->fd_file = file;
...@@ -199,14 +187,14 @@ static struct se_device *fd_create_virtdevice( ...@@ -199,14 +187,14 @@ static struct se_device *fd_create_virtdevice(
fd_dev->fd_dev_size = (i_size_read(file->f_mapping->host) - fd_dev->fd_dev_size = (i_size_read(file->f_mapping->host) -
fd_dev->fd_block_size); fd_dev->fd_block_size);
printk(KERN_INFO "FILEIO: Using size: %llu bytes from struct" pr_debug("FILEIO: Using size: %llu bytes from struct"
" block_device blocks: %llu logical_block_size: %d\n", " block_device blocks: %llu logical_block_size: %d\n",
fd_dev->fd_dev_size, fd_dev->fd_dev_size,
div_u64(fd_dev->fd_dev_size, fd_dev->fd_block_size), div_u64(fd_dev->fd_dev_size, fd_dev->fd_block_size),
fd_dev->fd_block_size); fd_dev->fd_block_size);
} else { } else {
if (!(fd_dev->fbd_flags & FBDF_HAS_SIZE)) { if (!(fd_dev->fbd_flags & FBDF_HAS_SIZE)) {
printk(KERN_ERR "FILEIO: Missing fd_dev_size=" pr_err("FILEIO: Missing fd_dev_size="
" parameter, and no backing struct" " parameter, and no backing struct"
" block_device\n"); " block_device\n");
goto fail; goto fail;
...@@ -225,13 +213,13 @@ static struct se_device *fd_create_virtdevice( ...@@ -225,13 +213,13 @@ static struct se_device *fd_create_virtdevice(
dev = transport_add_device_to_core_hba(hba, &fileio_template, dev = transport_add_device_to_core_hba(hba, &fileio_template,
se_dev, dev_flags, fd_dev, se_dev, dev_flags, fd_dev,
&dev_limits, "FILEIO", FD_VERSION); &dev_limits, "FILEIO", FD_VERSION);
if (!(dev)) if (!dev)
goto fail; goto fail;
fd_dev->fd_dev_id = fd_host->fd_host_dev_id_count++; fd_dev->fd_dev_id = fd_host->fd_host_dev_id_count++;
fd_dev->fd_queue_depth = dev->queue_depth; fd_dev->fd_queue_depth = dev->queue_depth;
printk(KERN_INFO "CORE_FILE[%u] - Added TCM FILEIO Device ID: %u at %s," pr_debug("CORE_FILE[%u] - Added TCM FILEIO Device ID: %u at %s,"
" %llu total bytes\n", fd_host->fd_host_id, fd_dev->fd_dev_id, " %llu total bytes\n", fd_host->fd_host_id, fd_dev->fd_dev_id,
fd_dev->fd_dev_name, fd_dev->fd_dev_size); fd_dev->fd_dev_name, fd_dev->fd_dev_size);
...@@ -269,25 +257,24 @@ static inline struct fd_request *FILE_REQ(struct se_task *task) ...@@ -269,25 +257,24 @@ static inline struct fd_request *FILE_REQ(struct se_task *task)
static struct se_task * static struct se_task *
fd_alloc_task(struct se_cmd *cmd) fd_alloc_task(unsigned char *cdb)
{ {
struct fd_request *fd_req; struct fd_request *fd_req;
fd_req = kzalloc(sizeof(struct fd_request), GFP_KERNEL); fd_req = kzalloc(sizeof(struct fd_request), GFP_KERNEL);
if (!(fd_req)) { if (!fd_req) {
printk(KERN_ERR "Unable to allocate struct fd_request\n"); pr_err("Unable to allocate struct fd_request\n");
return NULL; return NULL;
} }
fd_req->fd_dev = cmd->se_dev->dev_ptr;
return &fd_req->fd_task; return &fd_req->fd_task;
} }
static int fd_do_readv(struct se_task *task) static int fd_do_readv(struct se_task *task)
{ {
struct fd_request *req = FILE_REQ(task); struct fd_request *req = FILE_REQ(task);
struct file *fd = req->fd_dev->fd_file; struct fd_dev *dev = req->fd_task.se_dev->dev_ptr;
struct file *fd = dev->fd_file;
struct scatterlist *sg = task->task_sg; struct scatterlist *sg = task->task_sg;
struct iovec *iov; struct iovec *iov;
mm_segment_t old_fs; mm_segment_t old_fs;
...@@ -295,20 +282,20 @@ static int fd_do_readv(struct se_task *task) ...@@ -295,20 +282,20 @@ static int fd_do_readv(struct se_task *task)
task->se_dev->se_sub_dev->se_dev_attrib.block_size); task->se_dev->se_sub_dev->se_dev_attrib.block_size);
int ret = 0, i; int ret = 0, i;
iov = kzalloc(sizeof(struct iovec) * task->task_sg_num, GFP_KERNEL); iov = kzalloc(sizeof(struct iovec) * task->task_sg_nents, GFP_KERNEL);
if (!(iov)) { if (!iov) {
printk(KERN_ERR "Unable to allocate fd_do_readv iov[]\n"); pr_err("Unable to allocate fd_do_readv iov[]\n");
return -ENOMEM; return -ENOMEM;
} }
for (i = 0; i < task->task_sg_num; i++) { for (i = 0; i < task->task_sg_nents; i++) {
iov[i].iov_len = sg[i].length; iov[i].iov_len = sg[i].length;
iov[i].iov_base = sg_virt(&sg[i]); iov[i].iov_base = sg_virt(&sg[i]);
} }
old_fs = get_fs(); old_fs = get_fs();
set_fs(get_ds()); set_fs(get_ds());
ret = vfs_readv(fd, &iov[0], task->task_sg_num, &pos); ret = vfs_readv(fd, &iov[0], task->task_sg_nents, &pos);
set_fs(old_fs); set_fs(old_fs);
kfree(iov); kfree(iov);
...@@ -319,14 +306,14 @@ static int fd_do_readv(struct se_task *task) ...@@ -319,14 +306,14 @@ static int fd_do_readv(struct se_task *task)
*/ */
if (S_ISBLK(fd->f_dentry->d_inode->i_mode)) { if (S_ISBLK(fd->f_dentry->d_inode->i_mode)) {
if (ret < 0 || ret != task->task_size) { if (ret < 0 || ret != task->task_size) {
printk(KERN_ERR "vfs_readv() returned %d," pr_err("vfs_readv() returned %d,"
" expecting %d for S_ISBLK\n", ret, " expecting %d for S_ISBLK\n", ret,
(int)task->task_size); (int)task->task_size);
return (ret < 0 ? ret : -EINVAL); return (ret < 0 ? ret : -EINVAL);
} }
} else { } else {
if (ret < 0) { if (ret < 0) {
printk(KERN_ERR "vfs_readv() returned %d for non" pr_err("vfs_readv() returned %d for non"
" S_ISBLK\n", ret); " S_ISBLK\n", ret);
return ret; return ret;
} }
...@@ -338,7 +325,8 @@ static int fd_do_readv(struct se_task *task) ...@@ -338,7 +325,8 @@ static int fd_do_readv(struct se_task *task)
static int fd_do_writev(struct se_task *task) static int fd_do_writev(struct se_task *task)
{ {
struct fd_request *req = FILE_REQ(task); struct fd_request *req = FILE_REQ(task);
struct file *fd = req->fd_dev->fd_file; struct fd_dev *dev = req->fd_task.se_dev->dev_ptr;
struct file *fd = dev->fd_file;
struct scatterlist *sg = task->task_sg; struct scatterlist *sg = task->task_sg;
struct iovec *iov; struct iovec *iov;
mm_segment_t old_fs; mm_segment_t old_fs;
...@@ -346,26 +334,26 @@ static int fd_do_writev(struct se_task *task) ...@@ -346,26 +334,26 @@ static int fd_do_writev(struct se_task *task)
task->se_dev->se_sub_dev->se_dev_attrib.block_size); task->se_dev->se_sub_dev->se_dev_attrib.block_size);
int ret, i = 0; int ret, i = 0;
iov = kzalloc(sizeof(struct iovec) * task->task_sg_num, GFP_KERNEL); iov = kzalloc(sizeof(struct iovec) * task->task_sg_nents, GFP_KERNEL);
if (!(iov)) { if (!iov) {
printk(KERN_ERR "Unable to allocate fd_do_writev iov[]\n"); pr_err("Unable to allocate fd_do_writev iov[]\n");
return -ENOMEM; return -ENOMEM;
} }
for (i = 0; i < task->task_sg_num; i++) { for (i = 0; i < task->task_sg_nents; i++) {
iov[i].iov_len = sg[i].length; iov[i].iov_len = sg[i].length;
iov[i].iov_base = sg_virt(&sg[i]); iov[i].iov_base = sg_virt(&sg[i]);
} }
old_fs = get_fs(); old_fs = get_fs();
set_fs(get_ds()); set_fs(get_ds());
ret = vfs_writev(fd, &iov[0], task->task_sg_num, &pos); ret = vfs_writev(fd, &iov[0], task->task_sg_nents, &pos);
set_fs(old_fs); set_fs(old_fs);
kfree(iov); kfree(iov);
if (ret < 0 || ret != task->task_size) { if (ret < 0 || ret != task->task_size) {
printk(KERN_ERR "vfs_writev() returned %d\n", ret); pr_err("vfs_writev() returned %d\n", ret);
return (ret < 0 ? ret : -EINVAL); return (ret < 0 ? ret : -EINVAL);
} }
...@@ -404,7 +392,7 @@ static void fd_emulate_sync_cache(struct se_task *task) ...@@ -404,7 +392,7 @@ static void fd_emulate_sync_cache(struct se_task *task)
ret = vfs_fsync_range(fd_dev->fd_file, start, end, 1); ret = vfs_fsync_range(fd_dev->fd_file, start, end, 1);
if (ret != 0) if (ret != 0)
printk(KERN_ERR "FILEIO: vfs_fsync_range() failed: %d\n", ret); pr_err("FILEIO: vfs_fsync_range() failed: %d\n", ret);
if (!immed) if (!immed)
transport_complete_sync_cache(cmd, ret == 0); transport_complete_sync_cache(cmd, ret == 0);
...@@ -449,12 +437,12 @@ static void fd_emulate_write_fua(struct se_cmd *cmd, struct se_task *task) ...@@ -449,12 +437,12 @@ static void fd_emulate_write_fua(struct se_cmd *cmd, struct se_task *task)
loff_t end = start + task->task_size; loff_t end = start + task->task_size;
int ret; int ret;
DEBUG_FD_CACHE("FILEIO: FUA WRITE LBA: %llu, bytes: %u\n", pr_debug("FILEIO: FUA WRITE LBA: %llu, bytes: %u\n",
task->task_lba, task->task_size); task->task_lba, task->task_size);
ret = vfs_fsync_range(fd_dev->fd_file, start, end, 1); ret = vfs_fsync_range(fd_dev->fd_file, start, end, 1);
if (ret != 0) if (ret != 0)
printk(KERN_ERR "FILEIO: vfs_fsync_range() failed: %d\n", ret); pr_err("FILEIO: vfs_fsync_range() failed: %d\n", ret);
} }
static int fd_do_task(struct se_task *task) static int fd_do_task(struct se_task *task)
...@@ -548,7 +536,7 @@ static ssize_t fd_set_configfs_dev_params( ...@@ -548,7 +536,7 @@ static ssize_t fd_set_configfs_dev_params(
snprintf(fd_dev->fd_dev_name, FD_MAX_DEV_NAME, snprintf(fd_dev->fd_dev_name, FD_MAX_DEV_NAME,
"%s", arg_p); "%s", arg_p);
kfree(arg_p); kfree(arg_p);
printk(KERN_INFO "FILEIO: Referencing Path: %s\n", pr_debug("FILEIO: Referencing Path: %s\n",
fd_dev->fd_dev_name); fd_dev->fd_dev_name);
fd_dev->fbd_flags |= FBDF_HAS_PATH; fd_dev->fbd_flags |= FBDF_HAS_PATH;
break; break;
...@@ -561,23 +549,23 @@ static ssize_t fd_set_configfs_dev_params( ...@@ -561,23 +549,23 @@ static ssize_t fd_set_configfs_dev_params(
ret = strict_strtoull(arg_p, 0, &fd_dev->fd_dev_size); ret = strict_strtoull(arg_p, 0, &fd_dev->fd_dev_size);
kfree(arg_p); kfree(arg_p);
if (ret < 0) { if (ret < 0) {
printk(KERN_ERR "strict_strtoull() failed for" pr_err("strict_strtoull() failed for"
" fd_dev_size=\n"); " fd_dev_size=\n");
goto out; goto out;
} }
printk(KERN_INFO "FILEIO: Referencing Size: %llu" pr_debug("FILEIO: Referencing Size: %llu"
" bytes\n", fd_dev->fd_dev_size); " bytes\n", fd_dev->fd_dev_size);
fd_dev->fbd_flags |= FBDF_HAS_SIZE; fd_dev->fbd_flags |= FBDF_HAS_SIZE;
break; break;
case Opt_fd_buffered_io: case Opt_fd_buffered_io:
match_int(args, &arg); match_int(args, &arg);
if (arg != 1) { if (arg != 1) {
printk(KERN_ERR "bogus fd_buffered_io=%d value\n", arg); pr_err("bogus fd_buffered_io=%d value\n", arg);
ret = -EINVAL; ret = -EINVAL;
goto out; goto out;
} }
printk(KERN_INFO "FILEIO: Using buffered I/O" pr_debug("FILEIO: Using buffered I/O"
" operations for struct fd_dev\n"); " operations for struct fd_dev\n");
fd_dev->fbd_flags |= FDBD_USE_BUFFERED_IO; fd_dev->fbd_flags |= FDBD_USE_BUFFERED_IO;
...@@ -597,7 +585,7 @@ static ssize_t fd_check_configfs_dev_params(struct se_hba *hba, struct se_subsys ...@@ -597,7 +585,7 @@ static ssize_t fd_check_configfs_dev_params(struct se_hba *hba, struct se_subsys
struct fd_dev *fd_dev = (struct fd_dev *) se_dev->se_dev_su_ptr; struct fd_dev *fd_dev = (struct fd_dev *) se_dev->se_dev_su_ptr;
if (!(fd_dev->fbd_flags & FBDF_HAS_PATH)) { if (!(fd_dev->fbd_flags & FBDF_HAS_PATH)) {
printk(KERN_ERR "Missing fd_dev_name=\n"); pr_err("Missing fd_dev_name=\n");
return -EINVAL; return -EINVAL;
} }
......
...@@ -16,8 +16,6 @@ struct fd_request { ...@@ -16,8 +16,6 @@ struct fd_request {
struct se_task fd_task; struct se_task fd_task;
/* SCSI CDB from iSCSI Command PDU */ /* SCSI CDB from iSCSI Command PDU */
unsigned char fd_scsi_cdb[TCM_MAX_COMMAND_SIZE]; unsigned char fd_scsi_cdb[TCM_MAX_COMMAND_SIZE];
/* FILEIO device */
struct fd_dev *fd_dev;
} ____cacheline_aligned; } ____cacheline_aligned;
#define FBDF_HAS_PATH 0x01 #define FBDF_HAS_PATH 0x01
......
...@@ -58,8 +58,8 @@ int transport_subsystem_register(struct se_subsystem_api *sub_api) ...@@ -58,8 +58,8 @@ int transport_subsystem_register(struct se_subsystem_api *sub_api)
mutex_lock(&subsystem_mutex); mutex_lock(&subsystem_mutex);
list_for_each_entry(s, &subsystem_list, sub_api_list) { list_for_each_entry(s, &subsystem_list, sub_api_list) {
if (!(strcmp(s->name, sub_api->name))) { if (!strcmp(s->name, sub_api->name)) {
printk(KERN_ERR "%p is already registered with" pr_err("%p is already registered with"
" duplicate name %s, unable to process" " duplicate name %s, unable to process"
" request\n", s, s->name); " request\n", s, s->name);
mutex_unlock(&subsystem_mutex); mutex_unlock(&subsystem_mutex);
...@@ -69,7 +69,7 @@ int transport_subsystem_register(struct se_subsystem_api *sub_api) ...@@ -69,7 +69,7 @@ int transport_subsystem_register(struct se_subsystem_api *sub_api)
list_add_tail(&sub_api->sub_api_list, &subsystem_list); list_add_tail(&sub_api->sub_api_list, &subsystem_list);
mutex_unlock(&subsystem_mutex); mutex_unlock(&subsystem_mutex);
printk(KERN_INFO "TCM: Registered subsystem plugin: %s struct module:" pr_debug("TCM: Registered subsystem plugin: %s struct module:"
" %p\n", sub_api->name, sub_api->owner); " %p\n", sub_api->name, sub_api->owner);
return 0; return 0;
} }
...@@ -109,7 +109,7 @@ core_alloc_hba(const char *plugin_name, u32 plugin_dep_id, u32 hba_flags) ...@@ -109,7 +109,7 @@ core_alloc_hba(const char *plugin_name, u32 plugin_dep_id, u32 hba_flags)
hba = kzalloc(sizeof(*hba), GFP_KERNEL); hba = kzalloc(sizeof(*hba), GFP_KERNEL);
if (!hba) { if (!hba) {
printk(KERN_ERR "Unable to allocate struct se_hba\n"); pr_err("Unable to allocate struct se_hba\n");
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
} }
...@@ -135,7 +135,7 @@ core_alloc_hba(const char *plugin_name, u32 plugin_dep_id, u32 hba_flags) ...@@ -135,7 +135,7 @@ core_alloc_hba(const char *plugin_name, u32 plugin_dep_id, u32 hba_flags)
list_add_tail(&hba->hba_node, &hba_list); list_add_tail(&hba->hba_node, &hba_list);
spin_unlock(&hba_lock); spin_unlock(&hba_lock);
printk(KERN_INFO "CORE_HBA[%d] - Attached HBA to Generic Target" pr_debug("CORE_HBA[%d] - Attached HBA to Generic Target"
" Core\n", hba->hba_id); " Core\n", hba->hba_id);
return hba; return hba;
...@@ -161,7 +161,7 @@ core_delete_hba(struct se_hba *hba) ...@@ -161,7 +161,7 @@ core_delete_hba(struct se_hba *hba)
list_del(&hba->hba_node); list_del(&hba->hba_node);
spin_unlock(&hba_lock); spin_unlock(&hba_lock);
printk(KERN_INFO "CORE_HBA[%d] - Detached HBA from Generic Target" pr_debug("CORE_HBA[%d] - Detached HBA from Generic Target"
" Core\n", hba->hba_id); " Core\n", hba->hba_id);
if (hba->transport->owner) if (hba->transport->owner)
......
...@@ -47,12 +47,6 @@ ...@@ -47,12 +47,6 @@
#include "target_core_iblock.h" #include "target_core_iblock.h"
#if 0
#define DEBUG_IBLOCK(x...) printk(x)
#else
#define DEBUG_IBLOCK(x...)
#endif
static struct se_subsystem_api iblock_template; static struct se_subsystem_api iblock_template;
static void iblock_bio_done(struct bio *, int); static void iblock_bio_done(struct bio *, int);
...@@ -66,8 +60,8 @@ static int iblock_attach_hba(struct se_hba *hba, u32 host_id) ...@@ -66,8 +60,8 @@ static int iblock_attach_hba(struct se_hba *hba, u32 host_id)
struct iblock_hba *ib_host; struct iblock_hba *ib_host;
ib_host = kzalloc(sizeof(struct iblock_hba), GFP_KERNEL); ib_host = kzalloc(sizeof(struct iblock_hba), GFP_KERNEL);
if (!(ib_host)) { if (!ib_host) {
printk(KERN_ERR "Unable to allocate memory for" pr_err("Unable to allocate memory for"
" struct iblock_hba\n"); " struct iblock_hba\n");
return -ENOMEM; return -ENOMEM;
} }
...@@ -76,11 +70,11 @@ static int iblock_attach_hba(struct se_hba *hba, u32 host_id) ...@@ -76,11 +70,11 @@ static int iblock_attach_hba(struct se_hba *hba, u32 host_id)
hba->hba_ptr = ib_host; hba->hba_ptr = ib_host;
printk(KERN_INFO "CORE_HBA[%d] - TCM iBlock HBA Driver %s on" pr_debug("CORE_HBA[%d] - TCM iBlock HBA Driver %s on"
" Generic Target Core Stack %s\n", hba->hba_id, " Generic Target Core Stack %s\n", hba->hba_id,
IBLOCK_VERSION, TARGET_CORE_MOD_VERSION); IBLOCK_VERSION, TARGET_CORE_MOD_VERSION);
printk(KERN_INFO "CORE_HBA[%d] - Attached iBlock HBA: %u to Generic\n", pr_debug("CORE_HBA[%d] - Attached iBlock HBA: %u to Generic\n",
hba->hba_id, ib_host->iblock_host_id); hba->hba_id, ib_host->iblock_host_id);
return 0; return 0;
...@@ -90,7 +84,7 @@ static void iblock_detach_hba(struct se_hba *hba) ...@@ -90,7 +84,7 @@ static void iblock_detach_hba(struct se_hba *hba)
{ {
struct iblock_hba *ib_host = hba->hba_ptr; struct iblock_hba *ib_host = hba->hba_ptr;
printk(KERN_INFO "CORE_HBA[%d] - Detached iBlock HBA: %u from Generic" pr_debug("CORE_HBA[%d] - Detached iBlock HBA: %u from Generic"
" Target Core\n", hba->hba_id, ib_host->iblock_host_id); " Target Core\n", hba->hba_id, ib_host->iblock_host_id);
kfree(ib_host); kfree(ib_host);
...@@ -103,13 +97,13 @@ static void *iblock_allocate_virtdevice(struct se_hba *hba, const char *name) ...@@ -103,13 +97,13 @@ static void *iblock_allocate_virtdevice(struct se_hba *hba, const char *name)
struct iblock_hba *ib_host = hba->hba_ptr; struct iblock_hba *ib_host = hba->hba_ptr;
ib_dev = kzalloc(sizeof(struct iblock_dev), GFP_KERNEL); ib_dev = kzalloc(sizeof(struct iblock_dev), GFP_KERNEL);
if (!(ib_dev)) { if (!ib_dev) {
printk(KERN_ERR "Unable to allocate struct iblock_dev\n"); pr_err("Unable to allocate struct iblock_dev\n");
return NULL; return NULL;
} }
ib_dev->ibd_host = ib_host; ib_dev->ibd_host = ib_host;
printk(KERN_INFO "IBLOCK: Allocated ib_dev for %s\n", name); pr_debug( "IBLOCK: Allocated ib_dev for %s\n", name);
return ib_dev; return ib_dev;
} }
...@@ -128,8 +122,8 @@ static struct se_device *iblock_create_virtdevice( ...@@ -128,8 +122,8 @@ static struct se_device *iblock_create_virtdevice(
u32 dev_flags = 0; u32 dev_flags = 0;
int ret = -EINVAL; int ret = -EINVAL;
if (!(ib_dev)) { if (!ib_dev) {
printk(KERN_ERR "Unable to locate struct iblock_dev parameter\n"); pr_err("Unable to locate struct iblock_dev parameter\n");
return ERR_PTR(ret); return ERR_PTR(ret);
} }
memset(&dev_limits, 0, sizeof(struct se_dev_limits)); memset(&dev_limits, 0, sizeof(struct se_dev_limits));
...@@ -137,16 +131,16 @@ static struct se_device *iblock_create_virtdevice( ...@@ -137,16 +131,16 @@ static struct se_device *iblock_create_virtdevice(
* These settings need to be made tunable.. * These settings need to be made tunable..
*/ */
ib_dev->ibd_bio_set = bioset_create(32, 64); ib_dev->ibd_bio_set = bioset_create(32, 64);
if (!(ib_dev->ibd_bio_set)) { if (!ib_dev->ibd_bio_set) {
printk(KERN_ERR "IBLOCK: Unable to create bioset()\n"); pr_err("IBLOCK: Unable to create bioset()\n");
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
} }
printk(KERN_INFO "IBLOCK: Created bio_set()\n"); pr_debug("IBLOCK: Created bio_set()\n");
/* /*
* iblock_check_configfs_dev_params() ensures that ib_dev->ibd_udev_path * iblock_check_configfs_dev_params() ensures that ib_dev->ibd_udev_path
* must already have been set in order for echo 1 > $HBA/$DEV/enable to run. * must already have been set in order for echo 1 > $HBA/$DEV/enable to run.
*/ */
printk(KERN_INFO "IBLOCK: Claiming struct block_device: %s\n", pr_debug( "IBLOCK: Claiming struct block_device: %s\n",
ib_dev->ibd_udev_path); ib_dev->ibd_udev_path);
bd = blkdev_get_by_path(ib_dev->ibd_udev_path, bd = blkdev_get_by_path(ib_dev->ibd_udev_path,
...@@ -172,7 +166,7 @@ static struct se_device *iblock_create_virtdevice( ...@@ -172,7 +166,7 @@ static struct se_device *iblock_create_virtdevice(
dev = transport_add_device_to_core_hba(hba, dev = transport_add_device_to_core_hba(hba,
&iblock_template, se_dev, dev_flags, ib_dev, &iblock_template, se_dev, dev_flags, ib_dev,
&dev_limits, "IBLOCK", IBLOCK_VERSION); &dev_limits, "IBLOCK", IBLOCK_VERSION);
if (!(dev)) if (!dev)
goto failed; goto failed;
/* /*
...@@ -192,7 +186,7 @@ static struct se_device *iblock_create_virtdevice( ...@@ -192,7 +186,7 @@ static struct se_device *iblock_create_virtdevice(
dev->se_sub_dev->se_dev_attrib.unmap_granularity_alignment = dev->se_sub_dev->se_dev_attrib.unmap_granularity_alignment =
q->limits.discard_alignment; q->limits.discard_alignment;
printk(KERN_INFO "IBLOCK: BLOCK Discard support available," pr_debug("IBLOCK: BLOCK Discard support available,"
" disabled by default\n"); " disabled by default\n");
} }
...@@ -227,17 +221,16 @@ static inline struct iblock_req *IBLOCK_REQ(struct se_task *task) ...@@ -227,17 +221,16 @@ static inline struct iblock_req *IBLOCK_REQ(struct se_task *task)
} }
static struct se_task * static struct se_task *
iblock_alloc_task(struct se_cmd *cmd) iblock_alloc_task(unsigned char *cdb)
{ {
struct iblock_req *ib_req; struct iblock_req *ib_req;
ib_req = kzalloc(sizeof(struct iblock_req), GFP_KERNEL); ib_req = kzalloc(sizeof(struct iblock_req), GFP_KERNEL);
if (!(ib_req)) { if (!ib_req) {
printk(KERN_ERR "Unable to allocate memory for struct iblock_req\n"); pr_err("Unable to allocate memory for struct iblock_req\n");
return NULL; return NULL;
} }
ib_req->ib_dev = cmd->se_dev->dev_ptr;
atomic_set(&ib_req->ib_bio_cnt, 0); atomic_set(&ib_req->ib_bio_cnt, 0);
return &ib_req->ib_task; return &ib_req->ib_task;
} }
...@@ -345,7 +338,7 @@ static void iblock_emulate_sync_cache(struct se_task *task) ...@@ -345,7 +338,7 @@ static void iblock_emulate_sync_cache(struct se_task *task)
*/ */
ret = blkdev_issue_flush(ib_dev->ibd_bd, GFP_KERNEL, &error_sector); ret = blkdev_issue_flush(ib_dev->ibd_bd, GFP_KERNEL, &error_sector);
if (ret != 0) { if (ret != 0) {
printk(KERN_ERR "IBLOCK: block_issue_flush() failed: %d " pr_err("IBLOCK: block_issue_flush() failed: %d "
" error_sector: %llu\n", ret, " error_sector: %llu\n", ret,
(unsigned long long)error_sector); (unsigned long long)error_sector);
} }
...@@ -409,8 +402,9 @@ static int iblock_do_task(struct se_task *task) ...@@ -409,8 +402,9 @@ static int iblock_do_task(struct se_task *task)
while (bio) { while (bio) {
nbio = bio->bi_next; nbio = bio->bi_next;
bio->bi_next = NULL; bio->bi_next = NULL;
DEBUG_IBLOCK("Calling submit_bio() task: %p bio: %p" pr_debug("Calling submit_bio() task: %p bio: %p"
" bio->bi_sector: %llu\n", task, bio, bio->bi_sector); " bio->bi_sector: %llu\n", task, bio,
(unsigned long long)bio->bi_sector);
submit_bio(rw, bio); submit_bio(rw, bio);
bio = nbio; bio = nbio;
...@@ -480,7 +474,7 @@ static ssize_t iblock_set_configfs_dev_params(struct se_hba *hba, ...@@ -480,7 +474,7 @@ static ssize_t iblock_set_configfs_dev_params(struct se_hba *hba,
switch (token) { switch (token) {
case Opt_udev_path: case Opt_udev_path:
if (ib_dev->ibd_bd) { if (ib_dev->ibd_bd) {
printk(KERN_ERR "Unable to set udev_path= while" pr_err("Unable to set udev_path= while"
" ib_dev->ibd_bd exists\n"); " ib_dev->ibd_bd exists\n");
ret = -EEXIST; ret = -EEXIST;
goto out; goto out;
...@@ -493,7 +487,7 @@ static ssize_t iblock_set_configfs_dev_params(struct se_hba *hba, ...@@ -493,7 +487,7 @@ static ssize_t iblock_set_configfs_dev_params(struct se_hba *hba,
snprintf(ib_dev->ibd_udev_path, SE_UDEV_PATH_LEN, snprintf(ib_dev->ibd_udev_path, SE_UDEV_PATH_LEN,
"%s", arg_p); "%s", arg_p);
kfree(arg_p); kfree(arg_p);
printk(KERN_INFO "IBLOCK: Referencing UDEV path: %s\n", pr_debug("IBLOCK: Referencing UDEV path: %s\n",
ib_dev->ibd_udev_path); ib_dev->ibd_udev_path);
ib_dev->ibd_flags |= IBDF_HAS_UDEV_PATH; ib_dev->ibd_flags |= IBDF_HAS_UDEV_PATH;
break; break;
...@@ -516,7 +510,7 @@ static ssize_t iblock_check_configfs_dev_params( ...@@ -516,7 +510,7 @@ static ssize_t iblock_check_configfs_dev_params(
struct iblock_dev *ibd = se_dev->se_dev_su_ptr; struct iblock_dev *ibd = se_dev->se_dev_su_ptr;
if (!(ibd->ibd_flags & IBDF_HAS_UDEV_PATH)) { if (!(ibd->ibd_flags & IBDF_HAS_UDEV_PATH)) {
printk(KERN_ERR "Missing udev_path= parameters for IBLOCK\n"); pr_err("Missing udev_path= parameters for IBLOCK\n");
return -EINVAL; return -EINVAL;
} }
...@@ -574,15 +568,15 @@ static struct bio *iblock_get_bio( ...@@ -574,15 +568,15 @@ static struct bio *iblock_get_bio(
struct bio *bio; struct bio *bio;
bio = bio_alloc_bioset(GFP_NOIO, sg_num, ib_dev->ibd_bio_set); bio = bio_alloc_bioset(GFP_NOIO, sg_num, ib_dev->ibd_bio_set);
if (!(bio)) { if (!bio) {
printk(KERN_ERR "Unable to allocate memory for bio\n"); pr_err("Unable to allocate memory for bio\n");
*ret = PYX_TRANSPORT_OUT_OF_MEMORY_RESOURCES; *ret = PYX_TRANSPORT_OUT_OF_MEMORY_RESOURCES;
return NULL; return NULL;
} }
DEBUG_IBLOCK("Allocated bio: %p task_sg_num: %u using ibd_bio_set:" pr_debug("Allocated bio: %p task_sg_nents: %u using ibd_bio_set:"
" %p\n", bio, task->task_sg_num, ib_dev->ibd_bio_set); " %p\n", bio, task->task_sg_nents, ib_dev->ibd_bio_set);
DEBUG_IBLOCK("Allocated bio: %p task_size: %u\n", bio, task->task_size); pr_debug("Allocated bio: %p task_size: %u\n", bio, task->task_size);
bio->bi_bdev = ib_dev->ibd_bd; bio->bi_bdev = ib_dev->ibd_bd;
bio->bi_private = task; bio->bi_private = task;
...@@ -591,8 +585,8 @@ static struct bio *iblock_get_bio( ...@@ -591,8 +585,8 @@ static struct bio *iblock_get_bio(
bio->bi_sector = lba; bio->bi_sector = lba;
atomic_inc(&ib_req->ib_bio_cnt); atomic_inc(&ib_req->ib_bio_cnt);
DEBUG_IBLOCK("Set bio->bi_sector: %llu\n", bio->bi_sector); pr_debug("Set bio->bi_sector: %llu\n", (unsigned long long)bio->bi_sector);
DEBUG_IBLOCK("Set ib_req->ib_bio_cnt: %d\n", pr_debug("Set ib_req->ib_bio_cnt: %d\n",
atomic_read(&ib_req->ib_bio_cnt)); atomic_read(&ib_req->ib_bio_cnt));
return bio; return bio;
} }
...@@ -606,7 +600,7 @@ static int iblock_map_task_SG(struct se_task *task) ...@@ -606,7 +600,7 @@ static int iblock_map_task_SG(struct se_task *task)
struct bio *bio = NULL, *hbio = NULL, *tbio = NULL; struct bio *bio = NULL, *hbio = NULL, *tbio = NULL;
struct scatterlist *sg; struct scatterlist *sg;
int ret = 0; int ret = 0;
u32 i, sg_num = task->task_sg_num; u32 i, sg_num = task->task_sg_nents;
sector_t block_lba; sector_t block_lba;
/* /*
* Do starting conversion up from non 512-byte blocksize with * Do starting conversion up from non 512-byte blocksize with
...@@ -621,13 +615,13 @@ static int iblock_map_task_SG(struct se_task *task) ...@@ -621,13 +615,13 @@ static int iblock_map_task_SG(struct se_task *task)
else if (dev->se_sub_dev->se_dev_attrib.block_size == 512) else if (dev->se_sub_dev->se_dev_attrib.block_size == 512)
block_lba = task->task_lba; block_lba = task->task_lba;
else { else {
printk(KERN_ERR "Unsupported SCSI -> BLOCK LBA conversion:" pr_err("Unsupported SCSI -> BLOCK LBA conversion:"
" %u\n", dev->se_sub_dev->se_dev_attrib.block_size); " %u\n", dev->se_sub_dev->se_dev_attrib.block_size);
return PYX_TRANSPORT_LU_COMM_FAILURE; return PYX_TRANSPORT_LU_COMM_FAILURE;
} }
bio = iblock_get_bio(task, ib_req, ib_dev, &ret, block_lba, sg_num); bio = iblock_get_bio(task, ib_req, ib_dev, &ret, block_lba, sg_num);
if (!(bio)) if (!bio)
return ret; return ret;
ib_req->ib_bio = bio; ib_req->ib_bio = bio;
...@@ -636,41 +630,41 @@ static int iblock_map_task_SG(struct se_task *task) ...@@ -636,41 +630,41 @@ static int iblock_map_task_SG(struct se_task *task)
* Use fs/bio.c:bio_add_pages() to setup the bio_vec maplist * Use fs/bio.c:bio_add_pages() to setup the bio_vec maplist
* from task->task_sg -> struct scatterlist memory. * from task->task_sg -> struct scatterlist memory.
*/ */
for_each_sg(task->task_sg, sg, task->task_sg_num, i) { for_each_sg(task->task_sg, sg, task->task_sg_nents, i) {
DEBUG_IBLOCK("task: %p bio: %p Calling bio_add_page(): page:" pr_debug("task: %p bio: %p Calling bio_add_page(): page:"
" %p len: %u offset: %u\n", task, bio, sg_page(sg), " %p len: %u offset: %u\n", task, bio, sg_page(sg),
sg->length, sg->offset); sg->length, sg->offset);
again: again:
ret = bio_add_page(bio, sg_page(sg), sg->length, sg->offset); ret = bio_add_page(bio, sg_page(sg), sg->length, sg->offset);
if (ret != sg->length) { if (ret != sg->length) {
DEBUG_IBLOCK("*** Set bio->bi_sector: %llu\n", pr_debug("*** Set bio->bi_sector: %llu\n",
bio->bi_sector); (unsigned long long)bio->bi_sector);
DEBUG_IBLOCK("** task->task_size: %u\n", pr_debug("** task->task_size: %u\n",
task->task_size); task->task_size);
DEBUG_IBLOCK("*** bio->bi_max_vecs: %u\n", pr_debug("*** bio->bi_max_vecs: %u\n",
bio->bi_max_vecs); bio->bi_max_vecs);
DEBUG_IBLOCK("*** bio->bi_vcnt: %u\n", pr_debug("*** bio->bi_vcnt: %u\n",
bio->bi_vcnt); bio->bi_vcnt);
bio = iblock_get_bio(task, ib_req, ib_dev, &ret, bio = iblock_get_bio(task, ib_req, ib_dev, &ret,
block_lba, sg_num); block_lba, sg_num);
if (!(bio)) if (!bio)
goto fail; goto fail;
tbio = tbio->bi_next = bio; tbio = tbio->bi_next = bio;
DEBUG_IBLOCK("-----------------> Added +1 bio: %p to" pr_debug("-----------------> Added +1 bio: %p to"
" list, Going to again\n", bio); " list, Going to again\n", bio);
goto again; goto again;
} }
/* Always in 512 byte units for Linux/Block */ /* Always in 512 byte units for Linux/Block */
block_lba += sg->length >> IBLOCK_LBA_SHIFT; block_lba += sg->length >> IBLOCK_LBA_SHIFT;
sg_num--; sg_num--;
DEBUG_IBLOCK("task: %p bio-add_page() passed!, decremented" pr_debug("task: %p bio-add_page() passed!, decremented"
" sg_num to %u\n", task, sg_num); " sg_num to %u\n", task, sg_num);
DEBUG_IBLOCK("task: %p bio_add_page() passed!, increased lba" pr_debug("task: %p bio_add_page() passed!, increased lba"
" to %llu\n", task, block_lba); " to %llu\n", task, (unsigned long long)block_lba);
DEBUG_IBLOCK("task: %p bio_add_page() passed!, bio->bi_vcnt:" pr_debug("task: %p bio_add_page() passed!, bio->bi_vcnt:"
" %u\n", task, bio->bi_vcnt); " %u\n", task, bio->bi_vcnt);
} }
...@@ -716,11 +710,11 @@ static void iblock_bio_done(struct bio *bio, int err) ...@@ -716,11 +710,11 @@ static void iblock_bio_done(struct bio *bio, int err)
/* /*
* Set -EIO if !BIO_UPTODATE and the passed is still err=0 * Set -EIO if !BIO_UPTODATE and the passed is still err=0
*/ */
if (!(test_bit(BIO_UPTODATE, &bio->bi_flags)) && !(err)) if (!test_bit(BIO_UPTODATE, &bio->bi_flags) && !err)
err = -EIO; err = -EIO;
if (err != 0) { if (err != 0) {
printk(KERN_ERR "test_bit(BIO_UPTODATE) failed for bio: %p," pr_err("test_bit(BIO_UPTODATE) failed for bio: %p,"
" err: %d\n", bio, err); " err: %d\n", bio, err);
/* /*
* Bump the ib_bio_err_cnt and release bio. * Bump the ib_bio_err_cnt and release bio.
...@@ -731,15 +725,15 @@ static void iblock_bio_done(struct bio *bio, int err) ...@@ -731,15 +725,15 @@ static void iblock_bio_done(struct bio *bio, int err)
/* /*
* Wait to complete the task until the last bio as completed. * Wait to complete the task until the last bio as completed.
*/ */
if (!(atomic_dec_and_test(&ibr->ib_bio_cnt))) if (!atomic_dec_and_test(&ibr->ib_bio_cnt))
return; return;
ibr->ib_bio = NULL; ibr->ib_bio = NULL;
transport_complete_task(task, 0); transport_complete_task(task, 0);
return; return;
} }
DEBUG_IBLOCK("done[%p] bio: %p task_lba: %llu bio_lba: %llu err=%d\n", pr_debug("done[%p] bio: %p task_lba: %llu bio_lba: %llu err=%d\n",
task, bio, task->task_lba, bio->bi_sector, err); task, bio, task->task_lba, (unsigned long long)bio->bi_sector, err);
/* /*
* bio_put() will call iblock_bio_destructor() to release the bio back * bio_put() will call iblock_bio_destructor() to release the bio back
* to ibr->ib_bio_set. * to ibr->ib_bio_set.
...@@ -748,7 +742,7 @@ static void iblock_bio_done(struct bio *bio, int err) ...@@ -748,7 +742,7 @@ static void iblock_bio_done(struct bio *bio, int err)
/* /*
* Wait to complete the task until the last bio as completed. * Wait to complete the task until the last bio as completed.
*/ */
if (!(atomic_dec_and_test(&ibr->ib_bio_cnt))) if (!atomic_dec_and_test(&ibr->ib_bio_cnt))
return; return;
/* /*
* Return GOOD status for task if zero ib_bio_err_cnt exists. * Return GOOD status for task if zero ib_bio_err_cnt exists.
......
...@@ -12,7 +12,6 @@ struct iblock_req { ...@@ -12,7 +12,6 @@ struct iblock_req {
atomic_t ib_bio_cnt; atomic_t ib_bio_cnt;
atomic_t ib_bio_err_cnt; atomic_t ib_bio_err_cnt;
struct bio *ib_bio; struct bio *ib_bio;
struct iblock_dev *ib_dev;
} ____cacheline_aligned; } ____cacheline_aligned;
#define IBDF_HAS_UDEV_PATH 0x01 #define IBDF_HAS_UDEV_PATH 0x01
......
此差异已折叠。
...@@ -65,8 +65,8 @@ static int pscsi_attach_hba(struct se_hba *hba, u32 host_id) ...@@ -65,8 +65,8 @@ static int pscsi_attach_hba(struct se_hba *hba, u32 host_id)
struct pscsi_hba_virt *phv; struct pscsi_hba_virt *phv;
phv = kzalloc(sizeof(struct pscsi_hba_virt), GFP_KERNEL); phv = kzalloc(sizeof(struct pscsi_hba_virt), GFP_KERNEL);
if (!(phv)) { if (!phv) {
printk(KERN_ERR "Unable to allocate struct pscsi_hba_virt\n"); pr_err("Unable to allocate struct pscsi_hba_virt\n");
return -ENOMEM; return -ENOMEM;
} }
phv->phv_host_id = host_id; phv->phv_host_id = host_id;
...@@ -74,10 +74,10 @@ static int pscsi_attach_hba(struct se_hba *hba, u32 host_id) ...@@ -74,10 +74,10 @@ static int pscsi_attach_hba(struct se_hba *hba, u32 host_id)
hba->hba_ptr = phv; hba->hba_ptr = phv;
printk(KERN_INFO "CORE_HBA[%d] - TCM SCSI HBA Driver %s on" pr_debug("CORE_HBA[%d] - TCM SCSI HBA Driver %s on"
" Generic Target Core Stack %s\n", hba->hba_id, " Generic Target Core Stack %s\n", hba->hba_id,
PSCSI_VERSION, TARGET_CORE_MOD_VERSION); PSCSI_VERSION, TARGET_CORE_MOD_VERSION);
printk(KERN_INFO "CORE_HBA[%d] - Attached SCSI HBA to Generic\n", pr_debug("CORE_HBA[%d] - Attached SCSI HBA to Generic\n",
hba->hba_id); hba->hba_id);
return 0; return 0;
...@@ -91,12 +91,12 @@ static void pscsi_detach_hba(struct se_hba *hba) ...@@ -91,12 +91,12 @@ static void pscsi_detach_hba(struct se_hba *hba)
if (scsi_host) { if (scsi_host) {
scsi_host_put(scsi_host); scsi_host_put(scsi_host);
printk(KERN_INFO "CORE_HBA[%d] - Detached SCSI HBA: %s from" pr_debug("CORE_HBA[%d] - Detached SCSI HBA: %s from"
" Generic Target Core\n", hba->hba_id, " Generic Target Core\n", hba->hba_id,
(scsi_host->hostt->name) ? (scsi_host->hostt->name) : (scsi_host->hostt->name) ? (scsi_host->hostt->name) :
"Unknown"); "Unknown");
} else } else
printk(KERN_INFO "CORE_HBA[%d] - Detached Virtual SCSI HBA" pr_debug("CORE_HBA[%d] - Detached Virtual SCSI HBA"
" from Generic Target Core\n", hba->hba_id); " from Generic Target Core\n", hba->hba_id);
kfree(phv); kfree(phv);
...@@ -110,14 +110,14 @@ static int pscsi_pmode_enable_hba(struct se_hba *hba, unsigned long mode_flag) ...@@ -110,14 +110,14 @@ static int pscsi_pmode_enable_hba(struct se_hba *hba, unsigned long mode_flag)
/* /*
* Release the struct Scsi_Host * Release the struct Scsi_Host
*/ */
if (!(mode_flag)) { if (!mode_flag) {
if (!(sh)) if (!sh)
return 0; return 0;
phv->phv_lld_host = NULL; phv->phv_lld_host = NULL;
phv->phv_mode = PHV_VIRUTAL_HOST_ID; phv->phv_mode = PHV_VIRUTAL_HOST_ID;
printk(KERN_INFO "CORE_HBA[%d] - Disabled pSCSI HBA Passthrough" pr_debug("CORE_HBA[%d] - Disabled pSCSI HBA Passthrough"
" %s\n", hba->hba_id, (sh->hostt->name) ? " %s\n", hba->hba_id, (sh->hostt->name) ?
(sh->hostt->name) : "Unknown"); (sh->hostt->name) : "Unknown");
...@@ -130,7 +130,7 @@ static int pscsi_pmode_enable_hba(struct se_hba *hba, unsigned long mode_flag) ...@@ -130,7 +130,7 @@ static int pscsi_pmode_enable_hba(struct se_hba *hba, unsigned long mode_flag)
*/ */
sh = scsi_host_lookup(phv->phv_host_id); sh = scsi_host_lookup(phv->phv_host_id);
if (IS_ERR(sh)) { if (IS_ERR(sh)) {
printk(KERN_ERR "pSCSI: Unable to locate SCSI Host for" pr_err("pSCSI: Unable to locate SCSI Host for"
" phv_host_id: %d\n", phv->phv_host_id); " phv_host_id: %d\n", phv->phv_host_id);
return PTR_ERR(sh); return PTR_ERR(sh);
} }
...@@ -138,7 +138,7 @@ static int pscsi_pmode_enable_hba(struct se_hba *hba, unsigned long mode_flag) ...@@ -138,7 +138,7 @@ static int pscsi_pmode_enable_hba(struct se_hba *hba, unsigned long mode_flag)
phv->phv_lld_host = sh; phv->phv_lld_host = sh;
phv->phv_mode = PHV_LLD_SCSI_HOST_NO; phv->phv_mode = PHV_LLD_SCSI_HOST_NO;
printk(KERN_INFO "CORE_HBA[%d] - Enabled pSCSI HBA Passthrough %s\n", pr_debug("CORE_HBA[%d] - Enabled pSCSI HBA Passthrough %s\n",
hba->hba_id, (sh->hostt->name) ? (sh->hostt->name) : "Unknown"); hba->hba_id, (sh->hostt->name) ? (sh->hostt->name) : "Unknown");
return 1; return 1;
...@@ -257,15 +257,15 @@ pscsi_get_inquiry_vpd_device_ident(struct scsi_device *sdev, ...@@ -257,15 +257,15 @@ pscsi_get_inquiry_vpd_device_ident(struct scsi_device *sdev,
page_83 = &buf[off]; page_83 = &buf[off];
ident_len = page_83[3]; ident_len = page_83[3];
if (!ident_len) { if (!ident_len) {
printk(KERN_ERR "page_83[3]: identifier" pr_err("page_83[3]: identifier"
" length zero!\n"); " length zero!\n");
break; break;
} }
printk(KERN_INFO "T10 VPD Identifer Length: %d\n", ident_len); pr_debug("T10 VPD Identifer Length: %d\n", ident_len);
vpd = kzalloc(sizeof(struct t10_vpd), GFP_KERNEL); vpd = kzalloc(sizeof(struct t10_vpd), GFP_KERNEL);
if (!vpd) { if (!vpd) {
printk(KERN_ERR "Unable to allocate memory for" pr_err("Unable to allocate memory for"
" struct t10_vpd\n"); " struct t10_vpd\n");
goto out; goto out;
} }
...@@ -317,7 +317,7 @@ static struct se_device *pscsi_add_device_to_list( ...@@ -317,7 +317,7 @@ static struct se_device *pscsi_add_device_to_list(
if (!sd->queue_depth) { if (!sd->queue_depth) {
sd->queue_depth = PSCSI_DEFAULT_QUEUEDEPTH; sd->queue_depth = PSCSI_DEFAULT_QUEUEDEPTH;
printk(KERN_ERR "Set broken SCSI Device %d:%d:%d" pr_err("Set broken SCSI Device %d:%d:%d"
" queue_depth to %d\n", sd->channel, sd->id, " queue_depth to %d\n", sd->channel, sd->id,
sd->lun, sd->queue_depth); sd->lun, sd->queue_depth);
} }
...@@ -355,7 +355,7 @@ static struct se_device *pscsi_add_device_to_list( ...@@ -355,7 +355,7 @@ static struct se_device *pscsi_add_device_to_list(
dev = transport_add_device_to_core_hba(hba, &pscsi_template, dev = transport_add_device_to_core_hba(hba, &pscsi_template,
se_dev, dev_flags, pdv, se_dev, dev_flags, pdv,
&dev_limits, NULL, NULL); &dev_limits, NULL, NULL);
if (!(dev)) { if (!dev) {
pdv->pdv_sd = NULL; pdv->pdv_sd = NULL;
return NULL; return NULL;
} }
...@@ -385,13 +385,13 @@ static void *pscsi_allocate_virtdevice(struct se_hba *hba, const char *name) ...@@ -385,13 +385,13 @@ static void *pscsi_allocate_virtdevice(struct se_hba *hba, const char *name)
struct pscsi_dev_virt *pdv; struct pscsi_dev_virt *pdv;
pdv = kzalloc(sizeof(struct pscsi_dev_virt), GFP_KERNEL); pdv = kzalloc(sizeof(struct pscsi_dev_virt), GFP_KERNEL);
if (!(pdv)) { if (!pdv) {
printk(KERN_ERR "Unable to allocate memory for struct pscsi_dev_virt\n"); pr_err("Unable to allocate memory for struct pscsi_dev_virt\n");
return NULL; return NULL;
} }
pdv->pdv_se_hba = hba; pdv->pdv_se_hba = hba;
printk(KERN_INFO "PSCSI: Allocated pdv: %p for %s\n", pdv, name); pr_debug("PSCSI: Allocated pdv: %p for %s\n", pdv, name);
return pdv; return pdv;
} }
...@@ -412,7 +412,7 @@ static struct se_device *pscsi_create_type_disk( ...@@ -412,7 +412,7 @@ static struct se_device *pscsi_create_type_disk(
u32 dev_flags = 0; u32 dev_flags = 0;
if (scsi_device_get(sd)) { if (scsi_device_get(sd)) {
printk(KERN_ERR "scsi_device_get() failed for %d:%d:%d:%d\n", pr_err("scsi_device_get() failed for %d:%d:%d:%d\n",
sh->host_no, sd->channel, sd->id, sd->lun); sh->host_no, sd->channel, sd->id, sd->lun);
spin_unlock_irq(sh->host_lock); spin_unlock_irq(sh->host_lock);
return NULL; return NULL;
...@@ -425,19 +425,19 @@ static struct se_device *pscsi_create_type_disk( ...@@ -425,19 +425,19 @@ static struct se_device *pscsi_create_type_disk(
bd = blkdev_get_by_path(se_dev->se_dev_udev_path, bd = blkdev_get_by_path(se_dev->se_dev_udev_path,
FMODE_WRITE|FMODE_READ|FMODE_EXCL, pdv); FMODE_WRITE|FMODE_READ|FMODE_EXCL, pdv);
if (IS_ERR(bd)) { if (IS_ERR(bd)) {
printk(KERN_ERR "pSCSI: blkdev_get_by_path() failed\n"); pr_err("pSCSI: blkdev_get_by_path() failed\n");
scsi_device_put(sd); scsi_device_put(sd);
return NULL; return NULL;
} }
pdv->pdv_bd = bd; pdv->pdv_bd = bd;
dev = pscsi_add_device_to_list(hba, se_dev, pdv, sd, dev_flags); dev = pscsi_add_device_to_list(hba, se_dev, pdv, sd, dev_flags);
if (!(dev)) { if (!dev) {
blkdev_put(pdv->pdv_bd, FMODE_WRITE|FMODE_READ|FMODE_EXCL); blkdev_put(pdv->pdv_bd, FMODE_WRITE|FMODE_READ|FMODE_EXCL);
scsi_device_put(sd); scsi_device_put(sd);
return NULL; return NULL;
} }
printk(KERN_INFO "CORE_PSCSI[%d] - Added TYPE_DISK for %d:%d:%d:%d\n", pr_debug("CORE_PSCSI[%d] - Added TYPE_DISK for %d:%d:%d:%d\n",
phv->phv_host_id, sh->host_no, sd->channel, sd->id, sd->lun); phv->phv_host_id, sh->host_no, sd->channel, sd->id, sd->lun);
return dev; return dev;
...@@ -459,7 +459,7 @@ static struct se_device *pscsi_create_type_rom( ...@@ -459,7 +459,7 @@ static struct se_device *pscsi_create_type_rom(
u32 dev_flags = 0; u32 dev_flags = 0;
if (scsi_device_get(sd)) { if (scsi_device_get(sd)) {
printk(KERN_ERR "scsi_device_get() failed for %d:%d:%d:%d\n", pr_err("scsi_device_get() failed for %d:%d:%d:%d\n",
sh->host_no, sd->channel, sd->id, sd->lun); sh->host_no, sd->channel, sd->id, sd->lun);
spin_unlock_irq(sh->host_lock); spin_unlock_irq(sh->host_lock);
return NULL; return NULL;
...@@ -467,11 +467,11 @@ static struct se_device *pscsi_create_type_rom( ...@@ -467,11 +467,11 @@ static struct se_device *pscsi_create_type_rom(
spin_unlock_irq(sh->host_lock); spin_unlock_irq(sh->host_lock);
dev = pscsi_add_device_to_list(hba, se_dev, pdv, sd, dev_flags); dev = pscsi_add_device_to_list(hba, se_dev, pdv, sd, dev_flags);
if (!(dev)) { if (!dev) {
scsi_device_put(sd); scsi_device_put(sd);
return NULL; return NULL;
} }
printk(KERN_INFO "CORE_PSCSI[%d] - Added Type: %s for %d:%d:%d:%d\n", pr_debug("CORE_PSCSI[%d] - Added Type: %s for %d:%d:%d:%d\n",
phv->phv_host_id, scsi_device_type(sd->type), sh->host_no, phv->phv_host_id, scsi_device_type(sd->type), sh->host_no,
sd->channel, sd->id, sd->lun); sd->channel, sd->id, sd->lun);
...@@ -495,10 +495,10 @@ static struct se_device *pscsi_create_type_other( ...@@ -495,10 +495,10 @@ static struct se_device *pscsi_create_type_other(
spin_unlock_irq(sh->host_lock); spin_unlock_irq(sh->host_lock);
dev = pscsi_add_device_to_list(hba, se_dev, pdv, sd, dev_flags); dev = pscsi_add_device_to_list(hba, se_dev, pdv, sd, dev_flags);
if (!(dev)) if (!dev)
return NULL; return NULL;
printk(KERN_INFO "CORE_PSCSI[%d] - Added Type: %s for %d:%d:%d:%d\n", pr_debug("CORE_PSCSI[%d] - Added Type: %s for %d:%d:%d:%d\n",
phv->phv_host_id, scsi_device_type(sd->type), sh->host_no, phv->phv_host_id, scsi_device_type(sd->type), sh->host_no,
sd->channel, sd->id, sd->lun); sd->channel, sd->id, sd->lun);
...@@ -517,8 +517,8 @@ static struct se_device *pscsi_create_virtdevice( ...@@ -517,8 +517,8 @@ static struct se_device *pscsi_create_virtdevice(
struct Scsi_Host *sh = phv->phv_lld_host; struct Scsi_Host *sh = phv->phv_lld_host;
int legacy_mode_enable = 0; int legacy_mode_enable = 0;
if (!(pdv)) { if (!pdv) {
printk(KERN_ERR "Unable to locate struct pscsi_dev_virt" pr_err("Unable to locate struct pscsi_dev_virt"
" parameter\n"); " parameter\n");
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);
} }
...@@ -526,9 +526,9 @@ static struct se_device *pscsi_create_virtdevice( ...@@ -526,9 +526,9 @@ static struct se_device *pscsi_create_virtdevice(
* If not running in PHV_LLD_SCSI_HOST_NO mode, locate the * If not running in PHV_LLD_SCSI_HOST_NO mode, locate the
* struct Scsi_Host we will need to bring the TCM/pSCSI object online * struct Scsi_Host we will need to bring the TCM/pSCSI object online
*/ */
if (!(sh)) { if (!sh) {
if (phv->phv_mode == PHV_LLD_SCSI_HOST_NO) { if (phv->phv_mode == PHV_LLD_SCSI_HOST_NO) {
printk(KERN_ERR "pSCSI: Unable to locate struct" pr_err("pSCSI: Unable to locate struct"
" Scsi_Host for PHV_LLD_SCSI_HOST_NO\n"); " Scsi_Host for PHV_LLD_SCSI_HOST_NO\n");
return ERR_PTR(-ENODEV); return ERR_PTR(-ENODEV);
} }
...@@ -537,7 +537,7 @@ static struct se_device *pscsi_create_virtdevice( ...@@ -537,7 +537,7 @@ static struct se_device *pscsi_create_virtdevice(
* reference, we enforce that udev_path has been set * reference, we enforce that udev_path has been set
*/ */
if (!(se_dev->su_dev_flags & SDF_USING_UDEV_PATH)) { if (!(se_dev->su_dev_flags & SDF_USING_UDEV_PATH)) {
printk(KERN_ERR "pSCSI: udev_path attribute has not" pr_err("pSCSI: udev_path attribute has not"
" been set before ENABLE=1\n"); " been set before ENABLE=1\n");
return ERR_PTR(-EINVAL); return ERR_PTR(-EINVAL);
} }
...@@ -548,8 +548,8 @@ static struct se_device *pscsi_create_virtdevice( ...@@ -548,8 +548,8 @@ static struct se_device *pscsi_create_virtdevice(
*/ */
if (!(pdv->pdv_flags & PDF_HAS_VIRT_HOST_ID)) { if (!(pdv->pdv_flags & PDF_HAS_VIRT_HOST_ID)) {
spin_lock(&hba->device_lock); spin_lock(&hba->device_lock);
if (!(list_empty(&hba->hba_dev_list))) { if (!list_empty(&hba->hba_dev_list)) {
printk(KERN_ERR "pSCSI: Unable to set hba_mode" pr_err("pSCSI: Unable to set hba_mode"
" with active devices\n"); " with active devices\n");
spin_unlock(&hba->device_lock); spin_unlock(&hba->device_lock);
return ERR_PTR(-EEXIST); return ERR_PTR(-EEXIST);
...@@ -565,14 +565,14 @@ static struct se_device *pscsi_create_virtdevice( ...@@ -565,14 +565,14 @@ static struct se_device *pscsi_create_virtdevice(
} else { } else {
sh = scsi_host_lookup(pdv->pdv_host_id); sh = scsi_host_lookup(pdv->pdv_host_id);
if (IS_ERR(sh)) { if (IS_ERR(sh)) {
printk(KERN_ERR "pSCSI: Unable to locate" pr_err("pSCSI: Unable to locate"
" pdv_host_id: %d\n", pdv->pdv_host_id); " pdv_host_id: %d\n", pdv->pdv_host_id);
return (struct se_device *) sh; return (struct se_device *) sh;
} }
} }
} else { } else {
if (phv->phv_mode == PHV_VIRUTAL_HOST_ID) { if (phv->phv_mode == PHV_VIRUTAL_HOST_ID) {
printk(KERN_ERR "pSCSI: PHV_VIRUTAL_HOST_ID set while" pr_err("pSCSI: PHV_VIRUTAL_HOST_ID set while"
" struct Scsi_Host exists\n"); " struct Scsi_Host exists\n");
return ERR_PTR(-EEXIST); return ERR_PTR(-EEXIST);
} }
...@@ -601,7 +601,7 @@ static struct se_device *pscsi_create_virtdevice( ...@@ -601,7 +601,7 @@ static struct se_device *pscsi_create_virtdevice(
break; break;
} }
if (!(dev)) { if (!dev) {
if (phv->phv_mode == PHV_VIRUTAL_HOST_ID) if (phv->phv_mode == PHV_VIRUTAL_HOST_ID)
scsi_host_put(sh); scsi_host_put(sh);
else if (legacy_mode_enable) { else if (legacy_mode_enable) {
...@@ -615,7 +615,7 @@ static struct se_device *pscsi_create_virtdevice( ...@@ -615,7 +615,7 @@ static struct se_device *pscsi_create_virtdevice(
} }
spin_unlock_irq(sh->host_lock); spin_unlock_irq(sh->host_lock);
printk(KERN_ERR "pSCSI: Unable to locate %d:%d:%d:%d\n", sh->host_no, pr_err("pSCSI: Unable to locate %d:%d:%d:%d\n", sh->host_no,
pdv->pdv_channel_id, pdv->pdv_target_id, pdv->pdv_lun_id); pdv->pdv_channel_id, pdv->pdv_target_id, pdv->pdv_lun_id);
if (phv->phv_mode == PHV_VIRUTAL_HOST_ID) if (phv->phv_mode == PHV_VIRUTAL_HOST_ID)
...@@ -729,8 +729,8 @@ static int pscsi_transport_complete(struct se_task *task) ...@@ -729,8 +729,8 @@ static int pscsi_transport_complete(struct se_task *task)
u32 blocksize; u32 blocksize;
buf = sg_virt(&sg[0]); buf = sg_virt(&sg[0]);
if (!(buf)) { if (!buf) {
printk(KERN_ERR "Unable to get buf for scatterlist\n"); pr_err("Unable to get buf for scatterlist\n");
goto after_mode_select; goto after_mode_select;
} }
...@@ -760,34 +760,20 @@ static int pscsi_transport_complete(struct se_task *task) ...@@ -760,34 +760,20 @@ static int pscsi_transport_complete(struct se_task *task)
} }
static struct se_task * static struct se_task *
pscsi_alloc_task(struct se_cmd *cmd) pscsi_alloc_task(unsigned char *cdb)
{ {
struct pscsi_plugin_task *pt; struct pscsi_plugin_task *pt;
unsigned char *cdb = cmd->t_task_cdb;
pt = kzalloc(sizeof(struct pscsi_plugin_task), GFP_KERNEL); /*
* Dynamically alloc cdb space, since it may be larger than
* TCM_MAX_COMMAND_SIZE
*/
pt = kzalloc(sizeof(*pt) + scsi_command_size(cdb), GFP_KERNEL);
if (!pt) { if (!pt) {
printk(KERN_ERR "Unable to allocate struct pscsi_plugin_task\n"); pr_err("Unable to allocate struct pscsi_plugin_task\n");
return NULL; return NULL;
} }
/*
* If TCM Core is signaling a > TCM_MAX_COMMAND_SIZE allocation,
* allocate the extended CDB buffer for per struct se_task context
* pt->pscsi_cdb now.
*/
if (cmd->t_task_cdb != cmd->__t_task_cdb) {
pt->pscsi_cdb = kzalloc(scsi_command_size(cdb), GFP_KERNEL);
if (!(pt->pscsi_cdb)) {
printk(KERN_ERR "pSCSI: Unable to allocate extended"
" pt->pscsi_cdb\n");
kfree(pt);
return NULL;
}
} else
pt->pscsi_cdb = &pt->__pscsi_cdb[0];
return &pt->pscsi_task; return &pt->pscsi_task;
} }
...@@ -837,8 +823,8 @@ static int pscsi_blk_get_request(struct se_task *task) ...@@ -837,8 +823,8 @@ static int pscsi_blk_get_request(struct se_task *task)
pt->pscsi_req = blk_get_request(pdv->pdv_sd->request_queue, pt->pscsi_req = blk_get_request(pdv->pdv_sd->request_queue,
(task->task_data_direction == DMA_TO_DEVICE), (task->task_data_direction == DMA_TO_DEVICE),
GFP_KERNEL); GFP_KERNEL);
if (!(pt->pscsi_req) || IS_ERR(pt->pscsi_req)) { if (!pt->pscsi_req || IS_ERR(pt->pscsi_req)) {
printk(KERN_ERR "PSCSI: blk_get_request() failed: %ld\n", pr_err("PSCSI: blk_get_request() failed: %ld\n",
IS_ERR(pt->pscsi_req)); IS_ERR(pt->pscsi_req));
return PYX_TRANSPORT_LU_COMM_FAILURE; return PYX_TRANSPORT_LU_COMM_FAILURE;
} }
...@@ -883,14 +869,7 @@ static int pscsi_do_task(struct se_task *task) ...@@ -883,14 +869,7 @@ static int pscsi_do_task(struct se_task *task)
static void pscsi_free_task(struct se_task *task) static void pscsi_free_task(struct se_task *task)
{ {
struct pscsi_plugin_task *pt = PSCSI_TASK(task); struct pscsi_plugin_task *pt = PSCSI_TASK(task);
struct se_cmd *cmd = task->task_se_cmd;
/*
* Release the extended CDB allocation from pscsi_alloc_task()
* if one exists.
*/
if (cmd->t_task_cdb != cmd->__t_task_cdb)
kfree(pt->pscsi_cdb);
/* /*
* We do not release the bio(s) here associated with this task, as * We do not release the bio(s) here associated with this task, as
* this is handled by bio_put() and pscsi_bi_endio(). * this is handled by bio_put() and pscsi_bi_endio().
...@@ -936,7 +915,7 @@ static ssize_t pscsi_set_configfs_dev_params(struct se_hba *hba, ...@@ -936,7 +915,7 @@ static ssize_t pscsi_set_configfs_dev_params(struct se_hba *hba,
switch (token) { switch (token) {
case Opt_scsi_host_id: case Opt_scsi_host_id:
if (phv->phv_mode == PHV_LLD_SCSI_HOST_NO) { if (phv->phv_mode == PHV_LLD_SCSI_HOST_NO) {
printk(KERN_ERR "PSCSI[%d]: Unable to accept" pr_err("PSCSI[%d]: Unable to accept"
" scsi_host_id while phv_mode ==" " scsi_host_id while phv_mode =="
" PHV_LLD_SCSI_HOST_NO\n", " PHV_LLD_SCSI_HOST_NO\n",
phv->phv_host_id); phv->phv_host_id);
...@@ -945,14 +924,14 @@ static ssize_t pscsi_set_configfs_dev_params(struct se_hba *hba, ...@@ -945,14 +924,14 @@ static ssize_t pscsi_set_configfs_dev_params(struct se_hba *hba,
} }
match_int(args, &arg); match_int(args, &arg);
pdv->pdv_host_id = arg; pdv->pdv_host_id = arg;
printk(KERN_INFO "PSCSI[%d]: Referencing SCSI Host ID:" pr_debug("PSCSI[%d]: Referencing SCSI Host ID:"
" %d\n", phv->phv_host_id, pdv->pdv_host_id); " %d\n", phv->phv_host_id, pdv->pdv_host_id);
pdv->pdv_flags |= PDF_HAS_VIRT_HOST_ID; pdv->pdv_flags |= PDF_HAS_VIRT_HOST_ID;
break; break;
case Opt_scsi_channel_id: case Opt_scsi_channel_id:
match_int(args, &arg); match_int(args, &arg);
pdv->pdv_channel_id = arg; pdv->pdv_channel_id = arg;
printk(KERN_INFO "PSCSI[%d]: Referencing SCSI Channel" pr_debug("PSCSI[%d]: Referencing SCSI Channel"
" ID: %d\n", phv->phv_host_id, " ID: %d\n", phv->phv_host_id,
pdv->pdv_channel_id); pdv->pdv_channel_id);
pdv->pdv_flags |= PDF_HAS_CHANNEL_ID; pdv->pdv_flags |= PDF_HAS_CHANNEL_ID;
...@@ -960,7 +939,7 @@ static ssize_t pscsi_set_configfs_dev_params(struct se_hba *hba, ...@@ -960,7 +939,7 @@ static ssize_t pscsi_set_configfs_dev_params(struct se_hba *hba,
case Opt_scsi_target_id: case Opt_scsi_target_id:
match_int(args, &arg); match_int(args, &arg);
pdv->pdv_target_id = arg; pdv->pdv_target_id = arg;
printk(KERN_INFO "PSCSI[%d]: Referencing SCSI Target" pr_debug("PSCSI[%d]: Referencing SCSI Target"
" ID: %d\n", phv->phv_host_id, " ID: %d\n", phv->phv_host_id,
pdv->pdv_target_id); pdv->pdv_target_id);
pdv->pdv_flags |= PDF_HAS_TARGET_ID; pdv->pdv_flags |= PDF_HAS_TARGET_ID;
...@@ -968,7 +947,7 @@ static ssize_t pscsi_set_configfs_dev_params(struct se_hba *hba, ...@@ -968,7 +947,7 @@ static ssize_t pscsi_set_configfs_dev_params(struct se_hba *hba,
case Opt_scsi_lun_id: case Opt_scsi_lun_id:
match_int(args, &arg); match_int(args, &arg);
pdv->pdv_lun_id = arg; pdv->pdv_lun_id = arg;
printk(KERN_INFO "PSCSI[%d]: Referencing SCSI LUN ID:" pr_debug("PSCSI[%d]: Referencing SCSI LUN ID:"
" %d\n", phv->phv_host_id, pdv->pdv_lun_id); " %d\n", phv->phv_host_id, pdv->pdv_lun_id);
pdv->pdv_flags |= PDF_HAS_LUN_ID; pdv->pdv_flags |= PDF_HAS_LUN_ID;
break; break;
...@@ -991,7 +970,7 @@ static ssize_t pscsi_check_configfs_dev_params( ...@@ -991,7 +970,7 @@ static ssize_t pscsi_check_configfs_dev_params(
if (!(pdv->pdv_flags & PDF_HAS_CHANNEL_ID) || if (!(pdv->pdv_flags & PDF_HAS_CHANNEL_ID) ||
!(pdv->pdv_flags & PDF_HAS_TARGET_ID) || !(pdv->pdv_flags & PDF_HAS_TARGET_ID) ||
!(pdv->pdv_flags & PDF_HAS_LUN_ID)) { !(pdv->pdv_flags & PDF_HAS_LUN_ID)) {
printk(KERN_ERR "Missing scsi_channel_id=, scsi_target_id= and" pr_err("Missing scsi_channel_id=, scsi_target_id= and"
" scsi_lun_id= parameters\n"); " scsi_lun_id= parameters\n");
return -EINVAL; return -EINVAL;
} }
...@@ -1061,8 +1040,8 @@ static inline struct bio *pscsi_get_bio(int sg_num) ...@@ -1061,8 +1040,8 @@ static inline struct bio *pscsi_get_bio(int sg_num)
* in block/blk-core.c:blk_make_request() * in block/blk-core.c:blk_make_request()
*/ */
bio = bio_kmalloc(GFP_KERNEL, sg_num); bio = bio_kmalloc(GFP_KERNEL, sg_num);
if (!(bio)) { if (!bio) {
printk(KERN_ERR "PSCSI: bio_kmalloc() failed\n"); pr_err("PSCSI: bio_kmalloc() failed\n");
return NULL; return NULL;
} }
bio->bi_end_io = pscsi_bi_endio; bio->bi_end_io = pscsi_bi_endio;
...@@ -1070,12 +1049,6 @@ static inline struct bio *pscsi_get_bio(int sg_num) ...@@ -1070,12 +1049,6 @@ static inline struct bio *pscsi_get_bio(int sg_num)
return bio; return bio;
} }
#if 0
#define DEBUG_PSCSI(x...) printk(x)
#else
#define DEBUG_PSCSI(x...)
#endif
static int __pscsi_map_task_SG( static int __pscsi_map_task_SG(
struct se_task *task, struct se_task *task,
struct scatterlist *task_sg, struct scatterlist *task_sg,
...@@ -1106,34 +1079,34 @@ static int __pscsi_map_task_SG( ...@@ -1106,34 +1079,34 @@ static int __pscsi_map_task_SG(
* is ported to upstream SCSI passthrough functionality that accepts * is ported to upstream SCSI passthrough functionality that accepts
* struct scatterlist->page_link or struct page as a paraemeter. * struct scatterlist->page_link or struct page as a paraemeter.
*/ */
DEBUG_PSCSI("PSCSI: nr_pages: %d\n", nr_pages); pr_debug("PSCSI: nr_pages: %d\n", nr_pages);
for_each_sg(task_sg, sg, task_sg_num, i) { for_each_sg(task_sg, sg, task_sg_num, i) {
page = sg_page(sg); page = sg_page(sg);
off = sg->offset; off = sg->offset;
len = sg->length; len = sg->length;
DEBUG_PSCSI("PSCSI: i: %d page: %p len: %d off: %d\n", i, pr_debug("PSCSI: i: %d page: %p len: %d off: %d\n", i,
page, len, off); page, len, off);
while (len > 0 && data_len > 0) { while (len > 0 && data_len > 0) {
bytes = min_t(unsigned int, len, PAGE_SIZE - off); bytes = min_t(unsigned int, len, PAGE_SIZE - off);
bytes = min(bytes, data_len); bytes = min(bytes, data_len);
if (!(bio)) { if (!bio) {
nr_vecs = min_t(int, BIO_MAX_PAGES, nr_pages); nr_vecs = min_t(int, BIO_MAX_PAGES, nr_pages);
nr_pages -= nr_vecs; nr_pages -= nr_vecs;
/* /*
* Calls bio_kmalloc() and sets bio->bi_end_io() * Calls bio_kmalloc() and sets bio->bi_end_io()
*/ */
bio = pscsi_get_bio(nr_vecs); bio = pscsi_get_bio(nr_vecs);
if (!(bio)) if (!bio)
goto fail; goto fail;
if (rw) if (rw)
bio->bi_rw |= REQ_WRITE; bio->bi_rw |= REQ_WRITE;
DEBUG_PSCSI("PSCSI: Allocated bio: %p," pr_debug("PSCSI: Allocated bio: %p,"
" dir: %s nr_vecs: %d\n", bio, " dir: %s nr_vecs: %d\n", bio,
(rw) ? "rw" : "r", nr_vecs); (rw) ? "rw" : "r", nr_vecs);
/* /*
...@@ -1148,7 +1121,7 @@ static int __pscsi_map_task_SG( ...@@ -1148,7 +1121,7 @@ static int __pscsi_map_task_SG(
tbio = tbio->bi_next = bio; tbio = tbio->bi_next = bio;
} }
DEBUG_PSCSI("PSCSI: Calling bio_add_pc_page() i: %d" pr_debug("PSCSI: Calling bio_add_pc_page() i: %d"
" bio: %p page: %p len: %d off: %d\n", i, bio, " bio: %p page: %p len: %d off: %d\n", i, bio,
page, len, off); page, len, off);
...@@ -1157,11 +1130,11 @@ static int __pscsi_map_task_SG( ...@@ -1157,11 +1130,11 @@ static int __pscsi_map_task_SG(
if (rc != bytes) if (rc != bytes)
goto fail; goto fail;
DEBUG_PSCSI("PSCSI: bio->bi_vcnt: %d nr_vecs: %d\n", pr_debug("PSCSI: bio->bi_vcnt: %d nr_vecs: %d\n",
bio->bi_vcnt, nr_vecs); bio->bi_vcnt, nr_vecs);
if (bio->bi_vcnt > nr_vecs) { if (bio->bi_vcnt > nr_vecs) {
DEBUG_PSCSI("PSCSI: Reached bio->bi_vcnt max:" pr_debug("PSCSI: Reached bio->bi_vcnt max:"
" %d i: %d bio: %p, allocating another" " %d i: %d bio: %p, allocating another"
" bio\n", bio->bi_vcnt, i, bio); " bio\n", bio->bi_vcnt, i, bio);
/* /*
...@@ -1183,15 +1156,15 @@ static int __pscsi_map_task_SG( ...@@ -1183,15 +1156,15 @@ static int __pscsi_map_task_SG(
* Setup the primary pt->pscsi_req used for non BIDI and BIDI-COMMAND * Setup the primary pt->pscsi_req used for non BIDI and BIDI-COMMAND
* primary SCSI WRITE poayload mapped for struct se_task->task_sg[] * primary SCSI WRITE poayload mapped for struct se_task->task_sg[]
*/ */
if (!(bidi_read)) { if (!bidi_read) {
/* /*
* Starting with v2.6.31, call blk_make_request() passing in *hbio to * Starting with v2.6.31, call blk_make_request() passing in *hbio to
* allocate the pSCSI task a struct request. * allocate the pSCSI task a struct request.
*/ */
pt->pscsi_req = blk_make_request(pdv->pdv_sd->request_queue, pt->pscsi_req = blk_make_request(pdv->pdv_sd->request_queue,
hbio, GFP_KERNEL); hbio, GFP_KERNEL);
if (!(pt->pscsi_req)) { if (!pt->pscsi_req) {
printk(KERN_ERR "pSCSI: blk_make_request() failed\n"); pr_err("pSCSI: blk_make_request() failed\n");
goto fail; goto fail;
} }
/* /*
...@@ -1200,7 +1173,7 @@ static int __pscsi_map_task_SG( ...@@ -1200,7 +1173,7 @@ static int __pscsi_map_task_SG(
*/ */
pscsi_blk_init_request(task, pt, pt->pscsi_req, 0); pscsi_blk_init_request(task, pt, pt->pscsi_req, 0);
return task->task_sg_num; return task->task_sg_nents;
} }
/* /*
* Setup the secondary pt->pscsi_req->next_rq used for the extra BIDI-COMMAND * Setup the secondary pt->pscsi_req->next_rq used for the extra BIDI-COMMAND
...@@ -1208,13 +1181,13 @@ static int __pscsi_map_task_SG( ...@@ -1208,13 +1181,13 @@ static int __pscsi_map_task_SG(
*/ */
pt->pscsi_req->next_rq = blk_make_request(pdv->pdv_sd->request_queue, pt->pscsi_req->next_rq = blk_make_request(pdv->pdv_sd->request_queue,
hbio, GFP_KERNEL); hbio, GFP_KERNEL);
if (!(pt->pscsi_req->next_rq)) { if (!pt->pscsi_req->next_rq) {
printk(KERN_ERR "pSCSI: blk_make_request() failed for BIDI\n"); pr_err("pSCSI: blk_make_request() failed for BIDI\n");
goto fail; goto fail;
} }
pscsi_blk_init_request(task, pt, pt->pscsi_req->next_rq, 1); pscsi_blk_init_request(task, pt, pt->pscsi_req->next_rq, 1);
return task->task_sg_num; return task->task_sg_nents;
fail: fail:
while (hbio) { while (hbio) {
bio = hbio; bio = hbio;
...@@ -1233,14 +1206,14 @@ static int pscsi_map_task_SG(struct se_task *task) ...@@ -1233,14 +1206,14 @@ static int pscsi_map_task_SG(struct se_task *task)
* Setup the main struct request for the task->task_sg[] payload * Setup the main struct request for the task->task_sg[] payload
*/ */
ret = __pscsi_map_task_SG(task, task->task_sg, task->task_sg_num, 0); ret = __pscsi_map_task_SG(task, task->task_sg, task->task_sg_nents, 0);
if (ret >= 0 && task->task_sg_bidi) { if (ret >= 0 && task->task_sg_bidi) {
/* /*
* If present, set up the extra BIDI-COMMAND SCSI READ * If present, set up the extra BIDI-COMMAND SCSI READ
* struct request and payload. * struct request and payload.
*/ */
ret = __pscsi_map_task_SG(task, task->task_sg_bidi, ret = __pscsi_map_task_SG(task, task->task_sg_bidi,
task->task_sg_num, 1); task->task_sg_nents, 1);
} }
if (ret < 0) if (ret < 0)
...@@ -1319,9 +1292,9 @@ static inline void pscsi_process_SAM_status( ...@@ -1319,9 +1292,9 @@ static inline void pscsi_process_SAM_status(
struct pscsi_plugin_task *pt) struct pscsi_plugin_task *pt)
{ {
task->task_scsi_status = status_byte(pt->pscsi_result); task->task_scsi_status = status_byte(pt->pscsi_result);
if ((task->task_scsi_status)) { if (task->task_scsi_status) {
task->task_scsi_status <<= 1; task->task_scsi_status <<= 1;
printk(KERN_INFO "PSCSI Status Byte exception at task: %p CDB:" pr_debug("PSCSI Status Byte exception at task: %p CDB:"
" 0x%02x Result: 0x%08x\n", task, pt->pscsi_cdb[0], " 0x%02x Result: 0x%08x\n", task, pt->pscsi_cdb[0],
pt->pscsi_result); pt->pscsi_result);
} }
...@@ -1331,7 +1304,7 @@ static inline void pscsi_process_SAM_status( ...@@ -1331,7 +1304,7 @@ static inline void pscsi_process_SAM_status(
transport_complete_task(task, (!task->task_scsi_status)); transport_complete_task(task, (!task->task_scsi_status));
break; break;
default: default:
printk(KERN_INFO "PSCSI Host Byte exception at task: %p CDB:" pr_debug("PSCSI Host Byte exception at task: %p CDB:"
" 0x%02x Result: 0x%08x\n", task, pt->pscsi_cdb[0], " 0x%02x Result: 0x%08x\n", task, pt->pscsi_cdb[0],
pt->pscsi_result); pt->pscsi_result);
task->task_scsi_status = SAM_STAT_CHECK_CONDITION; task->task_scsi_status = SAM_STAT_CHECK_CONDITION;
......
...@@ -23,13 +23,12 @@ ...@@ -23,13 +23,12 @@
struct pscsi_plugin_task { struct pscsi_plugin_task {
struct se_task pscsi_task; struct se_task pscsi_task;
unsigned char *pscsi_cdb;
unsigned char __pscsi_cdb[TCM_MAX_COMMAND_SIZE];
unsigned char pscsi_sense[SCSI_SENSE_BUFFERSIZE]; unsigned char pscsi_sense[SCSI_SENSE_BUFFERSIZE];
int pscsi_direction; int pscsi_direction;
int pscsi_result; int pscsi_result;
u32 pscsi_resid; u32 pscsi_resid;
struct request *pscsi_req; struct request *pscsi_req;
unsigned char pscsi_cdb[0];
} ____cacheline_aligned; } ____cacheline_aligned;
#define PDF_HAS_CHANNEL_ID 0x01 #define PDF_HAS_CHANNEL_ID 0x01
......
此差异已折叠。
...@@ -32,8 +32,6 @@ struct rd_request { ...@@ -32,8 +32,6 @@ struct rd_request {
u32 rd_page_count; u32 rd_page_count;
/* Scatterlist count */ /* Scatterlist count */
u32 rd_size; u32 rd_size;
/* Ramdisk device */
struct rd_dev *rd_dev;
} ____cacheline_aligned; } ____cacheline_aligned;
struct rd_dev_sg_table { struct rd_dev_sg_table {
......
...@@ -41,13 +41,6 @@ ...@@ -41,13 +41,6 @@
#include "target_core_alua.h" #include "target_core_alua.h"
#include "target_core_pr.h" #include "target_core_pr.h"
#define DEBUG_LUN_RESET
#ifdef DEBUG_LUN_RESET
#define DEBUG_LR(x...) printk(KERN_INFO x)
#else
#define DEBUG_LR(x...)
#endif
struct se_tmr_req *core_tmr_alloc_req( struct se_tmr_req *core_tmr_alloc_req(
struct se_cmd *se_cmd, struct se_cmd *se_cmd,
void *fabric_tmr_ptr, void *fabric_tmr_ptr,
...@@ -57,8 +50,8 @@ struct se_tmr_req *core_tmr_alloc_req( ...@@ -57,8 +50,8 @@ struct se_tmr_req *core_tmr_alloc_req(
tmr = kmem_cache_zalloc(se_tmr_req_cache, (in_interrupt()) ? tmr = kmem_cache_zalloc(se_tmr_req_cache, (in_interrupt()) ?
GFP_ATOMIC : GFP_KERNEL); GFP_ATOMIC : GFP_KERNEL);
if (!(tmr)) { if (!tmr) {
printk(KERN_ERR "Unable to allocate struct se_tmr_req\n"); pr_err("Unable to allocate struct se_tmr_req\n");
return ERR_PTR(-ENOMEM); return ERR_PTR(-ENOMEM);
} }
tmr->task_cmd = se_cmd; tmr->task_cmd = se_cmd;
...@@ -93,14 +86,14 @@ static void core_tmr_handle_tas_abort( ...@@ -93,14 +86,14 @@ static void core_tmr_handle_tas_abort(
int tas, int tas,
int fe_count) int fe_count)
{ {
if (!(fe_count)) { if (!fe_count) {
transport_cmd_finish_abort(cmd, 1); transport_cmd_finish_abort(cmd, 1);
return; return;
} }
/* /*
* TASK ABORTED status (TAS) bit support * TASK ABORTED status (TAS) bit support
*/ */
if (((tmr_nacl != NULL) && if ((tmr_nacl &&
(tmr_nacl == cmd->se_sess->se_node_acl)) || tas) (tmr_nacl == cmd->se_sess->se_node_acl)) || tas)
transport_send_task_abort(cmd); transport_send_task_abort(cmd);
...@@ -141,13 +134,13 @@ int core_tmr_lun_reset( ...@@ -141,13 +134,13 @@ int core_tmr_lun_reset(
tmr_nacl = tmr->task_cmd->se_sess->se_node_acl; tmr_nacl = tmr->task_cmd->se_sess->se_node_acl;
tmr_tpg = tmr->task_cmd->se_sess->se_tpg; tmr_tpg = tmr->task_cmd->se_sess->se_tpg;
if (tmr_nacl && tmr_tpg) { if (tmr_nacl && tmr_tpg) {
DEBUG_LR("LUN_RESET: TMR caller fabric: %s" pr_debug("LUN_RESET: TMR caller fabric: %s"
" initiator port %s\n", " initiator port %s\n",
tmr_tpg->se_tpg_tfo->get_fabric_name(), tmr_tpg->se_tpg_tfo->get_fabric_name(),
tmr_nacl->initiatorname); tmr_nacl->initiatorname);
} }
} }
DEBUG_LR("LUN_RESET: %s starting for [%s], tas: %d\n", pr_debug("LUN_RESET: %s starting for [%s], tas: %d\n",
(preempt_and_abort_list) ? "Preempt" : "TMR", (preempt_and_abort_list) ? "Preempt" : "TMR",
dev->transport->name, tas); dev->transport->name, tas);
/* /*
...@@ -163,8 +156,8 @@ int core_tmr_lun_reset( ...@@ -163,8 +156,8 @@ int core_tmr_lun_reset(
continue; continue;
cmd = tmr_p->task_cmd; cmd = tmr_p->task_cmd;
if (!(cmd)) { if (!cmd) {
printk(KERN_ERR "Unable to locate struct se_cmd for TMR\n"); pr_err("Unable to locate struct se_cmd for TMR\n");
continue; continue;
} }
/* /*
...@@ -172,14 +165,14 @@ int core_tmr_lun_reset( ...@@ -172,14 +165,14 @@ int core_tmr_lun_reset(
* parameter (eg: for PROUT PREEMPT_AND_ABORT service action * parameter (eg: for PROUT PREEMPT_AND_ABORT service action
* skip non regisration key matching TMRs. * skip non regisration key matching TMRs.
*/ */
if ((preempt_and_abort_list != NULL) && if (preempt_and_abort_list &&
(core_scsi3_check_cdb_abort_and_preempt( (core_scsi3_check_cdb_abort_and_preempt(
preempt_and_abort_list, cmd) != 0)) preempt_and_abort_list, cmd) != 0))
continue; continue;
spin_unlock_irq(&dev->se_tmr_lock); spin_unlock_irq(&dev->se_tmr_lock);
spin_lock_irqsave(&cmd->t_state_lock, flags); spin_lock_irqsave(&cmd->t_state_lock, flags);
if (!(atomic_read(&cmd->t_transport_active))) { if (!atomic_read(&cmd->t_transport_active)) {
spin_unlock_irqrestore(&cmd->t_state_lock, flags); spin_unlock_irqrestore(&cmd->t_state_lock, flags);
spin_lock_irq(&dev->se_tmr_lock); spin_lock_irq(&dev->se_tmr_lock);
continue; continue;
...@@ -189,7 +182,7 @@ int core_tmr_lun_reset( ...@@ -189,7 +182,7 @@ int core_tmr_lun_reset(
spin_lock_irq(&dev->se_tmr_lock); spin_lock_irq(&dev->se_tmr_lock);
continue; continue;
} }
DEBUG_LR("LUN_RESET: %s releasing TMR %p Function: 0x%02x," pr_debug("LUN_RESET: %s releasing TMR %p Function: 0x%02x,"
" Response: 0x%02x, t_state: %d\n", " Response: 0x%02x, t_state: %d\n",
(preempt_and_abort_list) ? "Preempt" : "", tmr_p, (preempt_and_abort_list) ? "Preempt" : "", tmr_p,
tmr_p->function, tmr_p->response, cmd->t_state); tmr_p->function, tmr_p->response, cmd->t_state);
...@@ -224,7 +217,7 @@ int core_tmr_lun_reset( ...@@ -224,7 +217,7 @@ int core_tmr_lun_reset(
list_for_each_entry_safe(task, task_tmp, &dev->state_task_list, list_for_each_entry_safe(task, task_tmp, &dev->state_task_list,
t_state_list) { t_state_list) {
if (!task->task_se_cmd) { if (!task->task_se_cmd) {
printk(KERN_ERR "task->task_se_cmd is NULL!\n"); pr_err("task->task_se_cmd is NULL!\n");
continue; continue;
} }
cmd = task->task_se_cmd; cmd = task->task_se_cmd;
...@@ -233,7 +226,7 @@ int core_tmr_lun_reset( ...@@ -233,7 +226,7 @@ int core_tmr_lun_reset(
* For PREEMPT_AND_ABORT usage, only process commands * For PREEMPT_AND_ABORT usage, only process commands
* with a matching reservation key. * with a matching reservation key.
*/ */
if ((preempt_and_abort_list != NULL) && if (preempt_and_abort_list &&
(core_scsi3_check_cdb_abort_and_preempt( (core_scsi3_check_cdb_abort_and_preempt(
preempt_and_abort_list, cmd) != 0)) preempt_and_abort_list, cmd) != 0))
continue; continue;
...@@ -248,14 +241,14 @@ int core_tmr_lun_reset( ...@@ -248,14 +241,14 @@ int core_tmr_lun_reset(
spin_unlock_irqrestore(&dev->execute_task_lock, flags); spin_unlock_irqrestore(&dev->execute_task_lock, flags);
spin_lock_irqsave(&cmd->t_state_lock, flags); spin_lock_irqsave(&cmd->t_state_lock, flags);
DEBUG_LR("LUN_RESET: %s cmd: %p task: %p" pr_debug("LUN_RESET: %s cmd: %p task: %p"
" ITT/CmdSN: 0x%08x/0x%08x, i_state: %d, t_state/" " ITT/CmdSN: 0x%08x/0x%08x, i_state: %d, t_state/"
"def_t_state: %d/%d cdb: 0x%02x\n", "def_t_state: %d/%d cdb: 0x%02x\n",
(preempt_and_abort_list) ? "Preempt" : "", cmd, task, (preempt_and_abort_list) ? "Preempt" : "", cmd, task,
cmd->se_tfo->get_task_tag(cmd), 0, cmd->se_tfo->get_task_tag(cmd), 0,
cmd->se_tfo->get_cmd_state(cmd), cmd->t_state, cmd->se_tfo->get_cmd_state(cmd), cmd->t_state,
cmd->deferred_t_state, cmd->t_task_cdb[0]); cmd->deferred_t_state, cmd->t_task_cdb[0]);
DEBUG_LR("LUN_RESET: ITT[0x%08x] - pr_res_key: 0x%016Lx" pr_debug("LUN_RESET: ITT[0x%08x] - pr_res_key: 0x%016Lx"
" t_task_cdbs: %d t_task_cdbs_left: %d" " t_task_cdbs: %d t_task_cdbs_left: %d"
" t_task_cdbs_sent: %d -- t_transport_active: %d" " t_task_cdbs_sent: %d -- t_transport_active: %d"
" t_transport_stop: %d t_transport_sent: %d\n", " t_transport_stop: %d t_transport_sent: %d\n",
...@@ -272,10 +265,10 @@ int core_tmr_lun_reset( ...@@ -272,10 +265,10 @@ int core_tmr_lun_reset(
spin_unlock_irqrestore( spin_unlock_irqrestore(
&cmd->t_state_lock, flags); &cmd->t_state_lock, flags);
DEBUG_LR("LUN_RESET: Waiting for task: %p to shutdown" pr_debug("LUN_RESET: Waiting for task: %p to shutdown"
" for dev: %p\n", task, dev); " for dev: %p\n", task, dev);
wait_for_completion(&task->task_stop_comp); wait_for_completion(&task->task_stop_comp);
DEBUG_LR("LUN_RESET Completed task: %p shutdown for" pr_debug("LUN_RESET Completed task: %p shutdown for"
" dev: %p\n", task, dev); " dev: %p\n", task, dev);
spin_lock_irqsave(&cmd->t_state_lock, flags); spin_lock_irqsave(&cmd->t_state_lock, flags);
atomic_dec(&cmd->t_task_cdbs_left); atomic_dec(&cmd->t_task_cdbs_left);
...@@ -288,10 +281,10 @@ int core_tmr_lun_reset( ...@@ -288,10 +281,10 @@ int core_tmr_lun_reset(
} }
__transport_stop_task_timer(task, &flags); __transport_stop_task_timer(task, &flags);
if (!(atomic_dec_and_test(&cmd->t_task_cdbs_ex_left))) { if (!atomic_dec_and_test(&cmd->t_task_cdbs_ex_left)) {
spin_unlock_irqrestore( spin_unlock_irqrestore(
&cmd->t_state_lock, flags); &cmd->t_state_lock, flags);
DEBUG_LR("LUN_RESET: Skipping task: %p, dev: %p for" pr_debug("LUN_RESET: Skipping task: %p, dev: %p for"
" t_task_cdbs_ex_left: %d\n", task, dev, " t_task_cdbs_ex_left: %d\n", task, dev,
atomic_read(&cmd->t_task_cdbs_ex_left)); atomic_read(&cmd->t_task_cdbs_ex_left));
...@@ -301,7 +294,7 @@ int core_tmr_lun_reset( ...@@ -301,7 +294,7 @@ int core_tmr_lun_reset(
fe_count = atomic_read(&cmd->t_fe_count); fe_count = atomic_read(&cmd->t_fe_count);
if (atomic_read(&cmd->t_transport_active)) { if (atomic_read(&cmd->t_transport_active)) {
DEBUG_LR("LUN_RESET: got t_transport_active = 1 for" pr_debug("LUN_RESET: got t_transport_active = 1 for"
" task: %p, t_fe_count: %d dev: %p\n", task, " task: %p, t_fe_count: %d dev: %p\n", task,
fe_count, dev); fe_count, dev);
atomic_set(&cmd->t_transport_aborted, 1); atomic_set(&cmd->t_transport_aborted, 1);
...@@ -312,7 +305,7 @@ int core_tmr_lun_reset( ...@@ -312,7 +305,7 @@ int core_tmr_lun_reset(
spin_lock_irqsave(&dev->execute_task_lock, flags); spin_lock_irqsave(&dev->execute_task_lock, flags);
continue; continue;
} }
DEBUG_LR("LUN_RESET: Got t_transport_active = 0 for task: %p," pr_debug("LUN_RESET: Got t_transport_active = 0 for task: %p,"
" t_fe_count: %d dev: %p\n", task, fe_count, dev); " t_fe_count: %d dev: %p\n", task, fe_count, dev);
atomic_set(&cmd->t_transport_aborted, 1); atomic_set(&cmd->t_transport_aborted, 1);
spin_unlock_irqrestore(&cmd->t_state_lock, flags); spin_unlock_irqrestore(&cmd->t_state_lock, flags);
...@@ -335,7 +328,7 @@ int core_tmr_lun_reset( ...@@ -335,7 +328,7 @@ int core_tmr_lun_reset(
* For PREEMPT_AND_ABORT usage, only process commands * For PREEMPT_AND_ABORT usage, only process commands
* with a matching reservation key. * with a matching reservation key.
*/ */
if ((preempt_and_abort_list != NULL) && if (preempt_and_abort_list &&
(core_scsi3_check_cdb_abort_and_preempt( (core_scsi3_check_cdb_abort_and_preempt(
preempt_and_abort_list, cmd) != 0)) preempt_and_abort_list, cmd) != 0))
continue; continue;
...@@ -350,7 +343,7 @@ int core_tmr_lun_reset( ...@@ -350,7 +343,7 @@ int core_tmr_lun_reset(
list_del(&cmd->se_queue_node); list_del(&cmd->se_queue_node);
spin_unlock_irqrestore(&qobj->cmd_queue_lock, flags); spin_unlock_irqrestore(&qobj->cmd_queue_lock, flags);
DEBUG_LR("LUN_RESET: %s from Device Queue: cmd: %p t_state:" pr_debug("LUN_RESET: %s from Device Queue: cmd: %p t_state:"
" %d t_fe_count: %d\n", (preempt_and_abort_list) ? " %d t_fe_count: %d\n", (preempt_and_abort_list) ?
"Preempt" : "", cmd, cmd->t_state, "Preempt" : "", cmd, cmd->t_state,
atomic_read(&cmd->t_fe_count)); atomic_read(&cmd->t_fe_count));
...@@ -368,20 +361,20 @@ int core_tmr_lun_reset( ...@@ -368,20 +361,20 @@ int core_tmr_lun_reset(
* Clear any legacy SPC-2 reservation when called during * Clear any legacy SPC-2 reservation when called during
* LOGICAL UNIT RESET * LOGICAL UNIT RESET
*/ */
if (!(preempt_and_abort_list) && if (!preempt_and_abort_list &&
(dev->dev_flags & DF_SPC2_RESERVATIONS)) { (dev->dev_flags & DF_SPC2_RESERVATIONS)) {
spin_lock(&dev->dev_reservation_lock); spin_lock(&dev->dev_reservation_lock);
dev->dev_reserved_node_acl = NULL; dev->dev_reserved_node_acl = NULL;
dev->dev_flags &= ~DF_SPC2_RESERVATIONS; dev->dev_flags &= ~DF_SPC2_RESERVATIONS;
spin_unlock(&dev->dev_reservation_lock); spin_unlock(&dev->dev_reservation_lock);
printk(KERN_INFO "LUN_RESET: SCSI-2 Released reservation\n"); pr_debug("LUN_RESET: SCSI-2 Released reservation\n");
} }
spin_lock_irq(&dev->stats_lock); spin_lock_irq(&dev->stats_lock);
dev->num_resets++; dev->num_resets++;
spin_unlock_irq(&dev->stats_lock); spin_unlock_irq(&dev->stats_lock);
DEBUG_LR("LUN_RESET: %s for [%s] Complete\n", pr_debug("LUN_RESET: %s for [%s] Complete\n",
(preempt_and_abort_list) ? "Preempt" : "TMR", (preempt_and_abort_list) ? "Preempt" : "TMR",
dev->transport->name); dev->transport->name);
return 0; return 0;
......
此差异已折叠。
...@@ -49,15 +49,15 @@ int core_scsi3_ua_check( ...@@ -49,15 +49,15 @@ int core_scsi3_ua_check(
struct se_session *sess = cmd->se_sess; struct se_session *sess = cmd->se_sess;
struct se_node_acl *nacl; struct se_node_acl *nacl;
if (!(sess)) if (!sess)
return 0; return 0;
nacl = sess->se_node_acl; nacl = sess->se_node_acl;
if (!(nacl)) if (!nacl)
return 0; return 0;
deve = &nacl->device_list[cmd->orig_fe_lun]; deve = &nacl->device_list[cmd->orig_fe_lun];
if (!(atomic_read(&deve->ua_count))) if (!atomic_read(&deve->ua_count))
return 0; return 0;
/* /*
* From sam4r14, section 5.14 Unit attention condition: * From sam4r14, section 5.14 Unit attention condition:
...@@ -97,12 +97,12 @@ int core_scsi3_ua_allocate( ...@@ -97,12 +97,12 @@ int core_scsi3_ua_allocate(
/* /*
* PASSTHROUGH OPS * PASSTHROUGH OPS
*/ */
if (!(nacl)) if (!nacl)
return -EINVAL; return -EINVAL;
ua = kmem_cache_zalloc(se_ua_cache, GFP_ATOMIC); ua = kmem_cache_zalloc(se_ua_cache, GFP_ATOMIC);
if (!(ua)) { if (!ua) {
printk(KERN_ERR "Unable to allocate struct se_ua\n"); pr_err("Unable to allocate struct se_ua\n");
return -ENOMEM; return -ENOMEM;
} }
INIT_LIST_HEAD(&ua->ua_dev_list); INIT_LIST_HEAD(&ua->ua_dev_list);
...@@ -177,7 +177,7 @@ int core_scsi3_ua_allocate( ...@@ -177,7 +177,7 @@ int core_scsi3_ua_allocate(
spin_unlock(&deve->ua_lock); spin_unlock(&deve->ua_lock);
spin_unlock_irq(&nacl->device_list_lock); spin_unlock_irq(&nacl->device_list_lock);
printk(KERN_INFO "[%s]: Allocated UNIT ATTENTION, mapped LUN: %u, ASC:" pr_debug("[%s]: Allocated UNIT ATTENTION, mapped LUN: %u, ASC:"
" 0x%02x, ASCQ: 0x%02x\n", " 0x%02x, ASCQ: 0x%02x\n",
nacl->se_tpg->se_tpg_tfo->get_fabric_name(), unpacked_lun, nacl->se_tpg->se_tpg_tfo->get_fabric_name(), unpacked_lun,
asc, ascq); asc, ascq);
...@@ -215,16 +215,16 @@ void core_scsi3_ua_for_check_condition( ...@@ -215,16 +215,16 @@ void core_scsi3_ua_for_check_condition(
struct se_ua *ua = NULL, *ua_p; struct se_ua *ua = NULL, *ua_p;
int head = 1; int head = 1;
if (!(sess)) if (!sess)
return; return;
nacl = sess->se_node_acl; nacl = sess->se_node_acl;
if (!(nacl)) if (!nacl)
return; return;
spin_lock_irq(&nacl->device_list_lock); spin_lock_irq(&nacl->device_list_lock);
deve = &nacl->device_list[cmd->orig_fe_lun]; deve = &nacl->device_list[cmd->orig_fe_lun];
if (!(atomic_read(&deve->ua_count))) { if (!atomic_read(&deve->ua_count)) {
spin_unlock_irq(&nacl->device_list_lock); spin_unlock_irq(&nacl->device_list_lock);
return; return;
} }
...@@ -264,7 +264,7 @@ void core_scsi3_ua_for_check_condition( ...@@ -264,7 +264,7 @@ void core_scsi3_ua_for_check_condition(
spin_unlock(&deve->ua_lock); spin_unlock(&deve->ua_lock);
spin_unlock_irq(&nacl->device_list_lock); spin_unlock_irq(&nacl->device_list_lock);
printk(KERN_INFO "[%s]: %s UNIT ATTENTION condition with" pr_debug("[%s]: %s UNIT ATTENTION condition with"
" INTLCK_CTRL: %d, mapped LUN: %u, got CDB: 0x%02x" " INTLCK_CTRL: %d, mapped LUN: %u, got CDB: 0x%02x"
" reported ASC: 0x%02x, ASCQ: 0x%02x\n", " reported ASC: 0x%02x, ASCQ: 0x%02x\n",
nacl->se_tpg->se_tpg_tfo->get_fabric_name(), nacl->se_tpg->se_tpg_tfo->get_fabric_name(),
...@@ -284,16 +284,16 @@ int core_scsi3_ua_clear_for_request_sense( ...@@ -284,16 +284,16 @@ int core_scsi3_ua_clear_for_request_sense(
struct se_ua *ua = NULL, *ua_p; struct se_ua *ua = NULL, *ua_p;
int head = 1; int head = 1;
if (!(sess)) if (!sess)
return -EINVAL; return -EINVAL;
nacl = sess->se_node_acl; nacl = sess->se_node_acl;
if (!(nacl)) if (!nacl)
return -EINVAL; return -EINVAL;
spin_lock_irq(&nacl->device_list_lock); spin_lock_irq(&nacl->device_list_lock);
deve = &nacl->device_list[cmd->orig_fe_lun]; deve = &nacl->device_list[cmd->orig_fe_lun];
if (!(atomic_read(&deve->ua_count))) { if (!atomic_read(&deve->ua_count)) {
spin_unlock_irq(&nacl->device_list_lock); spin_unlock_irq(&nacl->device_list_lock);
return -EPERM; return -EPERM;
} }
...@@ -323,7 +323,7 @@ int core_scsi3_ua_clear_for_request_sense( ...@@ -323,7 +323,7 @@ int core_scsi3_ua_clear_for_request_sense(
spin_unlock(&deve->ua_lock); spin_unlock(&deve->ua_lock);
spin_unlock_irq(&nacl->device_list_lock); spin_unlock_irq(&nacl->device_list_lock);
printk(KERN_INFO "[%s]: Released UNIT ATTENTION condition, mapped" pr_debug("[%s]: Released UNIT ATTENTION condition, mapped"
" LUN: %u, got REQUEST_SENSE reported ASC: 0x%02x," " LUN: %u, got REQUEST_SENSE reported ASC: 0x%02x,"
" ASCQ: 0x%02x\n", nacl->se_tpg->se_tpg_tfo->get_fabric_name(), " ASCQ: 0x%02x\n", nacl->se_tpg->se_tpg_tfo->get_fabric_name(),
cmd->orig_fe_lun, *asc, *ascq); cmd->orig_fe_lun, *asc, *ascq);
......
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
此差异已折叠。
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册