Commit 6ec29cb8 authored by Mike Christie's avatar Mike Christie Committed by Martin K. Petersen

scsi: target: vhost-scsi: Use LIO wq cmd submission helper

Convert vhost-scsi to use the LIO wq cmd submission helper.

Link: https://lore.kernel.org/r/20210227170006.5077-18-michael.christie@oracle.comSigned-off-by: default avatarMike Christie <michael.christie@oracle.com>
Reviewed-by: default avatarStefan Hajnoczi <stefanha@redhat.com>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent eb44ce8c
...@@ -85,7 +85,7 @@ struct vhost_scsi_cmd { ...@@ -85,7 +85,7 @@ struct vhost_scsi_cmd {
/* The number of scatterlists associated with this cmd */ /* The number of scatterlists associated with this cmd */
u32 tvc_sgl_count; u32 tvc_sgl_count;
u32 tvc_prot_sgl_count; u32 tvc_prot_sgl_count;
/* Saved unpacked SCSI LUN for vhost_scsi_submission_work() */ /* Saved unpacked SCSI LUN for vhost_scsi_target_queue_cmd() */
u32 tvc_lun; u32 tvc_lun;
/* Pointer to the SGL formatted memory from virtio-scsi */ /* Pointer to the SGL formatted memory from virtio-scsi */
struct scatterlist *tvc_sgl; struct scatterlist *tvc_sgl;
...@@ -101,8 +101,6 @@ struct vhost_scsi_cmd { ...@@ -101,8 +101,6 @@ struct vhost_scsi_cmd {
struct vhost_scsi_nexus *tvc_nexus; struct vhost_scsi_nexus *tvc_nexus;
/* The TCM I/O descriptor that is accessed via container_of() */ /* The TCM I/O descriptor that is accessed via container_of() */
struct se_cmd tvc_se_cmd; struct se_cmd tvc_se_cmd;
/* work item used for cmwq dispatch to vhost_scsi_submission_work() */
struct work_struct work;
/* Copy of the incoming SCSI command descriptor block (CDB) */ /* Copy of the incoming SCSI command descriptor block (CDB) */
unsigned char tvc_cdb[VHOST_SCSI_MAX_CDB_SIZE]; unsigned char tvc_cdb[VHOST_SCSI_MAX_CDB_SIZE];
/* Sense buffer that will be mapped into outgoing status */ /* Sense buffer that will be mapped into outgoing status */
...@@ -240,8 +238,6 @@ struct vhost_scsi_ctx { ...@@ -240,8 +238,6 @@ struct vhost_scsi_ctx {
struct iov_iter out_iter; struct iov_iter out_iter;
}; };
static struct workqueue_struct *vhost_scsi_workqueue;
/* Global spinlock to protect vhost_scsi TPG list for vhost IOCTL access */ /* Global spinlock to protect vhost_scsi TPG list for vhost IOCTL access */
static DEFINE_MUTEX(vhost_scsi_mutex); static DEFINE_MUTEX(vhost_scsi_mutex);
static LIST_HEAD(vhost_scsi_list); static LIST_HEAD(vhost_scsi_list);
...@@ -782,12 +778,10 @@ static int vhost_scsi_to_tcm_attr(int attr) ...@@ -782,12 +778,10 @@ static int vhost_scsi_to_tcm_attr(int attr)
return TCM_SIMPLE_TAG; return TCM_SIMPLE_TAG;
} }
static void vhost_scsi_submission_work(struct work_struct *work) static void vhost_scsi_target_queue_cmd(struct vhost_scsi_cmd *cmd)
{ {
struct vhost_scsi_cmd *cmd =
container_of(work, struct vhost_scsi_cmd, work);
struct vhost_scsi_nexus *tv_nexus;
struct se_cmd *se_cmd = &cmd->tvc_se_cmd; struct se_cmd *se_cmd = &cmd->tvc_se_cmd;
struct vhost_scsi_nexus *tv_nexus;
struct scatterlist *sg_ptr, *sg_prot_ptr = NULL; struct scatterlist *sg_ptr, *sg_prot_ptr = NULL;
/* FIXME: BIDI operation */ /* FIXME: BIDI operation */
...@@ -814,7 +808,7 @@ static void vhost_scsi_submission_work(struct work_struct *work) ...@@ -814,7 +808,7 @@ static void vhost_scsi_submission_work(struct work_struct *work)
cmd->tvc_prot_sgl_count, GFP_KERNEL)) cmd->tvc_prot_sgl_count, GFP_KERNEL))
return; return;
target_submit(se_cmd); target_queue_submission(se_cmd);
} }
static void static void
...@@ -1130,14 +1124,7 @@ vhost_scsi_handle_vq(struct vhost_scsi *vs, struct vhost_virtqueue *vq) ...@@ -1130,14 +1124,7 @@ vhost_scsi_handle_vq(struct vhost_scsi *vs, struct vhost_virtqueue *vq)
* vhost_scsi_queue_data_in() and vhost_scsi_queue_status() * vhost_scsi_queue_data_in() and vhost_scsi_queue_status()
*/ */
cmd->tvc_vq_desc = vc.head; cmd->tvc_vq_desc = vc.head;
/* vhost_scsi_target_queue_cmd(cmd);
* Dispatch cmd descriptor for cmwq execution in process
* context provided by vhost_scsi_workqueue. This also ensures
* cmd is executed on the same kworker CPU as this vhost
* thread to gain positive L2 cache locality effects.
*/
INIT_WORK(&cmd->work, vhost_scsi_submission_work);
queue_work(vhost_scsi_workqueue, &cmd->work);
ret = 0; ret = 0;
err: err:
/* /*
...@@ -2484,17 +2471,9 @@ static int __init vhost_scsi_init(void) ...@@ -2484,17 +2471,9 @@ static int __init vhost_scsi_init(void)
" on "UTS_RELEASE"\n", VHOST_SCSI_VERSION, utsname()->sysname, " on "UTS_RELEASE"\n", VHOST_SCSI_VERSION, utsname()->sysname,
utsname()->machine); utsname()->machine);
/*
* Use our own dedicated workqueue for submitting I/O into
* target core to avoid contention within system_wq.
*/
vhost_scsi_workqueue = alloc_workqueue("vhost_scsi", 0, 0);
if (!vhost_scsi_workqueue)
goto out;
ret = vhost_scsi_register(); ret = vhost_scsi_register();
if (ret < 0) if (ret < 0)
goto out_destroy_workqueue; goto out;
ret = target_register_template(&vhost_scsi_ops); ret = target_register_template(&vhost_scsi_ops);
if (ret < 0) if (ret < 0)
...@@ -2504,8 +2483,6 @@ static int __init vhost_scsi_init(void) ...@@ -2504,8 +2483,6 @@ static int __init vhost_scsi_init(void)
out_vhost_scsi_deregister: out_vhost_scsi_deregister:
vhost_scsi_deregister(); vhost_scsi_deregister();
out_destroy_workqueue:
destroy_workqueue(vhost_scsi_workqueue);
out: out:
return ret; return ret;
}; };
...@@ -2514,7 +2491,6 @@ static void vhost_scsi_exit(void) ...@@ -2514,7 +2491,6 @@ static void vhost_scsi_exit(void)
{ {
target_unregister_template(&vhost_scsi_ops); target_unregister_template(&vhost_scsi_ops);
vhost_scsi_deregister(); vhost_scsi_deregister();
destroy_workqueue(vhost_scsi_workqueue);
}; };
MODULE_DESCRIPTION("VHOST_SCSI series fabric driver"); MODULE_DESCRIPTION("VHOST_SCSI series fabric driver");
......
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