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

scsi: target/core: Avoid that a kernel oops is triggered when COMPARE AND WRITE fails

Fixes: aa73237d ("scsi: target/core: Always call transport_complete_callback() upon failure")
Reviewed-by: default avatarDavid Disseldorp <ddiss@suse.de>
Cc: Nicholas Bellinger <nab@linux-iscsi.org>
Cc: Mike Christie <mchristi@redhat.com>
Cc: Christoph Hellwig <hch@lst.de>
Cc: Hannes Reinecke <hare@suse.de>
Signed-off-by: default avatarBart Van Assche <bvanassche@acm.org>
Signed-off-by: default avatarMartin K. Petersen <martin.petersen@oracle.com>
parent 65102238
...@@ -1778,7 +1778,7 @@ EXPORT_SYMBOL(target_submit_tmr); ...@@ -1778,7 +1778,7 @@ EXPORT_SYMBOL(target_submit_tmr);
void transport_generic_request_failure(struct se_cmd *cmd, void transport_generic_request_failure(struct se_cmd *cmd,
sense_reason_t sense_reason) sense_reason_t sense_reason)
{ {
int ret = 0; int ret = 0, post_ret;
pr_debug("-----[ Storage Engine Exception; sense_reason %d\n", pr_debug("-----[ Storage Engine Exception; sense_reason %d\n",
sense_reason); sense_reason);
...@@ -1790,7 +1790,7 @@ void transport_generic_request_failure(struct se_cmd *cmd, ...@@ -1790,7 +1790,7 @@ void transport_generic_request_failure(struct se_cmd *cmd,
transport_complete_task_attr(cmd); transport_complete_task_attr(cmd);
if (cmd->transport_complete_callback) if (cmd->transport_complete_callback)
cmd->transport_complete_callback(cmd, false, NULL); cmd->transport_complete_callback(cmd, false, &post_ret);
if (transport_check_aborted_status(cmd, 1)) if (transport_check_aborted_status(cmd, 1))
return; return;
......
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