Re: [PATCH v6 2/3] scsi: ufs: Maximum RTT supported by the host driver

From: Peter Wang (王信友)
Date: Tue May 28 2024 - 06:03:18 EST


On Sun, 2024-05-26 at 11:16 +0300, Avri Altman wrote:
>
> External email : Please do not click links or open attachments until
> you have verified the sender or the content.
> Allow platform vendors to take precedence having their own max rtt
> support. This makes sense because the host controller's nortt
> characteristic may vary among vendors.
>
> while at it, set this value for Mediatek, as requested by Peter -
>
https://lore.kernel.org/all/0a57d6bab739d6a10584f2baba115d00dfc9c94c.camel@xxxxxxxxxxxx/
>
> Signed-off-by: Avri Altman <avri.altman@xxxxxxx>
> ---
> drivers/ufs/core/ufshcd.c | 6 +++++-
> drivers/ufs/host/ufs-mediatek.c | 1 +
> drivers/ufs/host/ufs-mediatek.h | 3 +++
> include/ufs/ufshcd.h | 2 ++
> 4 files changed, 11 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/ufs/core/ufshcd.c b/drivers/ufs/core/ufshcd.c
> index 7df8bcacbe7e..b62023a6c306 100644
> --- a/drivers/ufs/core/ufshcd.c
> +++ b/drivers/ufs/core/ufshcd.c
> @@ -8144,7 +8144,11 @@ static void ufshcd_set_rtt(struct ufs_hba
> *hba)
> if (dev_rtt != DEFAULT_MAX_NUM_RTT)
> return;
>
> - rtt = min_t(int, dev_info->rtt_cap, hba->nortt);
> + if (hba->vops && hba->vops->max_num_rtt)
> + rtt = hba->vops->max_num_rtt;
> + else
> + rtt = min_t(int, dev_info->rtt_cap, hba->nortt);
> +
> if (rtt == dev_rtt)
> return;
>
> diff --git a/drivers/ufs/host/ufs-mediatek.c b/drivers/ufs/host/ufs-
> mediatek.c
> index c4f997196c57..c7a0ab9b1f59 100644
> --- a/drivers/ufs/host/ufs-mediatek.c
> +++ b/drivers/ufs/host/ufs-mediatek.c
> @@ -1785,6 +1785,7 @@ static int ufs_mtk_config_esi(struct ufs_hba
> *hba)
> */
> static const struct ufs_hba_variant_ops ufs_hba_mtk_vops = {
> .name = "mediatek.ufshci",
> + .max_num_rtt = MTK_MAX_NUM_RTT,
> .init = ufs_mtk_init,
> .get_ufs_hci_version = ufs_mtk_get_ufs_hci_version,
> .setup_clocks = ufs_mtk_setup_clocks,
> diff --git a/drivers/ufs/host/ufs-mediatek.h b/drivers/ufs/host/ufs-
> mediatek.h
> index 3ff17e95afab..05d76a6bd772 100644
> --- a/drivers/ufs/host/ufs-mediatek.h
> +++ b/drivers/ufs/host/ufs-mediatek.h
> @@ -189,4 +189,7 @@ struct ufs_mtk_host {
> /* MTK delay of autosuspend: 500 ms */
> #define MTK_RPM_AUTOSUSPEND_DELAY_MS 500
>
> +/* MTK RTT support number */
> +#define MTK_MAX_NUM_RTT 2
> +
> #endif /* !_UFS_MEDIATEK_H */
> diff --git a/include/ufs/ufshcd.h b/include/ufs/ufshcd.h
> index d74bd2d67b06..ef04ec8aad69 100644
> --- a/include/ufs/ufshcd.h
> +++ b/include/ufs/ufshcd.h
> @@ -295,6 +295,7 @@ struct ufs_pwr_mode_info {
> /**
> * struct ufs_hba_variant_ops - variant specific callbacks
> * @name: variant name
> + * @max_num_rtt: maximum RTT supported by the host
> * @init: called when the driver is initialized
> * @exit: called to cleanup everything done in init
> * @get_ufs_hci_version: called to get UFS HCI version
> @@ -332,6 +333,7 @@ struct ufs_pwr_mode_info {
> */
> struct ufs_hba_variant_ops {
> const char *name;
> + int max_num_rtt;
> int (*init)(struct ufs_hba *);
> void (*exit)(struct ufs_hba *);
> u32 (*get_ufs_hci_version)(struct ufs_hba *);
> --
> 2.34.1

Reviewed-by: Peter Wang <peter.wang@xxxxxxxxxxxx>