> -----Original Message----- > From: kishore kadiyala [mailto:kishorek.kadiyala@xxxxxxxxx] > Sent: Thursday, September 03, 2009 11:04 AM > To: Madhusudhan > Cc: kishore kadiyala; linux-kernel@xxxxxxxxxxxxxxx; linux- > omap@xxxxxxxxxxxxxxx; jarkko.lavinen@xxxxxxxxx > Subject: Re: [PATCH] OMAP4: MMC driver support on OMAP4 > > On Wed, Sep 2, 2009 at 10:00 PM, Madhusudhan <madhu.cr@xxxxxx> wrote: > > > > > > > -----Original Message----- > > > From: kishore kadiyala [mailto:kishore.kadiyala@xxxxxx] > > > Sent: Wednesday, September 02, 2009 8:30 AM > > > To: linux-kernel@xxxxxxxxxxxxxxx > > > Cc: linux-omap@xxxxxxxxxxxxxxx; jarkko.lavinen@xxxxxxxxx; > madhu.cr@xxxxxx > > > Subject: Re: [PATCH] OMAP4: MMC driver support on OMAP4 > > > > > > Resending the patch, CC'ing LO. > > > > > > --Kishore > > > > > > This Patch adds basic support for all 5 MMC controllers on OMAP4. > > > > > > Signed-off-by: Kishore Kadiyala <kishore.kadiyala@xxxxxx> > > > --- > > > This patch doesn't include mmc-regulator support > > > > What is the specific reason? How are MMC4 and MMC5 powered up then? > > Does MMC1 and MMC2 work with mmctwl4030 wrapper? > > OMAP4 uses twl6030 instead of twl4030 and the MMC1 & MMC2 doesn't > work as it is with the mmc-twl4030 . I will be sending a Patch for mmc- > regulator > which will have dependency on regulator patches from Rajendra Nayak. Which of the OMAP4 controllers become useable with this patch? I guess you might be supporting only one-bit bus width with this patch. It would be good if your patch header describes what is supported with this patch. Please CC linux-mmc@xxxxxxxxxxxxxxxx > > > > > > > > arch/arm/mach-omap2/devices.c | 42 > > > +++++++++++++++++++++++++++++---- > > > arch/arm/plat-omap/include/mach/irqs.h | 2 + > > > arch/arm/plat-omap/include/mach/mmc.h | 9 ++++++- > > > drivers/mmc/host/Kconfig | 6 ++-- > > > drivers/mmc/host/omap_hsmmc.c | 10 +++++++ > > > 5 files changed, 60 insertions(+), 9 deletions(-) > > > > > > Index: kernel-omap4-base/arch/arm/mach-omap2/devices.c > > > =================================================================== > > > --- kernel-omap4-base.orig/arch/arm/mach-omap2/devices.c > > > +++ kernel-omap4-base/arch/arm/mach-omap2/devices.c > > > @@ -397,7 +397,7 @@ static inline void omap_init_sha1_md5(vo > > > > > > /*------------------------------------------------------------------- > ---- > > > --*/ > > > > > > -#ifdef CONFIG_ARCH_OMAP3 > > > +#if defined(CONFIG_ARCH_OMAP3) || defined(CONFIG_ARCH_OMAP4) > > > > > > #define MMCHS_SYSCONFIG 0x0010 > > > #define MMCHS_SYSCONFIG_SWRESET (1 << 1) > > > @@ -424,8 +424,8 @@ static struct platform_device dummy_pdev > > > **/ > > > static void __init omap_hsmmc_reset(void) > > > { > > > - u32 i, nr_controllers = cpu_is_omap34xx() ? OMAP34XX_NR_MMC : > > > - OMAP24XX_NR_MMC; > > > + u32 i, nr_controllers = cpu_is_omap44xx() ? OMAP44XX_NR_MMC : > > > + (cpu_is_omap34xx() ? OMAP34XX_NR_MMC : OMAP24XX_NR_MMC); > > > > > > for (i = 0; i < nr_controllers; i++) { > > > u32 v, base = 0; > > > @@ -442,8 +442,21 @@ static void __init omap_hsmmc_reset(void > > > case 2: > > > base = OMAP3_MMC3_BASE; > > > break; > > > + case 3: > > > + if (!cpu_is_omap44xx()) > > > + return; > > > + base = OMAP4_MMC4_BASE; > > > + break; > > > + case 4: > > > + if (!cpu_is_omap44xx()) > > > + return; > > > + base = OMAP4_MMC5_BASE; > > > + break; > > > } > > > > > > + if (cpu_is_omap44xx()) > > > + base += OMAP4_MMC_REG_OFFSET; > > > + > > > dummy_pdev.id = i; > > > dev_set_name(&dummy_pdev.dev, "mmci-omap-hs.%d", i); > > > iclk = clk_get(dev, "ick"); > > > @@ -540,11 +553,23 @@ void __init omap2_init_mmc(struct omap_m > > > irq = INT_24XX_MMC2_IRQ; > > > break; > > > case 2: > > > - if (!cpu_is_omap34xx()) > > > + if (!cpu_is_omap44xx() && !cpu_is_omap34xx()) > > > return; > > > base = OMAP3_MMC3_BASE; > > > irq = INT_34XX_MMC3_IRQ; > > > break; > > > + case 3: > > > + if (!cpu_is_omap44xx()) > > > + return; > > > + base = OMAP4_MMC4_BASE + OMAP4_MMC_REG_OFFSET; > > > > The reset fn sets up the base as "OMAP4_MMC4_BASE". Why add the OFFSET > here? > > Check in reset fn , if it is omap44xx its adding OFFSET there as well. > > > > > + irq = INT_44XX_MMC4_IRQ; > > > + break; > > > + case 4: > > > + if (!cpu_is_omap44xx()) > > > + return; > > > + base = OMAP4_MMC5_BASE + OMAP4_MMC_REG_OFFSET; > > Ditto > > > + irq = INT_44XX_MMC5_IRQ; > > > + break; > > > default: > > > continue; > > > } > > > @@ -552,8 +577,15 @@ void __init omap2_init_mmc(struct omap_m > > > if (cpu_is_omap2420()) { > > > size = OMAP2420_MMC_SIZE; > > > name = "mmci-omap"; > > > + } else if (cpu_is_omap44xx()) { > > > + if (i < 3) { > > > + base += OMAP4_MMC_REG_OFFSET; > > > + irq += IRQ_GIC_START; > > Why base is updated at multiple places within this fn? > > For OMAP3 mmc controllers to support OMAP4 the OFFSET is added here and > these > avoids adding the offset to all controller registers in omap_hsmmc.c . > For new OMAP4 mmc controllers 4 & 5 , the addition of OFFSET has been > taken care in respective case statements > > > > > + } > > > + size = OMAP4_HSMMC_SIZE; > > > + name = "mmci-omap-hs"; > > > } else { > > > - size = HSMMC_SIZE; > > > + size = OMAP3_HSMMC_SIZE; > > > name = "mmci-omap-hs"; > > > } > > > omap_mmc_add(name, i, base, size, irq, mmc_data[i]); > > > Index: kernel-omap4-base/arch/arm/plat-omap/include/mach/irqs.h > > > =================================================================== > > > --- kernel-omap4-base.orig/arch/arm/plat-omap/include/mach/irqs.h > > > +++ kernel-omap4-base/arch/arm/plat-omap/include/mach/irqs.h > > > @@ -503,6 +503,7 @@ > > > #define INT_44XX_FPKA_READY_IRQ (50 + IRQ_GIC_START) > > > #define INT_44XX_SHA1MD51_IRQ (51 + IRQ_GIC_START) > > > #define INT_44XX_RNG_IRQ (52 + IRQ_GIC_START) > > > +#define INT_44XX_MMC5_IRQ (59 + IRQ_GIC_START) > > > #define INT_44XX_I2C3_IRQ (61 + IRQ_GIC_START) > > > #define INT_44XX_FPKA_ERROR_IRQ (64 + IRQ_GIC_START) > > > #define INT_44XX_PBIAS_IRQ (75 + IRQ_GIC_START) > > > @@ -511,6 +512,7 @@ > > > #define INT_44XX_TLL_IRQ (78 + IRQ_GIC_START) > > > #define INT_44XX_PARTHASH_IRQ (79 + IRQ_GIC_START) > > > #define INT_44XX_MMC3_IRQ (94 + IRQ_GIC_START) > > > +#define INT_44XX_MMC4_IRQ (96 + IRQ_GIC_START) > > > > > > > > > /* Max. 128 level 2 IRQs (OMAP1610), 192 GPIOs (OMAP730/850) and > > > Index: kernel-omap4-base/arch/arm/plat-omap/include/mach/mmc.h > > > =================================================================== > > > --- kernel-omap4-base.orig/arch/arm/plat-omap/include/mach/mmc.h > > > +++ kernel-omap4-base/arch/arm/plat-omap/include/mach/mmc.h > > > @@ -25,11 +25,18 @@ > > > > > > #define OMAP24XX_NR_MMC 2 > > > #define OMAP34XX_NR_MMC 3 > > > +#define OMAP44XX_NR_MMC 5 > > > #define OMAP2420_MMC_SIZE OMAP1_MMC_SIZE > > > -#define HSMMC_SIZE 0x200 > > > +#define OMAP3_HSMMC_SIZE 0x200 > > > +#define OMAP4_HSMMC_SIZE 0x1000 > > > #define OMAP2_MMC1_BASE 0x4809c000 > > > #define OMAP2_MMC2_BASE 0x480b4000 > > > #define OMAP3_MMC3_BASE 0x480ad000 > > > +#define OMAP4_MMC4_BASE 0x480d1000 > > > +#define OMAP4_MMC5_BASE 0x480d5000 > > > +#define OMAP4_MMC_REG_OFFSET 0x100 > > > +#define HSMMC5 (1 << 4) > > > +#define HSMMC4 (1 << 3) > > > #define HSMMC3 (1 << 2) > > > #define HSMMC2 (1 << 1) > > > #define HSMMC1 (1 << 0) > > > Index: kernel-omap4-base/drivers/mmc/host/Kconfig > > > =================================================================== > > > --- kernel-omap4-base.orig/drivers/mmc/host/Kconfig > > > +++ kernel-omap4-base/drivers/mmc/host/Kconfig > > > @@ -132,11 +132,11 @@ config MMC_OMAP > > > > > > config MMC_OMAP_HS > > > tristate "TI OMAP High Speed Multimedia Card Interface support" > > > - depends on ARCH_OMAP2430 || ARCH_OMAP3 > > > + depends on ARCH_OMAP2430 || ARCH_OMAP3 || ARCH_OMAP4 > > > help > > > This selects the TI OMAP High Speed Multimedia card Interface. > > > - If you have an OMAP2430 or OMAP3 board with a Multimedia Card > > > slot, > > > - say Y or M here. > > > + If you have an OMAP2430 or OMAP3 board or OMAP4 board with a > > > + Multimedia Card slot, say Y or M here. > > > > > > If unsure, say N. > > > > > > Index: kernel-omap4-base/drivers/mmc/host/omap_hsmmc.c > > > =================================================================== > > > --- kernel-omap4-base.orig/drivers/mmc/host/omap_hsmmc.c > > > +++ kernel-omap4-base/drivers/mmc/host/omap_hsmmc.c > > > > Does changes here conflict with Adrian's patches lined up for merge > > upstream? From a merge perspective as well as functionality? > > This patch applies with couple of hunks on Adrain's 32 series > Sorry, I forgot to mention that there is one more patch submitted by me lined up for merge upstream to handle the debounce clock on top of Adrian's series. http://userweb.kernel.org/~akpm/mmotm/broken-out/omap_hsmmc-ensure-all-clock -enables-and-disables-are-paired-fix-for-the-db-clock-failure-message.patch You might want to rebase on top of this and test the driver on both OMAP3/OMAP4 to make sure nothing is broken. > > > > > @@ -101,6 +101,8 @@ > > > #define OMAP_MMC1_DEVID 0 > > > #define OMAP_MMC2_DEVID 1 > > > #define OMAP_MMC3_DEVID 2 > > > +#define OMAP_MMC4_DEVID 3 > > > +#define OMAP_MMC5_DEVID 4 > > > > > > #define MMC_TIMEOUT_MS 20 > > > #define OMAP_MMC_MASTER_CLOCK 96000000 > > > @@ -1096,6 +1098,14 @@ static int __init omap_mmc_probe(struct > > > host->dma_line_tx = OMAP34XX_DMA_MMC3_TX; > > > host->dma_line_rx = OMAP34XX_DMA_MMC3_RX; > > > break; > > > + case OMAP_MMC4_DEVID: > > > + host->dma_line_tx = OMAP44XX_DMA_MMC4_TX; > > > + host->dma_line_rx = OMAP44XX_DMA_MMC4_RX; > > > + break; > > > + case OMAP_MMC5_DEVID: > > > + host->dma_line_tx = OMAP44XX_DMA_MMC5_TX; > > > + host->dma_line_rx = OMAP44XX_DMA_MMC5_RX; > > > + break; > > > default: > > > dev_err(mmc_dev(host->mmc), "Invalid MMC id\n"); > > > goto err_irq; > > > > > > > > > -- > > To unsubscribe from this list: send the line "unsubscribe linux-kernel" > in > > the body of a message to majordomo@xxxxxxxxxxxxxxx > > More majordomo info at http://vger.kernel.org/majordomo-info.html > > Please read the FAQ at http://www.tux.org/lkml/ -- To unsubscribe from this list: send the line "unsubscribe linux-omap" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html