On 14 December 2012 16:38, Pawel Moll <pawel.moll@xxxxxxx> wrote: > The Versatile Express IOFPGA as shipped on VECD 5.0 (bitfiles v108/208 > and v116/216) contains a modified version of the PL180 MMCI, with > PeriphID Configuration value changed to 0x2. > > This version adds an optional "hardware flow control" feature. When > enabled MMC card clock will be automatically disabled when FIFO is > about to over/underflow and re-enabled once the host retrieved some > data. This makes the controller immune to over/underrun errors caused > by big interrupt handling latencies. > > This patch adds relevant device variant in the driver. > > Signed-off-by: Pawel Moll <pawel.moll@xxxxxxx> > --- > drivers/mmc/host/mmci.c | 13 +++++++++++++ > drivers/mmc/host/mmci.h | 2 ++ > 2 files changed, 15 insertions(+) > > diff --git a/drivers/mmc/host/mmci.c b/drivers/mmc/host/mmci.c > index edc3e9b..b2b550f 100644 > --- a/drivers/mmc/host/mmci.c > +++ b/drivers/mmc/host/mmci.c > @@ -86,6 +86,14 @@ static struct variant_data variant_arm_extended_fifo = { > .pwrreg_powerup = MCI_PWR_UP, > }; > > +static struct variant_data variant_arm_extended_fifo_hwfc = { > + .fifosize = 128 * 4, > + .fifohalfsize = 64 * 4, > + .clkreg_enable = MCI_ARM_HWFCEN, So enabling this in the variant will also effect how the clock is being set/gated when the clock freq is 0. Please have a look at "mmc: mmci: Gate the clock when freq is 0", a patch I sent out as of 12 dec. That patch is using the power register to gate the clock. Will that work with this new version of the PL180 as well? If not, that patch must be reworked. > + .datalength_bits = 16, > + .pwrreg_powerup = MCI_PWR_UP, > +}; > + > static struct variant_data variant_u300 = { > .fifosize = 16 * 4, > .fifohalfsize = 8 * 4, > @@ -1628,6 +1636,11 @@ static struct amba_id mmci_ids[] = { > .data = &variant_arm_extended_fifo, > }, > { > + .id = 0x02041180, > + .mask = 0xff0fffff, > + .data = &variant_arm_extended_fifo_hwfc, > + }, > + { > .id = 0x00041181, > .mask = 0x000fffff, > .data = &variant_arm, > diff --git a/drivers/mmc/host/mmci.h b/drivers/mmc/host/mmci.h > index d437ccf..00d6d0c 100644 > --- a/drivers/mmc/host/mmci.h > +++ b/drivers/mmc/host/mmci.h > @@ -28,6 +28,8 @@ > #define MCI_ST_UX500_NEG_EDGE (1 << 13) > #define MCI_ST_UX500_HWFCEN (1 << 14) > #define MCI_ST_UX500_CLK_INV (1 << 15) > +/* Modified PL180 on Versatile Express platform */ > +#define MCI_ARM_HWFCEN (1 << 12) > > #define MMCIARGUMENT 0x008 > #define MMCICOMMAND 0x00c > -- > 1.7.10.4 > > > -- > To unsubscribe from this list: send the line "unsubscribe linux-mmc" in > the body of a message to majordomo@xxxxxxxxxxxxxxx > More majordomo info at http://vger.kernel.org/majordomo-info.html Kind regards Ulf Hansson -- To unsubscribe from this list: send the line "unsubscribe linux-mmc" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html