2022-11-07 21:41:04 +08:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
|
|
/*
|
|
|
|
* Device tree for D-Link DIR-890L
|
|
|
|
* D-Link calls this board "WRGAC36"
|
|
|
|
* this router has the same looks and form factor as D-Link DIR-885L.
|
|
|
|
*
|
|
|
|
* Some differences from DIR-885L include a separate USB2 port, separate LEDs
|
|
|
|
* for USB2 and USB3, a separate VCC supply for the USB2 slot and no
|
|
|
|
* router/extender switch is mounted (there is an empty mount point on the
|
|
|
|
* PCB) so this device is a pure router. Also the LAN ports are in the right
|
|
|
|
* order.
|
|
|
|
*
|
|
|
|
* Based on the device tree for DIR-885L
|
|
|
|
* Copyright (C) 2016 Rafał Miłecki <zajec5@gmail.com>
|
|
|
|
* Copyright (C) 2022 Linus Walleij
|
|
|
|
*/
|
|
|
|
|
|
|
|
/dts-v1/;
|
|
|
|
|
|
|
|
#include "bcm47094.dtsi"
|
|
|
|
#include "bcm5301x-nand-cs0-bch1.dtsi"
|
|
|
|
|
|
|
|
/ {
|
|
|
|
compatible = "dlink,dir-890l", "brcm,bcm47094", "brcm,bcm4708";
|
|
|
|
model = "D-Link DIR-890L";
|
|
|
|
|
|
|
|
chosen {
|
|
|
|
bootargs = "console=ttyS0,115200 earlycon";
|
|
|
|
};
|
|
|
|
|
|
|
|
memory@0 {
|
|
|
|
device_type = "memory";
|
|
|
|
reg = <0x00000000 0x08000000>,
|
|
|
|
<0x88000000 0x08000000>;
|
|
|
|
};
|
|
|
|
|
|
|
|
leds {
|
|
|
|
/*
|
|
|
|
* LED information is derived from the boot log which
|
|
|
|
* conveniently lists all the LEDs.
|
|
|
|
*/
|
|
|
|
compatible = "gpio-leds";
|
|
|
|
|
2022-11-25 22:41:27 +08:00
|
|
|
led-power-white {
|
2022-11-07 21:41:04 +08:00
|
|
|
label = "bcm53xx:white:power";
|
|
|
|
gpios = <&chipcommon 0 GPIO_ACTIVE_LOW>;
|
|
|
|
linux,default-trigger = "default-on";
|
|
|
|
};
|
|
|
|
|
2022-11-25 22:41:27 +08:00
|
|
|
led-wan-white {
|
2022-11-07 21:41:04 +08:00
|
|
|
label = "bcm53xx:white:wan";
|
|
|
|
gpios = <&chipcommon 1 GPIO_ACTIVE_LOW>;
|
|
|
|
};
|
|
|
|
|
2022-11-25 22:41:27 +08:00
|
|
|
led-power-amber {
|
2022-11-07 21:41:04 +08:00
|
|
|
label = "bcm53xx:amber:power";
|
|
|
|
gpios = <&chipcommon 2 GPIO_ACTIVE_LOW>;
|
|
|
|
};
|
|
|
|
|
2022-11-25 22:41:27 +08:00
|
|
|
led-wan-amber {
|
2022-11-07 21:41:04 +08:00
|
|
|
label = "bcm53xx:amber:wan";
|
|
|
|
gpios = <&chipcommon 3 GPIO_ACTIVE_LOW>;
|
|
|
|
};
|
|
|
|
|
2022-11-25 22:41:27 +08:00
|
|
|
led-usb3-white {
|
2022-11-07 21:41:04 +08:00
|
|
|
label = "bcm53xx:white:usb3";
|
|
|
|
gpios = <&chipcommon 8 GPIO_ACTIVE_LOW>;
|
|
|
|
trigger-sources = <&xhci_port1>;
|
|
|
|
linux,default-trigger = "usbport";
|
|
|
|
};
|
|
|
|
|
2022-11-25 22:41:27 +08:00
|
|
|
led-usb2-white {
|
2022-11-07 21:41:04 +08:00
|
|
|
label = "bcm53xx:white:usb2";
|
|
|
|
gpios = <&chipcommon 15 GPIO_ACTIVE_LOW>;
|
|
|
|
trigger-sources = <&ohci_port1>, <&ehci_port1>;
|
|
|
|
linux,default-trigger = "usbport";
|
|
|
|
};
|
|
|
|
|
2022-11-25 22:41:27 +08:00
|
|
|
led-2ghz {
|
2022-11-07 21:41:04 +08:00
|
|
|
label = "bcm53xx:white:2ghz";
|
|
|
|
gpios = <&chipcommon 13 GPIO_ACTIVE_LOW>;
|
|
|
|
};
|
|
|
|
|
2022-11-25 22:41:27 +08:00
|
|
|
led-5ghz {
|
2022-11-07 21:41:04 +08:00
|
|
|
label = "bcm53xx:white:5ghz";
|
|
|
|
gpios = <&chipcommon 14 GPIO_ACTIVE_LOW>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
gpio-keys {
|
|
|
|
compatible = "gpio-keys";
|
|
|
|
|
|
|
|
button-wps {
|
|
|
|
label = "WPS";
|
|
|
|
linux,code = <KEY_WPS_BUTTON>;
|
|
|
|
gpios = <&chipcommon 7 GPIO_ACTIVE_LOW>;
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Called "factory reset" in the vendor dmesg */
|
|
|
|
button-restart {
|
|
|
|
label = "Reset";
|
|
|
|
linux,code = <KEY_RESTART>;
|
|
|
|
gpios = <&chipcommon 17 GPIO_ACTIVE_LOW>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The flash memory is memory mapped at 0x1e000000-0x1fffffff
|
|
|
|
* 64KB blocks; total size 2MB, same that can be
|
|
|
|
* found attached to the spi_nor SPI controller.
|
|
|
|
*/
|
|
|
|
nvram@1e1f0000 {
|
|
|
|
compatible = "brcm,nvram";
|
|
|
|
reg = <0x1e1f0000 0x00010000>;
|
|
|
|
|
|
|
|
et0macaddr: et0macaddr {
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
&gmac2 {
|
|
|
|
/*
|
|
|
|
* The NVRAM curiously does not contain a MAC address
|
|
|
|
* for et2 so since that is the only ethernet interface
|
|
|
|
* actually in use on the platform, we use this et0 MAC
|
|
|
|
* address for et2.
|
|
|
|
*/
|
|
|
|
nvmem-cells = <&et0macaddr>;
|
|
|
|
nvmem-cell-names = "mac-address";
|
|
|
|
};
|
|
|
|
|
|
|
|
&spi_nor {
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&nandcs {
|
|
|
|
/* Spansion S34ML01G2, 128MB with 128KB erase blocks */
|
|
|
|
partitions {
|
|
|
|
compatible = "fixed-partitions";
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <1>;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* This is called "nflash" in the vendor kernel with
|
|
|
|
* "upgrade" and "rootfs" (probably using OpenWrt
|
|
|
|
* splitpart). We call it "firmware" like standard tools
|
|
|
|
* assume. The CFE loader contains incorrect information
|
|
|
|
* about TRX partitions, ignore this, there are no TRX
|
|
|
|
* partitions: this device uses SEAMA.
|
|
|
|
*/
|
|
|
|
firmware@0 {
|
2023-07-13 06:16:42 +08:00
|
|
|
compatible = "seama";
|
2022-11-07 21:41:04 +08:00
|
|
|
label = "firmware";
|
|
|
|
reg = <0x00000000 0x08000000>;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
&usb2 {
|
|
|
|
vcc-gpios = <&chipcommon 21 GPIO_ACTIVE_HIGH>;
|
|
|
|
};
|
|
|
|
|
|
|
|
&usb3 {
|
|
|
|
vcc-gpios = <&chipcommon 18 GPIO_ACTIVE_HIGH>;
|
|
|
|
};
|
|
|
|
|
|
|
|
&usb3_phy {
|
|
|
|
status = "okay";
|
|
|
|
};
|
|
|
|
|
|
|
|
&srab {
|
|
|
|
status = "okay";
|
|
|
|
|
|
|
|
ports {
|
|
|
|
port@0 {
|
|
|
|
label = "lan1";
|
|
|
|
};
|
|
|
|
|
|
|
|
port@1 {
|
|
|
|
label = "lan2";
|
|
|
|
};
|
|
|
|
|
|
|
|
port@2 {
|
|
|
|
label = "lan3";
|
|
|
|
};
|
|
|
|
|
|
|
|
port@3 {
|
|
|
|
label = "lan4";
|
|
|
|
};
|
|
|
|
|
|
|
|
port@4 {
|
|
|
|
label = "wan";
|
|
|
|
};
|
|
|
|
|
2023-10-13 18:33:13 +08:00
|
|
|
port@5 {
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
|
|
|
port@7 {
|
|
|
|
status = "disabled";
|
|
|
|
};
|
|
|
|
|
2022-11-07 21:41:04 +08:00
|
|
|
port@8 {
|
|
|
|
label = "cpu";
|
|
|
|
phy-mode = "rgmii";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|