// SPDX-License-Identifier: GPL-2.0-only
/*
* UFS PHY driver data for Samsung EXYNOS7 SoC
*
* Copyright (C) 2020 Samsung Electronics Co., Ltd.
*/
#include "phy-samsung-ufs.h"
#define EXYNOS7_EMBEDDED_COMBO_PHY_CTRL 0 x720
#define EXYNOS7_EMBEDDED_COMBO_PHY_CTRL_MASK 0 x1
#define EXYNOS7_EMBEDDED_COMBO_PHY_CTRL_EN BIT(0 )
#define EXYNOS7_EMBEDDED_COMBO_PHY_CDR_LOCK_STATUS 0 x5e
/* Calibration for phy initialization */
static const struct samsung_ufs_phy_cfg exynos7_pre_init_cfg[] = {
PHY_COMN_REG_CFG(0 x00f, 0 xfa, PWR_MODE_ANY),
PHY_COMN_REG_CFG(0 x010, 0 x82, PWR_MODE_ANY),
PHY_COMN_REG_CFG(0 x011, 0 x1e, PWR_MODE_ANY),
PHY_COMN_REG_CFG(0 x017, 0 x84, PWR_MODE_ANY),
PHY_TRSV_REG_CFG(0 x035, 0 x58, PWR_MODE_ANY),
PHY_TRSV_REG_CFG(0 x036, 0 x32, PWR_MODE_ANY),
PHY_TRSV_REG_CFG(0 x037, 0 x40, PWR_MODE_ANY),
PHY_TRSV_REG_CFG(0 x03b, 0 x83, PWR_MODE_ANY),
PHY_TRSV_REG_CFG(0 x042, 0 x88, PWR_MODE_ANY),
PHY_TRSV_REG_CFG(0 x043, 0 xa6, PWR_MODE_ANY),
PHY_TRSV_REG_CFG(0 x048, 0 x74, PWR_MODE_ANY),
PHY_TRSV_REG_CFG(0 x04c, 0 x5b, PWR_MODE_ANY),
PHY_TRSV_REG_CFG(0 x04d, 0 x83, PWR_MODE_ANY),
PHY_TRSV_REG_CFG(0 x05c, 0 x14, PWR_MODE_ANY),
END_UFS_PHY_CFG
};
/* Calibration for HS mode series A/B */
static const struct samsung_ufs_phy_cfg exynos7_pre_pwr_hs_cfg[] = {
PHY_COMN_REG_CFG(0 x00f, 0 xfa, PWR_MODE_HS_ANY),
PHY_COMN_REG_CFG(0 x010, 0 x82, PWR_MODE_HS_ANY),
PHY_COMN_REG_CFG(0 x011, 0 x1e, PWR_MODE_HS_ANY),
/* Setting order: 1st(0x16, 2nd(0x15) */
PHY_COMN_REG_CFG(0 x016, 0 xff, PWR_MODE_HS_ANY),
PHY_COMN_REG_CFG(0 x015, 0 x80, PWR_MODE_HS_ANY),
PHY_COMN_REG_CFG(0 x017, 0 x94, PWR_MODE_HS_ANY),
PHY_TRSV_REG_CFG(0 x036, 0 x32, PWR_MODE_HS_ANY),
PHY_TRSV_REG_CFG(0 x037, 0 x43, PWR_MODE_HS_ANY),
PHY_TRSV_REG_CFG(0 x038, 0 x3f, PWR_MODE_HS_ANY),
PHY_TRSV_REG_CFG(0 x042, 0 x88, PWR_MODE_HS_G2_SER_A),
PHY_TRSV_REG_CFG(0 x042, 0 xbb, PWR_MODE_HS_G2_SER_B),
PHY_TRSV_REG_CFG(0 x043, 0 xa6, PWR_MODE_HS_ANY),
PHY_TRSV_REG_CFG(0 x048, 0 x74, PWR_MODE_HS_ANY),
PHY_TRSV_REG_CFG(0 x034, 0 x35, PWR_MODE_HS_G2_SER_A),
PHY_TRSV_REG_CFG(0 x034, 0 x36, PWR_MODE_HS_G2_SER_B),
PHY_TRSV_REG_CFG(0 x035, 0 x5b, PWR_MODE_HS_G2_SER_A),
PHY_TRSV_REG_CFG(0 x035, 0 x5c, PWR_MODE_HS_G2_SER_B),
END_UFS_PHY_CFG
};
/* Calibration for HS mode series A/B atfer PMC */
static const struct samsung_ufs_phy_cfg exynos7_post_pwr_hs_cfg[] = {
PHY_COMN_REG_CFG(0 x015, 0 x00, PWR_MODE_HS_ANY),
PHY_TRSV_REG_CFG(0 x04d, 0 x83, PWR_MODE_HS_ANY),
END_UFS_PHY_CFG
};
static const struct samsung_ufs_phy_cfg *exynos7_ufs_phy_cfgs[CFG_TAG_MAX] = {
[CFG_PRE_INIT] = exynos7_pre_init_cfg,
[CFG_PRE_PWR_HS] = exynos7_pre_pwr_hs_cfg,
[CFG_POST_PWR_HS] = exynos7_post_pwr_hs_cfg,
};
static const char * const exynos7_ufs_phy_clks[] = {
"tx0_symbol_clk" , "rx0_symbol_clk" , "rx1_symbol_clk" , "ref_clk" ,
};
const struct samsung_ufs_phy_drvdata exynos7_ufs_phy = {
.cfgs = exynos7_ufs_phy_cfgs,
.isol = {
.offset = EXYNOS7_EMBEDDED_COMBO_PHY_CTRL,
.mask = EXYNOS7_EMBEDDED_COMBO_PHY_CTRL_MASK,
.en = EXYNOS7_EMBEDDED_COMBO_PHY_CTRL_EN,
},
.clk_list = exynos7_ufs_phy_clks,
.num_clks = ARRAY_SIZE(exynos7_ufs_phy_clks),
.cdr_lock_status_offset = EXYNOS7_EMBEDDED_COMBO_PHY_CDR_LOCK_STATUS,
.wait_for_cdr = samsung_ufs_phy_wait_for_lock_acq,
};
Messung V0.5 in Prozent C=95 H=92 G=93
¤ Dauer der Verarbeitung: 0.10 Sekunden
(vorverarbeitet am 2026-06-07)
¤
*© Formatika GbR, Deutschland