]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
mmc: exynos_dw_mmc: Fix getting private data in exynos_dwmci_board_init()
authorSam Protsenko <semen.protsenko@linaro.org>
Thu, 8 Aug 2024 03:14:24 +0000 (22:14 -0500)
committerMinkyu Kang <mk7.kang@samsung.com>
Mon, 19 Aug 2024 07:09:06 +0000 (16:09 +0900)
In case of CONFIG_DM_MMC, host->priv actually holds (struct udevice *),
and not (struct dwmci_exynos_priv_data *). This makes *priv pointer
invalid and may lead to Synchronous Abort during its dereference later
in exynos_dwmci_board_init(). Fix it by extracting
exynos_dwmmc_get_priv() helper from exynos_dwmci_clksel() and using it
for getting the private data in exynos_dwmci_board_init()

Fixes: 3537ee879e04 ("mmc: exynos_dw_mmc: support the Driver mode for Exynos")
Signed-off-by: Sam Protsenko <semen.protsenko@linaro.org>
Signed-off-by: Minkyu Kang <mk7.kang@samsung.com>
drivers/mmc/exynos_dw_mmc.c

index a86d58663c1b6037b459f1e599f5b6488ecc487f..aa542c13fea8ada07910fef97d8cdaac12f6fe94 100644 (file)
@@ -41,18 +41,24 @@ struct dwmci_exynos_priv_data {
        u32 sdr_timing;
 };
 
+static struct dwmci_exynos_priv_data *exynos_dwmmc_get_priv(
+               struct dwmci_host *host)
+{
+#ifdef CONFIG_DM_MMC
+       return container_of(host, struct dwmci_exynos_priv_data, host);
+#else
+       return host->priv;
+#endif
+}
+
 /*
  * Function used as callback function to initialise the
  * CLKSEL register for every mmc channel.
  */
 static int exynos_dwmci_clksel(struct dwmci_host *host)
 {
-#ifdef CONFIG_DM_MMC
-       struct dwmci_exynos_priv_data *priv =
-               container_of(host, struct dwmci_exynos_priv_data, host);
-#else
-       struct dwmci_exynos_priv_data *priv = host->priv;
-#endif
+       struct dwmci_exynos_priv_data *priv = exynos_dwmmc_get_priv(host);
+
        dwmci_writel(host, DWMCI_CLKSEL, priv->sdr_timing);
 
        return 0;
@@ -82,7 +88,7 @@ unsigned int exynos_dwmci_get_clk(struct dwmci_host *host, uint freq)
 
 static void exynos_dwmci_board_init(struct dwmci_host *host)
 {
-       struct dwmci_exynos_priv_data *priv = host->priv;
+       struct dwmci_exynos_priv_data *priv = exynos_dwmmc_get_priv(host);
 
        if (host->quirks & DWMCI_QUIRK_DISABLE_SMU) {
                dwmci_writel(host, EMMCP_MPSBEGIN0, 0);