svn commit: r309756 - in stable/11/sys/arm/allwinner: . clk
Emmanuel Vadot
manu at FreeBSD.org
Fri Dec 9 20:07:02 UTC 2016
Author: manu
Date: Fri Dec 9 20:07:01 2016
New Revision: 309756
URL: https://svnweb.freebsd.org/changeset/base/309756
Log:
MFC r308704-r308705 (jmcneill)
r308704:
Allow the MMC frequency to be set up to 52MHz for MMC high speed timings.
r308705:
On command error, reset only DMA and FIFO engines instead of the entire
controller. Fixes eMMC device detection on OrangePi Plus 2e (and likely
others).
Modified:
stable/11/sys/arm/allwinner/a10_mmc.c
stable/11/sys/arm/allwinner/clk/aw_mmcclk.c
Directory Properties:
stable/11/ (props changed)
Modified: stable/11/sys/arm/allwinner/a10_mmc.c
==============================================================================
--- stable/11/sys/arm/allwinner/a10_mmc.c Fri Dec 9 20:03:49 2016 (r309755)
+++ stable/11/sys/arm/allwinner/a10_mmc.c Fri Dec 9 20:07:01 2016 (r309756)
@@ -58,6 +58,7 @@ __FBSDID("$FreeBSD$");
#define A10_MMC_DMA_SEGS ((MAXPHYS / PAGE_SIZE) + 1)
#define A10_MMC_DMA_MAX_SIZE 0x2000
#define A10_MMC_DMA_FTRGLEVEL 0x20070008
+#define A10_MMC_RESET_RETRY 1000
#define CARD_ID_FREQUENCY 400000
@@ -229,7 +230,7 @@ a10_mmc_attach(device_t dev)
bus_width = 4;
sc->a10_host.f_min = 400000;
- sc->a10_host.f_max = 50000000;
+ sc->a10_host.f_max = 52000000;
sc->a10_host.host_ocr = MMC_OCR_320_330 | MMC_OCR_330_340;
sc->a10_host.mode = mode_sd;
sc->a10_host.caps = MMC_CAP_HSPEED;
@@ -449,11 +450,27 @@ a10_mmc_req_done(struct a10_mmc_softc *s
{
struct mmc_command *cmd;
struct mmc_request *req;
+ uint32_t val, mask;
+ int retry;
cmd = sc->a10_req->cmd;
if (cmd->error != MMC_ERR_NONE) {
- /* Reset the controller. */
- a10_mmc_reset(sc);
+ /* Reset the FIFO and DMA engines. */
+ mask = A10_MMC_CTRL_FIFO_RST | A10_MMC_CTRL_DMA_RST;
+ val = A10_MMC_READ_4(sc, A10_MMC_GCTL);
+ A10_MMC_WRITE_4(sc, A10_MMC_GCTL, val | mask);
+
+ retry = A10_MMC_RESET_RETRY;
+ while (--retry > 0) {
+ val = A10_MMC_READ_4(sc, A10_MMC_GCTL);
+ if ((val & mask) == 0)
+ break;
+ DELAY(10);
+ }
+ if (retry == 0)
+ device_printf(sc->a10_dev,
+ "timeout resetting DMA/FIFO\n");
+ a10_mmc_update_clock(sc, 1);
}
req = sc->a10_req;
Modified: stable/11/sys/arm/allwinner/clk/aw_mmcclk.c
==============================================================================
--- stable/11/sys/arm/allwinner/clk/aw_mmcclk.c Fri Dec 9 20:03:49 2016 (r309755)
+++ stable/11/sys/arm/allwinner/clk/aw_mmcclk.c Fri Dec 9 20:07:01 2016 (r309756)
@@ -185,7 +185,7 @@ aw_mmcclk_set_freq(struct clknode *clk,
ophase = 0;
phase = 5;
n = 2;
- } else if (*fout <= 50000000) {
+ } else if (*fout <= 52000000) {
parent_idx = CLK_SRC_SEL_PLL6;
ophase = 3;
phase = 5;
More information about the svn-src-stable-11
mailing list