提交 72f4ba1e 编写于 作者: N Nicholas Bellinger

target: Remove duplicate task completions in transport_emulate_control_cdb

This patch removes a duplicate set of transport_complete_task() calls in
target_emulate_unmap() and target_emulate_write_same() as the completion
call is already done within transport_emulate_control_cdb()

This patch also adds a check in transport_emulate_control_cdb() for the
existing SCF_EMULATE_CDB_ASYNC flag currently used by SYNCHRONIZE_CACHE
in order to handle IMMEDIATE processing.
Signed-off-by: NNicholas Bellinger <nab@linux-iscsi.org>
上级 12850626
...@@ -1077,8 +1077,6 @@ target_emulate_unmap(struct se_task *task) ...@@ -1077,8 +1077,6 @@ target_emulate_unmap(struct se_task *task)
size -= 16; size -= 16;
} }
task->task_scsi_status = GOOD;
transport_complete_task(task, 1);
err: err:
transport_kunmap_first_data_page(cmd); transport_kunmap_first_data_page(cmd);
...@@ -1115,8 +1113,6 @@ target_emulate_write_same(struct se_task *task, u32 num_blocks) ...@@ -1115,8 +1113,6 @@ target_emulate_write_same(struct se_task *task, u32 num_blocks)
return ret; return ret;
} }
task->task_scsi_status = GOOD;
transport_complete_task(task, 1);
return 0; return 0;
} }
...@@ -1228,8 +1224,14 @@ transport_emulate_control_cdb(struct se_task *task) ...@@ -1228,8 +1224,14 @@ transport_emulate_control_cdb(struct se_task *task)
if (ret < 0) if (ret < 0)
return ret; return ret;
task->task_scsi_status = GOOD; /*
transport_complete_task(task, 1); * Handle the successful completion here unless a caller
* has explictly requested an asychronous completion.
*/
if (!(cmd->se_cmd_flags & SCF_EMULATE_CDB_ASYNC)) {
task->task_scsi_status = GOOD;
transport_complete_task(task, 1);
}
return PYX_TRANSPORT_SENT_TO_TRANSPORT; return PYX_TRANSPORT_SENT_TO_TRANSPORT;
} }
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册