Skip to content

Commit

Permalink
risc-v/mpfs: emmcsd: enforce HS DDR mode
Browse files Browse the repository at this point in the history
Previously, address 0x03b70000u was written with shift bits
that only changed the bit width, not the mode. HS mode is
changed via 0x03B90100, which is required, according to Jedec
specs, for DDR mode. HS mode was not applied before. Enforce
DDR mode (50 MHz) for now.

The real boost, however, comes from removing the DMA limitation
at 0x08xxxxxx address space, which now seems unnecessary.

Signed-off-by: Eero Nurkkala <[email protected]>
  • Loading branch information
eenurkka committed Dec 15, 2023
1 parent 12c4549 commit 71764e1
Showing 1 changed file with 34 additions and 19 deletions.
53 changes: 34 additions & 19 deletions arch/risc-v/src/mpfs/mpfs_emmcsd.c
Original file line number Diff line number Diff line change
Expand Up @@ -1825,8 +1825,15 @@ static void mpfs_set_hs_8bit(struct sdio_dev_s *dev)
struct mpfs_dev_s *priv = (struct mpfs_dev_s *)dev;
int ret;
uint32_t r1;
uint32_t rr;

if ((ret = mpfs_sendcmd(dev, MMCSD_CMD6, 0x03b70000u | (6 << 8))) == OK)
/* mpfs to DDR mode */

modifyreg32(MPFS_EMMCSD_HRS06, 0x7, MPFS_EMMCSD_MODE_DDR);

/* eMMC to HS mode */

if ((ret = mpfs_sendcmd(dev, MMCSD_CMD6, 0x03b90100u)) == OK)
{
if ((ret == mpfs_waitresponse(dev, MMCSD_CMD6)) == OK)
{
Expand All @@ -1840,9 +1847,21 @@ static void mpfs_set_hs_8bit(struct sdio_dev_s *dev)
goto err;
}

modifyreg32(MPFS_EMMCSD_HRS06, 0, priv->bus_mode);
/* While busy */

do
{
rr = getreg32(MPFS_EMMCSD_SRS09);
}
while ((rr & (1 << 20)) == 0);

/* mpfs to 8-bit mode */

if ((ret = mpfs_sendcmd(dev, MMCSD_CMD6, 0x03b70000u | (2 << 8))) == OK)
modifyreg32(MPFS_EMMCSD_SRS10, 0, MPFS_EMMCSD_SRS10_EDTW);

/* eMMC to 8-bit DDR mode */

if ((ret = mpfs_sendcmd(dev, MMCSD_CMD6, 0x03b70600u)) == OK)
{
if ((ret == mpfs_waitresponse(dev, MMCSD_CMD6)) == OK)
{
Expand All @@ -1856,7 +1875,14 @@ static void mpfs_set_hs_8bit(struct sdio_dev_s *dev)
goto err;
}

modifyreg32(MPFS_EMMCSD_SRS10, 0, MPFS_EMMCSD_SRS10_EDTW);
/* While busy */

do
{
rr = getreg32(MPFS_EMMCSD_SRS09);
}
while ((rr & (1 << 20)) == 0);

return;

err:
Expand Down Expand Up @@ -1936,18 +1962,16 @@ static void mpfs_clock(struct sdio_dev_s *dev, enum sdio_clock_e rate)
break;
}

/* Set the new clock frequency */

mpfs_setclkrate(priv, clckr);

/* REVISIT: This should really be a separate configuration procedure */

if (rate == CLOCK_MMC_TRANSFER)
{
/* eMMC: Set 8-bit data bus and correct bus mode */

mpfs_set_hs_8bit(dev);
}

/* Set the new clock frequency */

mpfs_setclkrate(priv, clckr);
}

/****************************************************************************
Expand Down Expand Up @@ -2350,15 +2374,6 @@ static int mpfs_dmasendsetup(struct sdio_dev_s *dev,
return -EFAULT;
}

/* DMA send doesn't work in 0x08xxxxxxx address range. Default to IRQ mode
* in this special case.
*/

if (((uintptr_t)buffer & 0xff000000) == 0x08000000)
{
return mpfs_sendsetup(dev, buffer, buflen);
}

/* Save the source buffer information for use by the interrupt handler */

priv->buffer = (uint32_t *)buffer;
Expand Down

0 comments on commit 71764e1

Please sign in to comment.