Commit 8e8c7253 authored by Arnd Bergmann's avatar Arnd Bergmann

Merge tag 'mvebu-dt64-4.12-1' of git://git.infradead.org/linux-mvebu into next/dt64

Pull "mvebu dt64 for 4.12 (part 1)" from Gregory CLEMENT:

- Add RTC support on Armada 7k/8k
- Improve i2c support on Armada 37xx
- Add gpio expander and RTC on Armada 3720 board
- Improve USB3 support on Armada 37xx
- Add network support on Armada 7k/8k

* tag 'mvebu-dt64-4.12-1' of git://git.infradead.org/linux-mvebu:
  arm64: marvell: dts: add PPv2.2 description to Armada 7K/8K
  ARM64: dts: marvell: armada-3720 add RTC support
  ARM64: dts: marvell: armada-3720-db: Add phy for USB3
  ARM64: dts: marvell: armada-37xx: Add clock resource for USB3
  ARM64: dts: marvell: armada-37xx: Fix interrupt mapping for USB3
  ARM64: dts: marvell: armada-3720-db: add gpio expander
  ARM64: dts: marvell: armada37xx: add address and size property for i2c cells
  arm64: dts: marvell: add RTC description for Armada 7K/8K
parents 6cd8eaac 60894719
...@@ -46,6 +46,7 @@ ...@@ -46,6 +46,7 @@
/dts-v1/; /dts-v1/;
#include <dt-bindings/gpio/gpio.h>
#include "armada-372x.dtsi" #include "armada-372x.dtsi"
/ { / {
...@@ -60,10 +61,49 @@ memory@0 { ...@@ -60,10 +61,49 @@ memory@0 {
device_type = "memory"; device_type = "memory";
reg = <0x00000000 0x00000000 0x00000000 0x20000000>; reg = <0x00000000 0x00000000 0x00000000 0x20000000>;
}; };
exp_usb3_vbus: usb3-vbus {
compatible = "regulator-fixed";
regulator-name = "usb3-vbus";
regulator-min-microvolt = <5000000>;
regulator-max-microvolt = <5000000>;
enable-active-high;
regulator-always-on;
gpio = <&gpio_exp 1 GPIO_ACTIVE_HIGH>;
};
usb3_phy: usb3-phy {
compatible = "usb-nop-xceiv";
vcc-supply = <&exp_usb3_vbus>;
};
}; };
&i2c0 { &i2c0 {
status = "okay"; status = "okay";
gpio_exp: pca9555@22 {
compatible = "nxp,pca9555";
gpio-controller;
#gpio-cells = <2>;
reg = <0x22>;
/*
* IO0_0: PWR_EN_USB2 IO1_0: PWR_EN_VTT
* IO0_1: PWR_EN_USB23 IO1_1: MPCIE_WDISABLE
* IO0_2: PWR_EN_SATA IO1_2: RGMII_DEV_RSTN
* IO0_3: PWR_EN_PCIE IO1_3: SGMII_DEV_RSTN
* IO0_4: PWR_EN_SD
* IO0_5: PWR_EN_EMMC
* IO0_6: PWR_EN_RGMII IO1_6: SATA_USB3.0_SEL
* IO0_7: PWR_EN_SGMII IO1_7: PWR_MCI_PS
*/
};
rtc@68 {
/* PT7C4337A from pericom fully compatible with the ds1337 */
compatible = "dallas,ds1337";
reg = <0x68>;
};
}; };
/* CON3 */ /* CON3 */
...@@ -109,6 +149,7 @@ &uart0 { ...@@ -109,6 +149,7 @@ &uart0 {
/* CON31 */ /* CON31 */
&usb3 { &usb3 {
status = "okay"; status = "okay";
usb-phy = <&usb3_phy>;
}; };
/* CON17 (PCIe) / CON12 (mini-PCIe) */ /* CON17 (PCIe) / CON12 (mini-PCIe) */
......
...@@ -112,6 +112,8 @@ spi0: spi@10600 { ...@@ -112,6 +112,8 @@ spi0: spi@10600 {
i2c0: i2c@11000 { i2c0: i2c@11000 {
compatible = "marvell,armada-3700-i2c"; compatible = "marvell,armada-3700-i2c";
reg = <0x11000 0x24>; reg = <0x11000 0x24>;
#address-cells = <1>;
#size-cells = <0>;
clocks = <&nb_periph_clk 10>; clocks = <&nb_periph_clk 10>;
interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>; interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
mrvl,i2c-fast-mode; mrvl,i2c-fast-mode;
...@@ -121,6 +123,8 @@ i2c0: i2c@11000 { ...@@ -121,6 +123,8 @@ i2c0: i2c@11000 {
i2c1: i2c@11080 { i2c1: i2c@11080 {
compatible = "marvell,armada-3700-i2c"; compatible = "marvell,armada-3700-i2c";
reg = <0x11080 0x24>; reg = <0x11080 0x24>;
#address-cells = <1>;
#size-cells = <0>;
clocks = <&nb_periph_clk 9>; clocks = <&nb_periph_clk 9>;
interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>; interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
mrvl,i2c-fast-mode; mrvl,i2c-fast-mode;
...@@ -196,7 +200,8 @@ usb3: usb@58000 { ...@@ -196,7 +200,8 @@ usb3: usb@58000 {
compatible = "marvell,armada3700-xhci", compatible = "marvell,armada3700-xhci",
"generic-xhci"; "generic-xhci";
reg = <0x58000 0x4000>; reg = <0x58000 0x4000>;
interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>; interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
clocks = <&sb_periph_clk 12>;
status = "disabled"; status = "disabled";
}; };
......
...@@ -146,3 +146,28 @@ &cpm_usb3_0 { ...@@ -146,3 +146,28 @@ &cpm_usb3_0 {
&cpm_usb3_1 { &cpm_usb3_1 {
status = "okay"; status = "okay";
}; };
&cpm_mdio {
phy0: ethernet-phy@0 {
reg = <0>;
};
phy1: ethernet-phy@1 {
reg = <1>;
};
};
&cpm_ethernet {
status = "okay";
};
&cpm_eth1 {
status = "okay";
phy = <&phy0>;
phy-mode = "sgmii";
};
&cpm_eth2 {
status = "okay";
phy = <&phy1>;
phy-mode = "rgmii-id";
};
...@@ -54,3 +54,13 @@ / { ...@@ -54,3 +54,13 @@ / {
compatible = "marvell,armada8020", "marvell,armada-ap806-dual", compatible = "marvell,armada8020", "marvell,armada-ap806-dual",
"marvell,armada-ap806"; "marvell,armada-ap806";
}; };
/* The RTC requires external oscillator. But on Aramda 80x0, the RTC clock
* in CP master is not connected (by package) to the oscillator. So
* disable it. However, the RTC clock in CP slave is connected to the
* oscillator so this one is let enabled.
*/
&cpm_rtc {
status = "disabled";
};
...@@ -124,6 +124,22 @@ &cpm_usb3_1 { ...@@ -124,6 +124,22 @@ &cpm_usb3_1 {
status = "okay"; status = "okay";
}; };
&cpm_mdio {
phy1: ethernet-phy@1 {
reg = <1>;
};
};
&cpm_ethernet {
status = "okay";
};
&cpm_eth2 {
status = "okay";
phy = <&phy1>;
phy-mode = "rgmii-id";
};
/* CON5 on CP1 expansion */ /* CON5 on CP1 expansion */
&cps_pcie2 { &cps_pcie2 {
status = "okay"; status = "okay";
......
...@@ -54,3 +54,12 @@ / { ...@@ -54,3 +54,12 @@ / {
compatible = "marvell,armada8040", "marvell,armada-ap806-quad", compatible = "marvell,armada8040", "marvell,armada-ap806-quad",
"marvell,armada-ap806"; "marvell,armada-ap806";
}; };
/* The RTC requires external oscillator. But on Aramda 80x0, the RTC clock
* in CP master is not connected (by package) to the oscillator. So
* disable it. However, the RTC clock in CP slave is connected to the
* oscillator so this one is let enabled.
*/
&cpm_rtc {
status = "disabled";
};
...@@ -59,6 +59,43 @@ config-space@f2000000 { ...@@ -59,6 +59,43 @@ config-space@f2000000 {
interrupt-parent = <&gic>; interrupt-parent = <&gic>;
ranges = <0x0 0x0 0xf2000000 0x2000000>; ranges = <0x0 0x0 0xf2000000 0x2000000>;
cpm_ethernet: ethernet@0 {
compatible = "marvell,armada-7k-pp22";
reg = <0x0 0x100000>, <0x129000 0xb000>;
clocks = <&cpm_syscon0 1 3>, <&cpm_syscon0 1 9>, <&cpm_syscon0 1 5>;
clock-names = "pp_clk", "gop_clk", "mg_clk";
status = "disabled";
dma-coherent;
cpm_eth0: eth0 {
interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
port-id = <0>;
gop-port-id = <0>;
status = "disabled";
};
cpm_eth1: eth1 {
interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>;
port-id = <1>;
gop-port-id = <2>;
status = "disabled";
};
cpm_eth2: eth2 {
interrupts = <GIC_SPI 39 IRQ_TYPE_LEVEL_HIGH>;
port-id = <2>;
gop-port-id = <3>;
status = "disabled";
};
};
cpm_mdio: mdio@12a200 {
#address-cells = <1>;
#size-cells = <0>;
compatible = "marvell,orion-mdio";
reg = <0x12a200 0x10>;
};
cpm_syscon0: system-controller@440000 { cpm_syscon0: system-controller@440000 {
compatible = "marvell,cp110-system-controller0", compatible = "marvell,cp110-system-controller0",
"syscon"; "syscon";
...@@ -79,6 +116,13 @@ cpm_syscon0: system-controller@440000 { ...@@ -79,6 +116,13 @@ cpm_syscon0: system-controller@440000 {
"cpm-usb3dev", "cpm-eip150", "cpm-eip197"; "cpm-usb3dev", "cpm-eip150", "cpm-eip197";
}; };
cpm_rtc: rtc@284000 {
compatible = "marvell,armada-8k-rtc";
reg = <0x284000 0x20>, <0x284080 0x24>;
reg-names = "rtc", "rtc-soc";
interrupts = <GIC_SPI 71 IRQ_TYPE_LEVEL_HIGH>;
};
cpm_sata0: sata@540000 { cpm_sata0: sata@540000 {
compatible = "marvell,armada-8k-ahci", compatible = "marvell,armada-8k-ahci",
"generic-ahci"; "generic-ahci";
......
...@@ -59,6 +59,50 @@ config-space@f4000000 { ...@@ -59,6 +59,50 @@ config-space@f4000000 {
interrupt-parent = <&gic>; interrupt-parent = <&gic>;
ranges = <0x0 0x0 0xf4000000 0x2000000>; ranges = <0x0 0x0 0xf4000000 0x2000000>;
cps_rtc: rtc@284000 {
compatible = "marvell,armada-8k-rtc";
reg = <0x284000 0x20>, <0x284080 0x24>;
reg-names = "rtc", "rtc-soc";
interrupts = <GIC_SPI 71 IRQ_TYPE_LEVEL_HIGH>;
};
cps_ethernet: ethernet@0 {
compatible = "marvell,armada-7k-pp22";
reg = <0x0 0x100000>, <0x129000 0xb000>;
clocks = <&cps_syscon0 1 3>, <&cps_syscon0 1 9>, <&cps_syscon0 1 5>;
clock-names = "pp_clk", "gop_clk", "mg_clk";
status = "disabled";
dma-coherent;
cps_eth0: eth0 {
interrupts = <GIC_SPI 261 IRQ_TYPE_LEVEL_HIGH>;
port-id = <0>;
gop-port-id = <0>;
status = "disabled";
};
cps_eth1: eth1 {
interrupts = <GIC_SPI 262 IRQ_TYPE_LEVEL_HIGH>;
port-id = <1>;
gop-port-id = <2>;
status = "disabled";
};
cps_eth2: eth2 {
interrupts = <GIC_SPI 263 IRQ_TYPE_LEVEL_HIGH>;
port-id = <2>;
gop-port-id = <3>;
status = "disabled";
};
};
cps_mdio: mdio@12a200 {
#address-cells = <1>;
#size-cells = <0>;
compatible = "marvell,orion-mdio";
reg = <0x12a200 0x10>;
};
cps_syscon0: system-controller@440000 { cps_syscon0: system-controller@440000 {
compatible = "marvell,cp110-system-controller0", compatible = "marvell,cp110-system-controller0",
"syscon"; "syscon";
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment