target/user: Fix UFLAG_UNKNOWN_OP handling
Calling transport_generic_request_failure() from here causes list corruption. We should be using target_complete_cmd() instead. Which we do in all other cases, so the UNKNOWN_OP case can become just another member of the big else/if chain in tcmu_handle_completion(). Signed-off-by: Andy Grover <agrover@redhat.com> Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
This commit is contained in:
parent
06b967e429
commit
ed97d0cd78
|
@ -538,14 +538,8 @@ static void tcmu_handle_completion(struct tcmu_cmd *cmd, struct tcmu_cmd_entry *
|
||||||
UPDATE_HEAD(udev->data_tail, cmd->data_length, udev->data_size);
|
UPDATE_HEAD(udev->data_tail, cmd->data_length, udev->data_size);
|
||||||
pr_warn("TCMU: Userspace set UNKNOWN_OP flag on se_cmd %p\n",
|
pr_warn("TCMU: Userspace set UNKNOWN_OP flag on se_cmd %p\n",
|
||||||
cmd->se_cmd);
|
cmd->se_cmd);
|
||||||
transport_generic_request_failure(cmd->se_cmd,
|
entry->rsp.scsi_status = SAM_STAT_CHECK_CONDITION;
|
||||||
TCM_LOGICAL_UNIT_COMMUNICATION_FAILURE);
|
} else if (entry->rsp.scsi_status == SAM_STAT_CHECK_CONDITION) {
|
||||||
cmd->se_cmd = NULL;
|
|
||||||
kmem_cache_free(tcmu_cmd_cache, cmd);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (entry->rsp.scsi_status == SAM_STAT_CHECK_CONDITION) {
|
|
||||||
memcpy(se_cmd->sense_buffer, entry->rsp.sense_buffer,
|
memcpy(se_cmd->sense_buffer, entry->rsp.sense_buffer,
|
||||||
se_cmd->scsi_sense_length);
|
se_cmd->scsi_sense_length);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue