[PATCHv5 2/6] ARM: OMAP3 PM: Move IO Daisychain function to omap3 prm file
Rajendra Nayak
rnayak at ti.com
Mon Mar 12 06:15:21 EDT 2012
Hi Tero,
On Monday 12 March 2012 02:49 PM, Tero Kristo wrote:
>>> I see that you removed the second timeout test from this code, but not
>>> > > from the OMAP4 version. Any reason why? Seems like if the second timeout
>>> > > can be removed from one, then it can also be removed from the other?
>> >
>> > Actually FWIK, its nteeded in both OMAP3 and OMAP4. The OMAP3
>> > documentation does no mention about it. but that is just bad
>> > documentation.
> Both documentation and actual functionality appears to be different for
> OMAP3 / OMAP4. The status bit on OMAP3 is read / write, and writing 1 to
> it clears it. On OMAP4, it is read only and both values 0 / 1 indicate
> something has happened. On OMAP3 the bit must be cleared by writing 1 to
> it, otherwise it remains high indefinitely and will break all the
> subsequent trigger calls. Also, clearing EN_IO_CHAIN on OMAP3 does not
> appear to trigger any activity that would change the status of
> ST_IO_CHAIN, so there is nothing to poll at the end.
>
> Here is a sample trace I just generated for the trigger on OMAP3:
>
> [ 7.707824] omap3_trigger_io_chain(1): PM_WKST=00000000
> [ 7.707855] omap3_trigger_io_chain(2): PM_WKST=00000000
> [ 7.707855] omap3_trigger_io_chain(3): PM_WKST=00010000
> [ 7.707885] omap3_trigger_io_chain(4): PM_WKST=00000000
> [ 7.707977] omap3_trigger_io_chain(5): PM_WKST=00000000
>
> 1 = enter trigger function
> 2 = just after enabling io chain
> 3 = just after first poll loop
> 4 = just after clear of io status and disabling of io chain
> 5 = after udelay(100) from last event (you can see the status bit never
> raises)
Ok, I guess then the omap3 and omap4 implementations are indeed
different and should be handled differently. Thanks for the explanation.
regards,
Rajendra
>
> So, you can see that there is no change in the status bit between 4...5,
> so there is no point for polling anything there. I even tried changing
> the clear of IO status and disabling of IO chain to see if it had any
> impact on this result but no. The main point is that we must clear the
> status bit at #4, and thus polling for it to change at #5 makes no
> sense. We just need to force the register writes to PRCM by doing some
> access to the IP block.
>
>
> Looking at similar trace on omap4:
>
> [ 8.097503] omap4_trigger_io_chain(1): IO=00010020
> [ 8.097503] omap4_trigger_io_chain(2): IO=00010320
> [ 8.097534] omap4_trigger_io_chain(3): IO=00010320
> [ 8.097534] omap4_trigger_io_chain(4): IO=00010020
> [ 8.097534] omap4_trigger_io_chain(5): IO=00010020
>
> 1 = enter function
> 2 = just after enabling WUCLK_CTRL
> 3 = just after poll
> 4 = just after disabling WUCLK_CTRL
> 5 = just after poll
>
> Well, the status bit follows the state of the WUCLK_CTRL, but there is
> no time to actually poll the registers it seems, their state has already
> changed when the value from first read arrives back as the register
> access itself is so slow. But... we are not manually clearing the status
> bit, thus polling kind of makes sense (and it might make more sense if
> some future version of PRCM would allow faster register access.)
>
> I also did both of these tests by caching the register values to memory
> (no immediate printks to avoid delays) but the results are still the
> same.
>
More information about the linux-arm-kernel
mailing list