This source file includes following definitions.
- xenon_alloc_emmc_phy
- xenon_emmc_phy_init
- armada_3700_soc_pad_voltage_set
- xenon_emmc_phy_set_soc_pad
- xenon_emmc_phy_enable_dll
- xenon_emmc_phy_config_tuning
- xenon_emmc_phy_disable_strobe
- xenon_emmc_phy_strobe_delay_adj
- xenon_emmc_phy_slow_mode
- xenon_emmc_phy_set
- get_dt_pad_ctrl_data
- xenon_emmc_phy_parse_param_dt
- xenon_soc_pad_ctrl
- xenon_hs_delay_adj
- xenon_phy_adj
- xenon_add_phy
- xenon_phy_parse_dt
   1 
   2 
   3 
   4 
   5 
   6 
   7 
   8 
   9 
  10 
  11 #include <linux/slab.h>
  12 #include <linux/delay.h>
  13 #include <linux/ktime.h>
  14 #include <linux/of_address.h>
  15 
  16 #include "sdhci-pltfm.h"
  17 #include "sdhci-xenon.h"
  18 
  19 
  20 #define XENON_EMMC_5_0_PHY_REG_BASE             0x0160
  21 
  22 #define XENON_EMMC_PHY_REG_BASE                 0x0170
  23 
  24 #define XENON_EMMC_PHY_TIMING_ADJUST            XENON_EMMC_PHY_REG_BASE
  25 #define XENON_EMMC_5_0_PHY_TIMING_ADJUST        XENON_EMMC_5_0_PHY_REG_BASE
  26 #define XENON_TIMING_ADJUST_SLOW_MODE           BIT(29)
  27 #define XENON_TIMING_ADJUST_SDIO_MODE           BIT(28)
  28 #define XENON_SAMPL_INV_QSP_PHASE_SELECT        BIT(18)
  29 #define XENON_SAMPL_INV_QSP_PHASE_SELECT_SHIFT  18
  30 #define XENON_PHY_INITIALIZAION                 BIT(31)
  31 #define XENON_WAIT_CYCLE_BEFORE_USING_MASK      0xF
  32 #define XENON_WAIT_CYCLE_BEFORE_USING_SHIFT     12
  33 #define XENON_FC_SYNC_EN_DURATION_MASK          0xF
  34 #define XENON_FC_SYNC_EN_DURATION_SHIFT         8
  35 #define XENON_FC_SYNC_RST_EN_DURATION_MASK      0xF
  36 #define XENON_FC_SYNC_RST_EN_DURATION_SHIFT     4
  37 #define XENON_FC_SYNC_RST_DURATION_MASK         0xF
  38 #define XENON_FC_SYNC_RST_DURATION_SHIFT        0
  39 
  40 #define XENON_EMMC_PHY_FUNC_CONTROL             (XENON_EMMC_PHY_REG_BASE + 0x4)
  41 #define XENON_EMMC_5_0_PHY_FUNC_CONTROL         \
  42         (XENON_EMMC_5_0_PHY_REG_BASE + 0x4)
  43 #define XENON_ASYNC_DDRMODE_MASK                BIT(23)
  44 #define XENON_ASYNC_DDRMODE_SHIFT               23
  45 #define XENON_CMD_DDR_MODE                      BIT(16)
  46 #define XENON_DQ_DDR_MODE_SHIFT                 8
  47 #define XENON_DQ_DDR_MODE_MASK                  0xFF
  48 #define XENON_DQ_ASYNC_MODE                     BIT(4)
  49 
  50 #define XENON_EMMC_PHY_PAD_CONTROL              (XENON_EMMC_PHY_REG_BASE + 0x8)
  51 #define XENON_EMMC_5_0_PHY_PAD_CONTROL          \
  52         (XENON_EMMC_5_0_PHY_REG_BASE + 0x8)
  53 #define XENON_REC_EN_SHIFT                      24
  54 #define XENON_REC_EN_MASK                       0xF
  55 #define XENON_FC_DQ_RECEN                       BIT(24)
  56 #define XENON_FC_CMD_RECEN                      BIT(25)
  57 #define XENON_FC_QSP_RECEN                      BIT(26)
  58 #define XENON_FC_QSN_RECEN                      BIT(27)
  59 #define XENON_OEN_QSN                           BIT(28)
  60 #define XENON_AUTO_RECEN_CTRL                   BIT(30)
  61 #define XENON_FC_ALL_CMOS_RECEIVER              0xF000
  62 
  63 #define XENON_EMMC5_FC_QSP_PD                   BIT(18)
  64 #define XENON_EMMC5_FC_QSP_PU                   BIT(22)
  65 #define XENON_EMMC5_FC_CMD_PD                   BIT(17)
  66 #define XENON_EMMC5_FC_CMD_PU                   BIT(21)
  67 #define XENON_EMMC5_FC_DQ_PD                    BIT(16)
  68 #define XENON_EMMC5_FC_DQ_PU                    BIT(20)
  69 
  70 #define XENON_EMMC_PHY_PAD_CONTROL1             (XENON_EMMC_PHY_REG_BASE + 0xC)
  71 #define XENON_EMMC5_1_FC_QSP_PD                 BIT(9)
  72 #define XENON_EMMC5_1_FC_QSP_PU                 BIT(25)
  73 #define XENON_EMMC5_1_FC_CMD_PD                 BIT(8)
  74 #define XENON_EMMC5_1_FC_CMD_PU                 BIT(24)
  75 #define XENON_EMMC5_1_FC_DQ_PD                  0xFF
  76 #define XENON_EMMC5_1_FC_DQ_PU                  (0xFF << 16)
  77 
  78 #define XENON_EMMC_PHY_PAD_CONTROL2             (XENON_EMMC_PHY_REG_BASE + 0x10)
  79 #define XENON_EMMC_5_0_PHY_PAD_CONTROL2         \
  80         (XENON_EMMC_5_0_PHY_REG_BASE + 0xC)
  81 #define XENON_ZNR_MASK                          0x1F
  82 #define XENON_ZNR_SHIFT                         8
  83 #define XENON_ZPR_MASK                          0x1F
  84 
  85 
  86 
  87 
  88 #define XENON_ZNR_DEF_VALUE                     0xF
  89 #define XENON_ZPR_DEF_VALUE                     0xF
  90 
  91 #define XENON_EMMC_PHY_DLL_CONTROL              (XENON_EMMC_PHY_REG_BASE + 0x14)
  92 #define XENON_EMMC_5_0_PHY_DLL_CONTROL          \
  93         (XENON_EMMC_5_0_PHY_REG_BASE + 0x10)
  94 #define XENON_DLL_ENABLE                        BIT(31)
  95 #define XENON_DLL_UPDATE_STROBE_5_0             BIT(30)
  96 #define XENON_DLL_REFCLK_SEL                    BIT(30)
  97 #define XENON_DLL_UPDATE                        BIT(23)
  98 #define XENON_DLL_PHSEL1_SHIFT                  24
  99 #define XENON_DLL_PHSEL0_SHIFT                  16
 100 #define XENON_DLL_PHASE_MASK                    0x3F
 101 #define XENON_DLL_PHASE_90_DEGREE               0x1F
 102 #define XENON_DLL_FAST_LOCK                     BIT(5)
 103 #define XENON_DLL_GAIN2X                        BIT(3)
 104 #define XENON_DLL_BYPASS_EN                     BIT(0)
 105 
 106 #define XENON_EMMC_5_0_PHY_LOGIC_TIMING_ADJUST  \
 107         (XENON_EMMC_5_0_PHY_REG_BASE + 0x14)
 108 #define XENON_EMMC_5_0_PHY_LOGIC_TIMING_VALUE   0x5A54
 109 #define XENON_EMMC_PHY_LOGIC_TIMING_ADJUST      (XENON_EMMC_PHY_REG_BASE + 0x18)
 110 #define XENON_LOGIC_TIMING_VALUE                0x00AA8977
 111 
 112 
 113 
 114 
 115 
 116 struct xenon_emmc_phy_regs {
 117         
 118         u16 timing_adj;
 119         
 120         u16 func_ctrl;
 121         
 122         u16 pad_ctrl;
 123         
 124         u16 pad_ctrl2;
 125         
 126         u16 dll_ctrl;
 127         
 128         u16 logic_timing_adj;
 129         
 130         u32 dll_update;
 131         
 132         u32 logic_timing_val;
 133 };
 134 
 135 static const char * const phy_types[] = {
 136         "emmc 5.0 phy",
 137         "emmc 5.1 phy"
 138 };
 139 
 140 enum xenon_phy_type_enum {
 141         EMMC_5_0_PHY,
 142         EMMC_5_1_PHY,
 143         NR_PHY_TYPES
 144 };
 145 
 146 enum soc_pad_ctrl_type {
 147         SOC_PAD_SD,
 148         SOC_PAD_FIXED_1_8V,
 149 };
 150 
 151 struct soc_pad_ctrl {
 152         
 153         void __iomem    *reg;
 154         
 155         enum soc_pad_ctrl_type pad_type;
 156         
 157         void (*set_soc_pad)(struct sdhci_host *host,
 158                             unsigned char signal_voltage);
 159 };
 160 
 161 static struct xenon_emmc_phy_regs xenon_emmc_5_0_phy_regs = {
 162         .timing_adj     = XENON_EMMC_5_0_PHY_TIMING_ADJUST,
 163         .func_ctrl      = XENON_EMMC_5_0_PHY_FUNC_CONTROL,
 164         .pad_ctrl       = XENON_EMMC_5_0_PHY_PAD_CONTROL,
 165         .pad_ctrl2      = XENON_EMMC_5_0_PHY_PAD_CONTROL2,
 166         .dll_ctrl       = XENON_EMMC_5_0_PHY_DLL_CONTROL,
 167         .logic_timing_adj = XENON_EMMC_5_0_PHY_LOGIC_TIMING_ADJUST,
 168         .dll_update     = XENON_DLL_UPDATE_STROBE_5_0,
 169         .logic_timing_val = XENON_EMMC_5_0_PHY_LOGIC_TIMING_VALUE,
 170 };
 171 
 172 static struct xenon_emmc_phy_regs xenon_emmc_5_1_phy_regs = {
 173         .timing_adj     = XENON_EMMC_PHY_TIMING_ADJUST,
 174         .func_ctrl      = XENON_EMMC_PHY_FUNC_CONTROL,
 175         .pad_ctrl       = XENON_EMMC_PHY_PAD_CONTROL,
 176         .pad_ctrl2      = XENON_EMMC_PHY_PAD_CONTROL2,
 177         .dll_ctrl       = XENON_EMMC_PHY_DLL_CONTROL,
 178         .logic_timing_adj = XENON_EMMC_PHY_LOGIC_TIMING_ADJUST,
 179         .dll_update     = XENON_DLL_UPDATE,
 180         .logic_timing_val = XENON_LOGIC_TIMING_VALUE,
 181 };
 182 
 183 
 184 
 185 
 186 struct xenon_emmc_phy_params {
 187         bool    slow_mode;
 188 
 189         u8      znr;
 190         u8      zpr;
 191 
 192         
 193         u8      nr_tun_times;
 194         
 195         u8      tun_step_divider;
 196 
 197         struct soc_pad_ctrl pad_ctrl;
 198 };
 199 
 200 static int xenon_alloc_emmc_phy(struct sdhci_host *host)
 201 {
 202         struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host);
 203         struct xenon_priv *priv = sdhci_pltfm_priv(pltfm_host);
 204         struct xenon_emmc_phy_params *params;
 205 
 206         params = devm_kzalloc(mmc_dev(host->mmc), sizeof(*params), GFP_KERNEL);
 207         if (!params)
 208                 return -ENOMEM;
 209 
 210         priv->phy_params = params;
 211         if (priv->phy_type == EMMC_5_0_PHY)
 212                 priv->emmc_phy_regs = &xenon_emmc_5_0_phy_regs;
 213         else
 214                 priv->emmc_phy_regs = &xenon_emmc_5_1_phy_regs;
 215 
 216         return 0;
 217 }
 218 
 219 
 220 
 221 
 222 
 223 
 224 
 225 
 226 
 227 static int xenon_emmc_phy_init(struct sdhci_host *host)
 228 {
 229         u32 reg;
 230         u32 wait, clock;
 231         struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host);
 232         struct xenon_priv *priv = sdhci_pltfm_priv(pltfm_host);
 233         struct xenon_emmc_phy_regs *phy_regs = priv->emmc_phy_regs;
 234 
 235         reg = sdhci_readl(host, phy_regs->timing_adj);
 236         reg |= XENON_PHY_INITIALIZAION;
 237         sdhci_writel(host, reg, phy_regs->timing_adj);
 238 
 239         
 240         wait = ((reg >> XENON_FC_SYNC_RST_DURATION_SHIFT) &
 241                         XENON_FC_SYNC_RST_DURATION_MASK);
 242         
 243         wait += ((reg >> XENON_FC_SYNC_RST_EN_DURATION_SHIFT) &
 244                         XENON_FC_SYNC_RST_EN_DURATION_MASK);
 245         
 246         wait += ((reg >> XENON_FC_SYNC_EN_DURATION_SHIFT) &
 247                         XENON_FC_SYNC_EN_DURATION_MASK);
 248         
 249         wait += ((reg >> XENON_WAIT_CYCLE_BEFORE_USING_SHIFT) &
 250                         XENON_WAIT_CYCLE_BEFORE_USING_MASK);
 251         
 252         wait += 8;
 253         wait <<= 20;
 254 
 255         clock = host->clock;
 256         if (!clock)
 257                 
 258                 clock = XENON_LOWEST_SDCLK_FREQ;
 259         
 260         wait /= clock;
 261         wait++;
 262         
 263         udelay(wait);
 264 
 265         reg = sdhci_readl(host, phy_regs->timing_adj);
 266         reg &= XENON_PHY_INITIALIZAION;
 267         if (reg) {
 268                 dev_err(mmc_dev(host->mmc), "eMMC PHY init cannot complete after %d us\n",
 269                         wait);
 270                 return -ETIMEDOUT;
 271         }
 272 
 273         return 0;
 274 }
 275 
 276 #define ARMADA_3700_SOC_PAD_1_8V        0x1
 277 #define ARMADA_3700_SOC_PAD_3_3V        0x0
 278 
 279 static void armada_3700_soc_pad_voltage_set(struct sdhci_host *host,
 280                                             unsigned char signal_voltage)
 281 {
 282         struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host);
 283         struct xenon_priv *priv = sdhci_pltfm_priv(pltfm_host);
 284         struct xenon_emmc_phy_params *params = priv->phy_params;
 285 
 286         if (params->pad_ctrl.pad_type == SOC_PAD_FIXED_1_8V) {
 287                 writel(ARMADA_3700_SOC_PAD_1_8V, params->pad_ctrl.reg);
 288         } else if (params->pad_ctrl.pad_type == SOC_PAD_SD) {
 289                 if (signal_voltage == MMC_SIGNAL_VOLTAGE_180)
 290                         writel(ARMADA_3700_SOC_PAD_1_8V, params->pad_ctrl.reg);
 291                 else if (signal_voltage == MMC_SIGNAL_VOLTAGE_330)
 292                         writel(ARMADA_3700_SOC_PAD_3_3V, params->pad_ctrl.reg);
 293         }
 294 }
 295 
 296 
 297 
 298 
 299 
 300 
 301 static void xenon_emmc_phy_set_soc_pad(struct sdhci_host *host,
 302                                        unsigned char signal_voltage)
 303 {
 304         struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host);
 305         struct xenon_priv *priv = sdhci_pltfm_priv(pltfm_host);
 306         struct xenon_emmc_phy_params *params = priv->phy_params;
 307 
 308         if (!params->pad_ctrl.reg)
 309                 return;
 310 
 311         if (params->pad_ctrl.set_soc_pad)
 312                 params->pad_ctrl.set_soc_pad(host, signal_voltage);
 313 }
 314 
 315 
 316 
 317 
 318 
 319 
 320 static int xenon_emmc_phy_enable_dll(struct sdhci_host *host)
 321 {
 322         u32 reg;
 323         struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host);
 324         struct xenon_priv *priv = sdhci_pltfm_priv(pltfm_host);
 325         struct xenon_emmc_phy_regs *phy_regs = priv->emmc_phy_regs;
 326         ktime_t timeout;
 327 
 328         if (WARN_ON(host->clock <= MMC_HIGH_52_MAX_DTR))
 329                 return -EINVAL;
 330 
 331         reg = sdhci_readl(host, phy_regs->dll_ctrl);
 332         if (reg & XENON_DLL_ENABLE)
 333                 return 0;
 334 
 335         
 336         reg = sdhci_readl(host, phy_regs->dll_ctrl);
 337         reg |= (XENON_DLL_ENABLE | XENON_DLL_FAST_LOCK);
 338 
 339         
 340 
 341 
 342 
 343 
 344         reg &= ~((XENON_DLL_PHASE_MASK << XENON_DLL_PHSEL0_SHIFT) |
 345                  (XENON_DLL_PHASE_MASK << XENON_DLL_PHSEL1_SHIFT));
 346         reg |= ((XENON_DLL_PHASE_90_DEGREE << XENON_DLL_PHSEL0_SHIFT) |
 347                 (XENON_DLL_PHASE_90_DEGREE << XENON_DLL_PHSEL1_SHIFT));
 348 
 349         reg &= ~XENON_DLL_BYPASS_EN;
 350         reg |= phy_regs->dll_update;
 351         if (priv->phy_type == EMMC_5_1_PHY)
 352                 reg &= ~XENON_DLL_REFCLK_SEL;
 353         sdhci_writel(host, reg, phy_regs->dll_ctrl);
 354 
 355         
 356         timeout = ktime_add_ms(ktime_get(), 32);
 357         while (1) {
 358                 bool timedout = ktime_after(ktime_get(), timeout);
 359 
 360                 if (sdhci_readw(host, XENON_SLOT_EXT_PRESENT_STATE) &
 361                     XENON_DLL_LOCK_STATE)
 362                         break;
 363                 if (timedout) {
 364                         dev_err(mmc_dev(host->mmc), "Wait for DLL Lock time-out\n");
 365                         return -ETIMEDOUT;
 366                 }
 367                 udelay(100);
 368         }
 369         return 0;
 370 }
 371 
 372 
 373 
 374 
 375 
 376 static int xenon_emmc_phy_config_tuning(struct sdhci_host *host)
 377 {
 378         struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host);
 379         struct xenon_priv *priv = sdhci_pltfm_priv(pltfm_host);
 380         struct xenon_emmc_phy_params *params = priv->phy_params;
 381         u32 reg, tuning_step;
 382         int ret;
 383 
 384         if (host->clock <= MMC_HIGH_52_MAX_DTR)
 385                 return -EINVAL;
 386 
 387         ret = xenon_emmc_phy_enable_dll(host);
 388         if (ret)
 389                 return ret;
 390 
 391         
 392         reg = sdhci_readl(host, XENON_SLOT_DLL_CUR_DLY_VAL);
 393         tuning_step = reg / params->tun_step_divider;
 394         if (unlikely(tuning_step > XENON_TUNING_STEP_MASK)) {
 395                 dev_warn(mmc_dev(host->mmc),
 396                          "HS200 TUNING_STEP %d is larger than MAX value\n",
 397                          tuning_step);
 398                 tuning_step = XENON_TUNING_STEP_MASK;
 399         }
 400 
 401         
 402         reg = sdhci_readl(host, XENON_SLOT_OP_STATUS_CTRL);
 403         reg &= ~(XENON_TUN_CONSECUTIVE_TIMES_MASK <<
 404                  XENON_TUN_CONSECUTIVE_TIMES_SHIFT);
 405         reg |= (params->nr_tun_times << XENON_TUN_CONSECUTIVE_TIMES_SHIFT);
 406         reg &= ~(XENON_TUNING_STEP_MASK << XENON_TUNING_STEP_SHIFT);
 407         reg |= (tuning_step << XENON_TUNING_STEP_SHIFT);
 408         sdhci_writel(host, reg, XENON_SLOT_OP_STATUS_CTRL);
 409 
 410         return 0;
 411 }
 412 
 413 static void xenon_emmc_phy_disable_strobe(struct sdhci_host *host)
 414 {
 415         struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host);
 416         struct xenon_priv *priv = sdhci_pltfm_priv(pltfm_host);
 417         u32 reg;
 418 
 419         
 420         reg = sdhci_readl(host, XENON_SLOT_EMMC_CTRL);
 421         reg &= ~(XENON_ENABLE_DATA_STROBE | XENON_ENABLE_RESP_STROBE);
 422         sdhci_writel(host, reg, XENON_SLOT_EMMC_CTRL);
 423 
 424         
 425         if (priv->phy_type == EMMC_5_0_PHY) {
 426                 reg = sdhci_readl(host, XENON_EMMC_5_0_PHY_PAD_CONTROL);
 427                 reg &= ~(XENON_EMMC5_FC_QSP_PD | XENON_EMMC5_FC_QSP_PU);
 428                 sdhci_writel(host, reg, XENON_EMMC_5_0_PHY_PAD_CONTROL);
 429         } else {
 430                 reg = sdhci_readl(host, XENON_EMMC_PHY_PAD_CONTROL1);
 431                 reg &= ~(XENON_EMMC5_1_FC_QSP_PD | XENON_EMMC5_1_FC_QSP_PU);
 432                 sdhci_writel(host, reg, XENON_EMMC_PHY_PAD_CONTROL1);
 433         }
 434 }
 435 
 436 
 437 static void xenon_emmc_phy_strobe_delay_adj(struct sdhci_host *host)
 438 {
 439         struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host);
 440         struct xenon_priv *priv = sdhci_pltfm_priv(pltfm_host);
 441         u32 reg;
 442 
 443         if (WARN_ON(host->timing != MMC_TIMING_MMC_HS400))
 444                 return;
 445 
 446         if (host->clock <= MMC_HIGH_52_MAX_DTR)
 447                 return;
 448 
 449         dev_dbg(mmc_dev(host->mmc), "starts HS400 strobe delay adjustment\n");
 450 
 451         xenon_emmc_phy_enable_dll(host);
 452 
 453         
 454         reg = sdhci_readl(host, XENON_SLOT_EMMC_CTRL);
 455         reg |= XENON_ENABLE_DATA_STROBE;
 456         
 457 
 458 
 459 
 460 
 461 
 462 
 463         if (host->mmc->ios.enhanced_strobe)
 464                 reg |= XENON_ENABLE_RESP_STROBE;
 465         sdhci_writel(host, reg, XENON_SLOT_EMMC_CTRL);
 466 
 467         
 468         if (priv->phy_type == EMMC_5_0_PHY) {
 469                 reg = sdhci_readl(host, XENON_EMMC_5_0_PHY_PAD_CONTROL);
 470                 reg |= XENON_EMMC5_FC_QSP_PD;
 471                 reg &= ~XENON_EMMC5_FC_QSP_PU;
 472                 sdhci_writel(host, reg, XENON_EMMC_5_0_PHY_PAD_CONTROL);
 473         } else {
 474                 reg = sdhci_readl(host, XENON_EMMC_PHY_PAD_CONTROL1);
 475                 reg |= XENON_EMMC5_1_FC_QSP_PD;
 476                 reg &= ~XENON_EMMC5_1_FC_QSP_PU;
 477                 sdhci_writel(host, reg, XENON_EMMC_PHY_PAD_CONTROL1);
 478         }
 479 }
 480 
 481 
 482 
 483 
 484 
 485 
 486 
 487 
 488 
 489 static bool xenon_emmc_phy_slow_mode(struct sdhci_host *host,
 490                                      unsigned char timing)
 491 {
 492         struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host);
 493         struct xenon_priv *priv = sdhci_pltfm_priv(pltfm_host);
 494         struct xenon_emmc_phy_params *params = priv->phy_params;
 495         struct xenon_emmc_phy_regs *phy_regs = priv->emmc_phy_regs;
 496         u32 reg;
 497         int ret;
 498 
 499         if (host->clock > MMC_HIGH_52_MAX_DTR)
 500                 return false;
 501 
 502         reg = sdhci_readl(host, phy_regs->timing_adj);
 503         
 504 
 505 
 506         switch (timing) {
 507         case MMC_TIMING_LEGACY:
 508                 
 509 
 510 
 511 
 512                 if (params->slow_mode) {
 513                         reg |= XENON_TIMING_ADJUST_SLOW_MODE;
 514                         ret = true;
 515                 } else {
 516                         reg &= ~XENON_TIMING_ADJUST_SLOW_MODE;
 517                         ret = false;
 518                 }
 519                 break;
 520         case MMC_TIMING_UHS_SDR25:
 521         case MMC_TIMING_UHS_SDR12:
 522         case MMC_TIMING_SD_HS:
 523         case MMC_TIMING_MMC_HS:
 524                 if ((priv->init_card_type == MMC_TYPE_SDIO) ||
 525                     params->slow_mode) {
 526                         reg |= XENON_TIMING_ADJUST_SLOW_MODE;
 527                         ret = true;
 528                         break;
 529                 }
 530                 
 531         default:
 532                 reg &= ~XENON_TIMING_ADJUST_SLOW_MODE;
 533                 ret = false;
 534         }
 535 
 536         sdhci_writel(host, reg, phy_regs->timing_adj);
 537         return ret;
 538 }
 539 
 540 
 541 
 542 
 543 
 544 static void xenon_emmc_phy_set(struct sdhci_host *host,
 545                                unsigned char timing)
 546 {
 547         u32 reg;
 548         struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host);
 549         struct xenon_priv *priv = sdhci_pltfm_priv(pltfm_host);
 550         struct xenon_emmc_phy_params *params = priv->phy_params;
 551         struct xenon_emmc_phy_regs *phy_regs = priv->emmc_phy_regs;
 552 
 553         dev_dbg(mmc_dev(host->mmc), "eMMC PHY setting starts\n");
 554 
 555         
 556         reg = sdhci_readl(host, phy_regs->pad_ctrl);
 557         reg |= (XENON_FC_DQ_RECEN | XENON_FC_CMD_RECEN |
 558                 XENON_FC_QSP_RECEN | XENON_OEN_QSN);
 559         
 560         reg |= XENON_FC_ALL_CMOS_RECEIVER;
 561         sdhci_writel(host, reg, phy_regs->pad_ctrl);
 562 
 563         
 564         if (priv->phy_type == EMMC_5_0_PHY) {
 565                 reg = sdhci_readl(host, XENON_EMMC_5_0_PHY_PAD_CONTROL);
 566                 reg |= (XENON_EMMC5_FC_CMD_PU | XENON_EMMC5_FC_DQ_PU);
 567                 reg &= ~(XENON_EMMC5_FC_CMD_PD | XENON_EMMC5_FC_DQ_PD);
 568                 sdhci_writel(host, reg, XENON_EMMC_5_0_PHY_PAD_CONTROL);
 569         } else {
 570                 reg = sdhci_readl(host, XENON_EMMC_PHY_PAD_CONTROL1);
 571                 reg |= (XENON_EMMC5_1_FC_CMD_PU | XENON_EMMC5_1_FC_DQ_PU);
 572                 reg &= ~(XENON_EMMC5_1_FC_CMD_PD | XENON_EMMC5_1_FC_DQ_PD);
 573                 sdhci_writel(host, reg, XENON_EMMC_PHY_PAD_CONTROL1);
 574         }
 575 
 576         if (timing == MMC_TIMING_LEGACY) {
 577                 xenon_emmc_phy_slow_mode(host, timing);
 578                 goto phy_init;
 579         }
 580 
 581         
 582 
 583 
 584 
 585         reg = sdhci_readl(host, phy_regs->timing_adj);
 586         if (priv->init_card_type == MMC_TYPE_SDIO)
 587                 reg |= XENON_TIMING_ADJUST_SDIO_MODE;
 588         else
 589                 reg &= ~XENON_TIMING_ADJUST_SDIO_MODE;
 590         sdhci_writel(host, reg, phy_regs->timing_adj);
 591 
 592         if (xenon_emmc_phy_slow_mode(host, timing))
 593                 goto phy_init;
 594 
 595         
 596 
 597 
 598 
 599 
 600         reg = sdhci_readl(host, phy_regs->pad_ctrl2);
 601         reg &= ~((XENON_ZNR_MASK << XENON_ZNR_SHIFT) | XENON_ZPR_MASK);
 602         reg |= ((params->znr << XENON_ZNR_SHIFT) | params->zpr);
 603         sdhci_writel(host, reg, phy_regs->pad_ctrl2);
 604 
 605         
 606 
 607 
 608 
 609         reg = sdhci_readl(host, SDHCI_CLOCK_CONTROL);
 610         reg &= ~SDHCI_CLOCK_CARD_EN;
 611         sdhci_writew(host, reg, SDHCI_CLOCK_CONTROL);
 612 
 613         reg = sdhci_readl(host, phy_regs->func_ctrl);
 614         switch (timing) {
 615         case MMC_TIMING_MMC_HS400:
 616                 reg |= (XENON_DQ_DDR_MODE_MASK << XENON_DQ_DDR_MODE_SHIFT) |
 617                        XENON_CMD_DDR_MODE;
 618                 reg &= ~XENON_DQ_ASYNC_MODE;
 619                 break;
 620         case MMC_TIMING_UHS_DDR50:
 621         case MMC_TIMING_MMC_DDR52:
 622                 reg |= (XENON_DQ_DDR_MODE_MASK << XENON_DQ_DDR_MODE_SHIFT) |
 623                        XENON_CMD_DDR_MODE | XENON_DQ_ASYNC_MODE;
 624                 break;
 625         default:
 626                 reg &= ~((XENON_DQ_DDR_MODE_MASK << XENON_DQ_DDR_MODE_SHIFT) |
 627                          XENON_CMD_DDR_MODE);
 628                 reg |= XENON_DQ_ASYNC_MODE;
 629         }
 630         sdhci_writel(host, reg, phy_regs->func_ctrl);
 631 
 632         
 633         reg = sdhci_readl(host, SDHCI_CLOCK_CONTROL);
 634         reg |= SDHCI_CLOCK_CARD_EN;
 635         sdhci_writew(host, reg, SDHCI_CLOCK_CONTROL);
 636 
 637         if (timing == MMC_TIMING_MMC_HS400)
 638                 
 639                 sdhci_writel(host, phy_regs->logic_timing_val,
 640                              phy_regs->logic_timing_adj);
 641         else
 642                 xenon_emmc_phy_disable_strobe(host);
 643 
 644 phy_init:
 645         xenon_emmc_phy_init(host);
 646 
 647         dev_dbg(mmc_dev(host->mmc), "eMMC PHY setting completes\n");
 648 }
 649 
 650 static int get_dt_pad_ctrl_data(struct sdhci_host *host,
 651                                 struct device_node *np,
 652                                 struct xenon_emmc_phy_params *params)
 653 {
 654         int ret = 0;
 655         const char *name;
 656         struct resource iomem;
 657 
 658         if (of_device_is_compatible(np, "marvell,armada-3700-sdhci"))
 659                 params->pad_ctrl.set_soc_pad = armada_3700_soc_pad_voltage_set;
 660         else
 661                 return 0;
 662 
 663         if (of_address_to_resource(np, 1, &iomem)) {
 664                 dev_err(mmc_dev(host->mmc), "Unable to find SoC PAD ctrl register address for %pOFn\n",
 665                         np);
 666                 return -EINVAL;
 667         }
 668 
 669         params->pad_ctrl.reg = devm_ioremap_resource(mmc_dev(host->mmc),
 670                                                      &iomem);
 671         if (IS_ERR(params->pad_ctrl.reg))
 672                 return PTR_ERR(params->pad_ctrl.reg);
 673 
 674         ret = of_property_read_string(np, "marvell,pad-type", &name);
 675         if (ret) {
 676                 dev_err(mmc_dev(host->mmc), "Unable to determine SoC PHY PAD ctrl type\n");
 677                 return ret;
 678         }
 679         if (!strcmp(name, "sd")) {
 680                 params->pad_ctrl.pad_type = SOC_PAD_SD;
 681         } else if (!strcmp(name, "fixed-1-8v")) {
 682                 params->pad_ctrl.pad_type = SOC_PAD_FIXED_1_8V;
 683         } else {
 684                 dev_err(mmc_dev(host->mmc), "Unsupported SoC PHY PAD ctrl type %s\n",
 685                         name);
 686                 return -EINVAL;
 687         }
 688 
 689         return ret;
 690 }
 691 
 692 static int xenon_emmc_phy_parse_param_dt(struct sdhci_host *host,
 693                                          struct device_node *np,
 694                                          struct xenon_emmc_phy_params *params)
 695 {
 696         u32 value;
 697 
 698         params->slow_mode = false;
 699         if (of_property_read_bool(np, "marvell,xenon-phy-slow-mode"))
 700                 params->slow_mode = true;
 701 
 702         params->znr = XENON_ZNR_DEF_VALUE;
 703         if (!of_property_read_u32(np, "marvell,xenon-phy-znr", &value))
 704                 params->znr = value & XENON_ZNR_MASK;
 705 
 706         params->zpr = XENON_ZPR_DEF_VALUE;
 707         if (!of_property_read_u32(np, "marvell,xenon-phy-zpr", &value))
 708                 params->zpr = value & XENON_ZPR_MASK;
 709 
 710         params->nr_tun_times = XENON_TUN_CONSECUTIVE_TIMES;
 711         if (!of_property_read_u32(np, "marvell,xenon-phy-nr-success-tun",
 712                                   &value))
 713                 params->nr_tun_times = value & XENON_TUN_CONSECUTIVE_TIMES_MASK;
 714 
 715         params->tun_step_divider = XENON_TUNING_STEP_DIVIDER;
 716         if (!of_property_read_u32(np, "marvell,xenon-phy-tun-step-divider",
 717                                   &value))
 718                 params->tun_step_divider = value & 0xFF;
 719 
 720         return get_dt_pad_ctrl_data(host, np, params);
 721 }
 722 
 723 
 724 void xenon_soc_pad_ctrl(struct sdhci_host *host,
 725                         unsigned char signal_voltage)
 726 {
 727         xenon_emmc_phy_set_soc_pad(host, signal_voltage);
 728 }
 729 
 730 
 731 
 732 
 733 
 734 
 735 static int xenon_hs_delay_adj(struct sdhci_host *host)
 736 {
 737         int ret = 0;
 738 
 739         if (WARN_ON(host->clock <= XENON_DEFAULT_SDCLK_FREQ))
 740                 return -EINVAL;
 741 
 742         switch (host->timing) {
 743         case MMC_TIMING_MMC_HS400:
 744                 xenon_emmc_phy_strobe_delay_adj(host);
 745                 return 0;
 746         case MMC_TIMING_MMC_HS200:
 747         case MMC_TIMING_UHS_SDR104:
 748                 return xenon_emmc_phy_config_tuning(host);
 749         case MMC_TIMING_MMC_DDR52:
 750         case MMC_TIMING_UHS_DDR50:
 751                 
 752 
 753 
 754 
 755 
 756 
 757 
 758 
 759 
 760 
 761 
 762                 dev_warn_once(mmc_dev(host->mmc), "Timing issue might occur in DDR mode\n");
 763                 return 0;
 764         }
 765 
 766         return ret;
 767 }
 768 
 769 
 770 
 771 
 772 
 773 
 774 
 775 
 776 int xenon_phy_adj(struct sdhci_host *host, struct mmc_ios *ios)
 777 {
 778         struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host);
 779         struct xenon_priv *priv = sdhci_pltfm_priv(pltfm_host);
 780         int ret = 0;
 781 
 782         if (!host->clock) {
 783                 priv->clock = 0;
 784                 return 0;
 785         }
 786 
 787         
 788 
 789 
 790 
 791 
 792         if ((host->clock == priv->clock) &&
 793             (ios->bus_width == priv->bus_width) &&
 794             (ios->timing == priv->timing))
 795                 return 0;
 796 
 797         xenon_emmc_phy_set(host, ios->timing);
 798 
 799         
 800         priv->bus_width = ios->bus_width;
 801 
 802         priv->timing = ios->timing;
 803         priv->clock = host->clock;
 804 
 805         
 806         if (ios->timing == MMC_TIMING_LEGACY)
 807                 return 0;
 808 
 809         if (host->clock > XENON_DEFAULT_SDCLK_FREQ)
 810                 ret = xenon_hs_delay_adj(host);
 811         return ret;
 812 }
 813 
 814 static int xenon_add_phy(struct device_node *np, struct sdhci_host *host,
 815                          const char *phy_name)
 816 {
 817         struct sdhci_pltfm_host *pltfm_host = sdhci_priv(host);
 818         struct xenon_priv *priv = sdhci_pltfm_priv(pltfm_host);
 819         int ret;
 820 
 821         priv->phy_type = match_string(phy_types, NR_PHY_TYPES, phy_name);
 822         if (priv->phy_type < 0) {
 823                 dev_err(mmc_dev(host->mmc),
 824                         "Unable to determine PHY name %s. Use default eMMC 5.1 PHY\n",
 825                         phy_name);
 826                 priv->phy_type = EMMC_5_1_PHY;
 827         }
 828 
 829         ret = xenon_alloc_emmc_phy(host);
 830         if (ret)
 831                 return ret;
 832 
 833         return xenon_emmc_phy_parse_param_dt(host, np, priv->phy_params);
 834 }
 835 
 836 int xenon_phy_parse_dt(struct device_node *np, struct sdhci_host *host)
 837 {
 838         const char *phy_type = NULL;
 839 
 840         if (!of_property_read_string(np, "marvell,xenon-phy-type", &phy_type))
 841                 return xenon_add_phy(np, host, phy_type);
 842 
 843         return xenon_add_phy(np, host, "emmc 5.1 phy");
 844 }