* [PATCH v2 0/4] ks8851 DT/regulator/gpio updates @ 2014-05-23 19:57 Stephen Boyd 2014-05-23 19:57 ` [PATCH v2 1/4] devicetree: bindings: Properly document micrel ks8851 SPI chips Stephen Boyd 2014-05-24 18:03 ` [PATCH v2 0/4] ks8851 DT/regulator/gpio updates David Miller 0 siblings, 2 replies; 12+ messages in thread From: Stephen Boyd @ 2014-05-23 19:57 UTC (permalink / raw) To: David S . Miller Cc: linux-kernel, linux-arm-msm, linux-arm-kernel, netdev, Nishanth Menon, Rob Herring, Pawel Moll, Mark Rutland, Ian Campbell, Kumar Gala, devicetree This set of patches properly documents the micrel ks8851 spi ethernet controller, converts to devm_regulator_get_optional() to make error paths slightly simpler, and finally adds supports for another optional regulator and a reset gpio. This allows me to use the ks8851 on my MSM8960 CDP board. Changes since v1: * Dropped vendor prefix patch as that should go through DT tree Stephen Boyd (4): devicetree: bindings: Properly document micrel ks8851 SPI chips net: ks8851: Use devm_regulator_get_optional() net: ks8851: Add optional vdd_io regulator and reset gpio net: ks8851: Add of match table .../devicetree/bindings/net/micrel-ks8851.txt | 15 ++++- drivers/net/ethernet/micrel/ks8851.c | 71 +++++++++++++++++++--- 2 files changed, 74 insertions(+), 12 deletions(-) -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, hosted by The Linux Foundation ^ permalink raw reply [flat|nested] 12+ messages in thread
* [PATCH v2 1/4] devicetree: bindings: Properly document micrel ks8851 SPI chips 2014-05-23 19:57 [PATCH v2 0/4] ks8851 DT/regulator/gpio updates Stephen Boyd @ 2014-05-23 19:57 ` Stephen Boyd 2014-05-24 12:20 ` Mark Brown 2014-05-24 12:48 ` Mark Brown 2014-05-24 18:03 ` [PATCH v2 0/4] ks8851 DT/regulator/gpio updates David Miller 1 sibling, 2 replies; 12+ messages in thread From: Stephen Boyd @ 2014-05-23 19:57 UTC (permalink / raw) To: David S . Miller Cc: Nishanth Menon, Mark Rutland, Pawel Moll, Ian Campbell, linux-arm-msm, Kumar Gala, linux-kernel, devicetree, Rob Herring, netdev, linux-arm-kernel The ks8851 SPI ethernet wasn't documented, but we documented the optional regulator supply for it under the mll based ethernet chip. Furthermore, that compatible string needed another 'l'. Fix all of this and document the optional vdd-io and reset-gpios properties. Cc: Nishanth Menon <nm@ti.com> Cc: Rob Herring <robh+dt@kernel.org> Cc: Pawel Moll <pawel.moll@arm.com> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Ian Campbell <ijc+devicetree@hellion.org.uk> Cc: Kumar Gala <galak@codeaurora.org> Cc: <devicetree@vger.kernel.org> Signed-off-by: Stephen Boyd <sboyd@codeaurora.org> --- Documentation/devicetree/bindings/net/micrel-ks8851.txt | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) diff --git a/Documentation/devicetree/bindings/net/micrel-ks8851.txt b/Documentation/devicetree/bindings/net/micrel-ks8851.txt index d54d0cc79487..bbdf9a7359a2 100644 --- a/Documentation/devicetree/bindings/net/micrel-ks8851.txt +++ b/Documentation/devicetree/bindings/net/micrel-ks8851.txt @@ -1,9 +1,18 @@ -Micrel KS8851 Ethernet mac +Micrel KS8851 Ethernet mac (MLL) Required properties: -- compatible = "micrel,ks8851-ml" of parallel interface +- compatible = "micrel,ks8851-mll" of parallel interface - reg : 2 physical address and size of registers for data and command - interrupts : interrupt connection +Micrel KS8851 Ethernet mac (SPI) + +Required properties: +- compatible = "micrel,ks8851" or the deprecated "ks8851" +- reg : chip select number +- interrupts : interrupt connection + Optional properties: -- vdd-supply: supply for Ethernet mac +- vdd-supply: analog 3.3V supply for Ethernet mac +- vdd-io-supply: digital 1.8V IO supply for Ethernet mac +- reset-gpios: reset_n input pin -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, hosted by The Linux Foundation ^ permalink raw reply related [flat|nested] 12+ messages in thread
* Re: [PATCH v2 1/4] devicetree: bindings: Properly document micrel ks8851 SPI chips 2014-05-23 19:57 ` [PATCH v2 1/4] devicetree: bindings: Properly document micrel ks8851 SPI chips Stephen Boyd @ 2014-05-24 12:20 ` Mark Brown 2014-05-24 12:48 ` Mark Brown 1 sibling, 0 replies; 12+ messages in thread From: Mark Brown @ 2014-05-24 12:20 UTC (permalink / raw) To: Stephen Boyd Cc: David S . Miller, Nishanth Menon, Mark Rutland, Pawel Moll, Ian Campbell, linux-arm-msm, Kumar Gala, linux-kernel, devicetree, Rob Herring, netdev, linux-arm-kernel [-- Attachment #1: Type: text/plain, Size: 415 bytes --] On Fri, May 23, 2014 at 12:57:17PM -0700, Stephen Boyd wrote: > Optional properties: > -- vdd-supply: supply for Ethernet mac > +- vdd-supply: analog 3.3V supply for Ethernet mac > +- vdd-io-supply: digital 1.8V IO supply for Ethernet mac > +- reset-gpios: reset_n input pin Are we *positive* that power is optional? I do note that there aren't any mandatory supplies for the device which seems very strange... [-- Attachment #2: Digital signature --] [-- Type: application/pgp-signature, Size: 836 bytes --] ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH v2 1/4] devicetree: bindings: Properly document micrel ks8851 SPI chips 2014-05-23 19:57 ` [PATCH v2 1/4] devicetree: bindings: Properly document micrel ks8851 SPI chips Stephen Boyd 2014-05-24 12:20 ` Mark Brown @ 2014-05-24 12:48 ` Mark Brown 2014-05-27 21:40 ` Stephen Boyd 1 sibling, 1 reply; 12+ messages in thread From: Mark Brown @ 2014-05-24 12:48 UTC (permalink / raw) To: Stephen Boyd Cc: David S . Miller, Nishanth Menon, Mark Rutland, Pawel Moll, Ian Campbell, linux-arm-msm, Kumar Gala, linux-kernel, devicetree, Rob Herring, netdev, linux-arm-kernel [-- Attachment #1: Type: text/plain, Size: 1142 bytes --] On Fri, May 23, 2014 at 12:57:17PM -0700, Stephen Boyd wrote: > Optional properties: > -- vdd-supply: supply for Ethernet mac > +- vdd-supply: analog 3.3V supply for Ethernet mac > +- vdd-io-supply: digital 1.8V IO supply for Ethernet mac So, according to the datasheet I managed to find this device has a supply VDD_IO (so normally written vdd-io-supply here), some other supplies which are tied to VDD_IO (so can probably be omitted) and a supply VDD_A3.3 none of which are optional. There is an internal regulator which can be used to drop a higher voltage VDD_IO down for some of the supplies tied to it but that's essentially a noop from software as far as I can tell. None of these supplies are obviously optional, though I've not read the datasheet in detail so I may have missed something here. That said it looks like this is intended to be a supply for an external PHY rather than the device itself, but even so my original question about it being able to operate without power still applies. Looking at the code it's certainly not doing any of the handling of a missing supply that I would associate with using _optional(). [-- Attachment #2: Digital signature --] [-- Type: application/pgp-signature, Size: 836 bytes --] ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH v2 1/4] devicetree: bindings: Properly document micrel ks8851 SPI chips 2014-05-24 12:48 ` Mark Brown @ 2014-05-27 21:40 ` Stephen Boyd 2014-05-28 9:44 ` Mark Brown 2014-05-28 15:16 ` Uwe Kleine-König 0 siblings, 2 replies; 12+ messages in thread From: Stephen Boyd @ 2014-05-27 21:40 UTC (permalink / raw) To: Mark Brown Cc: David S . Miller, Nishanth Menon, Mark Rutland, Pawel Moll, Ian Campbell, linux-arm-msm, Kumar Gala, linux-kernel, devicetree, Rob Herring, netdev, linux-arm-kernel, Uwe Kleine-König On 05/24/14 05:48, Mark Brown wrote: > On Fri, May 23, 2014 at 12:57:17PM -0700, Stephen Boyd wrote: > >> Optional properties: >> -- vdd-supply: supply for Ethernet mac >> +- vdd-supply: analog 3.3V supply for Ethernet mac >> +- vdd-io-supply: digital 1.8V IO supply for Ethernet mac > So, according to the datasheet I managed to find this device has a > supply VDD_IO (so normally written vdd-io-supply here), some other > supplies which are tied to VDD_IO (so can probably be omitted) and a > supply VDD_A3.3 none of which are optional. There is an internal > regulator which can be used to drop a higher voltage VDD_IO down for > some of the supplies tied to it but that's essentially a noop from > software as far as I can tell. None of these supplies are obviously > optional, though I've not read the datasheet in detail so I may have > missed something here. > > That said it looks like this is intended to be a supply for an external > PHY rather than the device itself, but even so my original question > about it being able to operate without power still applies. Looking at > the code it's certainly not doing any of the handling of a missing > supply that I would associate with using _optional(). I agree, both supplies don't look optional. Unfortunately efm32gg-dk3750.dts doesn't look to be listing any supply, and this driver only recently got support for the VDD_A3.3 supply that the omap board uses (adding Uwe for any comments on efm setup). I presume on these boards VDD_IO is tied to some always on power source that software doesn't want to deal with. Nishant, what's VDD_IO connected to on omap? What's the proper solution here? Should we use regulator_get() and check for EPROBE_DEFER and ignore other errors? By the way, the documentation for regulator_get_optional() and regulator_get_exclusive() are confusing. It looks like we copy/pasted the exclusive text (typo and all). * regulator_get_optional - obtain optional access to a regulator. * @dev: device for regulator "consumer" * @id: Supply name or regulator ID. * * Returns a struct regulator corresponding to the regulator producer, * or IS_ERR() condition containing errno. Other consumers will be * unable to obtain this reference is held and the use count for the * regulator will be initialised to reflect the current state of the * regulator. vs. * regulator_get_exclusive - obtain exclusive access to a regulator. * @dev: device for regulator "consumer" * @id: Supply name or regulator ID. * * Returns a struct regulator corresponding to the regulator producer, * or IS_ERR() condition containing errno. Other consumers will be * unable to obtain this reference is held and the use count for the * regulator will be initialised to reflect the current state of the * regulator. Should the get_optional() variant just drop the "Other consumers will be... " part and should the get_exclusive() variant say "obtain this regulator while this reference is held" ? ----8<---- From: Stephen Boyd <sboyd@codeaurora.org> Subject: [PATCH] regulator: Fix regulator_get_{optional,exclusive}() documentation regulator_get_optional() doesn't hold an exclusive reference to the regulator. Fix the documentation and reword the exclusive documentation to fix the grammatical error "this reference is held". Signed-off-by: Stephen Boyd <sboyd@codeaurora.org> --- drivers/regulator/core.c | 11 ++++------- 1 file changed, 4 insertions(+), 7 deletions(-) diff --git a/drivers/regulator/core.c b/drivers/regulator/core.c index b97ffd2365d3..2fae21a9d0e5 100644 --- a/drivers/regulator/core.c +++ b/drivers/regulator/core.c @@ -1430,9 +1430,9 @@ EXPORT_SYMBOL_GPL(regulator_get); * * Returns a struct regulator corresponding to the regulator producer, * or IS_ERR() condition containing errno. Other consumers will be - * unable to obtain this reference is held and the use count for the - * regulator will be initialised to reflect the current state of the - * regulator. + * unable to obtain this regulator while this reference is held and the + * use count for the regulator will be initialised to reflect the current + * state of the regulator. * * This is intended for use by consumers which cannot tolerate shared * use of the regulator such as those which need to force the @@ -1456,10 +1456,7 @@ EXPORT_SYMBOL_GPL(regulator_get_exclusive); * @id: Supply name or regulator ID. * * Returns a struct regulator corresponding to the regulator producer, - * or IS_ERR() condition containing errno. Other consumers will be - * unable to obtain this reference is held and the use count for the - * regulator will be initialised to reflect the current state of the - * regulator. + * or IS_ERR() condition containing errno. * * This is intended for use by consumers for devices which can have * some supplies unconnected in normal use, such as some MMC devices. -- Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, hosted by The Linux Foundation ^ permalink raw reply related [flat|nested] 12+ messages in thread
* Re: [PATCH v2 1/4] devicetree: bindings: Properly document micrel ks8851 SPI chips 2014-05-27 21:40 ` Stephen Boyd @ 2014-05-28 9:44 ` Mark Brown 2014-05-28 15:16 ` Uwe Kleine-König 1 sibling, 0 replies; 12+ messages in thread From: Mark Brown @ 2014-05-28 9:44 UTC (permalink / raw) To: Stephen Boyd Cc: David S . Miller, Nishanth Menon, Mark Rutland, Pawel Moll, Ian Campbell, linux-arm-msm, Kumar Gala, linux-kernel, devicetree, Rob Herring, netdev, linux-arm-kernel, Uwe Kleine-König [-- Attachment #1: Type: text/plain, Size: 1551 bytes --] On Tue, May 27, 2014 at 02:40:15PM -0700, Stephen Boyd wrote: > On 05/24/14 05:48, Mark Brown wrote: > > That said it looks like this is intended to be a supply for an external > > PHY rather than the device itself, but even so my original question > > about it being able to operate without power still applies. Looking at > > the code it's certainly not doing any of the handling of a missing > > supply that I would associate with using _optional(). > I agree, both supplies don't look optional. Unfortunately > efm32gg-dk3750.dts doesn't look to be listing any supply, and this > driver only recently got support for the VDD_A3.3 supply that the omap > board uses (adding Uwe for any comments on efm setup). I presume on > these boards VDD_IO is tied to some always on power source that software > doesn't want to deal with. Nishant, what's VDD_IO connected to on omap? > What's the proper solution here? Should we use regulator_get() and check > for EPROBE_DEFER and ignore other errors? As an implementation extension if no supply is specified at all the regulator API will happily substitute in a dummy if the board is using DT or ACPI, or if it has specified full constraints. > Should the get_optional() variant just drop the "Other consumers will > be... " part and should the get_exclusive() variant say "obtain this > regulator while this reference is held" ? Yes. > From: Stephen Boyd <sboyd@codeaurora.org> > Subject: [PATCH] regulator: Fix regulator_get_{optional,exclusive}() > documentation Documentation/SubmittingPatches. [-- Attachment #2: Digital signature --] [-- Type: application/pgp-signature, Size: 836 bytes --] ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH v2 1/4] devicetree: bindings: Properly document micrel ks8851 SPI chips 2014-05-27 21:40 ` Stephen Boyd 2014-05-28 9:44 ` Mark Brown @ 2014-05-28 15:16 ` Uwe Kleine-König 2014-05-28 16:38 ` Rob Herring 2014-05-28 17:12 ` Mark Brown 1 sibling, 2 replies; 12+ messages in thread From: Uwe Kleine-König @ 2014-05-28 15:16 UTC (permalink / raw) To: Stephen Boyd Cc: Mark Brown, David S . Miller, Nishanth Menon, Mark Rutland, Pawel Moll, Ian Campbell, linux-arm-msm, Kumar Gala, linux-kernel, devicetree, Rob Herring, netdev, linux-arm-kernel Hello Stephen, On Tue, May 27, 2014 at 02:40:15PM -0700, Stephen Boyd wrote: > On 05/24/14 05:48, Mark Brown wrote: > > On Fri, May 23, 2014 at 12:57:17PM -0700, Stephen Boyd wrote: > > > >> Optional properties: > >> -- vdd-supply: supply for Ethernet mac > >> +- vdd-supply: analog 3.3V supply for Ethernet mac > >> +- vdd-io-supply: digital 1.8V IO supply for Ethernet mac > > So, according to the datasheet I managed to find this device has a > > supply VDD_IO (so normally written vdd-io-supply here), some other > > supplies which are tied to VDD_IO (so can probably be omitted) and a > > supply VDD_A3.3 none of which are optional. There is an internal > > regulator which can be used to drop a higher voltage VDD_IO down for > > some of the supplies tied to it but that's essentially a noop from > > software as far as I can tell. None of these supplies are obviously > > optional, though I've not read the datasheet in detail so I may have > > missed something here. There is a difference between the supply being optional for the hardware to work and the need to specify it in the device tree, isn't it? My expectation is that when it's not specified there is just nothing the the software needs to care for. > > That said it looks like this is intended to be a supply for an external > > PHY rather than the device itself, but even so my original question > > about it being able to operate without power still applies. Looking at > > the code it's certainly not doing any of the handling of a missing > > supply that I would associate with using _optional(). > > I agree, both supplies don't look optional. Unfortunately > efm32gg-dk3750.dts doesn't look to be listing any supply, and this > driver only recently got support for the VDD_A3.3 supply that the omap > board uses (adding Uwe for any comments on efm setup). I presume on If I read the schematic correctly there is nothing to regulate on the efm32 dev board. If you want to take a look on the schematic yourself, it's contained in the documentation package available at http://www.silabs.com/products/mcu/lowpower/pages/efm32gg-dk3750.aspx . BDR3201A_A02_sch.pdf, page 3 of 22. Best regards Uwe -- Pengutronix e.K. | Uwe Kleine-König | Industrial Linux Solutions | http://www.pengutronix.de/ | ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH v2 1/4] devicetree: bindings: Properly document micrel ks8851 SPI chips 2014-05-28 15:16 ` Uwe Kleine-König @ 2014-05-28 16:38 ` Rob Herring 2014-05-28 17:12 ` Mark Brown 1 sibling, 0 replies; 12+ messages in thread From: Rob Herring @ 2014-05-28 16:38 UTC (permalink / raw) To: Uwe Kleine-König Cc: Stephen Boyd, Mark Brown, David S . Miller, Nishanth Menon, Mark Rutland, Pawel Moll, Ian Campbell, linux-arm-msm, Kumar Gala, linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, Rob Herring, netdev, linux-arm-kernel@lists.infradead.org On Wed, May 28, 2014 at 10:16 AM, Uwe Kleine-König <u.kleine-koenig@pengutronix.de> wrote: > Hello Stephen, > > On Tue, May 27, 2014 at 02:40:15PM -0700, Stephen Boyd wrote: >> On 05/24/14 05:48, Mark Brown wrote: >> > On Fri, May 23, 2014 at 12:57:17PM -0700, Stephen Boyd wrote: >> > >> >> Optional properties: >> >> -- vdd-supply: supply for Ethernet mac >> >> +- vdd-supply: analog 3.3V supply for Ethernet mac >> >> +- vdd-io-supply: digital 1.8V IO supply for Ethernet mac >> > So, according to the datasheet I managed to find this device has a >> > supply VDD_IO (so normally written vdd-io-supply here), some other >> > supplies which are tied to VDD_IO (so can probably be omitted) and a >> > supply VDD_A3.3 none of which are optional. There is an internal >> > regulator which can be used to drop a higher voltage VDD_IO down for >> > some of the supplies tied to it but that's essentially a noop from >> > software as far as I can tell. None of these supplies are obviously >> > optional, though I've not read the datasheet in detail so I may have >> > missed something here. > There is a difference between the supply being optional for the hardware > to work and the need to specify it in the device tree, isn't it? My > expectation is that when it's not specified there is just nothing the > the software needs to care for. Yes, agreed. Of course you could have cases where a supply at the h/w level is optional like if a supply can be powered externally or via an internal regulator. Those cases will have to be made clear in the binding, but a heading "Optional properties" in a binding doc means properties which are optional to specify in DT. Rob ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH v2 1/4] devicetree: bindings: Properly document micrel ks8851 SPI chips 2014-05-28 15:16 ` Uwe Kleine-König 2014-05-28 16:38 ` Rob Herring @ 2014-05-28 17:12 ` Mark Brown [not found] ` <20140528171219.GD5099-GFdadSzt00ze9xe1eoZjHA@public.gmane.org> 1 sibling, 1 reply; 12+ messages in thread From: Mark Brown @ 2014-05-28 17:12 UTC (permalink / raw) To: Uwe Kleine-König Cc: Stephen Boyd, David S . Miller, Nishanth Menon, Mark Rutland, Pawel Moll, Ian Campbell, linux-arm-msm, Kumar Gala, linux-kernel, devicetree, Rob Herring, netdev, linux-arm-kernel [-- Attachment #1: Type: text/plain, Size: 3015 bytes --] On Wed, May 28, 2014 at 05:16:46PM +0200, Uwe Kleine-König wrote: > On Tue, May 27, 2014 at 02:40:15PM -0700, Stephen Boyd wrote: > > On 05/24/14 05:48, Mark Brown wrote: > > > So, according to the datasheet I managed to find this device has a > > > supply VDD_IO (so normally written vdd-io-supply here), some other > > > supplies which are tied to VDD_IO (so can probably be omitted) and a > > > supply VDD_A3.3 none of which are optional. There is an internal > > > regulator which can be used to drop a higher voltage VDD_IO down for > > > some of the supplies tied to it but that's essentially a noop from > > > software as far as I can tell. None of these supplies are obviously > > > optional, though I've not read the datasheet in detail so I may have > > > missed something here. > There is a difference between the supply being optional for the hardware > to work and the need to specify it in the device tree, isn't it? My > expectation is that when it's not specified there is just nothing the > the software needs to care for. If the supply must always be physically present the bindings should be specified as it being mandatory and the code written in that fashion; as an extension Linux will put a dummy in but this is attempting to handle incorrect DTs. This means we have functional error handling in cases where there is something to worry about and simplifies the code using the regulator. regulator_get_optional() should *only* be used if the supply may be omitted from the physical design and should generally always be accompanied by code which does something substantially different such as using an internal regulator or changing the source for a reference voltage instead. > > > That said it looks like this is intended to be a supply for an external > > > PHY rather than the device itself, but even so my original question > > > about it being able to operate without power still applies. Looking at > > > the code it's certainly not doing any of the handling of a missing > > > supply that I would associate with using _optional(). > > I agree, both supplies don't look optional. Unfortunately > > efm32gg-dk3750.dts doesn't look to be listing any supply, and this > > driver only recently got support for the VDD_A3.3 supply that the omap > > board uses (adding Uwe for any comments on efm setup). I presume on > If I read the schematic correctly there is nothing to regulate on the > efm32 dev board. If you want to take a look on the schematic yourself, > it's contained in the documentation package available at > http://www.silabs.com/products/mcu/lowpower/pages/efm32gg-dk3750.aspx . > BDR3201A_A02_sch.pdf, page 3 of 22. That shows all the supplies connected to fixed voltage regulators (including the internal 1.8V LDO); the device tree should represent this accurately though the internal 1.8V regulator could be omitted for simplicity. It would be a remarkable device that was able to operate without power. [-- Attachment #2: Digital signature --] [-- Type: application/pgp-signature, Size: 836 bytes --] ^ permalink raw reply [flat|nested] 12+ messages in thread
[parent not found: <20140528171219.GD5099-GFdadSzt00ze9xe1eoZjHA@public.gmane.org>]
* Re: [PATCH v2 1/4] devicetree: bindings: Properly document micrel ks8851 SPI chips [not found] ` <20140528171219.GD5099-GFdadSzt00ze9xe1eoZjHA@public.gmane.org> @ 2014-05-28 19:44 ` Stephen Boyd 2014-05-28 19:49 ` Mark Brown 0 siblings, 1 reply; 12+ messages in thread From: Stephen Boyd @ 2014-05-28 19:44 UTC (permalink / raw) To: Mark Brown Cc: Uwe Kleine-König, David S . Miller, Nishanth Menon, Mark Rutland, Pawel Moll, Ian Campbell, linux-arm-msm-u79uwXL29TY76Z2rM5mHXA, Kumar Gala, linux-kernel-u79uwXL29TY76Z2rM5mHXA, devicetree-u79uwXL29TY76Z2rM5mHXA, Rob Herring, netdev-u79uwXL29TY76Z2rM5mHXA, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r On 05/28/14 10:12, Mark Brown wrote: > On Wed, May 28, 2014 at 05:16:46PM +0200, Uwe Kleine-König wrote: >> On Tue, May 27, 2014 at 02:40:15PM -0700, Stephen Boyd wrote: >>> On 05/24/14 05:48, Mark Brown wrote: >>>> So, according to the datasheet I managed to find this device has a >>>> supply VDD_IO (so normally written vdd-io-supply here), some other >>>> supplies which are tied to VDD_IO (so can probably be omitted) and a >>>> supply VDD_A3.3 none of which are optional. There is an internal >>>> regulator which can be used to drop a higher voltage VDD_IO down for >>>> some of the supplies tied to it but that's essentially a noop from >>>> software as far as I can tell. None of these supplies are obviously >>>> optional, though I've not read the datasheet in detail so I may have >>>> missed something here. >> There is a difference between the supply being optional for the hardware >> to work and the need to specify it in the device tree, isn't it? My >> expectation is that when it's not specified there is just nothing the >> the software needs to care for. > If the supply must always be physically present the bindings should be > specified as it being mandatory and the code written in that fashion; as > an extension Linux will put a dummy in but this is attempting to handle > incorrect DTs. This means we have functional error handling in cases > where there is something to worry about and simplifies the code using > the regulator. Ok, you're saying the opposite of Rob. Should it be required or optional in the DT binding? > > regulator_get_optional() should *only* be used if the supply may be > omitted from the physical design and should generally always be > accompanied by code which does something substantially different such as > using an internal regulator or changing the source for a reference > voltage instead. > > Ok. Dave M has already picked up all these patches so I'll send a patch to replace regulator_get_optional() with regulator_get() and fix up the error handling unless I hear otherwise. -- Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, hosted by The Linux Foundation -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org More majordomo info at http://vger.kernel.org/majordomo-info.html ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH v2 1/4] devicetree: bindings: Properly document micrel ks8851 SPI chips 2014-05-28 19:44 ` Stephen Boyd @ 2014-05-28 19:49 ` Mark Brown 0 siblings, 0 replies; 12+ messages in thread From: Mark Brown @ 2014-05-28 19:49 UTC (permalink / raw) To: Stephen Boyd Cc: Uwe Kleine-König, David S . Miller, Nishanth Menon, Mark Rutland, Pawel Moll, Ian Campbell, linux-arm-msm, Kumar Gala, linux-kernel, devicetree, Rob Herring, netdev, linux-arm-kernel [-- Attachment #1: Type: text/plain, Size: 996 bytes --] On Wed, May 28, 2014 at 12:44:35PM -0700, Stephen Boyd wrote: > On 05/28/14 10:12, Mark Brown wrote: > > If the supply must always be physically present the bindings should be > > specified as it being mandatory and the code written in that fashion; as > > an extension Linux will put a dummy in but this is attempting to handle > > incorrect DTs. This means we have functional error handling in cases > > where there is something to worry about and simplifies the code using > > the regulator. > Ok, you're saying the opposite of Rob. Should it be required or optional > in the DT binding? I'm saying it should be required. The implementation accepts it as an extension (a recent extension at that). > Ok. Dave M has already picked up all these patches so I'll send a patch > to replace regulator_get_optional() with regulator_get() and fix up the > error handling unless I hear otherwise. Yes, please. I'm much more worried about the abuse of regulator_get_optional() than the binding. [-- Attachment #2: Digital signature --] [-- Type: application/pgp-signature, Size: 836 bytes --] ^ permalink raw reply [flat|nested] 12+ messages in thread
* Re: [PATCH v2 0/4] ks8851 DT/regulator/gpio updates 2014-05-23 19:57 [PATCH v2 0/4] ks8851 DT/regulator/gpio updates Stephen Boyd 2014-05-23 19:57 ` [PATCH v2 1/4] devicetree: bindings: Properly document micrel ks8851 SPI chips Stephen Boyd @ 2014-05-24 18:03 ` David Miller 1 sibling, 0 replies; 12+ messages in thread From: David Miller @ 2014-05-24 18:03 UTC (permalink / raw) To: sboyd Cc: linux-kernel, linux-arm-msm, linux-arm-kernel, netdev, nm, robh+dt, pawel.moll, mark.rutland, ijc+devicetree, galak, devicetree From: Stephen Boyd <sboyd@codeaurora.org> Date: Fri, 23 May 2014 12:57:16 -0700 > This set of patches properly documents the micrel ks8851 spi ethernet > controller, converts to devm_regulator_get_optional() to make error > paths slightly simpler, and finally adds supports for another > optional regulator and a reset gpio. This allows me to use the ks8851 > on my MSM8960 CDP board. > > Changes since v1: > * Dropped vendor prefix patch as that should go through DT tree Series applied, thanks Stephen! ^ permalink raw reply [flat|nested] 12+ messages in thread
end of thread, other threads:[~2014-05-28 19:49 UTC | newest] Thread overview: 12+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2014-05-23 19:57 [PATCH v2 0/4] ks8851 DT/regulator/gpio updates Stephen Boyd 2014-05-23 19:57 ` [PATCH v2 1/4] devicetree: bindings: Properly document micrel ks8851 SPI chips Stephen Boyd 2014-05-24 12:20 ` Mark Brown 2014-05-24 12:48 ` Mark Brown 2014-05-27 21:40 ` Stephen Boyd 2014-05-28 9:44 ` Mark Brown 2014-05-28 15:16 ` Uwe Kleine-König 2014-05-28 16:38 ` Rob Herring 2014-05-28 17:12 ` Mark Brown [not found] ` <20140528171219.GD5099-GFdadSzt00ze9xe1eoZjHA@public.gmane.org> 2014-05-28 19:44 ` Stephen Boyd 2014-05-28 19:49 ` Mark Brown 2014-05-24 18:03 ` [PATCH v2 0/4] ks8851 DT/regulator/gpio updates David Miller
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).