RE: [PATCH] OMAP4: MMC driver support on OMAP4

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




> -----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

[Index of Archives]     [Linux Arm (vger)]     [ARM Kernel]     [ARM MSM]     [Linux Tegra]     [Linux WPAN Networking]     [Linux Wireless Networking]     [Maemo Users]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite Trails]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux