aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--package/boot/uboot-envtools/files/ath793
-rw-r--r--target/linux/ath79/dts/ar9344_ruckus_zf7372.dts133
-rw-r--r--target/linux/ath79/dts/ar934x_ruckus_zf73xx.dtsi198
-rw-r--r--target/linux/ath79/generic/base-files/etc/board.d/01_leds3
-rw-r--r--target/linux/ath79/generic/base-files/etc/board.d/02_network5
-rw-r--r--target/linux/ath79/image/generic.mk16
6 files changed, 358 insertions, 0 deletions
diff --git a/package/boot/uboot-envtools/files/ath79 b/package/boot/uboot-envtools/files/ath79
index a435e06a0d..9e4d0ff96d 100644
--- a/package/boot/uboot-envtools/files/ath79
+++ b/package/boot/uboot-envtools/files/ath79
@@ -126,6 +126,9 @@ plasmacloud,pa300e)
qihoo,c301)
ubootenv_add_uci_config "/dev/mtd9" "0x0" "0x10000" "0x10000"
;;
+ruckus,zf7372)
+ ubootenv_add_uci_config "/dev/mtd2" "0x0" "0x40000" "0x10000"
+ ;;
sophos,ap15|\
sophos,ap55|\
sophos,ap55c|\
diff --git a/target/linux/ath79/dts/ar9344_ruckus_zf7372.dts b/target/linux/ath79/dts/ar9344_ruckus_zf7372.dts
new file mode 100644
index 0000000000..4bf7276db5
--- /dev/null
+++ b/target/linux/ath79/dts/ar9344_ruckus_zf7372.dts
@@ -0,0 +1,133 @@
+// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
+
+#include "ar934x_ruckus_zf73xx.dtsi"
+
+/ {
+ model = "Ruckus ZoneFlex 7352/7372[-E/-U]";
+ compatible = "ruckus,zf7372", "qca,ar9344";
+
+ leds {
+ air-green {
+ label = "green:air";
+ gpios = <&gpio 18 GPIO_ACTIVE_LOW>;
+ };
+
+ air-yellow {
+ label = "yellow:air";
+ gpios = <&gpio 11 GPIO_ACTIVE_LOW>;
+ };
+
+ dir-green {
+ label = "green:dir";
+ gpios = <&gpio 17 GPIO_ACTIVE_LOW>;
+ };
+
+ eth1-green {
+ label = "green:eth1";
+ gpios = <&gpio 13 GPIO_ACTIVE_LOW>;
+ };
+
+ power_red: power-red {
+ label = "red:power";
+ gpios = <&gpio 16 GPIO_ACTIVE_HIGH>;
+ panic-indicator;
+ };
+
+ wlan2g-green {
+ label = "green:wlan2g";
+ gpios = <&gpio 19 GPIO_ACTIVE_LOW>;
+ linux,default-trigger = "phy0assoc";
+ };
+
+ wlan2g-yellow {
+ label = "yellow:wlan2g";
+ gpios = <&gpio 20 GPIO_ACTIVE_LOW>;
+ linux,default-trigger = "phy0tpt";
+ };
+
+ wlan5g-green {
+ label = "green:wlan5g";
+ gpios = <&gpio 21 GPIO_ACTIVE_LOW>;
+ linux,default-trigger = "phy1assoc";
+ };
+
+ wlan5g-yellow {
+ label = "yellow:wlan5g";
+ gpios = <&gpio 22 GPIO_ACTIVE_LOW>;
+ linux,default-trigger = "phy1tpt";
+ };
+ };
+
+ beamforming-2g-spi {
+ compatible = "spi-gpio";
+ mosi-gpios = <&gpio 15 GPIO_ACTIVE_HIGH>;
+ sck-gpios = <&gpio 14 GPIO_ACTIVE_HIGH>;
+ num-chipselects = <0>;
+
+ beamforming-2g-gpio@0 {
+ compatible = "fairchild,74hc595";
+ reg = <0>;
+ registers-number = <1>;
+ spi-max-frequency = <24000000>;
+ gpio-controller;
+ #gpio-cells = <2>;
+ };
+ };
+
+ beamforming-5g-spi {
+ compatible = "spi-gpio";
+ mosi-gpios = <&ath9k 15 GPIO_ACTIVE_HIGH>;
+ sck-gpios = <&ath9k 14 GPIO_ACTIVE_HIGH>;
+ num-chipselects = <0>;
+
+ beamforming-5g-gpio@0 {
+ compatible = "fairchild,74hc595";
+ reg = <0>;
+ registers-number = <1>;
+ spi-max-frequency = <24000000>;
+ gpio-controller;
+ #gpio-cells = <2>;
+ };
+ };
+};
+
+&eth0 {
+ nvmem-cells = <&macaddr_board_data_6c>;
+};
+
+&eth1 {
+ status = "okay";
+
+ nvmem-cells = <&macaddr_board_data_66>;
+ nvmem-cell-names = "mac-address";
+
+ gmac-config {
+ device = <&gmac>;
+ switch-phy-swap = <0>;
+ switch-only-mode = <1>;
+ };
+};
+
+&pcie {
+ status = "okay";
+
+ ath9k: wifi@0,0 {
+ compatible = "pci168c,0033";
+ reg = <0x0000 0 0 0 0>;
+ gpio-controller;
+ #gpio-cells = <2>;
+
+ nvmem-cells = <&macaddr_board_data_76>;
+ nvmem-cell-names = "mac-address";
+ };
+};
+
+&board_data {
+ macaddr_board_data_6c: macaddr@6c {
+ reg = <0x6c 0x6>;
+ };
+
+ macaddr_board_data_76: macaddr@76 {
+ reg = <0x76 0x6>;
+ };
+};
diff --git a/target/linux/ath79/dts/ar934x_ruckus_zf73xx.dtsi b/target/linux/ath79/dts/ar934x_ruckus_zf73xx.dtsi
new file mode 100644
index 0000000000..a0348e7213
--- /dev/null
+++ b/target/linux/ath79/dts/ar934x_ruckus_zf73xx.dtsi
@@ -0,0 +1,198 @@
+// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
+
+#include "ar9344.dtsi"
+
+#include <dt-bindings/gpio/gpio.h>
+#include <dt-bindings/input/input.h>
+#include <dt-bindings/mtd/partitions/uimage.h>
+
+/ {
+ aliases {
+ led-boot = &power_green;
+ led-failsafe = &power_red;
+ led-running = &power_green;
+ led-upgrade = &power_red;
+ };
+
+ firmware-concat {
+ compatible = "mtd-concat";
+ devices = <&fwconcat0 &fwconcat1>;
+
+ partitions {
+ compatible = "fixed-partitions";
+ #address-cells = <1>;
+ #size-cells = <1>;
+
+ partition@0 {
+ reg = <0x0 0x1f00000>;
+ label = "firmware";
+ compatible = "openwrt,uimage", "denx,uimage";
+ };
+ };
+ };
+
+ keys {
+ compatible = "gpio-keys";
+
+ reset {
+ linux,code = <KEY_RESTART>;
+ label = "Reset button";
+ gpios = <&gpio 0 GPIO_ACTIVE_HIGH>;
+ debounce-interval = <50>;
+ };
+ };
+
+ leds {
+ compatible = "gpio-leds";
+ pinctrl-names = "default";
+ pinctrl-0 = <&enable_gpio_11>,
+ <&enable_gpio_16>,
+ <&enable_gpio_4>,
+ <&clks_disable_pins>;
+
+ power_green: power-green {
+ label = "green:power";
+ gpios = <&gpio 4 GPIO_ACTIVE_LOW>;
+ default-state = "on";
+ };
+ };
+
+ reserved-memory {
+ #address-cells = <1>;
+ #size-cells = <1>;
+ ranges;
+
+ ruckus-himem@7ff0000 {
+ /* Ruckus Himem area used to control
+ * redundant boot image selection
+ */
+ compatible = "nvmem-rmem";
+ reg = <0x7ff0000 0x10000>;
+ no-map;
+ };
+ };
+};
+
+&ref {
+ clock-frequency = <40000000>;
+};
+
+&spi {
+ status = "okay";
+
+ 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 = <0x000000 0x040000>;
+ read-only;
+ };
+
+ fwconcat0: partition@40000 {
+ label = "fwconcat0";
+ reg = <0x040000 0xf00000>;
+ };
+
+ partition@f40000 {
+ compatible = "u-boot,env";
+ label = "u-boot-env";
+ reg = <0xf40000 0x040000>;
+ };
+
+ board_data: partition@f80000 {
+ label = "board-data";
+ reg = <0xf80000 0x080000>;
+ read-only;
+ };
+
+ fwconcat1: partition@1000000 {
+ label = "fwconcat1";
+ reg = <0x1000000 0x1000000>;
+ };
+ };
+ };
+};
+
+&mdio0 {
+ status = "okay";
+
+ phy: ethernet-phy@6 {
+ compatible = "ethernet-phy-ieee802.3-c22";
+ reg = <6>;
+ };
+};
+
+&eth0 {
+ status = "okay";
+ pll-data = <0x02000000 0x00000101 0x00001313>;
+ phy-mode = "rgmii-id";
+ phy-handle = <&phy>;
+
+ nvmem-cell-names = "mac-address";
+
+ gmac-config {
+ device = <&gmac>;
+ rgmii-gmac0 = <1>;
+ rxdv-delay = <3>;
+ rxd-delay = <3>;
+ };
+};
+
+&pinmux {
+ clks_disable_pins: pinmux_clks_disable_pins {
+ pinctrl-single,bits = <0x40 0x0 0x20>;
+ };
+
+ enable_gpio_4: pinctrl_enable_gpio_4 {
+ pinctrl-single,bits = <0x4 0x0 0xff>;
+ };
+
+ enable_gpio_11: pinctrl_enable_gpio_11 {
+ pinctrl-single,bits = <0x8 0x0 0xff000000>;
+ };
+
+ enable_gpio_16: pinctrl_enable_gpio_16 {
+ pinctrl-single,bits = <0x10 0x0 0xff>;
+ };
+};
+
+&wmac {
+ status = "okay";
+
+ nvmem-cells = <&macaddr_board_data_60>, <&cal_board_data_41000>;
+ nvmem-cell-names = "mac-address", "calibration";
+};
+
+&usb {
+ status = "okay";
+};
+
+&usb_phy {
+ status = "okay";
+};
+
+&board_data {
+ compatible = "nvmem-cells";
+ #address-cells = <1>;
+ #size-cells = <1>;
+
+ macaddr_board_data_60: macaddr@60 {
+ reg = <0x60 0x6>;
+ };
+
+ macaddr_board_data_66: macaddr@66 {
+ reg = <0x66 0x6>;
+ };
+
+ cal_board_data_41000: cal@41000 {
+ reg = <0x41000 0x440>;
+ };
+};
diff --git a/target/linux/ath79/generic/base-files/etc/board.d/01_leds b/target/linux/ath79/generic/base-files/etc/board.d/01_leds
index 188262018c..4773826520 100644
--- a/target/linux/ath79/generic/base-files/etc/board.d/01_leds
+++ b/target/linux/ath79/generic/base-files/etc/board.d/01_leds
@@ -324,6 +324,9 @@ qca,ap143-16m)
qihoo,c301)
ucidef_set_led_wlan "wlan" "WLAN" "green:wlan" "phy0tpt"
;;
+ruckus,zf7372)
+ ucidef_set_led_switch "lan" "LAN" "green:eth1" "switch0" "0x02"
+ ;;
samsung,wam250)
ucidef_set_led_netdev "lan" "LAN" "white:lan" "eth0"
;;
diff --git a/target/linux/ath79/generic/base-files/etc/board.d/02_network b/target/linux/ath79/generic/base-files/etc/board.d/02_network
index 20dc564117..27482129ce 100644
--- a/target/linux/ath79/generic/base-files/etc/board.d/02_network
+++ b/target/linux/ath79/generic/base-files/etc/board.d/02_network
@@ -131,6 +131,7 @@ ath79_setup_interfaces()
engenius,enstationac-v1|\
engenius,ews511ap|\
ocedo,ursus|\
+ ruckus,zf7372|\
ubnt,unifi-ap-outdoor-plus)
ucidef_set_interface_lan "eth0 eth1"
;;
@@ -698,6 +699,10 @@ ath79_setup_macs()
wan_mac=$(mtd_get_mac_binary factory 0x0)
lan_mac=$(macaddr_setbit_la "$wan_mac")
;;
+ ruckus,zf7372)
+ lan_mac=$(mtd_get_mac_binary board-data 0x807E)
+ label_mac=$lan_mac
+ ;;
sitecom,wlr-7100|\
sitecom,wlr-8100)
lan_mac=$(mtd_get_mac_ascii u-boot-env ethaddr)
diff --git a/target/linux/ath79/image/generic.mk b/target/linux/ath79/image/generic.mk
index d205fd8d9e..2439429c60 100644
--- a/target/linux/ath79/image/generic.mk
+++ b/target/linux/ath79/image/generic.mk
@@ -2380,6 +2380,22 @@ define Device/rosinson_wr818
endef
TARGET_DEVICES += rosinson_wr818
+define Device/ruckus_zf73xx_common
+ DEVICE_VENDOR := Ruckus
+ DEVICE_PACKAGES := -swconfig kmod-usb2 kmod-usb-chipidea2
+ IMAGE_SIZE := 31744k
+ LOADER_TYPE := bin
+ KERNEL := kernel-bin | append-dtb | lzma | loader-kernel | uImage none
+ KERNEL_INITRAMFS := kernel-bin | append-dtb | lzma | loader-kernel | uImage none
+endef
+
+define Device/ruckus_zf7372
+ $(Device/ruckus_zf73xx_common)
+ SOC := ar9344
+ DEVICE_MODEL := ZoneFlex 7352/7372[-E/-U]
+endef
+TARGET_DEVICES += ruckus_zf7372
+
define Device/samsung_wam250
SOC := ar9344
DEVICE_VENDOR := Samsung