2015-11-20 09:51:21

by Jisheng Zhang

[permalink] [raw]
Subject: [PATCH 0/2] Add I2C support for Marvell Berlin BG4CT

The first patch adds i2c nodes in the soc's dtsi, the second patch
enables all i2c nodes for BG4CT STB board.

NOTE: this series depends on the missed-in-v4.4rc1 patches:

http://lists.infradead.org/pipermail/linux-arm-kernel/2015-October/378634.html
http://lists.infradead.org/pipermail/linux-arm-kernel/2015-October/378635.html
http://lists.infradead.org/pipermail/linux-arm-kernel/2015-October/378638.html

Jisheng Zhang (2):
arm64: dts: berlin4ct: add I2C nodes for BG4CT
arm64: dts: berlin4ct: enable all i2c nodes for the STB board

arch/arm64/boot/dts/marvell/berlin4ct-stb.dts | 50 ++++++++++++++++++++++++++
arch/arm64/boot/dts/marvell/berlin4ct.dtsi | 52 +++++++++++++++++++++++++++
2 files changed, 102 insertions(+)

--
2.6.2


2015-11-20 09:51:24

by Jisheng Zhang

[permalink] [raw]
Subject: [PATCH 1/2] arm64: dts: berlin4ct: add I2C nodes for BG4CT

The Marvell Berlin BG4CT SoC has 4 TWSI which are compatible with the
Synopsys DesignWare I2C driver. Add the corresponding nodes.

Signed-off-by: Jisheng Zhang <[email protected]>
---
arch/arm64/boot/dts/marvell/berlin4ct.dtsi | 52 ++++++++++++++++++++++++++++++
1 file changed, 52 insertions(+)

diff --git a/arch/arm64/boot/dts/marvell/berlin4ct.dtsi b/arch/arm64/boot/dts/marvell/berlin4ct.dtsi
index cca4c41..39d0676 100644
--- a/arch/arm64/boot/dts/marvell/berlin4ct.dtsi
+++ b/arch/arm64/boot/dts/marvell/berlin4ct.dtsi
@@ -232,6 +232,32 @@
};
};

+ i2c0: i2c@1400 {
+ compatible = "snps,designware-i2c";
+ #address-cells = <1>;
+ #size-cells = <0>;
+ reg = <0x1400 0x100>;
+ clocks = <&clk CLK_APBCORE>;
+ i2c-sda-hold-time-ns = <35>;
+ i2c-sda-falling-time-ns = <425>;
+ i2c-scl-falling-time-ns = <205>;
+ interrupts = <4>;
+ status = "disabled";
+ };
+
+ i2c1: i2c@1800 {
+ compatible = "snps,designware-i2c";
+ #address-cells = <1>;
+ #size-cells = <0>;
+ reg = <0x1800 0x100>;
+ clocks = <&clk CLK_APBCORE>;
+ i2c-sda-hold-time-ns = <35>;
+ i2c-sda-falling-time-ns = <425>;
+ i2c-scl-falling-time-ns = <205>;
+ interrupts = <5>;
+ status = "disabled";
+ };
+
aic: interrupt-controller@3800 {
compatible = "snps,dw-apb-ictl";
reg = <0x3800 0x30>;
@@ -319,6 +345,32 @@
};
};

+ i2c2: i2c@b000 {
+ compatible = "snps,designware-i2c";
+ #address-cells = <1>;
+ #size-cells = <0>;
+ reg = <0xb000 0x100>;
+ clocks = <&osc>;
+ i2c-sda-hold-time-ns = <140>;
+ i2c-sda-falling-time-ns = <500>;
+ i2c-scl-falling-time-ns = <220>;
+ interrupts = <6>;
+ status = "disabled";
+ };
+
+ i2c3: i2c@c000 {
+ compatible = "snps,designware-i2c";
+ #address-cells = <1>;
+ #size-cells = <0>;
+ reg = <0xc000 0x100>;
+ clocks = <&osc>;
+ i2c-sda-hold-time-ns = <140>;
+ i2c-sda-falling-time-ns = <500>;
+ i2c-scl-falling-time-ns = <220>;
+ interrupts = <7>;
+ status = "disabled";
+ };
+
uart0: uart@d000 {
compatible = "snps,dw-apb-uart";
reg = <0xd000 0x100>;
--
2.6.2

2015-11-20 09:53:26

by Jisheng Zhang

[permalink] [raw]
Subject: [PATCH 2/2] arm64: dts: berlin4ct: enable all i2c nodes for the STB board

Enable all i2c nodes for the Marvell berlin BG4CT STB board.

Signed-off-by: Jisheng Zhang <[email protected]>
---
arch/arm64/boot/dts/marvell/berlin4ct-stb.dts | 50 +++++++++++++++++++++++++++
1 file changed, 50 insertions(+)

diff --git a/arch/arm64/boot/dts/marvell/berlin4ct-stb.dts b/arch/arm64/boot/dts/marvell/berlin4ct-stb.dts
index 348c37e..9e8e2e0 100644
--- a/arch/arm64/boot/dts/marvell/berlin4ct-stb.dts
+++ b/arch/arm64/boot/dts/marvell/berlin4ct-stb.dts
@@ -61,6 +61,56 @@
};
};

+&avio_pinctrl {
+ twsi1_pmux: twsi1-pmux {
+ groups = "TX_EDDC_SCL", "TX_EDDC_SDA";
+ function = "tx_eddc";
+ };
+};
+
+&i2c0 {
+ status = "okay";
+ pinctrl-0 = <&twsi0_pmux>;
+ pinctrl-names = "default";
+};
+
+&i2c1 {
+ status = "okay";
+ pinctrl-0 = <&twsi1_pmux>;
+ pinctrl-names = "default";
+};
+
+&i2c2 {
+ status = "okay";
+ pinctrl-0 = <&twsi2_pmux>;
+ pinctrl-names = "default";
+};
+
+&i2c3 {
+ status = "okay";
+ pinctrl-0 = <&twsi3_pmux>;
+ pinctrl-names = "default";
+};
+
+&soc_pinctrl {
+ twsi0_pmux: twsi0-pmux {
+ groups = "TW0_SCL", "TW0_SDA";
+ function = "tw0";
+ };
+};
+
+&system_pinctrl {
+ twsi2_pmux: twsi2-pmux {
+ groups = "SM_TW2_SCL", "SM_TW2_SDA";
+ function = "tw2";
+ };
+
+ twsi3_pmux: twsi3-pmux {
+ groups = "SM_TW3_SCL", "SM_TW3_SDA";
+ function = "tw3";
+ };
+};
+
&uart0 {
status = "okay";
};
--
2.6.2

2015-11-20 09:55:33

by Jisheng Zhang

[permalink] [raw]
Subject: Re: [PATCH 0/2] Add I2C support for Marvell Berlin BG4CT



On Fri, 20 Nov 2015 17:46:59 +0800
Jisheng Zhang wrote:

> The first patch adds i2c nodes in the soc's dtsi, the second patch
> enables all i2c nodes for BG4CT STB board.
>
> NOTE: this series depends on the missed-in-v4.4rc1 patches:
>
> http://lists.infradead.org/pipermail/linux-arm-kernel/2015-October/378634.html
> http://lists.infradead.org/pipermail/linux-arm-kernel/2015-October/378635.html
> http://lists.infradead.org/pipermail/linux-arm-kernel/2015-October/378638.html

also depends on BG4CT clk support:
http://lists.infradead.org/pipermail/linux-arm-kernel/2015-November/386760.html

I just want to sent out for review early so that i2c support will get merged
once clk patches are accepted and merged.

Thanks,
Jisheng

>
> Jisheng Zhang (2):
> arm64: dts: berlin4ct: add I2C nodes for BG4CT
> arm64: dts: berlin4ct: enable all i2c nodes for the STB board
>
> arch/arm64/boot/dts/marvell/berlin4ct-stb.dts | 50 ++++++++++++++++++++++++++
> arch/arm64/boot/dts/marvell/berlin4ct.dtsi | 52 +++++++++++++++++++++++++++
> 2 files changed, 102 insertions(+)
>

2015-11-20 21:19:37

by Sebastian Hesselbarth

[permalink] [raw]
Subject: Re: [PATCH 2/2] arm64: dts: berlin4ct: enable all i2c nodes for the STB board

On 20.11.2015 10:47, Jisheng Zhang wrote:
> Enable all i2c nodes for the Marvell berlin BG4CT STB board.
>
> Signed-off-by: Jisheng Zhang <[email protected]>
> ---
> arch/arm64/boot/dts/marvell/berlin4ct-stb.dts | 50 +++++++++++++++++++++++++++
> 1 file changed, 50 insertions(+)
>
> diff --git a/arch/arm64/boot/dts/marvell/berlin4ct-stb.dts b/arch/arm64/boot/dts/marvell/berlin4ct-stb.dts
> index 348c37e..9e8e2e0 100644
> --- a/arch/arm64/boot/dts/marvell/berlin4ct-stb.dts
> +++ b/arch/arm64/boot/dts/marvell/berlin4ct-stb.dts
> @@ -61,6 +61,56 @@
> };
> };
>
> +&avio_pinctrl {
> + twsi1_pmux: twsi1-pmux {
> + groups = "TX_EDDC_SCL", "TX_EDDC_SDA";
> + function = "tx_eddc";
> + };

Please keep the pinmux sub-nodes in the SoC dtsi as long
as they are not strictly board specific, i.e. gpios.

> +};
> +
> +&i2c0 {
> + status = "okay";
> + pinctrl-0 = <&twsi0_pmux>;
> + pinctrl-names = "default";

If there is only one (or a default) pinctrl-0 option for i2c0,
you can also move it to the SoC dtsi.

> +};
> +
> +&i2c1 {
> + status = "okay";
> + pinctrl-0 = <&twsi1_pmux>;
> + pinctrl-names = "default";

ditto.

> +};
> +
> +&i2c2 {
> + status = "okay";
> + pinctrl-0 = <&twsi2_pmux>;
> + pinctrl-names = "default";

ditto.

> +};
> +
> +&i2c3 {
> + status = "okay";
> + pinctrl-0 = <&twsi3_pmux>;
> + pinctrl-names = "default";

ditto.

> +};
> +
> +&soc_pinctrl {
> + twsi0_pmux: twsi0-pmux {
> + groups = "TW0_SCL", "TW0_SDA";
> + function = "tw0";
> + };

Same comment about moving pinmux nodes to SoC dtsi.

> +};
> +
> +&system_pinctrl {
> + twsi2_pmux: twsi2-pmux {
> + groups = "SM_TW2_SCL", "SM_TW2_SDA";
> + function = "tw2";
> + };
> +
> + twsi3_pmux: twsi3-pmux {
> + groups = "SM_TW3_SCL", "SM_TW3_SDA";
> + function = "tw3";
> + };

ditto.

Sebastian

> +};
> +
> &uart0 {
> status = "okay";
> };
>

2015-11-20 21:22:00

by Sebastian Hesselbarth

[permalink] [raw]
Subject: Re: [PATCH 1/2] arm64: dts: berlin4ct: add I2C nodes for BG4CT

On 20.11.2015 10:47, Jisheng Zhang wrote:
> The Marvell Berlin BG4CT SoC has 4 TWSI which are compatible with the
> Synopsys DesignWare I2C driver. Add the corresponding nodes.
>
> Signed-off-by: Jisheng Zhang <[email protected]>
> ---
> arch/arm64/boot/dts/marvell/berlin4ct.dtsi | 52 ++++++++++++++++++++++++++++++
> 1 file changed, 52 insertions(+)
>
> diff --git a/arch/arm64/boot/dts/marvell/berlin4ct.dtsi b/arch/arm64/boot/dts/marvell/berlin4ct.dtsi
> index cca4c41..39d0676 100644
> --- a/arch/arm64/boot/dts/marvell/berlin4ct.dtsi
> +++ b/arch/arm64/boot/dts/marvell/berlin4ct.dtsi
> @@ -232,6 +232,32 @@
> };
> };
>
> + i2c0: i2c@1400 {
> + compatible = "snps,designware-i2c";
> + #address-cells = <1>;
> + #size-cells = <0>;
> + reg = <0x1400 0x100>;
> + clocks = <&clk CLK_APBCORE>;

This patch looks fine to me, except that clock node naming and
clock indices may change. We should really postpone this series
until we worked out clock.

Sebastian

> + i2c-sda-hold-time-ns = <35>;
> + i2c-sda-falling-time-ns = <425>;
> + i2c-scl-falling-time-ns = <205>;
> + interrupts = <4>;
> + status = "disabled";
> + };
> +
> + i2c1: i2c@1800 {
> + compatible = "snps,designware-i2c";
> + #address-cells = <1>;
> + #size-cells = <0>;
> + reg = <0x1800 0x100>;
> + clocks = <&clk CLK_APBCORE>;
> + i2c-sda-hold-time-ns = <35>;
> + i2c-sda-falling-time-ns = <425>;
> + i2c-scl-falling-time-ns = <205>;
> + interrupts = <5>;
> + status = "disabled";
> + };
> +
> aic: interrupt-controller@3800 {
> compatible = "snps,dw-apb-ictl";
> reg = <0x3800 0x30>;
> @@ -319,6 +345,32 @@
> };
> };
>
> + i2c2: i2c@b000 {
> + compatible = "snps,designware-i2c";
> + #address-cells = <1>;
> + #size-cells = <0>;
> + reg = <0xb000 0x100>;
> + clocks = <&osc>;
> + i2c-sda-hold-time-ns = <140>;
> + i2c-sda-falling-time-ns = <500>;
> + i2c-scl-falling-time-ns = <220>;
> + interrupts = <6>;
> + status = "disabled";
> + };
> +
> + i2c3: i2c@c000 {
> + compatible = "snps,designware-i2c";
> + #address-cells = <1>;
> + #size-cells = <0>;
> + reg = <0xc000 0x100>;
> + clocks = <&osc>;
> + i2c-sda-hold-time-ns = <140>;
> + i2c-sda-falling-time-ns = <500>;
> + i2c-scl-falling-time-ns = <220>;
> + interrupts = <7>;
> + status = "disabled";
> + };
> +
> uart0: uart@d000 {
> compatible = "snps,dw-apb-uart";
> reg = <0xd000 0x100>;
>

2015-11-23 02:47:48

by Jisheng Zhang

[permalink] [raw]
Subject: Re: [PATCH 1/2] arm64: dts: berlin4ct: add I2C nodes for BG4CT

On Fri, 20 Nov 2015 22:21:55 +0100
Sebastian Hesselbarth <[email protected]> wrote:

> On 20.11.2015 10:47, Jisheng Zhang wrote:
> > The Marvell Berlin BG4CT SoC has 4 TWSI which are compatible with the
> > Synopsys DesignWare I2C driver. Add the corresponding nodes.
> >
> > Signed-off-by: Jisheng Zhang <[email protected]>
> > ---
> > arch/arm64/boot/dts/marvell/berlin4ct.dtsi | 52 ++++++++++++++++++++++++++++++
> > 1 file changed, 52 insertions(+)
> >
> > diff --git a/arch/arm64/boot/dts/marvell/berlin4ct.dtsi b/arch/arm64/boot/dts/marvell/berlin4ct.dtsi
> > index cca4c41..39d0676 100644
> > --- a/arch/arm64/boot/dts/marvell/berlin4ct.dtsi
> > +++ b/arch/arm64/boot/dts/marvell/berlin4ct.dtsi
> > @@ -232,6 +232,32 @@
> > };
> > };
> >
> > + i2c0: i2c@1400 {
> > + compatible = "snps,designware-i2c";
> > + #address-cells = <1>;
> > + #size-cells = <0>;
> > + reg = <0x1400 0x100>;
> > + clocks = <&clk CLK_APBCORE>;
>
> This patch looks fine to me, except that clock node naming and
> clock indices may change. We should really postpone this series
> until we worked out clock.

Indeed. This is just to sent out for review early, so that we can merge
the i2c support once clk is ready.

Thanks for review,
Jisheng

>
> Sebastian
>
> > + i2c-sda-hold-time-ns = <35>;
> > + i2c-sda-falling-time-ns = <425>;
> > + i2c-scl-falling-time-ns = <205>;
> > + interrupts = <4>;
> > + status = "disabled";
> > + };
> > +
> > + i2c1: i2c@1800 {
> > + compatible = "snps,designware-i2c";
> > + #address-cells = <1>;
> > + #size-cells = <0>;
> > + reg = <0x1800 0x100>;
> > + clocks = <&clk CLK_APBCORE>;
> > + i2c-sda-hold-time-ns = <35>;
> > + i2c-sda-falling-time-ns = <425>;
> > + i2c-scl-falling-time-ns = <205>;
> > + interrupts = <5>;
> > + status = "disabled";
> > + };
> > +
> > aic: interrupt-controller@3800 {
> > compatible = "snps,dw-apb-ictl";
> > reg = <0x3800 0x30>;
> > @@ -319,6 +345,32 @@
> > };
> > };
> >
> > + i2c2: i2c@b000 {
> > + compatible = "snps,designware-i2c";
> > + #address-cells = <1>;
> > + #size-cells = <0>;
> > + reg = <0xb000 0x100>;
> > + clocks = <&osc>;
> > + i2c-sda-hold-time-ns = <140>;
> > + i2c-sda-falling-time-ns = <500>;
> > + i2c-scl-falling-time-ns = <220>;
> > + interrupts = <6>;
> > + status = "disabled";
> > + };
> > +
> > + i2c3: i2c@c000 {
> > + compatible = "snps,designware-i2c";
> > + #address-cells = <1>;
> > + #size-cells = <0>;
> > + reg = <0xc000 0x100>;
> > + clocks = <&osc>;
> > + i2c-sda-hold-time-ns = <140>;
> > + i2c-sda-falling-time-ns = <500>;
> > + i2c-scl-falling-time-ns = <220>;
> > + interrupts = <7>;
> > + status = "disabled";
> > + };
> > +
> > uart0: uart@d000 {
> > compatible = "snps,dw-apb-uart";
> > reg = <0xd000 0x100>;
> >
>

2015-11-23 02:54:15

by Jisheng Zhang

[permalink] [raw]
Subject: Re: [PATCH 2/2] arm64: dts: berlin4ct: enable all i2c nodes for the STB board

Dear Sebastian,

On Fri, 20 Nov 2015 22:19:32 +0100
Sebastian Hesselbarth wrote:

> On 20.11.2015 10:47, Jisheng Zhang wrote:
> > Enable all i2c nodes for the Marvell berlin BG4CT STB board.
> >
> > Signed-off-by: Jisheng Zhang <[email protected]>
> > ---
> > arch/arm64/boot/dts/marvell/berlin4ct-stb.dts | 50 +++++++++++++++++++++++++++
> > 1 file changed, 50 insertions(+)
> >
> > diff --git a/arch/arm64/boot/dts/marvell/berlin4ct-stb.dts b/arch/arm64/boot/dts/marvell/berlin4ct-stb.dts
> > index 348c37e..9e8e2e0 100644
> > --- a/arch/arm64/boot/dts/marvell/berlin4ct-stb.dts
> > +++ b/arch/arm64/boot/dts/marvell/berlin4ct-stb.dts
> > @@ -61,6 +61,56 @@
> > };
> > };
> >
> > +&avio_pinctrl {
> > + twsi1_pmux: twsi1-pmux {
> > + groups = "TX_EDDC_SCL", "TX_EDDC_SDA";
> > + function = "tx_eddc";
> > + };
>
> Please keep the pinmux sub-nodes in the SoC dtsi as long
> as they are not strictly board specific, i.e. gpios.

Hmm, seems all boards configure this pin for EDDC usage, so it's fine
to move to soc

>
> > +};
> > +
> > +&i2c0 {
> > + status = "okay";
> > + pinctrl-0 = <&twsi0_pmux>;
> > + pinctrl-names = "default";
>
> If there is only one (or a default) pinctrl-0 option for i2c0,
> you can also move it to the SoC dtsi.

Some board may not use i2c0, i2c2, i2c3 host and use the pin as gpio for other
purpose. Considering the above twsi1_pmux usage, what's the better solution?
move twsi1_pmux to soc's dtsi and leave i2c0, i2c2, i2c3 pinctrl in board dts?

>
> > +};
> > +
> > +&i2c1 {
> > + status = "okay";
> > + pinctrl-0 = <&twsi1_pmux>;
> > + pinctrl-names = "default";
>
> ditto.
>
> > +};
> > +
> > +&i2c2 {
> > + status = "okay";
> > + pinctrl-0 = <&twsi2_pmux>;
> > + pinctrl-names = "default";
>
> ditto.
>
> > +};
> > +
> > +&i2c3 {
> > + status = "okay";
> > + pinctrl-0 = <&twsi3_pmux>;
> > + pinctrl-names = "default";
>
> ditto.
>
> > +};
> > +
> > +&soc_pinctrl {
> > + twsi0_pmux: twsi0-pmux {
> > + groups = "TW0_SCL", "TW0_SDA";
> > + function = "tw0";
> > + };
>
> Same comment about moving pinmux nodes to SoC dtsi.
>
> > +};
> > +
> > +&system_pinctrl {
> > + twsi2_pmux: twsi2-pmux {
> > + groups = "SM_TW2_SCL", "SM_TW2_SDA";
> > + function = "tw2";
> > + };
> > +
> > + twsi3_pmux: twsi3-pmux {
> > + groups = "SM_TW3_SCL", "SM_TW3_SDA";
> > + function = "tw3";
> > + };
>
> ditto.
>
> Sebastian
>
> > +};
> > +
> > &uart0 {
> > status = "okay";
> > };
> >
>

2015-11-23 08:12:25

by Sebastian Hesselbarth

[permalink] [raw]
Subject: Re: [PATCH 2/2] arm64: dts: berlin4ct: enable all i2c nodes for the STB board

On 23.11.2015 03:49, Jisheng Zhang wrote:
> On Fri, 20 Nov 2015 22:19:32 +0100
> Sebastian Hesselbarth wrote:
>> On 20.11.2015 10:47, Jisheng Zhang wrote:
>>> Enable all i2c nodes for the Marvell berlin BG4CT STB board.
>>>
>>> Signed-off-by: Jisheng Zhang <[email protected]>
>>> ---
>>> arch/arm64/boot/dts/marvell/berlin4ct-stb.dts | 50 +++++++++++++++++++++++++++
>>> 1 file changed, 50 insertions(+)
>>>
>>> diff --git a/arch/arm64/boot/dts/marvell/berlin4ct-stb.dts b/arch/arm64/boot/dts/marvell/berlin4ct-stb.dts
>>> index 348c37e..9e8e2e0 100644
>>> --- a/arch/arm64/boot/dts/marvell/berlin4ct-stb.dts
>>> +++ b/arch/arm64/boot/dts/marvell/berlin4ct-stb.dts
>>> @@ -61,6 +61,56 @@
>>> };
>>> };
>>>
>>> +&avio_pinctrl {
>>> + twsi1_pmux: twsi1-pmux {
>>> + groups = "TX_EDDC_SCL", "TX_EDDC_SDA";
>>> + function = "tx_eddc";
>>> + };
>>
>> Please keep the pinmux sub-nodes in the SoC dtsi as long
>> as they are not strictly board specific, i.e. gpios.
>
> Hmm, seems all boards configure this pin for EDDC usage, so it's fine
> to move to soc
>
>>
>>> +};
>>> +
>>> +&i2c0 {
>>> + status = "okay";
>>> + pinctrl-0 = <&twsi0_pmux>;
>>> + pinctrl-names = "default";
>>
>> If there is only one (or a default) pinctrl-0 option for i2c0,
>> you can also move it to the SoC dtsi.
>
> Some board may not use i2c0, i2c2, i2c3 host and use the pin as gpio for other
> purpose. Considering the above twsi1_pmux usage, what's the better solution?
> move twsi1_pmux to soc's dtsi and leave i2c0, i2c2, i2c3 pinctrl in board dts?

If some boards don't use i2cN, they do not enable the node in their
board dts. That is sufficient to not configure the pinmux as it will
only be set if a driver is loaded for that node.

If there is only one or two different pinmux settings for a specific
function _always_ move the pinmux setting into SoC dtsi. If there is
a well known default out of two or more possible settings, we may also
have that pinmux as a default in the i2c node and only overwrite it
when we have a board that uses a different setting.

So, for i2c: Move all pinctrl/pinctrl-names properties to the SoC
dtsi.

Sebastian

2015-11-23 08:21:21

by Jisheng Zhang

[permalink] [raw]
Subject: Re: [PATCH 2/2] arm64: dts: berlin4ct: enable all i2c nodes for the STB board

On Mon, 23 Nov 2015 09:12:18 +0100
Sebastian Hesselbarth <[email protected]> wrote:

> On 23.11.2015 03:49, Jisheng Zhang wrote:
> > On Fri, 20 Nov 2015 22:19:32 +0100
> > Sebastian Hesselbarth wrote:
> >> On 20.11.2015 10:47, Jisheng Zhang wrote:
> >>> Enable all i2c nodes for the Marvell berlin BG4CT STB board.
> >>>
> >>> Signed-off-by: Jisheng Zhang <[email protected]>
> >>> ---
> >>> arch/arm64/boot/dts/marvell/berlin4ct-stb.dts | 50 +++++++++++++++++++++++++++
> >>> 1 file changed, 50 insertions(+)
> >>>
> >>> diff --git a/arch/arm64/boot/dts/marvell/berlin4ct-stb.dts b/arch/arm64/boot/dts/marvell/berlin4ct-stb.dts
> >>> index 348c37e..9e8e2e0 100644
> >>> --- a/arch/arm64/boot/dts/marvell/berlin4ct-stb.dts
> >>> +++ b/arch/arm64/boot/dts/marvell/berlin4ct-stb.dts
> >>> @@ -61,6 +61,56 @@
> >>> };
> >>> };
> >>>
> >>> +&avio_pinctrl {
> >>> + twsi1_pmux: twsi1-pmux {
> >>> + groups = "TX_EDDC_SCL", "TX_EDDC_SDA";
> >>> + function = "tx_eddc";
> >>> + };
> >>
> >> Please keep the pinmux sub-nodes in the SoC dtsi as long
> >> as they are not strictly board specific, i.e. gpios.
> >
> > Hmm, seems all boards configure this pin for EDDC usage, so it's fine
> > to move to soc
> >
> >>
> >>> +};
> >>> +
> >>> +&i2c0 {
> >>> + status = "okay";
> >>> + pinctrl-0 = <&twsi0_pmux>;
> >>> + pinctrl-names = "default";
> >>
> >> If there is only one (or a default) pinctrl-0 option for i2c0,
> >> you can also move it to the SoC dtsi.
> >
> > Some board may not use i2c0, i2c2, i2c3 host and use the pin as gpio for other
> > purpose. Considering the above twsi1_pmux usage, what's the better solution?
> > move twsi1_pmux to soc's dtsi and leave i2c0, i2c2, i2c3 pinctrl in board dts?
>
> If some boards don't use i2cN, they do not enable the node in their
> board dts. That is sufficient to not configure the pinmux as it will
> only be set if a driver is loaded for that node.
>
> If there is only one or two different pinmux settings for a specific
> function _always_ move the pinmux setting into SoC dtsi. If there is
> a well known default out of two or more possible settings, we may also
> have that pinmux as a default in the i2c node and only overwrite it
> when we have a board that uses a different setting.

Got it. Thanks for the detailed explanations.

>
> So, for i2c: Move all pinctrl/pinctrl-names properties to the SoC
> dtsi.

Will do in v2 when clk stuff is accepted.

Thanks,
Jisheng