Commit be71530a authored by Bart Van Assche's avatar Bart Van Assche Committed by Martin K. Petersen

scsi: target/core: Make the XCOPY setup code easier to read by inlining two functions

The target_xcopy_setup_pt_port() and target_xcopy_init_pt_lun() functions
obfuscate what is really going on. Hence inline these two functions. This
patch does not change any functionality.

Cc: Mike Christie <mchristi@redhat.com>
Cc: Christoph Hellwig <hch@lst.de>
Cc: Hannes Reinecke <hare@suse.com>
Cc: Nicholas Bellinger <nab@linux-iscsi.org>
Signed-off-by: default avatarBart Van Assche <bvanassche@acm.org>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent 0f57cf5c
...@@ -505,31 +505,20 @@ void target_xcopy_release_pt(void) ...@@ -505,31 +505,20 @@ void target_xcopy_release_pt(void)
destroy_workqueue(xcopy_wq); destroy_workqueue(xcopy_wq);
} }
static void target_xcopy_setup_pt_port( /*
struct xcopy_pt_cmd *xpt_cmd, * target_xcopy_setup_pt_cmd - set up a pass-through command
struct xcopy_op *xop, * @xpt_cmd: Data structure to initialize.
bool remote_port) * @xop: Describes the XCOPY operation received from an initiator.
{ * @se_dev: Backend device to associate with @xpt_cmd if
struct se_cmd *ec_cmd = xop->xop_se_cmd; * @remote_port == true.
struct se_cmd *pt_cmd = &xpt_cmd->se_cmd; * @cdb: SCSI CDB to be copied into @xpt_cmd.
* @remote_port: If false, use the LUN through which the XCOPY command has
if (!remote_port) { * been received. If true, use @se_dev->xcopy_lun.
pt_cmd->se_lun = ec_cmd->se_lun; * @alloc_mem: Whether or not to allocate an SGL list.
pt_cmd->se_dev = ec_cmd->se_dev; *
} * Set up a SCSI command (READ or WRITE) that will be used to execute an
} * XCOPY command.
*/
static void target_xcopy_init_pt_lun(struct se_device *se_dev,
struct se_cmd *pt_cmd, bool remote_port)
{
if (remote_port) {
pt_cmd->se_lun = &se_dev->xcopy_lun;
pt_cmd->se_dev = se_dev;
}
pt_cmd->se_cmd_flags |= SCF_SE_LUN_CMD;
}
static int target_xcopy_setup_pt_cmd( static int target_xcopy_setup_pt_cmd(
struct xcopy_pt_cmd *xpt_cmd, struct xcopy_pt_cmd *xpt_cmd,
struct xcopy_op *xop, struct xcopy_op *xop,
...@@ -541,12 +530,19 @@ static int target_xcopy_setup_pt_cmd( ...@@ -541,12 +530,19 @@ static int target_xcopy_setup_pt_cmd(
struct se_cmd *cmd = &xpt_cmd->se_cmd; struct se_cmd *cmd = &xpt_cmd->se_cmd;
sense_reason_t sense_rc; sense_reason_t sense_rc;
int ret = 0, rc; int ret = 0, rc;
/* /*
* Setup LUN+port to honor reservations based upon xop->op_origin for * Setup LUN+port to honor reservations based upon xop->op_origin for
* X-COPY PUSH or X-COPY PULL based upon where the CDB was received. * X-COPY PUSH or X-COPY PULL based upon where the CDB was received.
*/ */
target_xcopy_init_pt_lun(se_dev, cmd, remote_port); if (remote_port) {
target_xcopy_setup_pt_port(xpt_cmd, xop, remote_port); cmd->se_lun = &se_dev->xcopy_lun;
cmd->se_dev = se_dev;
} else {
cmd->se_lun = xop->xop_se_cmd->se_lun;
cmd->se_dev = xop->xop_se_cmd->se_dev;
}
cmd->se_cmd_flags |= SCF_SE_LUN_CMD;
cmd->tag = 0; cmd->tag = 0;
sense_rc = target_setup_cmd_from_cdb(cmd, cdb); sense_rc = target_setup_cmd_from_cdb(cmd, cdb);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment