lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <20211125210428.GA27075@gnbcxl0045.gnb.st.com>
Date:   Thu, 25 Nov 2021 22:04:28 +0100
From:   Alain Volmat <avolmat@...com>
To:     wsa@...nel.org, broonie@...nel.org, robh+dt@...nel.org
Cc:     linux-i2c@...r.kernel.org, linux-spi@...r.kernel.org,
        linux-kernel@...r.kernel.org, linux-arm-kernel@...ts.infradead.org,
        Patrice Chotard <patrice.chotard@...s.st.com>
Subject: [RFC] sti: Conflict in node name for an IP supporting both I2C and
 SPI

Hello,

in the STi platform [1], the I2C and SPI controllers are handled by the
same IP, which can be configured in either one or the other mode.
This leads to warnings during the DT build and I was wondering if you could
give me some hints about how such situation should be handled since this
concern DT warnings but also bindings and YAML.

In the SoC DT (dtsi), for each IP, there are 2 entries:

One for the I2C mode (implemented by the driver i2c/busses/i2c-st.c)
                i2c@...0000 {
                        compatible = "st,comms-ssc4-i2c";
                        interrupts = <GIC_SPI 112 IRQ_TYPE_LEVEL_HIGH>;
                        reg = <0x9840000 0x110>;
                        clocks = <&clk_s_c0_flexgen CLK_EXT2F_A9>;
                        clock-names = "ssc";
                        clock-frequency = <400000>;
                        pinctrl-names = "default";
                        pinctrl-0 = <&pinctrl_i2c0_default>;
                        #address-cells = <1>;
                        #size-cells = <0>;

                        status = "disabled";
                };

One for the SPI mode (implemented by the driver spi/spi-st-ssc4.c)
                spi@...0000 {
                        compatible = "st,comms-ssc4-spi";
                        reg = <0x9840000 0x110>;
                        interrupts = <GIC_SPI 112 IRQ_TYPE_LEVEL_HIGH>;
                        clocks = <&clk_s_c0_flexgen CLK_EXT2F_A9>;
                        clock-names = "ssc";
                        pinctrl-0 = <&pinctrl_spi0_default>;
                        pinctrl-names = "default";
                        #address-cells = <1>;
                        #size-cells = <0>;

                        status = "disabled";
                };

So basically, there are 2 nodes, one for each mode, and enabling one or the
other mode is done within the board DT.
Since the address is the same, this obviously leads to warning during the build
of the DT.

arch/arm/boot/dts/stih407-family.dtsi:363.15-376.5: Warning (unique_unit_address): /soc/i2c@...0000: duplicate unit-address (also used in node /soc/spi@...0000)

In order to fix this, I could think of only having one node (for example
I2C) in the SoC DT (dtsi) and then, within each board DT override some of the
properties (including the compatible) to make it be a SPI node when necessary.
However in such case I think this would leads to an issue regarding Yaml.
The YAML for I2C controller [2] mentions that the node name pattern should
be "^i2c(@.*)?", while in case of a SPI controller [3] it should be
"^spi(@.*|-[0-9a-f])*$".
For that reason, this way doesn't seem possible.

What would you advice to handle such case ?

Regards,
Alain

[1] arch/arm/boot/dts/stih407-family.dtsi
[2] schemas/i2c/i2c-controller.yaml
[3] Documentation/devicetree/bindings/spi/spi-controller.yaml

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ