linux/arch/arm/mach-omap2
Tony Lindgren 7db143b891 ARM: OMAP3: Fix I/O chain clock line assertion timed out error
We are getting "PRM: I/O chain clock line assertion timed out" errors
on early omaps for device tree based booting. This is because we are
unconditionally calling reconfigure_io_chain while legacy booting
has omap3_has_io_chain_ctrl() checks in place in omap_hwmod.c.

For device tree based booting, we are calling reconfigure_io_chain
unconditionally from pinctrl framework. So we need to add a check for
omap3_has_io_chain_ctrl() to avoid the errors for trying to access
a register that does not exist.

For es3.0, the documentation in "4.11.2 Device Off-Mode Configuration"
just mentions PM_WKEN_WKUP[8] bit. For es3.1, there's a new chapter in
documentation for "4.11.2.2 I/O Wake-Up Mechanism" that describes the
PM_WKEN_WKUP[16] ST_IO_CHAIN bit. So PM_WKEN_WKUP[16] bit did not get
added until in es3.1 probaly to fix issues with flakey wake-up events.

We are doing proper checks for ST_IO_CHAIN already in id.c and with
omap3_has_io_chain_ctrl(). For more information, see also commit
b02b917211d5 ("ARM: OMAP3: PM: fix I/O wakeup and I/O chain clock
control detection").

Let's fix the issue by selecting the right function during init for
reconfigure_io_chain depending on the omap revision. For es3.0 and
earlier we need to just toggle EN_IO. By doing this, we can move the
check for omap3_has_io_chain_ctrl() from omap_hwmod.c to the init code
in prm_3xxx.c. And then we can unconditionally call reconfigure_io_chain.

Thanks to Paul Walmsley and Nishanth Menon for help with debugging the
issue.

Fixes: 30a69ef785e8 ("ARM: OMAP: Move DT wake-up event handling over to use pinctrl-single-omap")
Cc: Kevin Hilman <khilman@kernel.org>
Cc: Paul Walmsley <paul@pwsan.com>
Cc: Tero Kristo <t-kristo@ti.com>
Reviewed-by: Nishanth Menon <nm@ti.com>
Signed-off-by: Tony Lindgren <tony@atomide.com>
2014-09-16 15:09:44 -07:00
..
2013-06-12 08:00:35 -07:00
2014-02-25 11:33:37 +00:00
2012-09-20 15:02:23 -07:00
2014-06-11 14:06:55 -07:00
2013-02-21 14:58:40 -08:00
2012-12-24 09:36:38 -07:00
2013-01-11 11:24:18 -08:00
2013-01-11 11:24:18 -08:00
2014-01-17 12:35:48 -08:00
2014-08-08 11:16:58 -07:00
2014-08-08 11:16:58 -07:00
2013-05-02 09:03:55 -07:00
2014-03-19 10:52:23 +02:00
2013-01-11 11:24:18 -08:00
2013-02-21 15:27:22 -08:00
2013-02-21 15:27:22 -08:00
2012-09-20 15:02:22 -07:00
2014-08-08 11:16:58 -07:00
2014-07-23 00:51:30 +02:00
2012-09-20 15:03:59 -07:00
2012-09-20 15:04:00 -07:00
2012-09-20 15:04:01 -07:00
2012-09-20 15:04:03 -07:00
2014-08-08 11:16:58 -07:00
2013-05-08 17:07:40 -07:00
2013-10-13 22:48:46 -06:00
2013-01-11 11:24:18 -08:00
2013-01-11 11:24:18 -08:00
2014-08-08 11:16:58 -07:00
2012-10-18 16:23:20 -07:00
2014-06-02 16:14:07 -07:00
2013-08-16 09:39:56 -07:00
2014-06-02 16:15:12 -07:00
2012-09-12 02:57:10 -06:00