Loading drivers/scsi/ufs/ufshcd.c +44 −8 Original line number Diff line number Diff line Loading @@ -1666,7 +1666,18 @@ static inline int ufshcd_read_power_desc(struct ufs_hba *hba, u8 *buf, u32 size) { return ufshcd_read_desc(hba, QUERY_DESC_IDN_POWER, 0, buf, size); int err = 0; int retries; for (retries = QUERY_REQ_RETRIES; retries > 0; retries--) { /* Read descriptor*/ err = ufshcd_read_desc(hba, QUERY_DESC_IDN_POWER, 0, buf, size); if (!err) break; dev_dbg(hba->dev, "%s: error %d retrying\n", __func__, err); } return err; } /** Loading Loading @@ -2454,17 +2465,25 @@ static int ufshcd_verify_dev_init(struct ufs_hba *hba) static void ufshcd_set_queue_depth(struct scsi_device *sdev) { int ret = 0; int retries; u8 lun_qdepth; struct ufs_hba *hba; hba = shost_priv(sdev->host); lun_qdepth = hba->nutrs; for (retries = QUERY_REQ_RETRIES; retries > 0; retries--) { /* Read descriptor*/ ret = ufshcd_read_unit_desc_param(hba, ufshcd_scsi_to_upiu_lun(sdev->lun), UNIT_DESC_PARAM_LU_Q_DEPTH, &lun_qdepth, sizeof(lun_qdepth)); if (!ret || ret == -ENOTSUPP) break; dev_dbg(hba->dev, "%s: error %d retrying\n", __func__, ret); } /* Some WLUN doesn't support unit descriptor */ if (ret == -EOPNOTSUPP) Loading Loading @@ -3740,6 +3759,24 @@ out: return icc_level; } static int ufshcd_set_icc_levels_attr(struct ufs_hba *hba, u32 icc_level) { int ret = 0; int retries; for (retries = QUERY_REQ_RETRIES; retries > 0; retries--) { /* write attribute */ ret = ufshcd_query_attr(hba, UPIU_QUERY_OPCODE_WRITE_ATTR, QUERY_ATTR_IDN_ACTIVE_ICC_LVL, 0, 0, &icc_level); if (!ret) break; dev_dbg(hba->dev, "%s: failed with error %d\n", __func__, ret); } return ret; } static void ufshcd_init_icc_levels(struct ufs_hba *hba) { u32 icc_level; Loading @@ -3759,8 +3796,7 @@ static void ufshcd_init_icc_levels(struct ufs_hba *hba) icc_level = ufshcd_find_max_sup_active_icc_level(hba, desc_buf, buff_len); ret = ufshcd_query_attr(hba, UPIU_QUERY_OPCODE_WRITE_ATTR, QUERY_ATTR_IDN_ACTIVE_ICC_LVL, 0, 0, &icc_level); ret = ufshcd_set_icc_levels_attr(hba, icc_level); if (ret) dev_err(hba->dev, Loading Loading
drivers/scsi/ufs/ufshcd.c +44 −8 Original line number Diff line number Diff line Loading @@ -1666,7 +1666,18 @@ static inline int ufshcd_read_power_desc(struct ufs_hba *hba, u8 *buf, u32 size) { return ufshcd_read_desc(hba, QUERY_DESC_IDN_POWER, 0, buf, size); int err = 0; int retries; for (retries = QUERY_REQ_RETRIES; retries > 0; retries--) { /* Read descriptor*/ err = ufshcd_read_desc(hba, QUERY_DESC_IDN_POWER, 0, buf, size); if (!err) break; dev_dbg(hba->dev, "%s: error %d retrying\n", __func__, err); } return err; } /** Loading Loading @@ -2454,17 +2465,25 @@ static int ufshcd_verify_dev_init(struct ufs_hba *hba) static void ufshcd_set_queue_depth(struct scsi_device *sdev) { int ret = 0; int retries; u8 lun_qdepth; struct ufs_hba *hba; hba = shost_priv(sdev->host); lun_qdepth = hba->nutrs; for (retries = QUERY_REQ_RETRIES; retries > 0; retries--) { /* Read descriptor*/ ret = ufshcd_read_unit_desc_param(hba, ufshcd_scsi_to_upiu_lun(sdev->lun), UNIT_DESC_PARAM_LU_Q_DEPTH, &lun_qdepth, sizeof(lun_qdepth)); if (!ret || ret == -ENOTSUPP) break; dev_dbg(hba->dev, "%s: error %d retrying\n", __func__, ret); } /* Some WLUN doesn't support unit descriptor */ if (ret == -EOPNOTSUPP) Loading Loading @@ -3740,6 +3759,24 @@ out: return icc_level; } static int ufshcd_set_icc_levels_attr(struct ufs_hba *hba, u32 icc_level) { int ret = 0; int retries; for (retries = QUERY_REQ_RETRIES; retries > 0; retries--) { /* write attribute */ ret = ufshcd_query_attr(hba, UPIU_QUERY_OPCODE_WRITE_ATTR, QUERY_ATTR_IDN_ACTIVE_ICC_LVL, 0, 0, &icc_level); if (!ret) break; dev_dbg(hba->dev, "%s: failed with error %d\n", __func__, ret); } return ret; } static void ufshcd_init_icc_levels(struct ufs_hba *hba) { u32 icc_level; Loading @@ -3759,8 +3796,7 @@ static void ufshcd_init_icc_levels(struct ufs_hba *hba) icc_level = ufshcd_find_max_sup_active_icc_level(hba, desc_buf, buff_len); ret = ufshcd_query_attr(hba, UPIU_QUERY_OPCODE_WRITE_ATTR, QUERY_ATTR_IDN_ACTIVE_ICC_LVL, 0, 0, &icc_level); ret = ufshcd_set_icc_levels_attr(hba, icc_level); if (ret) dev_err(hba->dev, Loading