[PATCH 12/13] ARM: dts: omap3-gta04: uart4 is not connected, so mark it "disabled"
Tony Lindgren
tony at atomide.com
Fri Jan 23 17:03:41 PST 2015
* NeilBrown <neilb at suse.de> [150123 14:31]:
> On Thu, 22 Jan 2015 13:40:53 -0800 Tony Lindgren <tony at atomide.com> wrote:
> > >
> > > +&uart4 {
> > > + status = "disabled";
> > > +};
> > > +
> >
> > This you probably want to avoid from PM point of view. Depending on
> > bootloader state of uart4, Linux may or may not be able to hit any
> > deeper power states.
> >
> > Marking something with status = "disabled" in dts causes the device
> > entry not even to be created. That means hwmod won't be able to reset
> > and idle this device during boot.
> >
> > The uart4 device is there for sure even if not muxed and in incomplete
> > state. You may want to also check other places where you're using
> > status = "disabled" for the same reasons.
>
> That's ... unfortunate. Would that apply to the MCBSPs too? They are
> disabled by default so you would need to explicitly enable them all for
> sensible behaviour....
Yeah that applies to all the SoC integrated devices that the bus code
(hwmod) is supposed to reset and idle if unused. Basically anything
that depends on the dev entry being created.
> Hopefully there is some way to mark as device as "this is not used, make sure
> it is turned off and stays off" ???
Not currently that I know of :) To do that, we should add something
like status = "incomplete" where the dev entry gets created but the
driver is never probed. And incomplete here meaning that the device
is missing some parts like pins that would make it work properly.
> Thanks for the heads-up. I'll have a look and see exactly what is happening.
OK
> BTW, on the topic of OMAP UARTs and power saving...
> I note that there are now two drivers for the OMAP3 UART - omap-serial and
> 8250_omap.
> I also note that your commit:
>
> commit a2fc36613ac1af2e92cbed7af80bc72d8114dd50
> ARM: OMAP3: Use manual idle for UARTs because of DMA errata
>
> is incompatible with omap-serial. In particular, if I enable runtime
> suspend of the serial port by setting the autosuspend_timeout, then incoming
> characters will no longer wake the port (if I revert your patch incoming
> chars do wake the port).
> This could (I think) be fixed by enabling the RX/CTS interrupt. However if
> omap-serial is being deprecated, then there probably isn't any point.
>
> So: what is the longer term expectation for these drivers? Should we be
> switching over to 8250?
Yeah you should alredy be able to do it. Hopefully we'll have some
translation layer and the old omap-serial.c can be mostly removed
now that we have 8250 support with runtime PM :)
Regards,
Tony
More information about the linux-arm-kernel
mailing list