ARM: mvebu: second PCIe unit of Armada XP mv78230 is only x1 capable
authorArnaud Ebalard <arno@natisbad.org>
Tue, 5 Nov 2013 20:45:48 +0000 (21:45 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 12 Dec 2013 06:36:29 +0000 (22:36 -0800)
commit 12b69a599745fc9e203f61fbb7160b2cc5f479dd upstream.

Various Marvell datasheets advertise second PCIe unit of mv78230
flavour of Armada XP as x4/quad x1 capable. This second unit is in
fact only x1 capable. This patch fixes current mv78230 .dtsi to
reflect that, i.e. makes 1.0 the second interface (instead of 2.0
at the moment). This was successfully tested on a mv78230-based
ReadyNAS 2120 platform with a x1 device (FL1009 XHCI controller)
connected to this second interface.

Signed-off-by: Arnaud Ebalard <arno@natisbad.org>
Acked-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
Signed-off-by: Jason Cooper <jason@lakedaemon.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
arch/arm/boot/dts/armada-xp-mv78230.dtsi

index f8eaa383e07fbdc6904711d72699bc2df6eb0190..f94cdbc579cbe31fd784e9c145db71d931a2d00c 100644 (file)
@@ -81,7 +81,7 @@
                        /*
                         * MV78230 has 2 PCIe units Gen2.0: One unit can be
                         * configured as x4 or quad x1 lanes. One unit is
-                        * x4/x1.
+                        * x1 only.
                         */
                        pcie-controller {
                                compatible = "marvell,armada-xp-pcie";
                                bus-range = <0x00 0xff>;
 
                                ranges = <0x82000000 0 0x40000 0x40000 0 0x00002000   /* Port 0.0 registers */
-                                       0x82000000 0 0x42000 0x42000 0 0x00002000   /* Port 2.0 registers */
                                        0x82000000 0 0x44000 0x44000 0 0x00002000   /* Port 0.1 registers */
                                        0x82000000 0 0x48000 0x48000 0 0x00002000   /* Port 0.2 registers */
                                        0x82000000 0 0x4c000 0x4c000 0 0x00002000   /* Port 0.3 registers */
+                                       0x82000000 0 0x80000 0x80000 0 0x00002000   /* Port 1.0 registers */
                                        0x82000000 0 0xe0000000 0xe0000000 0 0x08000000   /* non-prefetchable memory */
                                        0x81000000 0 0    0xe8000000 0 0x00100000>; /* downstream I/O */
 
                                        status = "disabled";
                                };
 
-                               pcie@9,0 {
+                               pcie@5,0 {
                                        device_type = "pci";
-                                       assigned-addresses = <0x82000800 0 0x42000 0 0x2000>;
-                                       reg = <0x4800 0 0 0 0>;
+                                       assigned-addresses = <0x82000800 0 0x80000 0 0x2000>;
+                                       reg = <0x2800 0 0 0 0>;
                                        #address-cells = <3>;
                                        #size-cells = <2>;
                                        #interrupt-cells = <1>;
                                        ranges;
                                        interrupt-map-mask = <0 0 0 0>;
-                                       interrupt-map = <0 0 0 0 &mpic 99>;
-                                       marvell,pcie-port = <2>;
+                                       interrupt-map = <0 0 0 0 &mpic 62>;
+                                       marvell,pcie-port = <1>;
                                        marvell,pcie-lane = <0>;
-                                       clocks = <&gateclk 26>;
+                                       clocks = <&gateclk 9>;
                                        status = "disabled";
                                };
                        };