summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAvri Altman <avri.altman@wdc.com>2019-02-20 02:11:13 -0500
committerMartin K. Petersen <martin.petersen@oracle.com>2019-02-27 08:59:13 -0500
commit4bbbe2421634fe1d1b230006200ad9cdb0e17a9e (patch)
treec577ae5463460763888a1be48fa389936b3c8e40
parent4eaa329e331343dd64996297583f2eee7d215e2a (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.c20
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
5852out:
5853 return err; 5861 return err;
5854} 5862}
5855 5863