On Sun, Mar 7, 2010 at 2:59 PM, Ben Dooks <ben@xxxxxxxxx> wrote: > On Sun, Mar 07, 2010 at 09:47:58AM -0800, Cory Maccarrone wrote: >> From: Marek Belisko <marek.belisko@xxxxxxxxxxxxxxx> >> >> The omap850 and omap730 use 16-bit registers instead of 32-bit, requiring >> a modification of the register addresses in the mmc-omap driver. To resolve >> this, a bit shift is performed on base register addresses, either by 1 or 2 >> bits depending on the CPU in use. This yields the correct registers for >> each CPU. > > merged the previous one into my tree earlier today. > >> Signed-off-by: Marek Belisko <marek.belisko@xxxxxxxxxxxxxxx> >> Signed-off-by: Cory Maccarrone <darkstar6262@xxxxxxxxx> >> Signed-off-by: Tony Lindgren <tony@xxxxxxxxxxx> >> --- >> drivers/mmc/host/omap.c | 62 +++++++++++++++++++++++++---------------------- >> 1 files changed, 33 insertions(+), 29 deletions(-) >> >> This is a resubmit of a patch I sent in several months ago. Tony Lindgren merged >> this into linux-omap's master and testing branches but has stated that he will not >> merge it further as linux-mmc needs to approve this. There hasn't been any comments >> raised on either of the linux-omap or linux-mmc mailing lists about problems. Due to >> the unique nature of the omap7xx platform, this patch is required for MMC card access. >> Is there any chance this can be included into the next -rc cycle, as it is a fix for >> devices that have 16-bit registers? >> >> diff --git a/drivers/mmc/host/omap.c b/drivers/mmc/host/omap.c >> index c6d7e8e..53362c4 100644 >> --- a/drivers/mmc/host/omap.c >> +++ b/drivers/mmc/host/omap.c >> @@ -38,30 +38,30 @@ >> #include <plat/fpga.h> >> >> #define OMAP_MMC_REG_CMD 0x00 >> -#define OMAP_MMC_REG_ARGL 0x04 >> -#define OMAP_MMC_REG_ARGH 0x08 >> -#define OMAP_MMC_REG_CON 0x0c >> -#define OMAP_MMC_REG_STAT 0x10 >> -#define OMAP_MMC_REG_IE 0x14 >> -#define OMAP_MMC_REG_CTO 0x18 >> -#define OMAP_MMC_REG_DTO 0x1c >> -#define OMAP_MMC_REG_DATA 0x20 >> -#define OMAP_MMC_REG_BLEN 0x24 >> -#define OMAP_MMC_REG_NBLK 0x28 >> -#define OMAP_MMC_REG_BUF 0x2c >> -#define OMAP_MMC_REG_SDIO 0x34 >> -#define OMAP_MMC_REG_REV 0x3c >> -#define OMAP_MMC_REG_RSP0 0x40 >> -#define OMAP_MMC_REG_RSP1 0x44 >> -#define OMAP_MMC_REG_RSP2 0x48 >> -#define OMAP_MMC_REG_RSP3 0x4c >> -#define OMAP_MMC_REG_RSP4 0x50 >> -#define OMAP_MMC_REG_RSP5 0x54 >> -#define OMAP_MMC_REG_RSP6 0x58 >> -#define OMAP_MMC_REG_RSP7 0x5c >> -#define OMAP_MMC_REG_IOSR 0x60 >> -#define OMAP_MMC_REG_SYSC 0x64 >> -#define OMAP_MMC_REG_SYSS 0x68 >> +#define OMAP_MMC_REG_ARGL 0x01 >> +#define OMAP_MMC_REG_ARGH 0x02 >> +#define OMAP_MMC_REG_CON 0x03 >> +#define OMAP_MMC_REG_STAT 0x04 >> +#define OMAP_MMC_REG_IE 0x05 >> +#define OMAP_MMC_REG_CTO 0x06 >> +#define OMAP_MMC_REG_DTO 0x07 >> +#define OMAP_MMC_REG_DATA 0x08 >> +#define OMAP_MMC_REG_BLEN 0x09 >> +#define OMAP_MMC_REG_NBLK 0x0a >> +#define OMAP_MMC_REG_BUF 0x0b >> +#define OMAP_MMC_REG_SDIO 0x0d >> +#define OMAP_MMC_REG_REV 0x0f >> +#define OMAP_MMC_REG_RSP0 0x10 >> +#define OMAP_MMC_REG_RSP1 0x11 >> +#define OMAP_MMC_REG_RSP2 0x12 >> +#define OMAP_MMC_REG_RSP3 0x13 >> +#define OMAP_MMC_REG_RSP4 0x14 >> +#define OMAP_MMC_REG_RSP5 0x15 >> +#define OMAP_MMC_REG_RSP6 0x16 >> +#define OMAP_MMC_REG_RSP7 0x17 >> +#define OMAP_MMC_REG_IOSR 0x18 >> +#define OMAP_MMC_REG_SYSC 0x19 >> +#define OMAP_MMC_REG_SYSS 0x1a >> >> #define OMAP_MMC_STAT_CARD_ERR (1 << 14) >> #define OMAP_MMC_STAT_CARD_IRQ (1 << 13) >> @@ -77,8 +77,9 @@ >> #define OMAP_MMC_STAT_CARD_BUSY (1 << 2) >> #define OMAP_MMC_STAT_END_OF_CMD (1 << 0) >> >> -#define OMAP_MMC_READ(host, reg) __raw_readw((host)->virt_base + OMAP_MMC_REG_##reg) >> -#define OMAP_MMC_WRITE(host, reg, val) __raw_writew((val), (host)->virt_base + OMAP_MMC_REG_##reg) >> +#define OMAP_MMC_REG(host, reg) (OMAP_MMC_REG_##reg << (host)->reg_shift) >> +#define OMAP_MMC_READ(host, reg) __raw_readw((host)->virt_base + OMAP_MMC_REG(host, reg)) >> +#define OMAP_MMC_WRITE(host, reg, val) __raw_writew((val), (host)->virt_base + OMAP_MMC_REG(host, reg)) >> >> /* >> * Command types >> @@ -132,6 +133,7 @@ struct mmc_omap_host { >> int irq; >> unsigned char bus_mode; >> unsigned char hw_bus_mode; >> + unsigned int reg_shift; >> >> struct work_struct cmd_abort_work; >> unsigned abort:1; >> @@ -679,9 +681,9 @@ mmc_omap_xfer_data(struct mmc_omap_host *host, int write) >> host->data->bytes_xfered += n; >> >> if (write) { >> - __raw_writesw(host->virt_base + OMAP_MMC_REG_DATA, host->buffer, n); >> + __raw_writesw(host->virt_base + OMAP_MMC_REG(host, DATA), host->buffer, n); >> } else { >> - __raw_readsw(host->virt_base + OMAP_MMC_REG_DATA, host->buffer, n); >> + __raw_readsw(host->virt_base + OMAP_MMC_REG(host, DATA), host->buffer, n); >> } >> } >> >> @@ -899,7 +901,7 @@ mmc_omap_prepare_dma(struct mmc_omap_host *host, struct mmc_data *data) >> int dst_port = 0; >> int sync_dev = 0; >> >> - data_addr = host->phys_base + OMAP_MMC_REG_DATA; >> + data_addr = host->phys_base + OMAP_MMC_REG(host, DATA); >> frame = data->blksz; >> count = sg_dma_len(sg); >> >> @@ -1492,6 +1494,8 @@ static int __init mmc_omap_probe(struct platform_device *pdev) >> } >> } >> >> + host->reg_shift = (cpu_is_omap7xx() ? 1 : 2); >> + >> return 0; >> >> err_plat_cleanup: >> -- >> 1.6.3.3 >> >> -- >> 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 > > -- > -- > Ben > > Q: What's a light-year? > A: One-third less calories than a regular year. > > Which branch? I can find the I2C patch, but not this mmc patch. Thanks - Cory -- 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