Message ID | Yk3nShkFzNJaI3/Z@robh.at.kernel.org (mailing list archive) |
---|---|
State | Accepted |
Commit | 1a67653de0ddc67d274ce2762265ae18d58cc09a |
Headers | show |
Series | [RESEND] arm64: dts: tegra: Fix boolean properties with values | expand |
Hello: This patch was applied to soc/soc.git (arm/fixes) by Arnd Bergmann <arnd@arndb.de>: On Wed, 6 Apr 2022 14:17:30 -0500 you wrote: > Boolean properties in DT are present or not present and don't take a value. > A property such as 'foo = <0>;' evaluated to true. IOW, the value doesn't > matter. > > It may have been intended that 0 values are false, but there is no change > in behavior with this patch. > > [...] Here is the summary with links: - [RESEND] arm64: dts: tegra: Fix boolean properties with values https://git.kernel.org/soc/soc/c/1a67653de0dd You are awesome, thank you!
On Wed, Apr 06, 2022 at 02:17:30PM -0500, Rob Herring wrote: > Boolean properties in DT are present or not present and don't take a value. > A property such as 'foo = <0>;' evaluated to true. IOW, the value doesn't > matter. > > It may have been intended that 0 values are false, but there is no change > in behavior with this patch. > > Signed-off-by: Rob Herring <robh@kernel.org> > --- > Can someone apply this for 5.18. > > arch/arm64/boot/dts/nvidia/tegra186-p3310.dtsi | 8 ++++---- > .../boot/dts/nvidia/tegra186-p3509-0000+p3636-0001.dts | 8 ++++---- > arch/arm64/boot/dts/nvidia/tegra194-p2888.dtsi | 6 +++--- > arch/arm64/boot/dts/nvidia/tegra194-p3668.dtsi | 6 +++--- > arch/arm64/boot/dts/nvidia/tegra210-p2180.dtsi | 6 +++--- > arch/arm64/boot/dts/nvidia/tegra210-p2894.dtsi | 8 ++++---- > arch/arm64/boot/dts/nvidia/tegra210-p3450-0000.dts | 8 ++++---- > arch/arm64/boot/dts/nvidia/tegra210-smaug.dts | 4 ++-- > 8 files changed, 27 insertions(+), 27 deletions(-) This causes multiple regressions on Tegra boards. The reason for this is that these properties are not in fact boolean, despite what the DT bindings say. If you look at the code that handles these, you'll notice that they are single-cell properties, typically with <0> and <1> values. What may have led to the conclusion that these are boolean is that there is also a special case where these can be left out, but the meaning of that is not the "false" (<0>) value. Instead, leaving these out means that the values should be left at whatever is currently in the register. See pinconf_generic_parse_dt_config() and parse_dt_cfg() specifically in drivers/pinctrl/pinconf-generic.c. Arnd, can you please revert this so that these boards can be unbroken? It's a bit unfortunate because there seem to be other platforms that also employ these in the boolean form that Rob mentioned, but I think it is those that probably need fixing instead. Not sure what the intentions were for those. Adding Bjorn for MSM, the Nuvoton and STM32 folks. Thierry
On 12/04/2022 10:05, Thierry Reding wrote: > On Wed, Apr 06, 2022 at 02:17:30PM -0500, Rob Herring wrote: >> Boolean properties in DT are present or not present and don't take a value. >> A property such as 'foo = <0>;' evaluated to true. IOW, the value doesn't >> matter. >> >> It may have been intended that 0 values are false, but there is no change >> in behavior with this patch. >> >> Signed-off-by: Rob Herring <robh@kernel.org> >> --- >> Can someone apply this for 5.18. >> >> arch/arm64/boot/dts/nvidia/tegra186-p3310.dtsi | 8 ++++---- >> .../boot/dts/nvidia/tegra186-p3509-0000+p3636-0001.dts | 8 ++++---- >> arch/arm64/boot/dts/nvidia/tegra194-p2888.dtsi | 6 +++--- >> arch/arm64/boot/dts/nvidia/tegra194-p3668.dtsi | 6 +++--- >> arch/arm64/boot/dts/nvidia/tegra210-p2180.dtsi | 6 +++--- >> arch/arm64/boot/dts/nvidia/tegra210-p2894.dtsi | 8 ++++---- >> arch/arm64/boot/dts/nvidia/tegra210-p3450-0000.dts | 8 ++++---- >> arch/arm64/boot/dts/nvidia/tegra210-smaug.dts | 4 ++-- >> 8 files changed, 27 insertions(+), 27 deletions(-) > > This causes multiple regressions on Tegra boards. The reason for this is > that these properties are not in fact boolean, despite what the DT > bindings say. If you look at the code that handles these, you'll notice > that they are single-cell properties, typically with <0> and <1> values. > What may have led to the conclusion that these are boolean is that there > is also a special case where these can be left out, but the meaning of > that is not the "false" (<0>) value. Instead, leaving these out means > that the values should be left at whatever is currently in the register. > > See pinconf_generic_parse_dt_config() and parse_dt_cfg() specifically in > drivers/pinctrl/pinconf-generic.c. > > Arnd, can you please revert this so that these boards can be unbroken? Arnd, any feedback on this? A lot of Tegra boards are still not booting with v5.18-rc4. Jon
On Mon, Apr 25, 2022 at 1:20 PM Jon Hunter <jonathanh@nvidia.com> wrote: > On 12/04/2022 10:05, Thierry Reding wrote: > > On Wed, Apr 06, 2022 at 02:17:30PM -0500, Rob Herring wrote: > >> Boolean properties in DT are present or not present and don't take a value. > >> A property such as 'foo = <0>;' evaluated to true. IOW, the value doesn't > >> matter. > >> > >> It may have been intended that 0 values are false, but there is no change > >> in behavior with this patch. > >> > >> Signed-off-by: Rob Herring <robh@kernel.org> > >> --- > >> Can someone apply this for 5.18. > >> > >> arch/arm64/boot/dts/nvidia/tegra186-p3310.dtsi | 8 ++++---- > >> .../boot/dts/nvidia/tegra186-p3509-0000+p3636-0001.dts | 8 ++++---- > >> arch/arm64/boot/dts/nvidia/tegra194-p2888.dtsi | 6 +++--- > >> arch/arm64/boot/dts/nvidia/tegra194-p3668.dtsi | 6 +++--- > >> arch/arm64/boot/dts/nvidia/tegra210-p2180.dtsi | 6 +++--- > >> arch/arm64/boot/dts/nvidia/tegra210-p2894.dtsi | 8 ++++---- > >> arch/arm64/boot/dts/nvidia/tegra210-p3450-0000.dts | 8 ++++---- > >> arch/arm64/boot/dts/nvidia/tegra210-smaug.dts | 4 ++-- > >> 8 files changed, 27 insertions(+), 27 deletions(-) > > > > This causes multiple regressions on Tegra boards. The reason for this is > > that these properties are not in fact boolean, despite what the DT > > bindings say. If you look at the code that handles these, you'll notice > > that they are single-cell properties, typically with <0> and <1> values. > > What may have led to the conclusion that these are boolean is that there > > is also a special case where these can be left out, but the meaning of > > that is not the "false" (<0>) value. Instead, leaving these out means > > that the values should be left at whatever is currently in the register. > > > > See pinconf_generic_parse_dt_config() and parse_dt_cfg() specifically in > > drivers/pinctrl/pinconf-generic.c. > > > > Arnd, can you please revert this so that these boards can be unbroken? > > > Arnd, any feedback on this? A lot of Tegra boards are still not booting > with v5.18-rc4. I have reverted this commit now, sorry for missing the earlier report. https://git.kernel.org/pub/scm/linux/kernel/git/soc/soc.git/commit/?h=arm/fixes > > Adding Bjorn for MSM, the Nuvoton and STM32 folks. I'll wait for the others to reply, but I do agree that these are likely broken as well. Could one of you propose a patch to make the binding describe what the kernel code actually expects here? Arnd
On Tue, Apr 12, 2022 at 11:05:15AM +0200, Thierry Reding wrote: > On Wed, Apr 06, 2022 at 02:17:30PM -0500, Rob Herring wrote: > > Boolean properties in DT are present or not present and don't take a value. > > A property such as 'foo = <0>;' evaluated to true. IOW, the value doesn't > > matter. > > > > It may have been intended that 0 values are false, but there is no change > > in behavior with this patch. > > > > Signed-off-by: Rob Herring <robh@kernel.org> > > --- > > Can someone apply this for 5.18. > > > > arch/arm64/boot/dts/nvidia/tegra186-p3310.dtsi | 8 ++++---- > > .../boot/dts/nvidia/tegra186-p3509-0000+p3636-0001.dts | 8 ++++---- > > arch/arm64/boot/dts/nvidia/tegra194-p2888.dtsi | 6 +++--- > > arch/arm64/boot/dts/nvidia/tegra194-p3668.dtsi | 6 +++--- > > arch/arm64/boot/dts/nvidia/tegra210-p2180.dtsi | 6 +++--- > > arch/arm64/boot/dts/nvidia/tegra210-p2894.dtsi | 8 ++++---- > > arch/arm64/boot/dts/nvidia/tegra210-p3450-0000.dts | 8 ++++---- > > arch/arm64/boot/dts/nvidia/tegra210-smaug.dts | 4 ++-- > > 8 files changed, 27 insertions(+), 27 deletions(-) > > This causes multiple regressions on Tegra boards. The reason for this is > that these properties are not in fact boolean, despite what the DT > bindings say. If you look at the code that handles these, you'll notice > that they are single-cell properties, typically with <0> and <1> values. > What may have led to the conclusion that these are boolean is that there > is also a special case where these can be left out, but the meaning of > that is not the "false" (<0>) value. Instead, leaving these out means > that the values should be left at whatever is currently in the register. The majority of users do use boolean in their DT. Treating these as tri-state doesn't make much sense because what does setting the pin to !push-pull mean? Isn't that just open-drain or open-source for which also have boolean values? Allowing these to have values is unnecessary and enables more invalid combinations. > See pinconf_generic_parse_dt_config() and parse_dt_cfg() specifically in > drivers/pinctrl/pinconf-generic.c. of_property_read_u32() will return -EOVERFLOW on a boolean value and then the default value (0) is used. However, at least for QCom the value is ignored. Looking at max77620, the value is used. However, it is clear that push-pull and open-drain operate on the same register bit. > Arnd, can you please revert this so that these boards can be unbroken? That's fine for now... > It's a bit unfortunate because there seem to be other platforms that > also employ these in the boolean form that Rob mentioned, but I think it > is those that probably need fixing instead. Not sure what the intentions > were for those. I still think it's Tegra that needs fixing. The question is to what extent forwards and backwards compatibity is needed on these platforms? I'm not sure if we can fix new dtb with old kernel. A new dtb with a stable kernel update would be plausible. It may work just replacing 'drive-push-pull = <0>' cases with 'drive-open-drain'. Rob
diff --git a/arch/arm64/boot/dts/nvidia/tegra186-p3310.dtsi b/arch/arm64/boot/dts/nvidia/tegra186-p3310.dtsi index aff857df25cf..1df84335925b 100644 --- a/arch/arm64/boot/dts/nvidia/tegra186-p3310.dtsi +++ b/arch/arm64/boot/dts/nvidia/tegra186-p3310.dtsi @@ -262,25 +262,25 @@ gpio3 { gpio4 { pins = "gpio4"; function = "32k-out1"; - drive-push-pull = <1>; + drive-push-pull; }; gpio5 { pins = "gpio5"; function = "gpio"; - drive-push-pull = <0>; + drive-push-pull; }; gpio6 { pins = "gpio6"; function = "gpio"; - drive-push-pull = <1>; + drive-push-pull; }; gpio7 { pins = "gpio7"; function = "gpio"; - drive-push-pull = <0>; + drive-push-pull; }; }; diff --git a/arch/arm64/boot/dts/nvidia/tegra186-p3509-0000+p3636-0001.dts b/arch/arm64/boot/dts/nvidia/tegra186-p3509-0000+p3636-0001.dts index 4631504c3c7a..1ab132c152bb 100644 --- a/arch/arm64/boot/dts/nvidia/tegra186-p3509-0000+p3636-0001.dts +++ b/arch/arm64/boot/dts/nvidia/tegra186-p3509-0000+p3636-0001.dts @@ -462,25 +462,25 @@ gpio3 { gpio4 { pins = "gpio4"; function = "32k-out1"; - drive-push-pull = <1>; + drive-push-pull; }; gpio5 { pins = "gpio5"; function = "gpio"; - drive-push-pull = <0>; + drive-push-pull; }; gpio6 { pins = "gpio6"; function = "gpio"; - drive-push-pull = <1>; + drive-push-pull; }; gpio7 { pins = "gpio7"; function = "gpio"; - drive-push-pull = <1>; + drive-push-pull; }; }; diff --git a/arch/arm64/boot/dts/nvidia/tegra194-p2888.dtsi b/arch/arm64/boot/dts/nvidia/tegra194-p2888.dtsi index a7d7cfd66379..634d0f493c2e 100644 --- a/arch/arm64/boot/dts/nvidia/tegra194-p2888.dtsi +++ b/arch/arm64/boot/dts/nvidia/tegra194-p2888.dtsi @@ -174,19 +174,19 @@ gpio3 { gpio4 { pins = "gpio4"; function = "32k-out1"; - drive-push-pull = <1>; + drive-push-pull; }; gpio6 { pins = "gpio6"; function = "gpio"; - drive-push-pull = <1>; + drive-push-pull; }; gpio7 { pins = "gpio7"; function = "gpio"; - drive-push-pull = <0>; + drive-push-pull; }; }; diff --git a/arch/arm64/boot/dts/nvidia/tegra194-p3668.dtsi b/arch/arm64/boot/dts/nvidia/tegra194-p3668.dtsi index 0bd66f9c620b..0b219e72765e 100644 --- a/arch/arm64/boot/dts/nvidia/tegra194-p3668.dtsi +++ b/arch/arm64/boot/dts/nvidia/tegra194-p3668.dtsi @@ -148,19 +148,19 @@ gpio3 { gpio4 { pins = "gpio4"; function = "32k-out1"; - drive-push-pull = <1>; + drive-push-pull; }; gpio6 { pins = "gpio6"; function = "gpio"; - drive-push-pull = <1>; + drive-push-pull; }; gpio7 { pins = "gpio7"; function = "gpio"; - drive-push-pull = <0>; + drive-push-pull; }; }; diff --git a/arch/arm64/boot/dts/nvidia/tegra210-p2180.dtsi b/arch/arm64/boot/dts/nvidia/tegra210-p2180.dtsi index 75eb743a7242..0fe772b04bd0 100644 --- a/arch/arm64/boot/dts/nvidia/tegra210-p2180.dtsi +++ b/arch/arm64/boot/dts/nvidia/tegra210-p2180.dtsi @@ -59,7 +59,7 @@ gpio0 { gpio1 { pins = "gpio1"; function = "fps-out"; - drive-push-pull = <1>; + drive-push-pull; maxim,active-fps-source = <MAX77620_FPS_SRC_0>; maxim,active-fps-power-up-slot = <7>; maxim,active-fps-power-down-slot = <0>; @@ -68,7 +68,7 @@ gpio1 { gpio2_3 { pins = "gpio2", "gpio3"; function = "fps-out"; - drive-open-drain = <1>; + drive-open-drain; maxim,active-fps-source = <MAX77620_FPS_SRC_0>; }; @@ -80,7 +80,7 @@ gpio4 { gpio5_6_7 { pins = "gpio5", "gpio6", "gpio7"; function = "gpio"; - drive-push-pull = <1>; + drive-push-pull; }; }; diff --git a/arch/arm64/boot/dts/nvidia/tegra210-p2894.dtsi b/arch/arm64/boot/dts/nvidia/tegra210-p2894.dtsi index 10347b6e6e84..936a309e288c 100644 --- a/arch/arm64/boot/dts/nvidia/tegra210-p2894.dtsi +++ b/arch/arm64/boot/dts/nvidia/tegra210-p2894.dtsi @@ -1351,7 +1351,7 @@ gpio0 { gpio1 { pins = "gpio1"; function = "fps-out"; - drive-push-pull = <1>; + drive-push-pull; maxim,active-fps-source = <MAX77620_FPS_SRC_0>; maxim,active-fps-power-up-slot = <7>; maxim,active-fps-power-down-slot = <0>; @@ -1360,14 +1360,14 @@ gpio1 { gpio2 { pins = "gpio2"; function = "fps-out"; - drive-open-drain = <1>; + drive-open-drain; maxim,active-fps-source = <MAX77620_FPS_SRC_0>; }; gpio3 { pins = "gpio3"; function = "fps-out"; - drive-open-drain = <1>; + drive-open-drain; maxim,active-fps-source = <MAX77620_FPS_SRC_0>; }; @@ -1379,7 +1379,7 @@ gpio4 { gpio5_6_7 { pins = "gpio5", "gpio6", "gpio7"; function = "gpio"; - drive-push-pull = <1>; + drive-push-pull; }; }; diff --git a/arch/arm64/boot/dts/nvidia/tegra210-p3450-0000.dts b/arch/arm64/boot/dts/nvidia/tegra210-p3450-0000.dts index 72c2dc3c14ea..f6446120c267 100644 --- a/arch/arm64/boot/dts/nvidia/tegra210-p3450-0000.dts +++ b/arch/arm64/boot/dts/nvidia/tegra210-p3450-0000.dts @@ -195,7 +195,7 @@ gpio0 { gpio1 { pins = "gpio1"; function = "fps-out"; - drive-push-pull = <1>; + drive-push-pull; maxim,active-fps-source = <MAX77620_FPS_SRC_NONE>; maxim,active-fps-power-up-slot = <0>; maxim,active-fps-power-down-slot = <7>; @@ -204,7 +204,7 @@ gpio1 { gpio2 { pins = "gpio2"; function = "fps-out"; - drive-open-drain = <1>; + drive-open-drain; maxim,active-fps-source = <MAX77620_FPS_SRC_0>; maxim,active-fps-power-up-slot = <0>; maxim,active-fps-power-down-slot = <7>; @@ -213,7 +213,7 @@ gpio2 { gpio3 { pins = "gpio3"; function = "fps-out"; - drive-open-drain = <1>; + drive-open-drain; maxim,active-fps-source = <MAX77620_FPS_SRC_0>; maxim,active-fps-power-up-slot = <4>; maxim,active-fps-power-down-slot = <3>; @@ -227,7 +227,7 @@ gpio4 { gpio5_6_7 { pins = "gpio5", "gpio6", "gpio7"; function = "gpio"; - drive-push-pull = <1>; + drive-push-pull; }; }; diff --git a/arch/arm64/boot/dts/nvidia/tegra210-smaug.dts b/arch/arm64/boot/dts/nvidia/tegra210-smaug.dts index a263d51882ee..e42384f097d6 100644 --- a/arch/arm64/boot/dts/nvidia/tegra210-smaug.dts +++ b/arch/arm64/boot/dts/nvidia/tegra210-smaug.dts @@ -1386,7 +1386,7 @@ gpio0_1_2_7 { gpio3 { pins = "gpio3"; function = "fps-out"; - drive-open-drain = <1>; + drive-open-drain; maxim,active-fps-source = <MAX77620_FPS_SRC_0>; maxim,active-fps-power-up-slot = <4>; maxim,active-fps-power-down-slot = <2>; @@ -1395,7 +1395,7 @@ gpio3 { gpio5_6 { pins = "gpio5", "gpio6"; function = "gpio"; - drive-push-pull = <1>; + drive-push-pull; }; gpio4 {
Boolean properties in DT are present or not present and don't take a value. A property such as 'foo = <0>;' evaluated to true. IOW, the value doesn't matter. It may have been intended that 0 values are false, but there is no change in behavior with this patch. Signed-off-by: Rob Herring <robh@kernel.org> --- Can someone apply this for 5.18. arch/arm64/boot/dts/nvidia/tegra186-p3310.dtsi | 8 ++++---- .../boot/dts/nvidia/tegra186-p3509-0000+p3636-0001.dts | 8 ++++---- arch/arm64/boot/dts/nvidia/tegra194-p2888.dtsi | 6 +++--- arch/arm64/boot/dts/nvidia/tegra194-p3668.dtsi | 6 +++--- arch/arm64/boot/dts/nvidia/tegra210-p2180.dtsi | 6 +++--- arch/arm64/boot/dts/nvidia/tegra210-p2894.dtsi | 8 ++++---- arch/arm64/boot/dts/nvidia/tegra210-p3450-0000.dts | 8 ++++---- arch/arm64/boot/dts/nvidia/tegra210-smaug.dts | 4 ++-- 8 files changed, 27 insertions(+), 27 deletions(-)