summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/dev/fdt/dwmmc.c12
1 files changed, 8 insertions, 4 deletions
diff --git a/sys/dev/fdt/dwmmc.c b/sys/dev/fdt/dwmmc.c
index 6efe48d1580..0f6203c2ff5 100644
--- a/sys/dev/fdt/dwmmc.c
+++ b/sys/dev/fdt/dwmmc.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: dwmmc.c,v 1.16 2018/08/06 10:52:30 patrick Exp $ */
+/* $OpenBSD: dwmmc.c,v 1.17 2018/08/26 14:12:47 kettenis Exp $ */
/*
* Copyright (c) 2017 Mark Kettenis
*
@@ -101,6 +101,7 @@
#define SDMMC_FIFOTH 0x004c
#define SDMMC_FIFOTH_MSIZE_SHIFT 28
#define SDMMC_FIFOTH_RXWM_SHIFT 16
+#define SDMMC_FIFOTH_RXWM(x) (((x) >> 16) & 0xfff)
#define SDMMC_FIFOTH_TXWM_SHIFT 0
#define SDMMC_CDETECT 0x0050
#define SDMMC_CDETECT_CARD_DETECT_0 (1 << 0)
@@ -250,7 +251,9 @@ dwmmc_match(struct device *parent, void *match, void *aux)
{
struct fdt_attach_args *faa = aux;
- return (OF_is_compatible(faa->fa_node, "rockchip,rk3288-dw-mshc") ||
+ return (OF_is_compatible(faa->fa_node, "hisilicon,hi3660-dw-mshc") ||
+ OF_is_compatible(faa->fa_node, "hisilicon,hi3670-dw-mshc") ||
+ OF_is_compatible(faa->fa_node, "rockchip,rk3288-dw-mshc") ||
OF_is_compatible(faa->fa_node, "samsung,exynos5420-dw-mshc"));
}
@@ -262,6 +265,7 @@ dwmmc_attach(struct device *parent, struct device *self, void *aux)
struct sdmmcbus_attach_args saa;
uint32_t freq, div = 0;
uint32_t hcon, width;
+ uint32_t fifoth;
int error, timeout;
if (faa->fa_nreg < 1) {
@@ -307,8 +311,8 @@ dwmmc_attach(struct device *parent, struct device *self, void *aux)
sc->sc_fifo_depth = OF_getpropint(faa->fa_node, "fifo-depth", 0);
if (sc->sc_fifo_depth == 0) {
- printf(": unsupported FIFO depth\n");
- return;
+ fifoth = HREAD4(sc, SDMMC_FIFOTH);
+ sc->sc_fifo_depth = SDMMC_FIFOTH_RXWM(fifoth) + 1;
}
/* Some Rockchip variants pre-divide the clock. */