mmc: sdricoh_cs: Respect the cmd->busy_timeout from the mmc core
[linux-2.6-microblaze.git] / drivers / mmc / host / sdhci-xenon-phy.c
1 // SPDX-License-Identifier: GPL-2.0-only
2 /*
3  * PHY support for Xenon SDHC
4  *
5  * Copyright (C) 2016 Marvell, All Rights Reserved.
6  *
7  * Author:      Hu Ziji <huziji@marvell.com>
8  * Date:        2016-8-24
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 /* Register base for eMMC PHY 5.0 Version */
20 #define XENON_EMMC_5_0_PHY_REG_BASE             0x0160
21 /* Register base for eMMC PHY 5.1 Version */
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 /* Preferred ZNR and ZPR value vary between different boards.
85  * The specific ZNR and ZPR value should be defined here
86  * according to board actual timing.
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  * List offset of PHY registers and some special register values
114  * in eMMC PHY 5.0 or eMMC PHY 5.1
115  */
116 struct xenon_emmc_phy_regs {
117         /* Offset of Timing Adjust register */
118         u16 timing_adj;
119         /* Offset of Func Control register */
120         u16 func_ctrl;
121         /* Offset of Pad Control register */
122         u16 pad_ctrl;
123         /* Offset of Pad Control register 2 */
124         u16 pad_ctrl2;
125         /* Offset of DLL Control register */
126         u16 dll_ctrl;
127         /* Offset of Logic Timing Adjust register */
128         u16 logic_timing_adj;
129         /* DLL Update Enable bit */
130         u32 dll_update;
131         /* value in Logic Timing Adjustment register */
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         /* Register address of SoC PHY PAD ctrl */
153         void __iomem    *reg;
154         /* SoC PHY PAD ctrl type */
155         enum soc_pad_ctrl_type pad_type;
156         /* SoC specific operation to set SoC PHY PAD */
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  * eMMC PHY configuration and operations
185  */
186 struct xenon_emmc_phy_params {
187         bool    slow_mode;
188
189         u8      znr;
190         u8      zpr;
191
192         /* Nr of consecutive Sampling Points of a Valid Sampling Window */
193         u8      nr_tun_times;
194         /* Divider for calculating Tuning Step */
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  * eMMC 5.0/5.1 PHY init/re-init.
221  * eMMC PHY init should be executed after:
222  * 1. SDCLK frequency changes.
223  * 2. SDCLK is stopped and re-enabled.
224  * 3. config in emmc_phy_regs->timing_adj and emmc_phy_regs->func_ctrl
225  * are changed
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         /* Add duration of FC_SYNC_RST */
240         wait = ((reg >> XENON_FC_SYNC_RST_DURATION_SHIFT) &
241                         XENON_FC_SYNC_RST_DURATION_MASK);
242         /* Add interval between FC_SYNC_EN and FC_SYNC_RST */
243         wait += ((reg >> XENON_FC_SYNC_RST_EN_DURATION_SHIFT) &
244                         XENON_FC_SYNC_RST_EN_DURATION_MASK);
245         /* Add duration of asserting FC_SYNC_EN */
246         wait += ((reg >> XENON_FC_SYNC_EN_DURATION_SHIFT) &
247                         XENON_FC_SYNC_EN_DURATION_MASK);
248         /* Add duration of waiting for PHY */
249         wait += ((reg >> XENON_WAIT_CYCLE_BEFORE_USING_SHIFT) &
250                         XENON_WAIT_CYCLE_BEFORE_USING_MASK);
251         /* 4 additional bus clock and 4 AXI bus clock are required */
252         wait += 8;
253         wait <<= 20;
254
255         clock = host->clock;
256         if (!clock)
257                 /* Use the possibly slowest bus frequency value */
258                 clock = XENON_LOWEST_SDCLK_FREQ;
259         /* get the wait time */
260         wait /= clock;
261         wait++;
262         /* wait for host eMMC PHY init completes */
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  * Set SoC PHY voltage PAD control register,
298  * according to the operation voltage on PAD.
299  * The detailed operation depends on SoC implementation.
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  * Enable eMMC PHY HW DLL
317  * DLL should be enabled and stable before HS200/SDR104 tuning,
318  * and before HS400 data strobe setting.
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         /* Enable DLL */
336         reg = sdhci_readl(host, phy_regs->dll_ctrl);
337         reg |= (XENON_DLL_ENABLE | XENON_DLL_FAST_LOCK);
338
339         /*
340          * Set Phase as 90 degree, which is most common value.
341          * Might set another value if necessary.
342          * The granularity is 1 degree.
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         /* Wait max 32 ms */
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  * Config to eMMC PHY to prepare for tuning.
374  * Enable HW DLL and set the TUNING_STEP
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         /* Achieve TUNING_STEP with HW DLL help */
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         /* Set TUNING_STEP for later tuning */
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         /* Disable both SDHC Data Strobe and Enhanced Strobe */
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         /* Clear Strobe line Pull down or Pull up */
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 /* Set HS400 Data Strobe and Enhanced Strobe */
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         /* Enable SDHC Data Strobe */
454         reg = sdhci_readl(host, XENON_SLOT_EMMC_CTRL);
455         reg |= XENON_ENABLE_DATA_STROBE;
456         /*
457          * Enable SDHC Enhanced Strobe if supported
458          * Xenon Enhanced Strobe should be enabled only when
459          * 1. card is in HS400 mode and
460          * 2. SDCLK is higher than 52MHz
461          * 3. DLL is enabled
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         /* Set Data Strobe Pull down */
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  * If eMMC PHY Slow Mode is required in lower speed mode (SDCLK < 55MHz)
483  * in SDR mode, enable Slow Mode to bypass eMMC PHY.
484  * SDIO slower SDR mode also requires Slow Mode.
485  *
486  * If Slow Mode is enabled, return true.
487  * Otherwise, return false.
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         /* When in slower SDR mode, enable Slow Mode for SDIO
504          * or when Slow Mode flag is set
505          */
506         switch (timing) {
507         case MMC_TIMING_LEGACY:
508                 /*
509                  * If Slow Mode is required, enable Slow Mode by default
510                  * in early init phase to avoid any potential issue.
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                 /* fall through */
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  * Set-up eMMC 5.0/5.1 PHY.
542  * Specific configuration depends on the current speed mode in use.
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         /* Setup pad, set bit[28] and bits[26:24] */
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         /* All FC_XX_RECEIVCE should be set as CMOS Type */
560         reg |= XENON_FC_ALL_CMOS_RECEIVER;
561         sdhci_writel(host, reg, phy_regs->pad_ctrl);
562
563         /* Set CMD and DQ Pull Up */
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          * If SDIO card, set SDIO Mode
583          * Otherwise, clear SDIO Mode
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          * Set preferred ZNR and ZPR value
597          * The ZNR and ZPR value vary between different boards.
598          * Define them both in sdhci-xenon-emmc-phy.h.
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          * When setting EMMC_PHY_FUNC_CONTROL register,
607          * SD clock should be disabled
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         /* Enable bus clock */
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                 /* Hardware team recommend a value for HS400 */
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 /* Set SoC PHY Voltage PAD */
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  * Setting PHY when card is working in High Speed Mode.
732  * HS400 set Data Strobe and Enhanced Strobe if it is supported.
733  * HS200/SDR104 set tuning config to prepare for tuning.
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                  * DDR Mode requires driver to scan Sampling Fixed Delay Line,
753                  * to find out a perfect operation sampling point.
754                  * It is hard to implement such a scan in host driver
755                  * since initiating commands by host driver is not safe.
756                  * Thus so far just keep PHY Sampling Fixed Delay in
757                  * default value of DDR mode.
758                  *
759                  * If any timing issue occurs in DDR mode on Marvell products,
760                  * please contact maintainer for internal support in Marvell.
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  * Adjust PHY setting.
771  * PHY setting should be adjusted when SDCLK frequency, Bus Width
772  * or Speed Mode is changed.
773  * Additional config are required when card is working in High Speed mode,
774  * after leaving Legacy Mode.
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          * The timing, frequency or bus width is changed,
789          * better to set eMMC PHY based on current setting
790          * and adjust Xenon SDHC delay.
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         /* Update the record */
800         priv->bus_width = ios->bus_width;
801
802         priv->timing = ios->timing;
803         priv->clock = host->clock;
804
805         /* Legacy mode is a special case */
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 }