diff options
author | Andy Fleming <afleming@freescale.com> | 2012-01-04 15:28:31 -0600 |
---|---|---|
committer | Kumar Gala <galak@kernel.crashing.org> | 2012-01-04 15:33:51 -0600 |
commit | 220669495bf8b68130a8218607147c7b74c28d2b (patch) | |
tree | af31ad750cf3ea770084c4020e2eaa582e2393e3 /arch/powerpc/boot | |
parent | dabc78403fc2ad96e6fc8b53c6c6abcc02e152ee (diff) |
powerpc: Add TBI PHY node to first MDIO bus
Systems which use the fsl_pq_mdio driver need to specify an
address for TBI PHY transactions such that the address does
not conflict with any PHYs on the bus (all transactions to
that address are directed to the onboard TBI PHY). The driver
used to scan for a free address if no address was specified,
however this ran into issues when the PHY Lib was fixed so
that all MDIO transactions were protected by a mutex. As it
is, the code was meant to serve as a transitional tool until
the device trees were all updated to specify the TBI address.
The best fix for the mutex issue was to remove the scanning code,
but it turns out some of the newer SoCs have started to omit
the tbi-phy node when SGMII is not being used. As such, these
devices will now fail unless we add a tbi-phy node to the first
mdio controller.
Signed-off-by: Andy Fleming <afleming@freescale.com>
Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
Diffstat (limited to 'arch/powerpc/boot')
-rw-r--r-- | arch/powerpc/boot/dts/p1010rdb.dtsi | 5 | ||||
-rw-r--r-- | arch/powerpc/boot/dts/p1020rdb.dtsi | 5 | ||||
-rw-r--r-- | arch/powerpc/boot/dts/p1021mds.dts | 4 | ||||
-rw-r--r-- | arch/powerpc/boot/dts/p1022ds.dts | 4 | ||||
-rw-r--r-- | arch/powerpc/boot/dts/p2020rdb.dts | 8 |
5 files changed, 24 insertions, 2 deletions
diff --git a/arch/powerpc/boot/dts/p1010rdb.dtsi b/arch/powerpc/boot/dts/p1010rdb.dtsi index 3aa2b823fb0..d4c4a773028 100644 --- a/arch/powerpc/boot/dts/p1010rdb.dtsi +++ b/arch/powerpc/boot/dts/p1010rdb.dtsi @@ -194,6 +194,11 @@ interrupts = <2 1 0 0>; reg = <0x2>; }; + + tbi-phy@3 { + device-type = "tbi-phy"; + reg = <0x3>; + }; }; mdio@25000 { diff --git a/arch/powerpc/boot/dts/p1020rdb.dtsi b/arch/powerpc/boot/dts/p1020rdb.dtsi index 37389464ad8..b5bd86f4baf 100644 --- a/arch/powerpc/boot/dts/p1020rdb.dtsi +++ b/arch/powerpc/boot/dts/p1020rdb.dtsi @@ -214,6 +214,11 @@ interrupts = <2 1>; reg = <0x1>; }; + + tbi-phy@2 { + device_type = "tbi-phy"; + reg = <0x2>; + }; }; mdio@25000 { diff --git a/arch/powerpc/boot/dts/p1021mds.dts b/arch/powerpc/boot/dts/p1021mds.dts index b1bef1fa66d..d9540791e43 100644 --- a/arch/powerpc/boot/dts/p1021mds.dts +++ b/arch/powerpc/boot/dts/p1021mds.dts @@ -165,6 +165,10 @@ phy4: ethernet-phy@4 { reg = <0x4>; }; + tbi-phy@5 { + device_type = "tbi-phy"; + reg = <0x5>; + }; }; mdio@25000 { diff --git a/arch/powerpc/boot/dts/p1022ds.dts b/arch/powerpc/boot/dts/p1022ds.dts index 3e85d8c3850..0ca0eb1ce51 100644 --- a/arch/powerpc/boot/dts/p1022ds.dts +++ b/arch/powerpc/boot/dts/p1022ds.dts @@ -207,6 +207,10 @@ interrupts = <9 1 0 0>; reg = <0x2>; }; + tbi-phy@2 { + device_type = "tbi-phy"; + reg = <0x2>; + }; }; ethernet@b0000 { diff --git a/arch/powerpc/boot/dts/p2020rdb.dts b/arch/powerpc/boot/dts/p2020rdb.dts index fd4271296f8..26759a59171 100644 --- a/arch/powerpc/boot/dts/p2020rdb.dts +++ b/arch/powerpc/boot/dts/p2020rdb.dts @@ -203,11 +203,15 @@ phy0: ethernet-phy@0 { interrupts = <3 1 0 0>; reg = <0x0>; - }; + }; phy1: ethernet-phy@1 { interrupts = <3 1 0 0>; reg = <0x1>; - }; + }; + tbi-phy@2 { + device_type = "tbi-phy"; + reg = <0x2>; + }; }; mdio@25520 { |