mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-14 12:56:46 +07:00
3d2521810e
Program rx/tx-delay always from DT. Signed-off-by: Aaro Koskinen <aaro.koskinen@iki.fi> Signed-off-by: Paul Burton <paul.burton@mips.com> Cc: linux-mips@vger.kernel.org
407 lines
10 KiB
Plaintext
407 lines
10 KiB
Plaintext
// SPDX-License-Identifier: GPL-2.0
|
|
/*
|
|
* OCTEON 3XXX, 5XXX, 63XX device tree skeleton.
|
|
*
|
|
* This device tree is pruned and patched by early boot code before
|
|
* use. Because of this, it contains a super-set of the available
|
|
* devices and properties.
|
|
*/
|
|
|
|
/include/ "octeon_3xxx.dtsi"
|
|
|
|
/ {
|
|
soc@0 {
|
|
smi0: mdio@1180000001800 {
|
|
phy0: ethernet-phy@0 {
|
|
compatible = "marvell,88e1118";
|
|
marvell,reg-init =
|
|
/* Fix rx and tx clock transition timing */
|
|
<2 0x15 0xffcf 0>, /* Reg 2,21 Clear bits 4, 5 */
|
|
/* Adjust LED drive. */
|
|
<3 0x11 0 0x442a>, /* Reg 3,17 <- 0442a */
|
|
/* irq, blink-activity, blink-link */
|
|
<3 0x10 0 0x0242>; /* Reg 3,16 <- 0x0242 */
|
|
reg = <0>;
|
|
};
|
|
|
|
phy1: ethernet-phy@1 {
|
|
compatible = "marvell,88e1118";
|
|
marvell,reg-init =
|
|
/* Fix rx and tx clock transition timing */
|
|
<2 0x15 0xffcf 0>, /* Reg 2,21 Clear bits 4, 5 */
|
|
/* Adjust LED drive. */
|
|
<3 0x11 0 0x442a>, /* Reg 3,17 <- 0442a */
|
|
/* irq, blink-activity, blink-link */
|
|
<3 0x10 0 0x0242>; /* Reg 3,16 <- 0x0242 */
|
|
reg = <1>;
|
|
};
|
|
|
|
phy2: ethernet-phy@2 {
|
|
reg = <2>;
|
|
compatible = "marvell,88e1149r";
|
|
marvell,reg-init = <3 0x10 0 0x5777>,
|
|
<3 0x11 0 0x00aa>,
|
|
<3 0x12 0 0x4105>,
|
|
<3 0x13 0 0x0a60>;
|
|
};
|
|
phy3: ethernet-phy@3 {
|
|
reg = <3>;
|
|
compatible = "marvell,88e1149r";
|
|
marvell,reg-init = <3 0x10 0 0x5777>,
|
|
<3 0x11 0 0x00aa>,
|
|
<3 0x12 0 0x4105>,
|
|
<3 0x13 0 0x0a60>;
|
|
};
|
|
phy4: ethernet-phy@4 {
|
|
reg = <4>;
|
|
compatible = "marvell,88e1149r";
|
|
marvell,reg-init = <3 0x10 0 0x5777>,
|
|
<3 0x11 0 0x00aa>,
|
|
<3 0x12 0 0x4105>,
|
|
<3 0x13 0 0x0a60>;
|
|
};
|
|
phy5: ethernet-phy@5 {
|
|
reg = <5>;
|
|
compatible = "marvell,88e1149r";
|
|
marvell,reg-init = <3 0x10 0 0x5777>,
|
|
<3 0x11 0 0x00aa>,
|
|
<3 0x12 0 0x4105>,
|
|
<3 0x13 0 0x0a60>;
|
|
};
|
|
|
|
phy6: ethernet-phy@6 {
|
|
reg = <6>;
|
|
compatible = "marvell,88e1149r";
|
|
marvell,reg-init = <3 0x10 0 0x5777>,
|
|
<3 0x11 0 0x00aa>,
|
|
<3 0x12 0 0x4105>,
|
|
<3 0x13 0 0x0a60>;
|
|
};
|
|
phy7: ethernet-phy@7 {
|
|
reg = <7>;
|
|
compatible = "marvell,88e1149r";
|
|
marvell,reg-init = <3 0x10 0 0x5777>,
|
|
<3 0x11 0 0x00aa>,
|
|
<3 0x12 0 0x4105>,
|
|
<3 0x13 0 0x0a60>;
|
|
};
|
|
phy8: ethernet-phy@8 {
|
|
reg = <8>;
|
|
compatible = "marvell,88e1149r";
|
|
marvell,reg-init = <3 0x10 0 0x5777>,
|
|
<3 0x11 0 0x00aa>,
|
|
<3 0x12 0 0x4105>,
|
|
<3 0x13 0 0x0a60>;
|
|
};
|
|
phy9: ethernet-phy@9 {
|
|
reg = <9>;
|
|
compatible = "marvell,88e1149r";
|
|
marvell,reg-init = <3 0x10 0 0x5777>,
|
|
<3 0x11 0 0x00aa>,
|
|
<3 0x12 0 0x4105>,
|
|
<3 0x13 0 0x0a60>;
|
|
};
|
|
};
|
|
|
|
smi1: mdio@1180000001900 {
|
|
compatible = "cavium,octeon-3860-mdio";
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
reg = <0x11800 0x00001900 0x0 0x40>;
|
|
|
|
phy100: ethernet-phy@1 {
|
|
reg = <1>;
|
|
compatible = "marvell,88e1149r";
|
|
marvell,reg-init = <3 0x10 0 0x5777>,
|
|
<3 0x11 0 0x00aa>,
|
|
<3 0x12 0 0x4105>,
|
|
<3 0x13 0 0x0a60>;
|
|
interrupt-parent = <&gpio>;
|
|
interrupts = <12 8>; /* Pin 12, active low */
|
|
};
|
|
phy101: ethernet-phy@2 {
|
|
reg = <2>;
|
|
compatible = "marvell,88e1149r";
|
|
marvell,reg-init = <3 0x10 0 0x5777>,
|
|
<3 0x11 0 0x00aa>,
|
|
<3 0x12 0 0x4105>,
|
|
<3 0x13 0 0x0a60>;
|
|
interrupt-parent = <&gpio>;
|
|
interrupts = <12 8>; /* Pin 12, active low */
|
|
};
|
|
phy102: ethernet-phy@3 {
|
|
reg = <3>;
|
|
compatible = "marvell,88e1149r";
|
|
marvell,reg-init = <3 0x10 0 0x5777>,
|
|
<3 0x11 0 0x00aa>,
|
|
<3 0x12 0 0x4105>,
|
|
<3 0x13 0 0x0a60>;
|
|
interrupt-parent = <&gpio>;
|
|
interrupts = <12 8>; /* Pin 12, active low */
|
|
};
|
|
phy103: ethernet-phy@4 {
|
|
reg = <4>;
|
|
compatible = "marvell,88e1149r";
|
|
marvell,reg-init = <3 0x10 0 0x5777>,
|
|
<3 0x11 0 0x00aa>,
|
|
<3 0x12 0 0x4105>,
|
|
<3 0x13 0 0x0a60>;
|
|
interrupt-parent = <&gpio>;
|
|
interrupts = <12 8>; /* Pin 12, active low */
|
|
};
|
|
};
|
|
|
|
mix0: ethernet@1070000100000 {
|
|
compatible = "cavium,octeon-5750-mix";
|
|
reg = <0x10700 0x00100000 0x0 0x100>, /* MIX */
|
|
<0x11800 0xE0000000 0x0 0x300>, /* AGL */
|
|
<0x11800 0xE0000400 0x0 0x400>, /* AGL_SHARED */
|
|
<0x11800 0xE0002000 0x0 0x8>; /* AGL_PRT_CTL */
|
|
cell-index = <0>;
|
|
interrupts = <0 62>, <1 46>;
|
|
local-mac-address = [ 00 00 00 00 00 00 ];
|
|
phy-handle = <&phy0>;
|
|
};
|
|
|
|
mix1: ethernet@1070000100800 {
|
|
compatible = "cavium,octeon-5750-mix";
|
|
reg = <0x10700 0x00100800 0x0 0x100>, /* MIX */
|
|
<0x11800 0xE0000800 0x0 0x300>, /* AGL */
|
|
<0x11800 0xE0000400 0x0 0x400>, /* AGL_SHARED */
|
|
<0x11800 0xE0002008 0x0 0x8>; /* AGL_PRT_CTL */
|
|
cell-index = <1>;
|
|
interrupts = <1 18>, < 1 46>;
|
|
local-mac-address = [ 00 00 00 00 00 00 ];
|
|
phy-handle = <&phy1>;
|
|
};
|
|
|
|
pip: pip@11800a0000000 {
|
|
interface@0 {
|
|
ethernet@0 {
|
|
phy-handle = <&phy2>;
|
|
cavium,alt-phy-handle = <&phy100>;
|
|
rx-delay = <0>;
|
|
tx-delay = <0>;
|
|
fixed-link {
|
|
speed = <1000>;
|
|
full-duplex;
|
|
};
|
|
};
|
|
ethernet@1 {
|
|
phy-handle = <&phy3>;
|
|
cavium,alt-phy-handle = <&phy101>;
|
|
rx-delay = <0>;
|
|
tx-delay = <0>;
|
|
fixed-link {
|
|
speed = <1000>;
|
|
full-duplex;
|
|
};
|
|
};
|
|
ethernet@2 {
|
|
phy-handle = <&phy4>;
|
|
cavium,alt-phy-handle = <&phy102>;
|
|
rx-delay = <0>;
|
|
tx-delay = <0>;
|
|
};
|
|
ethernet@3 {
|
|
compatible = "cavium,octeon-3860-pip-port";
|
|
reg = <0x3>; /* Port */
|
|
local-mac-address = [ 00 00 00 00 00 00 ];
|
|
phy-handle = <&phy5>;
|
|
cavium,alt-phy-handle = <&phy103>;
|
|
};
|
|
ethernet@4 {
|
|
compatible = "cavium,octeon-3860-pip-port";
|
|
reg = <0x4>; /* Port */
|
|
local-mac-address = [ 00 00 00 00 00 00 ];
|
|
};
|
|
ethernet@5 {
|
|
compatible = "cavium,octeon-3860-pip-port";
|
|
reg = <0x5>; /* Port */
|
|
local-mac-address = [ 00 00 00 00 00 00 ];
|
|
};
|
|
ethernet@6 {
|
|
compatible = "cavium,octeon-3860-pip-port";
|
|
reg = <0x6>; /* Port */
|
|
local-mac-address = [ 00 00 00 00 00 00 ];
|
|
};
|
|
ethernet@7 {
|
|
compatible = "cavium,octeon-3860-pip-port";
|
|
reg = <0x7>; /* Port */
|
|
local-mac-address = [ 00 00 00 00 00 00 ];
|
|
};
|
|
ethernet@8 {
|
|
compatible = "cavium,octeon-3860-pip-port";
|
|
reg = <0x8>; /* Port */
|
|
local-mac-address = [ 00 00 00 00 00 00 ];
|
|
};
|
|
ethernet@9 {
|
|
compatible = "cavium,octeon-3860-pip-port";
|
|
reg = <0x9>; /* Port */
|
|
local-mac-address = [ 00 00 00 00 00 00 ];
|
|
};
|
|
ethernet@a {
|
|
compatible = "cavium,octeon-3860-pip-port";
|
|
reg = <0xa>; /* Port */
|
|
local-mac-address = [ 00 00 00 00 00 00 ];
|
|
};
|
|
ethernet@b {
|
|
compatible = "cavium,octeon-3860-pip-port";
|
|
reg = <0xb>; /* Port */
|
|
local-mac-address = [ 00 00 00 00 00 00 ];
|
|
};
|
|
ethernet@c {
|
|
compatible = "cavium,octeon-3860-pip-port";
|
|
reg = <0xc>; /* Port */
|
|
local-mac-address = [ 00 00 00 00 00 00 ];
|
|
};
|
|
ethernet@d {
|
|
compatible = "cavium,octeon-3860-pip-port";
|
|
reg = <0xd>; /* Port */
|
|
local-mac-address = [ 00 00 00 00 00 00 ];
|
|
};
|
|
ethernet@e {
|
|
compatible = "cavium,octeon-3860-pip-port";
|
|
reg = <0xe>; /* Port */
|
|
local-mac-address = [ 00 00 00 00 00 00 ];
|
|
};
|
|
ethernet@f {
|
|
compatible = "cavium,octeon-3860-pip-port";
|
|
reg = <0xf>; /* Port */
|
|
local-mac-address = [ 00 00 00 00 00 00 ];
|
|
};
|
|
};
|
|
|
|
interface@1 {
|
|
ethernet@0 {
|
|
compatible = "cavium,octeon-3860-pip-port";
|
|
reg = <0x0>; /* Port */
|
|
local-mac-address = [ 00 00 00 00 00 00 ];
|
|
phy-handle = <&phy6>;
|
|
};
|
|
ethernet@1 {
|
|
compatible = "cavium,octeon-3860-pip-port";
|
|
reg = <0x1>; /* Port */
|
|
local-mac-address = [ 00 00 00 00 00 00 ];
|
|
phy-handle = <&phy7>;
|
|
};
|
|
ethernet@2 {
|
|
compatible = "cavium,octeon-3860-pip-port";
|
|
reg = <0x2>; /* Port */
|
|
local-mac-address = [ 00 00 00 00 00 00 ];
|
|
phy-handle = <&phy8>;
|
|
};
|
|
ethernet@3 {
|
|
compatible = "cavium,octeon-3860-pip-port";
|
|
reg = <0x3>; /* Port */
|
|
local-mac-address = [ 00 00 00 00 00 00 ];
|
|
phy-handle = <&phy9>;
|
|
};
|
|
};
|
|
};
|
|
|
|
twsi0: i2c@1180000001000 {
|
|
rtc@68 {
|
|
compatible = "dallas,ds1337";
|
|
reg = <0x68>;
|
|
};
|
|
tmp@4c {
|
|
compatible = "ti,tmp421";
|
|
reg = <0x4c>;
|
|
};
|
|
};
|
|
|
|
twsi1: i2c@1180000001200 {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
compatible = "cavium,octeon-3860-twsi";
|
|
reg = <0x11800 0x00001200 0x0 0x200>;
|
|
interrupts = <0 59>;
|
|
clock-frequency = <100000>;
|
|
};
|
|
|
|
uart1: serial@1180000000c00 {
|
|
compatible = "cavium,octeon-3860-uart","ns16550";
|
|
reg = <0x11800 0x00000c00 0x0 0x400>;
|
|
clock-frequency = <0>;
|
|
current-speed = <115200>;
|
|
reg-shift = <3>;
|
|
interrupts = <0 35>;
|
|
};
|
|
|
|
uart2: serial@1180000000400 {
|
|
compatible = "cavium,octeon-3860-uart","ns16550";
|
|
reg = <0x11800 0x00000400 0x0 0x400>;
|
|
clock-frequency = <0>;
|
|
current-speed = <115200>;
|
|
reg-shift = <3>;
|
|
interrupts = <1 16>;
|
|
};
|
|
|
|
bootbus: bootbus@1180000000000 {
|
|
led0: led-display@4,0 {
|
|
compatible = "avago,hdsp-253x";
|
|
reg = <4 0x20 0x20>, <4 0 0x20>;
|
|
};
|
|
|
|
cf0: compact-flash@5,0 {
|
|
compatible = "cavium,ebt3000-compact-flash";
|
|
reg = <5 0 0x10000>, <6 0 0x10000>;
|
|
cavium,bus-width = <16>;
|
|
cavium,true-ide;
|
|
cavium,dma-engine-handle = <&dma0>;
|
|
};
|
|
};
|
|
|
|
uctl: uctl@118006f000000 {
|
|
compatible = "cavium,octeon-6335-uctl";
|
|
reg = <0x11800 0x6f000000 0x0 0x100>;
|
|
ranges; /* Direct mapping */
|
|
#address-cells = <2>;
|
|
#size-cells = <2>;
|
|
/* 12MHz, 24MHz and 48MHz allowed */
|
|
refclk-frequency = <12000000>;
|
|
/* Either "crystal" or "external" */
|
|
refclk-type = "crystal";
|
|
|
|
ehci@16f0000000000 {
|
|
compatible = "cavium,octeon-6335-ehci","usb-ehci";
|
|
reg = <0x16f00 0x00000000 0x0 0x100>;
|
|
interrupts = <0 56>;
|
|
big-endian-regs;
|
|
};
|
|
ohci@16f0000000400 {
|
|
compatible = "cavium,octeon-6335-ohci","usb-ohci";
|
|
reg = <0x16f00 0x00000400 0x0 0x100>;
|
|
interrupts = <0 56>;
|
|
big-endian-regs;
|
|
};
|
|
};
|
|
|
|
usbn: usbn@1180068000000 {
|
|
/* 12MHz, 24MHz and 48MHz allowed */
|
|
refclk-frequency = <12000000>;
|
|
/* Either "crystal" or "external" */
|
|
refclk-type = "crystal";
|
|
};
|
|
};
|
|
|
|
aliases {
|
|
mix0 = &mix0;
|
|
mix1 = &mix1;
|
|
pip = &pip;
|
|
smi0 = &smi0;
|
|
smi1 = &smi1;
|
|
twsi0 = &twsi0;
|
|
twsi1 = &twsi1;
|
|
uart0 = &uart0;
|
|
uart1 = &uart1;
|
|
uart2 = &uart2;
|
|
flash0 = &flash0;
|
|
cf0 = &cf0;
|
|
uctl = &uctl;
|
|
usbn = &usbn;
|
|
led0 = &led0;
|
|
};
|
|
};
|