LKML Archive on lore.kernel.org help / color / mirror / Atom feed
From: Tony Lindgren <tony@atomide.com> To: Johan Hovold <johan@kernel.org> Cc: Sebastian Reichel <sre@kernel.org>, "H. Nikolaus Schaller" <hns@goldelico.com>, Andreas Kemnade <andreas@kemnade.info>, Mark Rutland <mark.rutland@arm.com>, Arnd Bergmann <arnd@arndb.de>, Pavel Machek <pavel@ucw.cz>, "linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>, "open list:OPEN FIRMWARE AND FLATTENED DEVICE TREE BINDINGS" <devicetree@vger.kernel.org>, Greg Kroah-Hartman <gregkh@linuxfoundation.org>, Rob Herring <robh+dt@kernel.org> Subject: Re: [PATCH 4/7] dt-bindings: gnss: add u-blox binding Date: Tue, 8 May 2018 08:22:28 -0700 [thread overview] Message-ID: <20180508152228.GV98604@atomide.com> (raw) In-Reply-To: <20180508065852.GW2285@localhost> * Johan Hovold <johan@kernel.org> [180508 07:00]: > On Mon, May 07, 2018 at 10:50:32AM -0700, Tony Lindgren wrote: > > I don't know, they are there for the ports that don't have any > > serdev device. But if there is a serdev child node, the sysfs > > disappear for the 8250 port like it's /dev/ttyS* entry. That is > > even with no hci_serdev.ko loaded :) > > It sounds to me like you have a udev rule that's matching on TTY devices > and setting an autosuspend timeout that allows the controller to runtime > suspend. Is that so? Oh you are right, I do have an old init script that idles the UARTs. And that script is looking for tty[SO]*. Updating it to use /sys/bus/platform/devices fixes the issue I was seeing: uarts=$(find /sys/bus/platform/devices/4*.serial/power/ -type d) for uart in $uarts; do echo -n 1000 > $uart/autosuspend_delay_ms echo -n enabled > $uart/wakeup echo -n auto > $uart/control done The above also idles the console so beware though. > But the point is, we really don't want the runtime PM behaviour to be > dependent on the presence of such rules. The serial controllers should > always be idle when not in use (unless overridden by user space). I agree, and that seems broken right now. > > Do you have also a /dev/ttyO* entry created for the serdev port? > > No, serdev claims the port and no tty device is created. And this is no longer the issue when using /sys/bus/platform/devices instead of tty[SO]* in my init script :) > > > I'd say the omap drivers are broken; the controller should definitely > > > idle when the port is closed (whether using serdev or not) without > > > having to fiddle with sysfs. > > > > This is happening for the non-serdev ports for sure. FYI, there is > > one patch needed for omap4 to idle unused ports that I posted > > few days ago: > > > > [PATCHv3] serial: 8250: omap: Fix idling of clocks for unused uarts > > > > But the serdev port is never idled, even if unused. > > With the negative autosuspend set in both omap drivers probe functions, > this is the expected behaviour. Which I think we must fix. Yes indeed. I've been using my script for years now and have completely missed the fact that the unused ports are not idled at all on start-up when unused. > > Can you check your serdev port clkctrl reg with rwmem or similar > > tool when it's idle? > > > > You can do it with: > > > > rwmem -s32 0x44e004b4 # uart 1 on l4_wkup > > rwmem -s32 0x44e0006c+0x10 # uart 2 - 5 on l4_per > > rwmem -s32 0x44e00038 # uart 6 on l4_per > > > > And here's what I have on my bbb with 8250_omap: > > > > 0x44e004b4 = 0x00000002 > > 0x44e0006c = 0x00030000 > > 0x44e00070 = 0x00030000 > > 0x44e00074 = 0x00030000 > > 0x44e00078 = 0x00030000 > > 0x44e00038 = 0x00030000 > > > > So all disabled except for the console UART. > > On BBB with omap-serial I have: > > 0x44e004b4 = 0x2 (uart 1, console, open) > 0x44e0006c = 0x2 (uart 2, serdev, closed) > 0x44e00070 = 0x30000 (uart 3, disabled in DT) > 0x44e00074 = 0x30000 (uart 4, disabled in DT) > 0x44e00078 = 0x2 (uart 5, serdev, closed) > 0x44e00038 = 0x2 (uart 6, ttyO5, closed) > > So no enabled and closed port is idle, whether using serdev or not. OK so we really have currently just one PM related bug where unused UARTs should be idled on init. And then the serdev PM can be handled the way you're doing it and tested with the above rwmem. Hmm maybe all we need for serdev runtime PM is to set the parent UART autoidle timeout to immediate (0 instead of -1) from the serdev child driver to allow the serdev driver manage the PM. Regards, Tony
next prev parent reply other threads:[~2018-05-08 15:22 UTC|newest] Thread overview: 86+ messages / expand[flat|nested] mbox.gz Atom feed top 2018-04-24 16:34 [PATCH 0/7] gnss: add new GNSS subsystem Johan Hovold 2018-04-24 16:34 ` [PATCH 1/7] gnss: add GNSS receiver subsystem Johan Hovold 2018-04-25 8:56 ` Greg Kroah-Hartman 2018-04-25 10:56 ` Johan Hovold 2018-04-25 12:23 ` Johan Hovold 2018-04-29 13:35 ` Greg Kroah-Hartman 2018-05-02 7:57 ` Johan Hovold 2018-04-24 16:34 ` [PATCH 2/7] dt-bindings: add generic gnss binding Johan Hovold 2018-04-25 18:26 ` Rob Herring 2018-04-24 16:34 ` [PATCH 3/7] gnss: add generic serial driver Johan Hovold 2018-04-25 8:57 ` Greg Kroah-Hartman 2018-04-25 10:58 ` Johan Hovold 2018-04-25 9:00 ` Greg Kroah-Hartman 2018-04-25 11:05 ` Johan Hovold 2018-04-24 16:34 ` [PATCH 4/7] dt-bindings: gnss: add u-blox binding Johan Hovold 2018-04-25 18:16 ` Rob Herring 2018-04-26 9:10 ` Johan Hovold 2018-05-01 14:05 ` Rob Herring 2018-05-02 8:16 ` Johan Hovold 2018-05-02 13:16 ` Rob Herring 2018-05-07 9:06 ` Johan Hovold 2018-05-03 9:35 ` H. Nikolaus Schaller 2018-05-03 18:50 ` Andreas Kemnade 2018-05-04 5:16 ` H. Nikolaus Schaller 2018-05-04 11:42 ` Sebastian Reichel 2018-05-04 12:04 ` H. Nikolaus Schaller 2018-05-04 13:37 ` Sebastian Reichel 2018-05-04 14:29 ` Tony Lindgren 2018-05-07 10:07 ` Johan Hovold 2018-05-07 10:01 ` Johan Hovold 2018-05-07 15:45 ` Tony Lindgren 2018-05-07 16:34 ` Johan Hovold 2018-05-07 17:50 ` Tony Lindgren 2018-05-08 6:58 ` Johan Hovold 2018-05-08 15:22 ` Tony Lindgren [this message] 2018-05-08 15:47 ` Tony Lindgren 2018-05-08 15:54 ` Tony Lindgren 2018-05-08 16:49 ` Tony Lindgren 2018-05-09 13:10 ` OMAP serial runtime PM and autosuspend (was: Re: [PATCH 4/7] dt-bindings: gnss: add u-blox binding)) Johan Hovold 2018-05-09 13:57 ` Tony Lindgren 2018-05-17 10:09 ` Johan Hovold 2018-05-17 17:10 ` Tony Lindgren 2018-05-21 13:48 ` Johan Hovold 2018-05-21 15:48 ` Tony Lindgren 2018-05-24 9:17 ` Johan Hovold 2018-05-24 13:32 ` Tony Lindgren 2018-05-25 14:02 ` Johan Hovold 2018-05-08 15:56 ` [PATCH 4/7] dt-bindings: gnss: add u-blox binding Sebastian Reichel 2018-05-09 9:18 ` Serdev runtime PM (was: Re: [PATCH 4/7] dt-bindings: gnss: add u-blox binding) Johan Hovold 2018-05-09 9:49 ` Johan Hovold 2018-05-09 14:05 ` Tony Lindgren 2018-05-17 10:25 ` Johan Hovold 2018-05-07 9:47 ` [PATCH 4/7] dt-bindings: gnss: add u-blox binding Johan Hovold 2018-04-24 16:34 ` [PATCH 5/7] gnss: add driver for u-blox receivers Johan Hovold 2018-04-24 16:34 ` [PATCH 6/7] dt-bindings: gnss: add sirfstar binding Johan Hovold 2018-04-25 18:25 ` Rob Herring 2018-04-26 9:12 ` Johan Hovold 2018-04-24 16:34 ` [PATCH 7/7] gnss: add driver for sirfstar-based receivers Johan Hovold 2018-04-24 17:40 ` [PATCH 0/7] gnss: add new GNSS subsystem H. Nikolaus Schaller 2018-04-24 17:50 ` Johan Hovold 2018-04-24 19:44 ` H. Nikolaus Schaller 2018-04-25 8:11 ` Johan Hovold 2018-04-26 10:10 ` H. Nikolaus Schaller 2018-04-26 18:21 ` Johan Hovold 2018-04-24 20:13 ` Pavel Machek 2018-04-24 20:59 ` Andreas Kemnade 2018-04-25 7:32 ` Johan Hovold 2018-04-25 6:49 ` Marcel Holtmann 2018-04-25 7:24 ` Johan Hovold 2018-04-24 20:38 ` Pavel Machek 2018-04-25 6:26 ` Pavel Machek 2018-04-25 6:51 ` Johan Hovold 2018-04-25 8:48 ` Greg Kroah-Hartman 2018-04-25 10:31 ` Johan Hovold 2018-05-04 13:27 ` Sebastian Reichel 2018-05-04 20:03 ` Pavel Machek 2018-05-05 17:28 ` Sebastian Reichel 2018-05-05 21:11 ` Pavel Machek 2018-05-06 6:47 ` Marcel Holtmann 2018-05-07 10:20 ` Johan Hovold 2018-05-07 19:06 ` Marcel Holtmann 2018-05-08 7:01 ` Johan Hovold 2018-05-08 7:49 ` Marcel Holtmann 2018-05-08 12:48 ` Johan Hovold 2018-05-08 20:03 ` Marcel Holtmann 2018-05-30 10:26 ` Johan Hovold
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=20180508152228.GV98604@atomide.com \ --to=tony@atomide.com \ --cc=andreas@kemnade.info \ --cc=arnd@arndb.de \ --cc=devicetree@vger.kernel.org \ --cc=gregkh@linuxfoundation.org \ --cc=hns@goldelico.com \ --cc=johan@kernel.org \ --cc=linux-kernel@vger.kernel.org \ --cc=mark.rutland@arm.com \ --cc=pavel@ucw.cz \ --cc=robh+dt@kernel.org \ --cc=sre@kernel.org \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).