RE: [PATCH v5 10/12] OMAP: dmtimer: switch-over to platform device driver

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

 



> -----Original Message-----
> From: Varadarajan, Charulatha
> Sent: Tuesday, December 07, 2010 10:58 AM
> To: DebBarma, Tarun Kanti
> Cc: linux-omap@xxxxxxxxxxxxxxx
> Subject: Re: [PATCH v5 10/12] OMAP: dmtimer: switch-over to platform
> device driver
> 
> Tarun,
> 
> On Tue, Dec 7, 2010 at 05:14, Tarun Kanti DebBarma <tarun.kanti@xxxxxx>
> wrote:
> > switch-over to platform device driver through following changes:
> > (a) call to dmtimer initialization routine from timer-gp.c is
> > removed (b) initiate dmtimer early initialization from
> omap2_init_common_hw
> > in io.c (c) modify plat-omap/dmtimer routines to use new register map
> and
> > platform data.
> >
> > Signed-off-by: Tarun Kanti DebBarma <tarun.kanti@xxxxxx>
> > Reviewed-by: Cousson, Benoit <b-cousson@xxxxxx>
> > Reviewed-by: Varadarajan, Charulatha <charu@xxxxxx>
> > ---
> >  arch/arm/mach-omap2/clock2420_data.c      |    2 +-
> >  arch/arm/mach-omap2/clock2430_data.c      |    2 +-
> >  arch/arm/mach-omap2/clock3xxx_data.c      |    2 +-
> >  arch/arm/mach-omap2/clock44xx_data.c      |    2 +-
> >  arch/arm/mach-omap2/dmtimer.c             |   40 ++++
> >  arch/arm/mach-omap2/io.c                  |    2 +
> >  arch/arm/mach-omap2/timer-gp.c            |    1 -
> >  arch/arm/plat-omap/dmtimer.c              |  323 +++++++++-------------
> -------
> >  arch/arm/plat-omap/include/plat/dmtimer.h |    2 -
> >  9 files changed, 148 insertions(+), 228 deletions(-)
> >
> <<snip>>
> 
> > diff --git a/arch/arm/plat-omap/dmtimer.c b/arch/arm/plat-omap/dmtimer.c
> > index ddc875b..ac6a498 100644
> > --- a/arch/arm/plat-omap/dmtimer.c
> > +++ b/arch/arm/plat-omap/dmtimer.c
> 
> <<snip>>
> > -static struct omap_dm_timer *dm_timers;
> > -static const char **dm_source_names;
> > -static struct clk **dm_source_clocks;
> > -
> >  static LIST_HEAD(omap_timer_list);
> >  static DEFINE_SPINLOCK(dm_timer_lock);
> >
> > -/*
> > - * Reads timer registers in posted and non-posted mode. The posted mode
> bit
> > - * is encoded in reg. Note that in posted mode write pending bit must
> be
> > - * checked. Otherwise a read of a non completed write will produce an
> error.
> > +/**
> > + * omap_dm_timer_read_reg - read timer registers in posted and non-
> posted mode
> > + * @timer:      timer pointer over which read operation to perform
> > + * @reg:        lowest byte holds the register offset
> > + *
> > + * The posted mode bit is encoded in reg. Note that in posted mode
> write
> > + * pending bit must be checked. Otherwise a read of a non completed
> write
> > + * will produce an error.
> >  */
> >  static inline u32 omap_dm_timer_read_reg(struct omap_dm_timer *timer,
> u32 reg)
> >  {
> > +       struct dmtimer_platform_data *pdata = timer->pdev-
> >dev.platform_data;
> 
> Leave one line
Ok.

> 
> > +       if (reg >= OMAP_TIMER_WAKEUP_EN_REG)
> > +               reg += pdata->func_offset;
> > +       else if (reg >= OMAP_TIMER_STAT_REG)
> > +               reg += pdata->intr_offset;
> >        if (timer->posted)
> >                while (readl(timer->io_base + (OMAP_TIMER_WRITE_PEND_REG
> & 0xff))
> >                                & (reg >> WPSHIFT))
> > @@ -290,15 +195,24 @@ static inline u32 omap_dm_timer_read_reg(struct
> omap_dm_timer *timer, u32 reg)
> >        return readl(timer->io_base + (reg & 0xff));
> >  }
> >
> > -/*
> > - * Writes timer registers in posted and non-posted mode. The posted
> mode bit
> > - * is encoded in reg. Note that in posted mode the write pending bit
> must be
> > - * checked. Otherwise a write on a register which has a pending write
> will be
> > - * lost.
> > +/**
> > + * omap_dm_timer_write_reg - write timer registers in posted and non-
> posted mode
> > + * @timer:      timer pointer over which write operation is to perform
> > + * @reg:        lowest byte holds the register offset
> > + * @value:      data to write into the register
> > + *
> > + * The posted mode bit is encoded in reg. Note that in posted mode the
> write
> > + * pending bit must be checked. Otherwise a write on a register which
> has a
> > + * pending write will be lost.
> >  */
> >  static void omap_dm_timer_write_reg(struct omap_dm_timer *timer, u32
> reg,
> >                                                u32 value)
> >  {
> > +       struct dmtimer_platform_data *pdata = timer->pdev-
> >dev.platform_data;
> 
> Leave one line
Ok.

> 
> > +       if (reg >= OMAP_TIMER_WAKEUP_EN_REG)
> > +               reg += pdata->func_offset;
> > +       else if (reg >= OMAP_TIMER_STAT_REG)
> > +               reg += pdata->intr_offset;
> >        if (timer->posted)
> >                while (readl(timer->io_base + (OMAP_TIMER_WRITE_PEND_REG
> & 0xff))
> >                                & (reg >> WPSHIFT))
> > @@ -306,6 +220,8 @@ static void omap_dm_timer_write_reg(struct
> omap_dm_timer *timer, u32 reg,
> >        writel(value, timer->io_base + (reg & 0xff));
> >  }
> >
> > +#if defined(CONFIG_ARCH_OMAP1)
> > +
> >  static void omap_dm_timer_wait_for_reset(struct omap_dm_timer *timer)
> >  {
> >        int c;
> > @@ -324,54 +240,77 @@ static void omap_dm_timer_reset(struct
> omap_dm_timer *timer)
> >  {
> >        u32 l;
> >
> > -       if (!cpu_class_is_omap2() || timer != &dm_timers[0]) {
> > +       if (!cpu_class_is_omap2() || timer->pdev->id != 1) {
> 
> Should this be '&&' instead of '||' ?
> 
> Not required to check the cpu_class as this function is under
> CONFIG_ARCH_OMAP1.
Yes, the check is no longer needed. Thanks.

> Also I think, it is better to use cpu_class is checks than using
> CONFIG_ARCH_OMAP1 checks.
In case this piece of code is kept here I will use cpu_class.

> I guess that this function can be considered to be moved to mach-omap1/*
Sounds good! In this case we have to introduce a function pointer in
Platform data structure guarded by a macro. This can then be called
>From omap_dm_timer_prepare() with cpu_class check. Thanks.

> 
> >                omap_dm_timer_write_reg(timer, OMAP_TIMER_IF_CTRL_REG,
> 0x06);
> >                omap_dm_timer_wait_for_reset(timer);
> >        }
> > -       omap_dm_timer_set_source(timer, OMAP_TIMER_SRC_32_KHZ);
> >
> >        l = omap_dm_timer_read_reg(timer, OMAP_TIMER_OCP_CFG_REG);
> >        l |= 0x02 << 3;  /* Set to smart-idle mode */
> >        l |= 0x2 << 8;   /* Set clock activity to perserve f-clock on
> idle */
> >
> > -       /*
> > -        * Enable wake-up on OMAP2 CPUs.
> > -        */
> > -       if (cpu_class_is_omap2())
> > -               l |= 1 << 2;
> >        omap_dm_timer_write_reg(timer, OMAP_TIMER_OCP_CFG_REG, l);
> >
> > -       /* Match hardware reset default of posted mode */
> > -       omap_dm_timer_write_reg(timer, OMAP_TIMER_IF_CTRL_REG,
> > -                       OMAP_TIMER_CTRL_POSTED);
> > -       timer->posted = 1;
> >  }
> > +#endif
> >
> >  static void omap_dm_timer_prepare(struct omap_dm_timer *timer)
> >  {
> > +       u32 l;
> > +
> > +       timer->fclk = clk_get(&timer->pdev->dev, "fck");
> > +       if (IS_ERR_OR_NULL(timer->fclk)) {
> > +               pr_info("omap_timer: failed to acquire fclk handle.\n");
> > +               WARN_ON(1);
> 
> Embed warning message in WARN_ON  and remove pr_info usage.
> Give proper warning message in all other places where WARN_ON(1) is being
> used
Ok.
> 
> > +               return;
> > +       }
> > +
> >        omap_dm_timer_enable(timer);
> > +
> > +#if defined(CONFIG_ARCH_OMAP1)
> >        omap_dm_timer_reset(timer);
> > +#endif
> > +
> > +       /*
> > +        * Enable wake-up on OMAP2420, OMAP2430 and OMAP3430 CPUs.
> > +        * FIXME: SYSC_HAS_ENAWAKEUP flag is already set in hwmod.
> > +        * But on OMAP2 code does not work without following
> configuration.
> > +        * Need to investigate why this is happening.
> > +        */
> > +       if (is_omap2430() || is_omap2420() || is_omap3430()) {
> 
> Do not use these checks in plat-omap/*.
Yes, there is FIXME message. Need to figure out why this is happening.

> Prefer using cpu_is* checks instead of is_omap2420().
Ok.
> 
> > +               l = omap_dm_timer_read_reg(timer,
> OMAP_TIMER_OCP_CFG_REG);
> > +               l |= 1 << 2;
> > +               omap_dm_timer_write_reg(timer, OMAP_TIMER_OCP_CFG_REG,
> l);
> > +       }
> > +
> > +       omap_dm_timer_set_source(timer, OMAP_TIMER_SRC_32_KHZ);
> > +
> > +       /* Match hardware reset default of posted mode */
> > +       omap_dm_timer_write_reg(timer, OMAP_TIMER_IF_CTRL_REG,
> > +                       OMAP_TIMER_CTRL_POSTED);
> > +       timer->posted = 1;
> >  }
> 
> <<snip>>
--
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