diff options
author | Avri Altman <avri.altman@wdc.com> | 2019-02-20 02:11:13 -0500 |
---|---|---|
committer | Martin K. Petersen <martin.petersen@oracle.com> | 2019-02-27 08:59:13 -0500 |
commit | 4bbbe2421634fe1d1b230006200ad9cdb0e17a9e (patch) | |
tree | c577ae5463460763888a1be48fa389936b3c8e40 | |
parent | 4eaa329e331343dd64996297583f2eee7d215e2a (diff) |
scsi: ufs: Allow reading descriptor via raw upiu
Allow to read descriptors via raw upiu. This in fact was forbidden just as
a precaution, as ufs-bsg actually enforces which functionality is
supported.
Signed-off-by: Avri Altman <avri.altman@wdc.com>
Reviewed-by: Evan Green <evgreen@chromium.org>
Reviewed-by: Bean Huo <beanhuo@micron.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
-rw-r--r-- | drivers/scsi/ufs/ufshcd.c | 20 |
1 files changed, 14 insertions, 6 deletions
diff --git a/drivers/scsi/ufs/ufshcd.c b/drivers/scsi/ufs/ufshcd.c index 85ebe7cab440..3da21bb149a4 100644 --- a/drivers/scsi/ufs/ufshcd.c +++ b/drivers/scsi/ufs/ufshcd.c | |||
@@ -5769,6 +5769,20 @@ static int ufshcd_issue_devman_upiu_cmd(struct ufs_hba *hba, | |||
5769 | 5769 | ||
5770 | /* just copy the upiu response as it is */ | 5770 | /* just copy the upiu response as it is */ |
5771 | memcpy(rsp_upiu, lrbp->ucd_rsp_ptr, sizeof(*rsp_upiu)); | 5771 | memcpy(rsp_upiu, lrbp->ucd_rsp_ptr, sizeof(*rsp_upiu)); |
5772 | if (desc_buff && desc_op == UPIU_QUERY_OPCODE_READ_DESC) { | ||
5773 | u8 *descp = (u8 *)lrbp->ucd_rsp_ptr + sizeof(*rsp_upiu); | ||
5774 | u16 resp_len = be32_to_cpu(lrbp->ucd_rsp_ptr->header.dword_2) & | ||
5775 | MASK_QUERY_DATA_SEG_LEN; | ||
5776 | |||
5777 | if (*buff_len >= resp_len) { | ||
5778 | memcpy(desc_buff, descp, resp_len); | ||
5779 | *buff_len = resp_len; | ||
5780 | } else { | ||
5781 | dev_warn(hba->dev, "rsp size is bigger than buffer"); | ||
5782 | *buff_len = 0; | ||
5783 | err = -EINVAL; | ||
5784 | } | ||
5785 | } | ||
5772 | 5786 | ||
5773 | ufshcd_put_dev_cmd_tag(hba, tag); | 5787 | ufshcd_put_dev_cmd_tag(hba, tag); |
5774 | wake_up(&hba->dev_cmd.tag_wq); | 5788 | wake_up(&hba->dev_cmd.tag_wq); |
@@ -5804,11 +5818,6 @@ int ufshcd_exec_raw_upiu_cmd(struct ufs_hba *hba, | |||
5804 | int ocs_value; | 5818 | int ocs_value; |
5805 | u8 tm_f = be32_to_cpu(req_upiu->header.dword_1) >> 16 & MASK_TM_FUNC; | 5819 | u8 tm_f = be32_to_cpu(req_upiu->header.dword_1) >> 16 & MASK_TM_FUNC; |
5806 | 5820 | ||
5807 | if (desc_buff && desc_op != UPIU_QUERY_OPCODE_WRITE_DESC) { | ||
5808 | err = -ENOTSUPP; | ||
5809 | goto out; | ||
5810 | } | ||
5811 | |||
5812 | switch (msgcode) { | 5821 | switch (msgcode) { |
5813 | case UPIU_TRANSACTION_NOP_OUT: | 5822 | case UPIU_TRANSACTION_NOP_OUT: |
5814 | cmd_type = DEV_CMD_TYPE_NOP; | 5823 | cmd_type = DEV_CMD_TYPE_NOP; |
@@ -5849,7 +5858,6 @@ int ufshcd_exec_raw_upiu_cmd(struct ufs_hba *hba, | |||
5849 | break; | 5858 | break; |
5850 | } | 5859 | } |
5851 | 5860 | ||
5852 | out: | ||
5853 | return err; | 5861 | return err; |
5854 | } | 5862 | } |
5855 | 5863 | ||