From: maxime.ripard@free-electrons.com (Maxime Ripard)
To: linux-arm-kernel@lists.infradead.org
Subject: Including empty regulator nodes in axp209.dtsi is a BAD idea
Date: Tue, 13 Jan 2015 17:46:06 +0100 [thread overview]
Message-ID: <20150113164606.GA4891@lukather> (raw)
In-Reply-To: <54B4E7B5.6060304@redhat.com>
On Tue, Jan 13, 2015 at 10:39:01AM +0100, Hans de Goede wrote:
> Hi ChenYu, Maxime,
>
> During the review of a few dts files for new boards Maxime asked me to use
> axp209.dtsi to avoid the standard axp209 "boilerplate" present in most
> boards using the axp209 pmic.
>
> But axp209.dtsi includes empty regulator nodes, e.g. :
>
> reg_dcdc3: dcdc3 {
> regulator-name = "dcdc3";
> };
>
> This is a BAD idea, the presence of these empty nodes causes the
> axp20x-regulator driver to actually register regulators for them,
> and then on late_init the regulator subsys turns them off, since
> they have absolutely no constraints set (nor users registered)
> and the regulator subsys assumes that when devicetree is used their
> is always a compete set of constraints and that thus turning them
> off is safe.
>
> So when I switched to using axp209.dtsi for the bananapro.dts,
> and booted the bananapro this is the last message I got from the
> kernel while booting:
>
> [ 2.314014] dcdc3: disabling
>
> And away went our DRAM power-supply, oops.
>
> So for dcdc2 (CPU) and dcdc3 (DRAM), the boilerplate
> should contain reasonable constraints (eg the operating range
> from the datasheet)
Indeed.
> and an always-on property.
I disagree. The regulator disabling is a feature, and how the board is
wired is, well, up to the board.
If an always-on property is needed, then it's in the DTS, not in the
AXP DTSI.
> The ldo-s are trickier, since we simply do not know how those
> are used, I think ldo2 is used for Avcc on most boards, so it
> too should be always on, since almost any board will have some
> analog parts on it (be it the ir receiver, lradc, rtp, lvds, vga,
> or analog audio in/out). Assuming that we're willing to assume
> that ldo2 is used this way, we should give it matching constraints
> and always mark it always-on.
Ideally, all the drivers that have a analogic component should have a
reference to the regulator they use. But again, at the board
level. And more realistically, putting always-on should also happen at
the board level.
> As for ldo3 - 5 I've no idea when / for what these are used, but
> if we do not know it is better to just leave them be then to turn
> them off IMHO, so we should remove the nodes for these from axp209.dtsi
>
> Anyways sorting this all out is going to take some time, so I'm
> not going to use axp209.dtsi in dts files for new boards for now.
I'm afraid it's an "all or nothing" situation. Either you load the
PMIC and describe as accurately as possible which regulator are in
use, or you don't. I'm fine with both, even if have a small preference
for the former, but getting stuck half-way is not really an option.
Maxime
--
Maxime Ripard, Free Electrons
Embedded Linux, Kernel and Android engineering
http://free-electrons.com
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 819 bytes
Desc: Digital signature
URL: <http://lists.infradead.org/pipermail/linux-arm-kernel/attachments/20150113/5c323c1e/attachment.sig>
next prev parent reply other threads:[~2015-01-13 16:46 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-01-13 9:39 Including empty regulator nodes in axp209.dtsi is a BAD idea Hans de Goede
2015-01-13 16:46 ` Maxime Ripard [this message]
2015-01-14 7:42 ` Hans de Goede
2015-01-14 8:11 ` [linux-sunxi] " Michal Suchanek
2015-01-15 16:54 ` Chen-Yu Tsai
2015-01-15 22:04 ` Maxime Ripard
2015-01-16 0:58 ` Chen-Yu Tsai
2015-01-16 7:42 ` Hans de Goede
2015-01-15 21:57 ` Maxime Ripard
2015-01-14 10:18 ` [linux-sunxi] " Lars Doelle
2015-01-15 16:48 ` Chen-Yu Tsai
2015-01-15 21:51 ` Maxime Ripard
2015-01-15 23:41 ` Lars Doelle
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=20150113164606.GA4891@lukather \
--to=maxime.ripard@free-electrons.com \
--cc=linux-arm-kernel@lists.infradead.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: link
Be 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).