]> git.ipfire.org Git - thirdparty/u-boot.git/commitdiff
mmc: sdhci: zynq: Added support to read Tap Delay values from DT
authorVipul Kumar <vipul.kumar@xilinx.com>
Mon, 10 Sep 2018 08:59:50 +0000 (14:29 +0530)
committerMichal Simek <michal.simek@xilinx.com>
Mon, 17 Sep 2018 07:15:47 +0000 (09:15 +0200)
This patch added support to read ITAP and OTAP delay values from
he device tree. If the DT does not contain tap delay values, the
predefined values will be used for the same.

Signed-off-by: Vipul Kumar <vipul.kumar@xilinx.com>
Acked-by: Siva Durga Prasad Paladugu <siva.durga.paladugu@xilinx.com>
Signed-off-by: Michal Simek <michal.simek@xilinx.com>
board/xilinx/zynqmp/tap_delays.c
drivers/mmc/zynq_sdhci.c
include/zynqmp_tap_delay.h

index 9c93291503183b9b19a8d3d08c1c48ae658bee0f..7829bedb580e5cbdde3007f0a3ef34daef18214e 100644 (file)
 #define SD1_ITAPDLYENA_MASK            0x01000000
 #define SD1_ITAPDLYENA                 0x01000000
 #define SD0_ITAPDLYSEL_MASK            0x000000FF
-#define SD0_ITAPDLYSEL_HSD             0x00000015
-#define SD0_ITAPDLYSEL_SD_DDR50                0x0000003D
-#define SD0_ITAPDLYSEL_MMC_DDR50       0x00000012
 
 #define SD1_ITAPDLYSEL_MASK            0x00FF0000
-#define SD1_ITAPDLYSEL_HSD             0x00150000
-#define SD1_ITAPDLYSEL_SD_DDR50                0x003D0000
-#define SD1_ITAPDLYSEL_MMC_DDR50       0x00120000
 
 #define SD0_OTAPDLYSEL_MASK            0x0000003F
-#define SD0_OTAPDLYSEL_MMC_HSD         0x00000006
-#define SD0_OTAPDLYSEL_SD_HSD          0x00000005
-#define SD0_OTAPDLYSEL_SDR50           0x00000003
-#define SD0_OTAPDLYSEL_SDR104_B0       0x00000003
-#define SD0_OTAPDLYSEL_SDR104_B2       0x00000002
-#define SD0_OTAPDLYSEL_SD_DDR50                0x00000004
-#define SD0_OTAPDLYSEL_MMC_DDR50       0x00000006
 
 #define SD1_OTAPDLYSEL_MASK            0x003F0000
-#define SD1_OTAPDLYSEL_MMC_HSD         0x00060000
-#define SD1_OTAPDLYSEL_SD_HSD          0x00050000
-#define SD1_OTAPDLYSEL_SDR50           0x00030000
-#define SD1_OTAPDLYSEL_SDR104_B0       0x00030000
-#define SD1_OTAPDLYSEL_SDR104_B2       0x00020000
-#define SD1_OTAPDLYSEL_SD_DDR50                0x00040000
-#define SD1_OTAPDLYSEL_MMC_DDR50       0x00060000
-
-#define MMC_BANK2              0x2
-
-#define MMC_TIMING_UHS_SDR25           1
-#define MMC_TIMING_UHS_SDR50           2
-#define MMC_TIMING_UHS_SDR104          3
-#define MMC_TIMING_UHS_DDR50           4
-#define MMC_TIMING_MMC_HS200           5
-#define MMC_TIMING_SD_HS               6
-#define MMC_TIMING_MMC_DDR52           7
-#define MMC_TIMING_MMC_HS              8
 
 void zynqmp_dll_reset(u8 deviceid)
 {
@@ -82,149 +51,49 @@ void zynqmp_dll_reset(u8 deviceid)
                zynqmp_mmio_write(SD_DLL_CTRL, SD1_DLL_RST_MASK, 0x0);
 }
 
-static void arasan_zynqmp_tap_sdr104(u8 deviceid, u8 timing, u8 bank)
-{
-       if (deviceid == 0) {
-               /* Program OTAP */
-               if (bank == MMC_BANK2)
-                       zynqmp_mmio_write(SD_OTAP_DLY, SD0_OTAPDLYSEL_MASK,
-                                         SD0_OTAPDLYSEL_SDR104_B2);
-               else
-                       zynqmp_mmio_write(SD_OTAP_DLY, SD0_OTAPDLYSEL_MASK,
-                                         SD0_OTAPDLYSEL_SDR104_B0);
-       } else {
-               /* Program OTAP */
-               if (bank == MMC_BANK2)
-                       zynqmp_mmio_write(SD_OTAP_DLY, SD1_OTAPDLYSEL_MASK,
-                                         SD1_OTAPDLYSEL_SDR104_B2);
-               else
-                       zynqmp_mmio_write(SD_OTAP_DLY, SD1_OTAPDLYSEL_MASK,
-                                         SD1_OTAPDLYSEL_SDR104_B0);
-       }
-}
-
-static void arasan_zynqmp_tap_hs(u8 deviceid, u8 timing, u8 bank)
-{
-       if (deviceid == 0) {
-               /* Program ITAP */
-               zynqmp_mmio_write(SD_ITAP_DLY, SD0_ITAPCHGWIN_MASK,
-                                 SD0_ITAPCHGWIN);
-               zynqmp_mmio_write(SD_ITAP_DLY, SD0_ITAPDLYENA_MASK,
-                                 SD0_ITAPDLYENA);
-               zynqmp_mmio_write(SD_ITAP_DLY, SD0_ITAPDLYSEL_MASK,
-                                 SD0_ITAPDLYSEL_HSD);
-               zynqmp_mmio_write(SD_ITAP_DLY, SD0_ITAPCHGWIN_MASK, 0x0);
-               /* Program OTAP */
-               if (timing == MMC_TIMING_MMC_HS)
-                       zynqmp_mmio_write(SD_OTAP_DLY, SD0_OTAPDLYSEL_MASK,
-                                         SD0_OTAPDLYSEL_MMC_HSD);
-               else
-                       zynqmp_mmio_write(SD_OTAP_DLY, SD0_OTAPDLYSEL_MASK,
-                                         SD0_OTAPDLYSEL_SD_HSD);
-       } else {
-               /* Program ITAP */
-               zynqmp_mmio_write(SD_ITAP_DLY, SD1_ITAPCHGWIN_MASK,
-                                 SD1_ITAPCHGWIN);
-               zynqmp_mmio_write(SD_ITAP_DLY, SD1_ITAPDLYENA_MASK,
-                                 SD1_ITAPDLYENA);
-               zynqmp_mmio_write(SD_ITAP_DLY, SD1_ITAPDLYSEL_MASK,
-                                 SD1_ITAPDLYSEL_HSD);
-               zynqmp_mmio_write(SD_ITAP_DLY, SD1_ITAPCHGWIN_MASK, 0x0);
-               /* Program OTAP */
-               if (timing == MMC_TIMING_MMC_HS)
-                       zynqmp_mmio_write(SD_OTAP_DLY, SD1_OTAPDLYSEL_MASK,
-                                         SD1_OTAPDLYSEL_MMC_HSD);
-               else
-                       zynqmp_mmio_write(SD_OTAP_DLY, SD1_OTAPDLYSEL_MASK,
-                                         SD1_OTAPDLYSEL_SD_HSD);
-       }
-}
-
-static void arasan_zynqmp_tap_ddr50(u8 deviceid, u8 timing, u8 bank)
+void arasan_zynqmp_set_tapdelay(u8 deviceid, u32 itap_delay, u32 otap_delay)
 {
        if (deviceid == 0) {
+               zynqmp_mmio_write(SD_DLL_CTRL, SD0_DLL_RST_MASK,
+                                 SD0_DLL_RST);
                /* Program ITAP */
-               zynqmp_mmio_write(SD_ITAP_DLY, SD0_ITAPCHGWIN_MASK,
-                                 SD0_ITAPCHGWIN);
-               zynqmp_mmio_write(SD_ITAP_DLY, SD0_ITAPDLYENA_MASK,
-                                 SD0_ITAPDLYENA);
-               if (timing == MMC_TIMING_UHS_DDR50)
+               if (itap_delay) {
+                       zynqmp_mmio_write(SD_ITAP_DLY, SD0_ITAPCHGWIN_MASK,
+                                         SD0_ITAPCHGWIN);
+                       zynqmp_mmio_write(SD_ITAP_DLY, SD0_ITAPDLYENA_MASK,
+                                         SD0_ITAPDLYENA);
                        zynqmp_mmio_write(SD_ITAP_DLY, SD0_ITAPDLYSEL_MASK,
-                                         SD0_ITAPDLYSEL_SD_DDR50);
-               else
-                       zynqmp_mmio_write(SD_ITAP_DLY, SD0_ITAPDLYSEL_MASK,
-                                         SD0_ITAPDLYSEL_MMC_DDR50);
-               zynqmp_mmio_write(SD_ITAP_DLY, SD0_ITAPCHGWIN_MASK, 0x0);
+                                         itap_delay);
+                       zynqmp_mmio_write(SD_ITAP_DLY, SD0_ITAPCHGWIN_MASK,
+                                         0x0);
+               }
+
                /* Program OTAP */
-               if (timing == MMC_TIMING_UHS_DDR50)
+               if (otap_delay)
                        zynqmp_mmio_write(SD_OTAP_DLY, SD0_OTAPDLYSEL_MASK,
-                                         SD0_OTAPDLYSEL_SD_DDR50);
-               else
-                       zynqmp_mmio_write(SD_OTAP_DLY, SD0_OTAPDLYSEL_MASK,
-                                         SD0_OTAPDLYSEL_MMC_DDR50);
-       } else {
-               /* Program ITAP */
-               zynqmp_mmio_write(SD_ITAP_DLY, SD1_ITAPCHGWIN_MASK,
-                                 SD1_ITAPCHGWIN);
-               zynqmp_mmio_write(SD_ITAP_DLY, SD1_ITAPDLYENA_MASK,
-                                 SD1_ITAPDLYENA);
-               if (timing == MMC_TIMING_UHS_DDR50)
-                       zynqmp_mmio_write(SD_ITAP_DLY, SD1_ITAPDLYSEL_MASK,
-                                         SD1_ITAPDLYSEL_SD_DDR50);
-               else
-                       zynqmp_mmio_write(SD_ITAP_DLY, SD1_ITAPDLYSEL_MASK,
-                                         SD1_ITAPDLYSEL_MMC_DDR50);
-               zynqmp_mmio_write(SD_ITAP_DLY, SD1_ITAPCHGWIN_MASK, 0x0);
-               /* Program OTAP */
-               if (timing == MMC_TIMING_UHS_DDR50)
-                       zynqmp_mmio_write(SD_OTAP_DLY, SD1_OTAPDLYSEL_MASK,
-                                         SD1_OTAPDLYSEL_SD_DDR50);
-               else
-                       zynqmp_mmio_write(SD_OTAP_DLY, SD1_OTAPDLYSEL_MASK,
-                                         SD1_OTAPDLYSEL_MMC_DDR50);
-       }
-}
+                                         otap_delay);
 
-static void arasan_zynqmp_tap_sdr50(u8 deviceid, u8 timing, u8 bank)
-{
-       if (deviceid == 0) {
-               /* Program OTAP */
-               zynqmp_mmio_write(SD_OTAP_DLY, SD0_OTAPDLYSEL_MASK,
-                                 SD0_OTAPDLYSEL_SDR50);
+               zynqmp_mmio_write(SD_DLL_CTRL, SD0_DLL_RST_MASK, 0x0);
        } else {
-               /* Program OTAP */
-               zynqmp_mmio_write(SD_OTAP_DLY, SD1_OTAPDLYSEL_MASK,
-                                 SD1_OTAPDLYSEL_SDR50);
-       }
-}
-
-void arasan_zynqmp_set_tapdelay(u8 deviceid, u8 timing, u8 bank)
-{
-       if (deviceid == 0)
-               zynqmp_mmio_write(SD_DLL_CTRL, SD0_DLL_RST_MASK,
-                                 SD0_DLL_RST);
-       else
                zynqmp_mmio_write(SD_DLL_CTRL, SD1_DLL_RST_MASK,
                                  SD1_DLL_RST);
+               /* Program ITAP */
+               if (itap_delay) {
+                       zynqmp_mmio_write(SD_ITAP_DLY, SD1_ITAPCHGWIN_MASK,
+                                         SD1_ITAPCHGWIN);
+                       zynqmp_mmio_write(SD_ITAP_DLY, SD1_ITAPDLYENA_MASK,
+                                         SD1_ITAPDLYENA);
+                       zynqmp_mmio_write(SD_ITAP_DLY, SD1_ITAPDLYSEL_MASK,
+                                         (itap_delay << 16));
+                       zynqmp_mmio_write(SD_ITAP_DLY, SD1_ITAPCHGWIN_MASK,
+                                         0x0);
+               }
 
-       switch (timing) {
-       case MMC_TIMING_UHS_SDR25:
-               arasan_zynqmp_tap_hs(deviceid, timing, bank);
-               break;
-       case MMC_TIMING_UHS_SDR50:
-               arasan_zynqmp_tap_sdr50(deviceid, timing, bank);
-               break;
-       case MMC_TIMING_UHS_SDR104:
-       case MMC_TIMING_MMC_HS200:
-               arasan_zynqmp_tap_sdr104(deviceid, timing, bank);
-               break;
-       case MMC_TIMING_UHS_DDR50:
-               arasan_zynqmp_tap_ddr50(deviceid, timing, bank);
-               break;
-       }
+               /* Program OTAP */
+               if (otap_delay)
+                       zynqmp_mmio_write(SD_OTAP_DLY, SD1_OTAPDLYSEL_MASK,
+                                         (otap_delay << 16));
 
-       if (deviceid == 0)
-               zynqmp_mmio_write(SD_DLL_CTRL, SD0_DLL_RST_MASK, 0x0);
-       else
                zynqmp_mmio_write(SD_DLL_CTRL, SD1_DLL_RST_MASK, 0x0);
+       }
 }
index 5a6765ad884228db811fe427a0724c82eb8b26e6..99bdaded378f32f0bf9d786a639f89cd1d224bc5 100644 (file)
@@ -26,6 +26,33 @@ DECLARE_GLOBAL_DATA_PTR;
 # define CONFIG_ZYNQ_SDHCI_MIN_FREQ    0
 #endif
 
+#define SDHCI_ITAPDLYSEL_SD_HSD                0x00000015
+#define SDHCI_ITAPDLYSEL_SDR25         0x00000015
+#define SDHCI_ITAPDLYSEL_SDR50         0x00000000
+#define SDHCI_ITAPDLYSEL_SDR104_B2     0x00000000
+#define SDHCI_ITAPDLYSEL_SDR104_B0     0x00000000
+#define SDHCI_ITAPDLYSEL_MMC_HSD       0x00000015
+#define SDHCI_ITAPDLYSEL_SD_DDR50      0x0000003D
+#define SDHCI_ITAPDLYSEL_MMC_DDR52     0x00000012
+#define SDHCI_ITAPDLYSEL_MMC_HS200_B2  0x00000000
+#define SDHCI_ITAPDLYSEL_MMC_HS200_B0  0x00000000
+#define SDHCI_OTAPDLYSEL_SD_HSD                0x00000005
+#define SDHCI_OTAPDLYSEL_SDR25         0x00000005
+#define SDHCI_OTAPDLYSEL_SDR50         0x00000003
+#define SDHCI_OTAPDLYSEL_SDR104_B0     0x00000003
+#define SDHCI_OTAPDLYSEL_SDR104_B2     0x00000002
+#define SDHCI_OTAPDLYSEL_MMC_HSD       0x00000006
+#define SDHCI_OTAPDLYSEL_SD_DDR50      0x00000004
+#define SDHCI_OTAPDLYSEL_MMC_DDR52     0x00000006
+#define SDHCI_OTAPDLYSEL_MMC_HS200_B0  0x00000003
+#define SDHCI_OTAPDLYSEL_MMC_HS200_B2  0x00000002
+
+#define MMC_BANK2                      0x2
+#define SD_HS_BUS_SPEED                        6
+#define MMC_DDR52_BUS_SPEED            7
+#define MMC_HS_BUS_SPEED               8
+#define MMC_MAX_BUS_SPEED              9
+
 struct arasan_sdhci_plat {
        struct mmc_config cfg;
        struct mmc mmc;
@@ -34,6 +61,8 @@ struct arasan_sdhci_plat {
 
 struct arasan_sdhci_priv {
        struct sdhci_host *host;
+       u32 itapdly[MMC_MAX_BUS_SPEED];
+       u32 otapdly[MMC_MAX_BUS_SPEED];
        u8 deviceid;
        u8 bank;
        u8 no_1p8;
@@ -153,6 +182,8 @@ static void arasan_sdhci_set_tapdelay(struct sdhci_host *host)
        struct arasan_sdhci_priv *priv = dev_get_priv(host->mmc->dev);
        struct mmc *mmc = (struct mmc *)host->mmc;
        u8 uhsmode;
+       u32 itap_delay;
+       u32 otap_delay;
 
        if (mmc->is_uhs)
                uhsmode = mmc->uhsmode;
@@ -166,9 +197,183 @@ static void arasan_sdhci_set_tapdelay(struct sdhci_host *host)
        debug("%s, host:%s devId:%d, bank:%d, mode:%d\n", __func__, host->name,
              priv->deviceid, priv->bank, uhsmode);
        if ((uhsmode >= MMC_TIMING_UHS_SDR25) &&
-           (uhsmode <= MMC_TIMING_HS200))
-               arasan_zynqmp_set_tapdelay(priv->deviceid, uhsmode,
-                                          priv->bank);
+           (uhsmode <= MMC_TIMING_HS200)) {
+               itap_delay = priv->itapdly[uhsmode];
+               otap_delay = priv->otapdly[uhsmode];
+               arasan_zynqmp_set_tapdelay(priv->deviceid, itap_delay,
+                                          otap_delay);
+       }
+}
+
+/**
+ * arasan_zynqmp_dt_parse_tap_delays - Read Tap Delay values from DT
+ *
+ * Called at initialization to parse the values of Tap Delays.
+ *
+ * @dev:                Pointer to our struct udevice.
+ */
+static void arasan_zynqmp_dt_parse_tap_delays(struct udevice *dev)
+{
+       struct arasan_sdhci_priv *priv = dev_get_priv(dev);
+       u32 *itapdly = priv->itapdly;
+       u32 *otapdly = priv->otapdly;
+       int ret;
+
+       /*
+        * Read Tap Delay values from DT, if the DT does not contain the
+        * Tap Values then use the pre-defined values
+        */
+       ret = dev_read_u32(dev, "xlnx,itap-delay-sd-hsd",
+                          &itapdly[SD_HS_BUS_SPEED]);
+       if (ret) {
+               dev_dbg(dev,
+                       "Using predefined itapdly for SD_HS_BUS_SPEED\n");
+               itapdly[SD_HS_BUS_SPEED] = SDHCI_ITAPDLYSEL_SD_HSD;
+       }
+
+       ret = dev_read_u32(dev, "xlnx,otap-delay-sd-hsd",
+                          &otapdly[SD_HS_BUS_SPEED]);
+       if (ret) {
+               dev_dbg(dev,
+                       "Using predefined otapdly for SD_HS_BUS_SPEED\n");
+               otapdly[SD_HS_BUS_SPEED] = SDHCI_OTAPDLYSEL_SD_HSD;
+       }
+
+       ret = dev_read_u32(dev, "xlnx,itap-delay-sdr25",
+                          &itapdly[MMC_TIMING_UHS_SDR25]);
+       if (ret) {
+               dev_dbg(dev,
+                       "Using predefined itapdly for MMC_TIMING_UHS_SDR25\n");
+               itapdly[MMC_TIMING_UHS_SDR25] = SDHCI_ITAPDLYSEL_SDR25;
+       }
+
+       ret = dev_read_u32(dev, "xlnx,otap-delay-sdr25",
+                          &otapdly[MMC_TIMING_UHS_SDR25]);
+       if (ret) {
+               dev_dbg(dev,
+                       "Using predefined otapdly for MMC_TIMING_UHS_SDR25\n");
+               otapdly[MMC_TIMING_UHS_SDR25] = SDHCI_OTAPDLYSEL_SDR25;
+       }
+
+       ret = dev_read_u32(dev, "xlnx,itap-delay-sdr50",
+                          &itapdly[MMC_TIMING_UHS_SDR50]);
+       if (ret) {
+               dev_dbg(dev,
+                       "Using predefined itapdly for MMC_TIMING_UHS_SDR50\n");
+               itapdly[MMC_TIMING_UHS_SDR50] = SDHCI_ITAPDLYSEL_SDR50;
+       }
+
+       ret = dev_read_u32(dev, "xlnx,otap-delay-sdr50",
+                          &otapdly[MMC_TIMING_UHS_SDR50]);
+       if (ret) {
+               dev_dbg(dev,
+                       "Using predefined otapdly for MMC_TIMING_UHS_SDR50\n");
+               otapdly[MMC_TIMING_UHS_SDR50] = SDHCI_OTAPDLYSEL_SDR50;
+       }
+
+       ret = dev_read_u32(dev, "xlnx,itap-delay-sd-ddr50",
+                          &itapdly[MMC_TIMING_UHS_DDR50]);
+       if (ret) {
+               dev_dbg(dev,
+                       "Using predefined itapdly for MMC_TIMING_UHS_DDR50\n");
+               itapdly[MMC_TIMING_UHS_DDR50] = SDHCI_ITAPDLYSEL_SD_DDR50;
+       }
+
+       ret = dev_read_u32(dev, "xlnx,otap-delay-sd-ddr50",
+                          &otapdly[MMC_TIMING_UHS_DDR50]);
+       if (ret) {
+               dev_dbg(dev,
+                       "Using predefined otapdly for MMC_TIMING_UHS_DDR50\n");
+               otapdly[MMC_TIMING_UHS_DDR50] = SDHCI_OTAPDLYSEL_SD_DDR50;
+       }
+
+       ret = dev_read_u32(dev, "xlnx,itap-delay-mmc-hsd",
+                          &itapdly[MMC_HS_BUS_SPEED]);
+       if (ret) {
+               dev_dbg(dev,
+                       "Using predefined itapdly for MMC_HS_BUS_SPEED\n");
+               itapdly[MMC_HS_BUS_SPEED] = SDHCI_ITAPDLYSEL_MMC_HSD;
+       }
+
+       ret = dev_read_u32(dev, "xlnx,otap-delay-mmc-hsd",
+                          &otapdly[MMC_HS_BUS_SPEED]);
+       if (ret) {
+               dev_dbg(dev,
+                       "Using predefined otapdly for MMC_HS_BUS_SPEED\n");
+               otapdly[MMC_HS_BUS_SPEED] = SDHCI_OTAPDLYSEL_MMC_HSD;
+       }
+
+       ret = dev_read_u32(dev, "xlnx,itap-delay-mmc-ddr52",
+                          &itapdly[MMC_DDR52_BUS_SPEED]);
+       if (ret) {
+               dev_dbg(dev,
+                       "Using predefined itapdly for MMC_DDR52_BUS_SPEED\n");
+               itapdly[MMC_DDR52_BUS_SPEED] = SDHCI_ITAPDLYSEL_MMC_DDR52;
+       }
+
+       ret = dev_read_u32(dev, "xlnx,otap-delay-mmc-ddr52",
+                          &otapdly[MMC_DDR52_BUS_SPEED]);
+       if (ret) {
+               dev_dbg(dev,
+                       "Using predefined otapdly for MMC_DDR52_BUS_SPEED\n");
+               otapdly[MMC_DDR52_BUS_SPEED] = SDHCI_OTAPDLYSEL_MMC_DDR52;
+       }
+
+       ret = dev_read_u32(dev, "xlnx,itap-delay-sdr104",
+                          &itapdly[MMC_TIMING_UHS_SDR104]);
+       if (ret) {
+               dev_dbg(dev,
+                       "Using predefined itapdly for MMC_TIMING_UHS_SDR104\n");
+               if (priv->bank == MMC_BANK2) {
+                       itapdly[MMC_TIMING_UHS_SDR104] =
+                               SDHCI_ITAPDLYSEL_SDR104_B2;
+               } else {
+                       itapdly[MMC_TIMING_UHS_SDR104] =
+                               SDHCI_ITAPDLYSEL_SDR104_B0;
+               }
+       }
+
+       ret = dev_read_u32(dev, "xlnx,otap-delay-sdr104",
+                          &otapdly[MMC_TIMING_UHS_SDR104]);
+       if (ret) {
+               dev_dbg(dev,
+                       "Using predefined otapdly for MMC_TIMING_UHS_SDR104\n");
+               if (priv->bank == MMC_BANK2) {
+                       otapdly[MMC_TIMING_UHS_SDR104] =
+                               SDHCI_OTAPDLYSEL_SDR104_B2;
+               } else {
+                       otapdly[MMC_TIMING_UHS_SDR104] =
+                               SDHCI_OTAPDLYSEL_SDR104_B0;
+               }
+       }
+
+       ret = dev_read_u32(dev, "xlnx,itap-delay-mmc-hs200",
+                          &itapdly[MMC_TIMING_HS200]);
+       if (ret) {
+               dev_dbg(dev,
+                       "Using predefined itapdly for MMC_TIMING_HS200\n");
+               if (priv->bank == MMC_BANK2) {
+                       itapdly[MMC_TIMING_HS200] =
+                               SDHCI_ITAPDLYSEL_MMC_HS200_B2;
+               } else {
+                       itapdly[MMC_TIMING_HS200] =
+                               SDHCI_ITAPDLYSEL_MMC_HS200_B0;
+               }
+       }
+
+       ret = dev_read_u32(dev, "xlnx,otap-delay-mmc-hs200",
+                          &otapdly[MMC_TIMING_HS200]);
+       if (ret) {
+               dev_dbg(dev,
+                       "Using predefined otapdly for MMC_TIMING_HS200\n");
+               if (priv->bank == MMC_BANK2) {
+                       otapdly[MMC_TIMING_HS200] =
+                               SDHCI_OTAPDLYSEL_MMC_HS200_B2;
+               } else {
+                       otapdly[MMC_TIMING_HS200] =
+                               SDHCI_OTAPDLYSEL_MMC_HS200_B0;
+               }
+       }
 }
 #endif
 
@@ -226,6 +431,7 @@ static int arasan_sdhci_probe(struct udevice *dev)
        upriv->mmc = host->mmc;
 
 #if defined(CONFIG_ARCH_ZYNQMP)
+       arasan_zynqmp_dt_parse_tap_delays(dev);
        host->set_delay = arasan_sdhci_set_tapdelay;
        host->platform_execute_tuning = arasan_sdhci_execute_tuning;
 #endif
index 14cff9d489db1b28f77c0360d368334c1897dbdc..656ce3dbf16adaf365b48f7294681a6cb2cc15c8 100644 (file)
 
 #ifdef CONFIG_ARCH_ZYNQMP
 void zynqmp_dll_reset(u8 deviceid);
-void arasan_zynqmp_set_tapdelay(u8 device_id, u8 uhsmode, u8 bank);
+void arasan_zynqmp_set_tapdelay(u8 device_id, u32 itap_delay, u32 otap_delay);
 #else
 inline void zynqmp_dll_reset(u8 deviceid) {}
-inline void arasan_zynqmp_set_tapdelay(u8 device_id, u8 uhsmode, u8 bank) {}
+inline void arasan_zynqmp_set_tapdelay(u8 device_id, u32 itap_delay,
+                                      u32 otap_delay) {}
 #endif
 
 #endif