[PATCH v1 6/7] ufs: host: mediatek: support mphy reset

Chun-Hung Wu (巫駿宏) Chun-hung.Wu at mediatek.com
Thu Mar 14 19:39:11 PDT 2024


On Fri, 2024-03-08 at 15:02 +0800, peter.wang at mediatek.com wrote:
> From: Peter Wang <peter.wang at mediatek.com>
> 
> This patch will reset mphy when host reset.
> Backup mphy setting after mphy reset control get.
> Restore mphy setting after mphy reset.
> 
> Signed-off-by: Peter Wang <peter.wang at mediatek.com>
> ---
>  drivers/ufs/host/ufs-mediatek-sip.h |  9 ++++++++-
>  drivers/ufs/host/ufs-mediatek.c     | 14 ++++++++++++++
>  drivers/ufs/host/ufs-mediatek.h     |  1 +
>  3 files changed, 23 insertions(+), 1 deletion(-)
> 
> diff --git a/drivers/ufs/host/ufs-mediatek-sip.h
> b/drivers/ufs/host/ufs-mediatek-sip.h
> index fd640846910a..64f48ecc54c7 100755
> --- a/drivers/ufs/host/ufs-mediatek-sip.h
> +++ b/drivers/ufs/host/ufs-mediatek-sip.h
> @@ -19,7 +19,7 @@
>  #define UFS_MTK_SIP_SRAM_PWR_CTRL         BIT(5)
>  #define UFS_MTK_SIP_GET_VCC_NUM           BIT(6)
>  #define UFS_MTK_SIP_DEVICE_PWR_CTRL       BIT(7)
> -
> +#define UFS_MTK_SIP_MPHY_CTRL             BIT(8)
>  
>  /*
>   * Multi-VCC by Numbering
> @@ -31,6 +31,10 @@ enum ufs_mtk_vcc_num {
>  	UFS_VCC_MAX
>  };
>  
> +enum ufs_mtk_mphy_op {
> +	UFS_MPHY_BACKUP = 0,
> +	UFS_MPHY_RESTORE
> +};
>  
>  /*
>   * SMC call wrapper function
> @@ -80,4 +84,7 @@ static inline void _ufs_mtk_smc(struct
> ufs_mtk_smc_arg s)
>  #define ufs_mtk_device_pwr_ctrl(on, ufs_version, res) \
>  	ufs_mtk_smc(UFS_MTK_SIP_DEVICE_PWR_CTRL, &(res), on,
> ufs_version)
>  
> +#define ufs_mtk_mphy_ctrl(op, res) \
> +	ufs_mtk_smc(UFS_MTK_SIP_MPHY_CTRL, &(res), op)
> +
>  #endif /* !_UFS_MEDIATEK_SIP_H */
> diff --git a/drivers/ufs/host/ufs-mediatek.c b/drivers/ufs/host/ufs-
> mediatek.c
> index 2caf0c1d4e17..c4aae031b694 100644
> --- a/drivers/ufs/host/ufs-mediatek.c
> +++ b/drivers/ufs/host/ufs-mediatek.c
> @@ -185,16 +185,23 @@ static void ufs_mtk_crypto_enable(struct
> ufs_hba *hba)
>  static void ufs_mtk_host_reset(struct ufs_hba *hba)
>  {
>  	struct ufs_mtk_host *host = ufshcd_get_variant(hba);
> +	struct arm_smccc_res res;
>  
>  	reset_control_assert(host->hci_reset);
>  	reset_control_assert(host->crypto_reset);
>  	reset_control_assert(host->unipro_reset);
> +	reset_control_assert(host->mphy_reset);
>  
>  	usleep_range(100, 110);
>  
>  	reset_control_deassert(host->unipro_reset);
>  	reset_control_deassert(host->crypto_reset);
>  	reset_control_deassert(host->hci_reset);
> +	reset_control_deassert(host->mphy_reset);
> +
> +	/* restore mphy setting aftre mphy reset */
> +	if (host->mphy_reset)
> +		ufs_mtk_mphy_ctrl(UFS_MPHY_RESTORE, res);
>  }
>  
>  static void ufs_mtk_init_reset_control(struct ufs_hba *hba,
> @@ -219,6 +226,8 @@ static void ufs_mtk_init_reset(struct ufs_hba
> *hba)
>  				   "unipro_rst");
>  	ufs_mtk_init_reset_control(hba, &host->crypto_reset,
>  				   "crypto_rst");
> +	ufs_mtk_init_reset_control(hba, &host->mphy_reset,
> +				   "mphy_rst");
>  }
>  
>  static int ufs_mtk_hce_enable_notify(struct ufs_hba *hba,
> @@ -918,6 +927,7 @@ static int ufs_mtk_init(struct ufs_hba *hba)
>  	struct device *dev = hba->dev;
>  	struct ufs_mtk_host *host;
>  	int err = 0;
> +	struct arm_smccc_res res;
>  
>  	host = devm_kzalloc(dev, sizeof(*host), GFP_KERNEL);
>  	if (!host) {
> @@ -946,6 +956,10 @@ static int ufs_mtk_init(struct ufs_hba *hba)
>  
>  	ufs_mtk_init_reset(hba);
>  
> +	/* backup mphy setting if mphy can reset */
> +	if (host->mphy_reset)
> +		ufs_mtk_mphy_ctrl(UFS_MPHY_BACKUP, res);
> +
>  	/* Enable runtime autosuspend */
>  	hba->caps |= UFSHCD_CAP_RPM_AUTOSUSPEND;
>  
> diff --git a/drivers/ufs/host/ufs-mediatek.h b/drivers/ufs/host/ufs-
> mediatek.h
> index 17be3f748fa0..6129ab59e5f5 100644
> --- a/drivers/ufs/host/ufs-mediatek.h
> +++ b/drivers/ufs/host/ufs-mediatek.h
> @@ -166,6 +166,7 @@ struct ufs_mtk_host {
>  	struct reset_control *hci_reset;
>  	struct reset_control *unipro_reset;
>  	struct reset_control *crypto_reset;
> +	struct reset_control *mphy_reset;
>  	struct ufs_hba *hba;
>  	struct ufs_mtk_crypt_cfg *crypt;
>  	struct ufs_mtk_clk mclk;
Acked-by: Chun-Hung Wu <Chun-Hung.Wu at mediatek.com>


More information about the Linux-mediatek mailing list