|
|
@@ -0,0 +1,186 @@
|
|
|
+// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
|
|
|
+/dts-v1/;
|
|
|
+
|
|
|
+#include <dt-bindings/gpio/gpio.h>
|
|
|
+#include <dt-bindings/input/input.h>
|
|
|
+
|
|
|
+#include "ar7100.dtsi"
|
|
|
+
|
|
|
+/ {
|
|
|
+ compatible = "siemens,ws-ap3610", "qca,ar7161";
|
|
|
+ model = "Siemens WS-AP3610";
|
|
|
+
|
|
|
+ chosen {
|
|
|
+ bootargs = "console=ttyS0,115200";
|
|
|
+ };
|
|
|
+
|
|
|
+ aliases {
|
|
|
+ led-boot = &led_power_green;
|
|
|
+ led-failsafe = &led_power_red;
|
|
|
+ led-running = &led_power_green;
|
|
|
+ led-upgrade = &led_power_red;
|
|
|
+ label-mac-device = ð0;
|
|
|
+ };
|
|
|
+
|
|
|
+ extosc: ref {
|
|
|
+ compatible = "fixed-clock";
|
|
|
+ #clock-cells = <0>;
|
|
|
+ clock-output-names = "ref";
|
|
|
+ clock-frequency = <40000000>;
|
|
|
+ };
|
|
|
+
|
|
|
+ leds {
|
|
|
+ compatible = "gpio-leds";
|
|
|
+
|
|
|
+ led_power_green: led_power_green {
|
|
|
+ label = "ws-ap3610:green:power";
|
|
|
+ gpios = <&gpio 7 GPIO_ACTIVE_LOW>;
|
|
|
+ };
|
|
|
+
|
|
|
+ led_power_red: led_power_red {
|
|
|
+ label = "ws-ap3610:red:power";
|
|
|
+ gpios = <&gpio 8 GPIO_ACTIVE_LOW>;
|
|
|
+ };
|
|
|
+
|
|
|
+ led_wlan5_blue {
|
|
|
+ label = "ws-ap3610:blue:wlan5";
|
|
|
+ gpios = <&gpio 2 GPIO_ACTIVE_LOW>;
|
|
|
+ linux,default-trigger = "phy0tpt";
|
|
|
+ };
|
|
|
+
|
|
|
+ led_wlan5_green {
|
|
|
+ label = "ws-ap3610:green:wlan5";
|
|
|
+ gpios = <&gpio 3 GPIO_ACTIVE_LOW>;
|
|
|
+ };
|
|
|
+
|
|
|
+ led_wlan2_blue {
|
|
|
+ label = "ws-ap3610:blue:wlan2";
|
|
|
+ gpios = <&gpio 4 GPIO_ACTIVE_LOW>;
|
|
|
+ linux,default-trigger = "phy1tpt";
|
|
|
+ };
|
|
|
+
|
|
|
+ led_wlan2_green {
|
|
|
+ label = "ws-ap3610:green:wlan2";
|
|
|
+ gpios = <&gpio 5 GPIO_ACTIVE_LOW>;
|
|
|
+ };
|
|
|
+ };
|
|
|
+
|
|
|
+ keys {
|
|
|
+ compatible = "gpio-keys";
|
|
|
+
|
|
|
+ reset {
|
|
|
+ label = "reset";
|
|
|
+ linux,code = <KEY_RESTART>;
|
|
|
+ gpios = <&gpio 11 GPIO_ACTIVE_LOW>;
|
|
|
+ };
|
|
|
+ };
|
|
|
+};
|
|
|
+
|
|
|
+&pcie0 {
|
|
|
+ status = "okay";
|
|
|
+};
|
|
|
+
|
|
|
+&uart {
|
|
|
+ status = "okay";
|
|
|
+};
|
|
|
+
|
|
|
+&mdio0 {
|
|
|
+ status = "okay";
|
|
|
+
|
|
|
+ phy0: ethernet-phy@0 {
|
|
|
+ /*
|
|
|
+ * When the compatible-is missing, PHY autodetection
|
|
|
+ * is performed, but the PHY-ID reads all 0xff.
|
|
|
+ *
|
|
|
+ * Linux does not create the device in this case,
|
|
|
+ * and the reset is never even de-asserted.
|
|
|
+ */
|
|
|
+ compatible = "ethernet-phy-id0143.bca2",
|
|
|
+ "ethernet-phy-ieee802.3-c22";
|
|
|
+ reg = <0>;
|
|
|
+
|
|
|
+ resets = <&rst 8>;
|
|
|
+ reset-names = "phy";
|
|
|
+ reset-assert-us = <10000>;
|
|
|
+ reset-deassert-us = <10000>;
|
|
|
+ };
|
|
|
+};
|
|
|
+
|
|
|
+ð0 {
|
|
|
+ status = "okay";
|
|
|
+
|
|
|
+ phy-mode = "rgmii-id";
|
|
|
+ phy-handle = <&phy0>;
|
|
|
+};
|
|
|
+
|
|
|
+&spi {
|
|
|
+ status = "okay";
|
|
|
+
|
|
|
+ num-cs = <1>;
|
|
|
+
|
|
|
+ flash@0 {
|
|
|
+ compatible = "jedec,spi-nor";
|
|
|
+ reg = <0>;
|
|
|
+ spi-max-frequency = <25000000>;
|
|
|
+
|
|
|
+ partitions {
|
|
|
+ compatible = "fixed-partitions";
|
|
|
+ #address-cells = <1>;
|
|
|
+ #size-cells = <1>;
|
|
|
+
|
|
|
+ partition@0 {
|
|
|
+ label = "u-boot";
|
|
|
+ reg = <0x0 0x40000>;
|
|
|
+ read-only;
|
|
|
+ };
|
|
|
+
|
|
|
+ partition@40000 {
|
|
|
+ label = "u-boot-bak";
|
|
|
+ reg = <0x40000 0x40000>;
|
|
|
+ read-only;
|
|
|
+ };
|
|
|
+
|
|
|
+ partition@80000 {
|
|
|
+ compatible = "denx,uimage";
|
|
|
+ label = "firmware";
|
|
|
+ reg = <0x80000 0xe00000>;
|
|
|
+ };
|
|
|
+
|
|
|
+ partition@e80000 {
|
|
|
+ label = "cfg1";
|
|
|
+ reg = <0xe80000 0x40000>;
|
|
|
+ read-only;
|
|
|
+ };
|
|
|
+
|
|
|
+ partition@ec0000 {
|
|
|
+ label = "cfg2";
|
|
|
+ reg = <0xec0000 0x40000>;
|
|
|
+ read-only;
|
|
|
+ };
|
|
|
+
|
|
|
+ partition@f00000 {
|
|
|
+ label = "nvram1";
|
|
|
+ reg = <0xf00000 0x40000>;
|
|
|
+ read-only;
|
|
|
+ };
|
|
|
+
|
|
|
+ partition@f40000 {
|
|
|
+ label = "nvram2";
|
|
|
+ reg = <0xf40000 0x40000>;
|
|
|
+ read-only;
|
|
|
+ };
|
|
|
+
|
|
|
+ partition@f80000 {
|
|
|
+ label = "rsvd1";
|
|
|
+ reg = <0xf80000 0x40000>;
|
|
|
+ read-only;
|
|
|
+ };
|
|
|
+
|
|
|
+ partition@fc0000 {
|
|
|
+ label = "rsvd2";
|
|
|
+ reg = <0xfc0000 0x40000>;
|
|
|
+ read-only;
|
|
|
+ };
|
|
|
+ };
|
|
|
+ };
|
|
|
+};
|