mirror of
https://github.com/openwrt/openwrt.git
synced 2024-12-27 01:11:14 +00:00
70000ab509
The RTL8366S/RB switch node in DTS defines "mii-bus = <&mdio0>" to permit management via SMI but this has likely never worked, instead falling back to using GPIOs in the past: rtl8366s switch: cannot find mdio bus from bus handle (yet) rtl8366s switch: using GPIO pins 19 (SDA) and 20 (SCK) rtl8366s switch: RTL8366 ver. 1 chip found Recently, the rtl8366s and rtl8366_smi drivers were changed from built-in to loadable modules. This affected driver probing order and caused switch initialization (and network access) to fail: rtl8366s switch: using MDIO bus 'ag71xx_mdio' rtl8366s switch: unknown chip id (ffff) rtl8366s switch: chip detection failed, err=-19 Force using GPIOs to manage the switch by dropping the "mii-bus" DTS definition, which works for both built-in and loadable switch drivers. Fixes:6e0f0eae5b
("ath79: use rtl8366s and rtl8366_smi as a module") Fixes:575ec7a4b1
("ath79: use rtl8366rb as a module") Tested-by: Tony Ambardar <itugrok@yahoo.com> # WZR-HP-G300NH (RTL8366S) Signed-off-by: Tony Ambardar <itugrok@yahoo.com>
263 lines
4.4 KiB
Plaintext
263 lines
4.4 KiB
Plaintext
// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
|
|
#include "ar9132.dtsi"
|
|
#include <dt-bindings/gpio/gpio.h>
|
|
#include <dt-bindings/input/input.h>
|
|
|
|
/ {
|
|
aliases {
|
|
led-boot = &led_diag;
|
|
led-failsafe = &led_security;
|
|
led-upgrade = &led_diag;
|
|
};
|
|
|
|
/* There is a GPIO driven NXP 74HC153 dual 4-way multiplexer on board
|
|
* used for buttons that are on top of the the device.
|
|
*/
|
|
mux: mux-controller {
|
|
compatible = "gpio-mux";
|
|
#mux-control-cells = <0>;
|
|
|
|
mux-gpios = <&gpio 9 GPIO_ACTIVE_HIGH>, /* s0 */
|
|
<&gpio 11 GPIO_ACTIVE_HIGH>; /* s1 */
|
|
};
|
|
|
|
gpio2: key-mux1 {
|
|
compatible = "gpio-cascade";
|
|
mux-controls = <&mux>;
|
|
|
|
gpio-controller;
|
|
#gpio-cells = <2>;
|
|
|
|
// GPIOs used by this node, the mux pin
|
|
upstream-gpios = <&gpio 12 GPIO_ACTIVE_HIGH>; /* 1y */
|
|
};
|
|
|
|
gpio3: key-mux2 {
|
|
compatible = "gpio-cascade";
|
|
mux-controls = <&mux>;
|
|
|
|
gpio-controller;
|
|
#gpio-cells = <2>;
|
|
|
|
// GPIOs used by this node, the mux pin
|
|
upstream-gpios = <&gpio 14 GPIO_ACTIVE_HIGH>; /* 2y */
|
|
};
|
|
|
|
keys {
|
|
compatible = "gpio-keys-polled";
|
|
poll-interval = <20>;
|
|
|
|
aoss {
|
|
label = "aoss";
|
|
linux,code = <KEY_WPS_BUTTON>;
|
|
gpios = <&gpio2 0 GPIO_ACTIVE_LOW>;
|
|
debounce-interval = <60>;
|
|
};
|
|
|
|
reset {
|
|
label = "reset";
|
|
linux,code = <KEY_RESTART>;
|
|
gpios = <&gpio2 1 GPIO_ACTIVE_LOW>;
|
|
debounce-interval = <60>;
|
|
};
|
|
|
|
router_on {
|
|
label = "router_on";
|
|
linux,code = <BTN_5>;
|
|
gpios = <&gpio2 2 GPIO_ACTIVE_HIGH>;
|
|
debounce-interval = <60>;
|
|
};
|
|
|
|
movie_off {
|
|
label = "movie_off";
|
|
linux,code = <BTN_3>;
|
|
gpios = <&gpio2 3 GPIO_ACTIVE_HIGH>;
|
|
debounce-interval = <60>;
|
|
};
|
|
|
|
usb {
|
|
label = "usb";
|
|
linux,code = <BTN_2>;
|
|
gpios = <&gpio3 1 GPIO_ACTIVE_LOW>;
|
|
debounce-interval = <60>;
|
|
};
|
|
|
|
router_auto {
|
|
label = "router_auto";
|
|
linux,code = <BTN_6>;
|
|
gpios = <&gpio3 2 GPIO_ACTIVE_HIGH>;
|
|
debounce-interval = <60>;
|
|
};
|
|
|
|
movie_on {
|
|
label = "movie_on";
|
|
linux,code = <BTN_4>;
|
|
gpios = <&gpio3 3 GPIO_ACTIVE_HIGH>;
|
|
debounce-interval = <60>;
|
|
};
|
|
};
|
|
|
|
flash@1e000000 {
|
|
compatible = "cfi-flash";
|
|
reg = <0x1e000000 0x2000000>;
|
|
bank-width = <2>;
|
|
device-width = <2>;
|
|
|
|
partitions {
|
|
compatible = "fixed-partitions";
|
|
#address-cells = <1>;
|
|
#size-cells = <1>;
|
|
|
|
partition@0 {
|
|
label = "u-boot";
|
|
reg = <0x0000000 0x0040000>;
|
|
read-only;
|
|
};
|
|
|
|
partition@40000 {
|
|
label = "u-boot-env";
|
|
reg = <0x0040000 0x0020000>;
|
|
read-only;
|
|
};
|
|
|
|
partition@60000 {
|
|
compatible = "denx,uimage";
|
|
label = "firmware";
|
|
reg = <0x0060000 0x1f60000>;
|
|
};
|
|
|
|
partition@1fc0000 {
|
|
label = "user_property";
|
|
reg = <0x1fc0000 0x0020000>;
|
|
read-only;
|
|
};
|
|
|
|
art: partition@1fe0000 {
|
|
label = "art";
|
|
reg = <0x1fe0000 0x020000>;
|
|
read-only;
|
|
};
|
|
};
|
|
};
|
|
|
|
leds {
|
|
compatible = "gpio-leds";
|
|
|
|
usb {
|
|
label = "blue:usb";
|
|
gpios = <&gpio 0 GPIO_ACTIVE_LOW>;
|
|
trigger-sources = <&hub_port>;
|
|
linux,default-trigger = "usbport";
|
|
};
|
|
|
|
led_diag: diag {
|
|
label = "red:diag";
|
|
gpios = <&gpio 1 GPIO_ACTIVE_LOW>;
|
|
};
|
|
|
|
wireless {
|
|
label = "green:wireless";
|
|
gpios = <&gpio 6 GPIO_ACTIVE_LOW>;
|
|
linux,default-trigger = "phy0tpt";
|
|
};
|
|
|
|
led_security: security {
|
|
label = "amber:security";
|
|
gpios = <&gpio 17 GPIO_ACTIVE_LOW>;
|
|
};
|
|
|
|
router {
|
|
label = "green:router";
|
|
gpios = <&gpio 18 GPIO_ACTIVE_LOW>;
|
|
};
|
|
};
|
|
|
|
switch: switch {
|
|
status = "disabled";
|
|
|
|
gpio-sda = <&gpio 19 GPIO_ACTIVE_HIGH>;
|
|
gpio-sck = <&gpio 20 GPIO_ACTIVE_HIGH>;
|
|
|
|
mdio-bus {
|
|
status = "okay";
|
|
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
|
|
phy4: ethernet-phy@4 {
|
|
reg = <4>;
|
|
phy-mode = "rgmii";
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
&mdio0 {
|
|
status = "okay";
|
|
};
|
|
|
|
ð0 {
|
|
status = "disabled";
|
|
|
|
phy-mode = "rgmii";
|
|
nvmem-cells = <&macaddr_art_1120c>;
|
|
nvmem-cell-names = "mac-address";
|
|
|
|
fixed-link {
|
|
speed = <1000>;
|
|
full-duplex;
|
|
};
|
|
};
|
|
|
|
&mdio1 {
|
|
status = "okay";
|
|
};
|
|
|
|
ð1 {
|
|
status = "disabled";
|
|
|
|
compatible = "qca,ar9130-eth", "syscon";
|
|
reg = <0x1a000000 0x200
|
|
0x18070004 0x4>;
|
|
|
|
pll-reg = <0x4 0x18 22>;
|
|
pll-handle = <&pll>;
|
|
|
|
phy-mode = "rgmii";
|
|
phy-handle = <&phy4>;
|
|
resets = <&rst 13>;
|
|
reset-names = "mac";
|
|
qca,mac-idx = <1>;
|
|
nvmem-cells = <&macaddr_art_1120c>;
|
|
nvmem-cell-names = "mac-address";
|
|
};
|
|
|
|
&wmac {
|
|
status = "okay";
|
|
|
|
mtd-cal-data = <&art 0x11000>;
|
|
};
|
|
|
|
&uart {
|
|
status = "okay";
|
|
};
|
|
|
|
&usb {
|
|
status = "okay";
|
|
};
|
|
|
|
&usb_phy {
|
|
status = "okay";
|
|
};
|
|
|
|
&art {
|
|
compatible = "nvmem-cells";
|
|
#address-cells = <1>;
|
|
#size-cells = <1>;
|
|
|
|
macaddr_art_1120c: macaddr@1120c {
|
|
reg = <0x1120c 0x6>;
|
|
};
|
|
};
|