diff options
Diffstat (limited to 'drivers/infiniband/ulp/srpt/ib_srpt.c')
-rw-r--r-- | drivers/infiniband/ulp/srpt/ib_srpt.c | 19 |
1 files changed, 12 insertions, 7 deletions
diff --git a/drivers/infiniband/ulp/srpt/ib_srpt.c b/drivers/infiniband/ulp/srpt/ib_srpt.c index 6735b63d96f..c3cb907d810 100644 --- a/drivers/infiniband/ulp/srpt/ib_srpt.c +++ b/drivers/infiniband/ulp/srpt/ib_srpt.c | |||
@@ -1757,6 +1757,7 @@ static int srpt_handle_cmd(struct srpt_rdma_ch *ch, | |||
1757 | srp_cmd->tag); | 1757 | srp_cmd->tag); |
1758 | cmd->se_cmd_flags |= SCF_SCSI_CDB_EXCEPTION; | 1758 | cmd->se_cmd_flags |= SCF_SCSI_CDB_EXCEPTION; |
1759 | cmd->scsi_sense_reason = TCM_INVALID_CDB_FIELD; | 1759 | cmd->scsi_sense_reason = TCM_INVALID_CDB_FIELD; |
1760 | kref_put(&send_ioctx->kref, srpt_put_send_ioctx_kref); | ||
1760 | goto send_sense; | 1761 | goto send_sense; |
1761 | } | 1762 | } |
1762 | 1763 | ||
@@ -1764,15 +1765,19 @@ static int srpt_handle_cmd(struct srpt_rdma_ch *ch, | |||
1764 | cmd->data_direction = dir; | 1765 | cmd->data_direction = dir; |
1765 | unpacked_lun = srpt_unpack_lun((uint8_t *)&srp_cmd->lun, | 1766 | unpacked_lun = srpt_unpack_lun((uint8_t *)&srp_cmd->lun, |
1766 | sizeof(srp_cmd->lun)); | 1767 | sizeof(srp_cmd->lun)); |
1767 | if (transport_lookup_cmd_lun(cmd, unpacked_lun) < 0) | 1768 | if (transport_lookup_cmd_lun(cmd, unpacked_lun) < 0) { |
1769 | kref_put(&send_ioctx->kref, srpt_put_send_ioctx_kref); | ||
1768 | goto send_sense; | 1770 | goto send_sense; |
1771 | } | ||
1769 | ret = transport_generic_allocate_tasks(cmd, srp_cmd->cdb); | 1772 | ret = transport_generic_allocate_tasks(cmd, srp_cmd->cdb); |
1770 | if (cmd->se_cmd_flags & SCF_SCSI_RESERVATION_CONFLICT) | 1773 | if (ret < 0) { |
1771 | srpt_queue_status(cmd); | 1774 | kref_put(&send_ioctx->kref, srpt_put_send_ioctx_kref); |
1772 | else if (cmd->se_cmd_flags & SCF_SCSI_CDB_EXCEPTION) | 1775 | if (cmd->se_cmd_flags & SCF_SCSI_RESERVATION_CONFLICT) { |
1773 | goto send_sense; | 1776 | srpt_queue_status(cmd); |
1774 | else | 1777 | return 0; |
1775 | WARN_ON_ONCE(ret); | 1778 | } else |
1779 | goto send_sense; | ||
1780 | } | ||
1776 | 1781 | ||
1777 | transport_handle_cdb_direct(cmd); | 1782 | transport_handle_cdb_direct(cmd); |
1778 | return 0; | 1783 | return 0; |