* [PATCH v2 0/2] scsi: ufs: qcom: Add missing interconnect bandwidth values for Gear 5
@ 2024-04-03 13:20 Manivannan Sadhasivam
2024-04-03 13:20 ` [PATCH v2 1/2] " Manivannan Sadhasivam
` (3 more replies)
0 siblings, 4 replies; 8+ messages in thread
From: Manivannan Sadhasivam @ 2024-04-03 13:20 UTC (permalink / raw)
To: Bjorn Andersson, Konrad Dybcio, James E.J. Bottomley,
Martin K. Petersen
Cc: linux-arm-msm, linux-scsi, linux-kernel, Manivannan Sadhasivam,
Amit Pundir
Hi,
This series adds the interconnect bandwidth values for Gear 5 to the Qcom
driver and also adds the check for the unsupported gear/lane values.
- Mani
Signed-off-by: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
---
Changes in v2:
- Added sanity check for gear/lane values
- Collected tags
- Link to v1: https://lore.kernel.org/r/20240401-ufs-icc-fix-v1-1-3bac41bdfa7a@linaro.org
---
Manivannan Sadhasivam (2):
scsi: ufs: qcom: Add missing interconnect bandwidth values for Gear 5
scsi: ufs: qcom: Add sanity checks for gear/lane values during ICC scaling
drivers/ufs/host/ufs-qcom.c | 18 +++++++++++++++++-
1 file changed, 17 insertions(+), 1 deletion(-)
---
base-commit: 4cece764965020c22cff7665b18a012006359095
change-id: 20240401-ufs-icc-fix-123c7ca1be45
Best regards,
--
Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
^ permalink raw reply [flat|nested] 8+ messages in thread* [PATCH v2 1/2] scsi: ufs: qcom: Add missing interconnect bandwidth values for Gear 5 2024-04-03 13:20 [PATCH v2 0/2] scsi: ufs: qcom: Add missing interconnect bandwidth values for Gear 5 Manivannan Sadhasivam @ 2024-04-03 13:20 ` Manivannan Sadhasivam 2024-04-03 13:20 ` [PATCH v2 2/2] scsi: ufs: qcom: Add sanity checks for gear/lane values during ICC scaling Manivannan Sadhasivam ` (2 subsequent siblings) 3 siblings, 0 replies; 8+ messages in thread From: Manivannan Sadhasivam @ 2024-04-03 13:20 UTC (permalink / raw) To: Bjorn Andersson, Konrad Dybcio, James E.J. Bottomley, Martin K. Petersen Cc: linux-arm-msm, linux-scsi, linux-kernel, Manivannan Sadhasivam, Amit Pundir These entries are necessary to scale the interconnect bandwidth while operating in Gear 5. Cc: Amit Pundir <amit.pundir@linaro.org> Fixes: 03ce80a1bb86 ("scsi: ufs: qcom: Add support for scaling interconnects") Tested-by: Amit Pundir <amit.pundir@linaro.org> Signed-off-by: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org> --- drivers/ufs/host/ufs-qcom.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/drivers/ufs/host/ufs-qcom.c b/drivers/ufs/host/ufs-qcom.c index 8d68bd21ae73..696540ca835e 100644 --- a/drivers/ufs/host/ufs-qcom.c +++ b/drivers/ufs/host/ufs-qcom.c @@ -47,7 +47,7 @@ enum { TSTBUS_MAX, }; -#define QCOM_UFS_MAX_GEAR 4 +#define QCOM_UFS_MAX_GEAR 5 #define QCOM_UFS_MAX_LANE 2 enum { @@ -67,26 +67,32 @@ static const struct __ufs_qcom_bw_table { [MODE_PWM][UFS_PWM_G2][UFS_LANE_1] = { 1844, 1000 }, [MODE_PWM][UFS_PWM_G3][UFS_LANE_1] = { 3688, 1000 }, [MODE_PWM][UFS_PWM_G4][UFS_LANE_1] = { 7376, 1000 }, + [MODE_PWM][UFS_PWM_G5][UFS_LANE_1] = { 14752, 1000 }, [MODE_PWM][UFS_PWM_G1][UFS_LANE_2] = { 1844, 1000 }, [MODE_PWM][UFS_PWM_G2][UFS_LANE_2] = { 3688, 1000 }, [MODE_PWM][UFS_PWM_G3][UFS_LANE_2] = { 7376, 1000 }, [MODE_PWM][UFS_PWM_G4][UFS_LANE_2] = { 14752, 1000 }, + [MODE_PWM][UFS_PWM_G5][UFS_LANE_2] = { 29504, 1000 }, [MODE_HS_RA][UFS_HS_G1][UFS_LANE_1] = { 127796, 1000 }, [MODE_HS_RA][UFS_HS_G2][UFS_LANE_1] = { 255591, 1000 }, [MODE_HS_RA][UFS_HS_G3][UFS_LANE_1] = { 1492582, 102400 }, [MODE_HS_RA][UFS_HS_G4][UFS_LANE_1] = { 2915200, 204800 }, + [MODE_HS_RA][UFS_HS_G5][UFS_LANE_1] = { 5836800, 409600 }, [MODE_HS_RA][UFS_HS_G1][UFS_LANE_2] = { 255591, 1000 }, [MODE_HS_RA][UFS_HS_G2][UFS_LANE_2] = { 511181, 1000 }, [MODE_HS_RA][UFS_HS_G3][UFS_LANE_2] = { 1492582, 204800 }, [MODE_HS_RA][UFS_HS_G4][UFS_LANE_2] = { 2915200, 409600 }, + [MODE_HS_RA][UFS_HS_G5][UFS_LANE_2] = { 5836800, 819200 }, [MODE_HS_RB][UFS_HS_G1][UFS_LANE_1] = { 149422, 1000 }, [MODE_HS_RB][UFS_HS_G2][UFS_LANE_1] = { 298189, 1000 }, [MODE_HS_RB][UFS_HS_G3][UFS_LANE_1] = { 1492582, 102400 }, [MODE_HS_RB][UFS_HS_G4][UFS_LANE_1] = { 2915200, 204800 }, + [MODE_HS_RB][UFS_HS_G5][UFS_LANE_1] = { 5836800, 409600 }, [MODE_HS_RB][UFS_HS_G1][UFS_LANE_2] = { 298189, 1000 }, [MODE_HS_RB][UFS_HS_G2][UFS_LANE_2] = { 596378, 1000 }, [MODE_HS_RB][UFS_HS_G3][UFS_LANE_2] = { 1492582, 204800 }, [MODE_HS_RB][UFS_HS_G4][UFS_LANE_2] = { 2915200, 409600 }, + [MODE_HS_RB][UFS_HS_G5][UFS_LANE_2] = { 5836800, 819200 }, [MODE_MAX][0][0] = { 7643136, 307200 }, }; -- 2.25.1 ^ permalink raw reply related [flat|nested] 8+ messages in thread
* [PATCH v2 2/2] scsi: ufs: qcom: Add sanity checks for gear/lane values during ICC scaling 2024-04-03 13:20 [PATCH v2 0/2] scsi: ufs: qcom: Add missing interconnect bandwidth values for Gear 5 Manivannan Sadhasivam 2024-04-03 13:20 ` [PATCH v2 1/2] " Manivannan Sadhasivam @ 2024-04-03 13:20 ` Manivannan Sadhasivam 2024-04-03 14:12 ` Andrew Halaney 2024-04-06 1:24 ` [PATCH v2 0/2] scsi: ufs: qcom: Add missing interconnect bandwidth values for Gear 5 Martin K. Petersen 2024-04-09 3:08 ` Martin K. Petersen 3 siblings, 1 reply; 8+ messages in thread From: Manivannan Sadhasivam @ 2024-04-03 13:20 UTC (permalink / raw) To: Bjorn Andersson, Konrad Dybcio, James E.J. Bottomley, Martin K. Petersen Cc: linux-arm-msm, linux-scsi, linux-kernel, Manivannan Sadhasivam Let's add the checks to warn the user if the ICC scaling is not supported for the gear/lane values and also fallback to the max value if that's the case. Signed-off-by: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org> --- drivers/ufs/host/ufs-qcom.c | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/drivers/ufs/host/ufs-qcom.c b/drivers/ufs/host/ufs-qcom.c index 696540ca835e..79b4ce05f7c5 100644 --- a/drivers/ufs/host/ufs-qcom.c +++ b/drivers/ufs/host/ufs-qcom.c @@ -696,6 +696,16 @@ static struct __ufs_qcom_bw_table ufs_qcom_get_bw_table(struct ufs_qcom_host *ho int gear = max_t(u32, p->gear_rx, p->gear_tx); int lane = max_t(u32, p->lane_rx, p->lane_tx); + if (WARN_ONCE(gear > QCOM_UFS_MAX_GEAR, + "ICC scaling for UFS Gear (%d) not supported. Using Gear (%d) bandwidth\n", + gear, QCOM_UFS_MAX_GEAR)) + gear = QCOM_UFS_MAX_GEAR; + + if (WARN_ONCE(lane > QCOM_UFS_MAX_LANE, + "ICC scaling for UFS Lane (%d) not supported. Using Lane (%d) bandwidth\n", + lane, QCOM_UFS_MAX_LANE)) + lane = QCOM_UFS_MAX_LANE; + if (ufshcd_is_hs_mode(p)) { if (p->hs_rate == PA_HS_MODE_B) return ufs_qcom_bw_table[MODE_HS_RB][gear][lane]; -- 2.25.1 ^ permalink raw reply related [flat|nested] 8+ messages in thread
* Re: [PATCH v2 2/2] scsi: ufs: qcom: Add sanity checks for gear/lane values during ICC scaling 2024-04-03 13:20 ` [PATCH v2 2/2] scsi: ufs: qcom: Add sanity checks for gear/lane values during ICC scaling Manivannan Sadhasivam @ 2024-04-03 14:12 ` Andrew Halaney 0 siblings, 0 replies; 8+ messages in thread From: Andrew Halaney @ 2024-04-03 14:12 UTC (permalink / raw) To: Manivannan Sadhasivam Cc: Bjorn Andersson, Konrad Dybcio, James E.J. Bottomley, Martin K. Petersen, linux-arm-msm, linux-scsi, linux-kernel On Wed, Apr 03, 2024 at 06:50:04PM +0530, Manivannan Sadhasivam wrote: > Let's add the checks to warn the user if the ICC scaling is not supported > for the gear/lane values and also fallback to the max value if that's the > case. > > Signed-off-by: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org> Reviewed-by: Andrew Halaney <ahalaney@redhat.com> > --- > drivers/ufs/host/ufs-qcom.c | 10 ++++++++++ > 1 file changed, 10 insertions(+) > > diff --git a/drivers/ufs/host/ufs-qcom.c b/drivers/ufs/host/ufs-qcom.c > index 696540ca835e..79b4ce05f7c5 100644 > --- a/drivers/ufs/host/ufs-qcom.c > +++ b/drivers/ufs/host/ufs-qcom.c > @@ -696,6 +696,16 @@ static struct __ufs_qcom_bw_table ufs_qcom_get_bw_table(struct ufs_qcom_host *ho > int gear = max_t(u32, p->gear_rx, p->gear_tx); > int lane = max_t(u32, p->lane_rx, p->lane_tx); > > + if (WARN_ONCE(gear > QCOM_UFS_MAX_GEAR, > + "ICC scaling for UFS Gear (%d) not supported. Using Gear (%d) bandwidth\n", > + gear, QCOM_UFS_MAX_GEAR)) > + gear = QCOM_UFS_MAX_GEAR; > + > + if (WARN_ONCE(lane > QCOM_UFS_MAX_LANE, > + "ICC scaling for UFS Lane (%d) not supported. Using Lane (%d) bandwidth\n", > + lane, QCOM_UFS_MAX_LANE)) > + lane = QCOM_UFS_MAX_LANE; > + > if (ufshcd_is_hs_mode(p)) { > if (p->hs_rate == PA_HS_MODE_B) > return ufs_qcom_bw_table[MODE_HS_RB][gear][lane]; > > -- > 2.25.1 > > ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH v2 0/2] scsi: ufs: qcom: Add missing interconnect bandwidth values for Gear 5 2024-04-03 13:20 [PATCH v2 0/2] scsi: ufs: qcom: Add missing interconnect bandwidth values for Gear 5 Manivannan Sadhasivam 2024-04-03 13:20 ` [PATCH v2 1/2] " Manivannan Sadhasivam 2024-04-03 13:20 ` [PATCH v2 2/2] scsi: ufs: qcom: Add sanity checks for gear/lane values during ICC scaling Manivannan Sadhasivam @ 2024-04-06 1:24 ` Martin K. Petersen 2024-04-06 3:56 ` Manivannan Sadhasivam 2024-04-09 3:08 ` Martin K. Petersen 3 siblings, 1 reply; 8+ messages in thread From: Martin K. Petersen @ 2024-04-06 1:24 UTC (permalink / raw) To: Manivannan Sadhasivam Cc: Bjorn Andersson, Konrad Dybcio, James E.J. Bottomley, Martin K. Petersen, linux-arm-msm, linux-scsi, linux-kernel, Amit Pundir Manivannan, > This series adds the interconnect bandwidth values for Gear 5 to the > Qcom driver and also adds the check for the unsupported gear/lane > values. Applied to 6.10/scsi-staging, thanks! -- Martin K. Petersen Oracle Linux Engineering ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH v2 0/2] scsi: ufs: qcom: Add missing interconnect bandwidth values for Gear 5 2024-04-06 1:24 ` [PATCH v2 0/2] scsi: ufs: qcom: Add missing interconnect bandwidth values for Gear 5 Martin K. Petersen @ 2024-04-06 3:56 ` Manivannan Sadhasivam 2024-04-08 19:12 ` Martin K. Petersen 0 siblings, 1 reply; 8+ messages in thread From: Manivannan Sadhasivam @ 2024-04-06 3:56 UTC (permalink / raw) To: Martin K. Petersen Cc: Bjorn Andersson, Konrad Dybcio, James E.J. Bottomley, linux-arm-msm, linux-scsi, linux-kernel, Amit Pundir On Fri, Apr 05, 2024 at 09:24:00PM -0400, Martin K. Petersen wrote: > > Manivannan, > > > This series adds the interconnect bandwidth values for Gear 5 to the > > Qcom driver and also adds the check for the unsupported gear/lane > > values. > > Applied to 6.10/scsi-staging, thanks! > Thanks Martin! But patch 1/2 is actually a fix that needs to be merged for 6.9, since starting from 6.9 we are seeing the crash on some Qcom boards. But patch 2/2 is just an improvement, so it can be part of 6.10. - Mani -- மணிவண்ணன் சதாசிவம் ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH v2 0/2] scsi: ufs: qcom: Add missing interconnect bandwidth values for Gear 5 2024-04-06 3:56 ` Manivannan Sadhasivam @ 2024-04-08 19:12 ` Martin K. Petersen 0 siblings, 0 replies; 8+ messages in thread From: Martin K. Petersen @ 2024-04-08 19:12 UTC (permalink / raw) To: Manivannan Sadhasivam Cc: Martin K. Petersen, Bjorn Andersson, Konrad Dybcio, James E.J. Bottomley, linux-arm-msm, linux-scsi, linux-kernel, Amit Pundir Manivannan, > Thanks Martin! But patch 1/2 is actually a fix that needs to be merged > for 6.9, since starting from 6.9 we are seeing the crash on some Qcom > boards. > > But patch 2/2 is just an improvement, so it can be part of 6.10. OK, done! -- Martin K. Petersen Oracle Linux Engineering ^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH v2 0/2] scsi: ufs: qcom: Add missing interconnect bandwidth values for Gear 5 2024-04-03 13:20 [PATCH v2 0/2] scsi: ufs: qcom: Add missing interconnect bandwidth values for Gear 5 Manivannan Sadhasivam ` (2 preceding siblings ...) 2024-04-06 1:24 ` [PATCH v2 0/2] scsi: ufs: qcom: Add missing interconnect bandwidth values for Gear 5 Martin K. Petersen @ 2024-04-09 3:08 ` Martin K. Petersen 3 siblings, 0 replies; 8+ messages in thread From: Martin K. Petersen @ 2024-04-09 3:08 UTC (permalink / raw) To: Bjorn Andersson, Konrad Dybcio, James E.J. Bottomley, Manivannan Sadhasivam Cc: Martin K . Petersen, linux-arm-msm, linux-scsi, linux-kernel, Amit Pundir On Wed, 03 Apr 2024 18:50:02 +0530, Manivannan Sadhasivam wrote: > This series adds the interconnect bandwidth values for Gear 5 to the Qcom > driver and also adds the check for the unsupported gear/lane values. > > - Mani > > Applied to 6.10/scsi-queue, thanks! [2/2] scsi: ufs: qcom: Add sanity checks for gear/lane values during ICC scaling https://git.kernel.org/mkp/scsi/c/33507b3964f1 -- Martin K. Petersen Oracle Linux Engineering ^ permalink raw reply [flat|nested] 8+ messages in thread
end of thread, other threads:[~2024-04-09 3:09 UTC | newest] Thread overview: 8+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2024-04-03 13:20 [PATCH v2 0/2] scsi: ufs: qcom: Add missing interconnect bandwidth values for Gear 5 Manivannan Sadhasivam 2024-04-03 13:20 ` [PATCH v2 1/2] " Manivannan Sadhasivam 2024-04-03 13:20 ` [PATCH v2 2/2] scsi: ufs: qcom: Add sanity checks for gear/lane values during ICC scaling Manivannan Sadhasivam 2024-04-03 14:12 ` Andrew Halaney 2024-04-06 1:24 ` [PATCH v2 0/2] scsi: ufs: qcom: Add missing interconnect bandwidth values for Gear 5 Martin K. Petersen 2024-04-06 3:56 ` Manivannan Sadhasivam 2024-04-08 19:12 ` Martin K. Petersen 2024-04-09 3:08 ` Martin K. Petersen
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox