aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xtarget/linux/ath79/base-files/etc/board.d/02_network1
-rw-r--r--target/linux/ath79/dts/ar9341_pisen_wmb001n.dts225
-rw-r--r--target/linux/ath79/image/Makefile4
-rw-r--r--target/linux/ath79/image/bin/pisen_wmb001n_factory-header.binbin0 -> 288 bytes
-rw-r--r--target/linux/ath79/image/generic.mk29
5 files changed, 259 insertions, 0 deletions
diff --git a/target/linux/ath79/base-files/etc/board.d/02_network b/target/linux/ath79/base-files/etc/board.d/02_network
index e3c1f423f1..3b89c9c58d 100755
--- a/target/linux/ath79/base-files/etc/board.d/02_network
+++ b/target/linux/ath79/base-files/etc/board.d/02_network
@@ -25,6 +25,7 @@ ath79_setup_interfaces()
ocedo,koala|\
ocedo,raccoon|\
pcs,cap324|\
+ pisen,wmb001n|\
pisen,wmm003n|\
pqi,air-pen|\
tplink,cpe210-v2|\
diff --git a/target/linux/ath79/dts/ar9341_pisen_wmb001n.dts b/target/linux/ath79/dts/ar9341_pisen_wmb001n.dts
new file mode 100644
index 0000000000..8029de5495
--- /dev/null
+++ b/target/linux/ath79/dts/ar9341_pisen_wmb001n.dts
@@ -0,0 +1,225 @@
+// 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 "ar9341.dtsi"
+
+/ {
+ model = "PISEN WMB001N";
+ compatible = "pisen,wmb001n", "qca,ar9341";
+
+ aliases {
+ serial0 = &uart;
+ led-boot = &wifi;
+ led-failsafe = &wifi;
+ led-running = &wifi;
+ led-upgrade = &wifi;
+ };
+
+ i2c {
+ compatible = "i2c-gpio";
+ pinctrl-names = "default";
+ pinctrl-0 = <&pmx_i2c_gpio &pmx_i2s_spdif>;
+
+ sda-gpios = <&gpio 16 (GPIO_ACTIVE_HIGH|GPIO_OPEN_DRAIN)>;
+ scl-gpios = <&gpio 20 GPIO_ACTIVE_HIGH>;
+ /*
+ * Pull-up resistor for scl is missing on this board.
+ * Following settings trick i2c-gpio to use output mode
+ * instead of open-drain for scl.
+ */
+ i2c-gpio,scl-output-only;
+ i2c-gpio,scl-open-drain;
+ };
+
+ keys {
+ compatible = "gpio-keys";
+
+ reset {
+ label = "reset";
+ linux,code = <KEY_RESTART>;
+ gpios = <&gpio 17 GPIO_ACTIVE_LOW>;
+ debounce-interval = <60>;
+ };
+
+ vol_down {
+ label = "volume down";
+ linux,code = <KEY_VOLUMEDOWN>;
+ gpios = <&gpio 18 GPIO_ACTIVE_LOW>;
+ debounce-interval = <60>;
+ };
+
+ vol_up {
+ label = "volume up";
+ linux,code = <KEY_VOLUMEUP>;
+ gpios = <&gpio 19 GPIO_ACTIVE_LOW>;
+ debounce-interval = <60>;
+ };
+ };
+
+ leds {
+ compatible = "gpio-leds";
+ pinctrl-names = "default";
+ pinctrl-0 = <&jtag_disable_pins>;
+
+ volume1 {
+ label = "wmb001n:blue:volume1";
+ gpios = <&gpio 0 GPIO_ACTIVE_HIGH>;
+ };
+
+ volume2 {
+ label = "wmb001n:blue:volume2";
+ gpios = <&gpio 1 GPIO_ACTIVE_HIGH>;
+ };
+
+ volume3 {
+ label = "wmb001n:blue:volume3";
+ gpios = <&gpio 2 GPIO_ACTIVE_HIGH>;
+ };
+
+ volume4 {
+ label = "wmb001n:blue:volume4";
+ gpios = <&gpio 3 GPIO_ACTIVE_HIGH>;
+ };
+
+ volume5 {
+ label = "wmb001n:blue:volume5";
+ gpios = <&gpio 4 GPIO_ACTIVE_HIGH>;
+ };
+
+ wifi: wifi {
+ label = "wmb001n:blue:wifi";
+ gpios = <&gpio 22 GPIO_ACTIVE_HIGH>;
+ };
+ };
+
+ virtual_flash {
+ compatible = "mtd-concat";
+ devices = <&fwpart1 &fwpart2>;
+
+ partitions {
+ compatible = "fixed-partitions";
+ #address-cells = <1>;
+ #size-cells = <1>;
+
+ partition@0 {
+ reg = <0x0 0x0>;
+ label = "firmware";
+ compatible = "openwrt,okli";
+ };
+ };
+ };
+};
+
+&pinmux {
+ pmx_i2c_gpio: pinmux_i2c_gpio {
+ pinctrl-single,bits = <0x10 0x0 0xff>,
+ <0x14 0x0 0xff>;
+ };
+
+ pmx_i2s_spdif: pinmux_i2s_spdif {
+ pinctrl-single,bits = <0x8 0x0e000000 0xff000000>,
+ <0xc 0x0f0c0d 0xffffff>,
+ <0x14 0x1900 0xff00>;
+ };
+};
+
+&ref {
+ clock-frequency = <25000000>;
+};
+
+&uart {
+ status = "okay";
+};
+
+&gpio {
+ status = "okay";
+};
+
+&spi {
+ num-cs = <1>;
+
+ status = "okay";
+
+ flash@0 {
+ compatible = "jedec,spi-nor";
+ reg = <0>;
+ spi-max-frequency = <25000000>;
+
+ partitions {
+ compatible = "fixed-partitions";
+ #address-cells = <1>;
+ #size-cells = <1>;
+
+ uboot: partition@0 {
+ label = "u-boot";
+ reg = <0x0 0x10000>;
+ read-only;
+ };
+
+ partition@10000 {
+ label = "u-boot-env";
+ reg = <0x10000 0x10000>;
+ read-only;
+ };
+
+ fwpart1: partition@20000 {
+ label = "fwpart1";
+ reg = <0x20000 0xdc0000>;
+ };
+
+ partition@de0000 {
+ label = "loader";
+ reg = <0xde0000 0x10000>;
+ };
+
+ fwpart2: partition@df0000 {
+ label = "fwpart2";
+ reg = <0xdf0000 0x1f0000>;
+ };
+
+ partition@fe0000 {
+ label = "mib0";
+ reg = <0xfe0000 0x10000>;
+ read-only;
+ };
+
+ art: partition@ff0000 {
+ label = "art";
+ reg = <0xff0000 0x10000>;
+ read-only;
+ };
+ };
+ };
+};
+
+&eth0 {
+ status = "okay";
+ phy-handle = <&swphy4>;
+ mtd-mac-address = <&art 0x0>;
+};
+
+&eth1 {
+ compatible = "syscon", "simple-mfd";
+ status = "okay";
+
+ gmac-config {
+ device = <&gmac>;
+ switch-phy-swap = <0>;
+ };
+};
+
+&usb {
+ status = "okay";
+};
+
+&usb_phy {
+ status = "okay";
+};
+
+&wmac {
+ status = "okay";
+ mtd-cal-data = <&art 0x1000>;
+};
diff --git a/target/linux/ath79/image/Makefile b/target/linux/ath79/image/Makefile
index 734f27e689..24768ef5e0 100644
--- a/target/linux/ath79/image/Makefile
+++ b/target/linux/ath79/image/Makefile
@@ -36,6 +36,10 @@ define Build/loader-okli
mv "$@.new" "$@"
endef
+define Build/append-loader-okli
+ cat "$(KDIR)/loader-$(word 1,$(1)).$(LOADER_TYPE)" >> "$@"
+endef
+
define Build/relocate-kernel
rm -rf $@.relocate
$(CP) ../../generic/image/relocate $@.relocate
diff --git a/target/linux/ath79/image/bin/pisen_wmb001n_factory-header.bin b/target/linux/ath79/image/bin/pisen_wmb001n_factory-header.bin
new file mode 100644
index 0000000000..99e1e8a2db
--- /dev/null
+++ b/target/linux/ath79/image/bin/pisen_wmb001n_factory-header.bin
Binary files differ
diff --git a/target/linux/ath79/image/generic.mk b/target/linux/ath79/image/generic.mk
index abaf1a3e07..5127cfd510 100644
--- a/target/linux/ath79/image/generic.mk
+++ b/target/linux/ath79/image/generic.mk
@@ -58,6 +58,18 @@ define Build/nec-fw
mv $@.new $@
endef
+define Build/pisen_wmb001n-factory
+ -[ -f "$@" ] && \
+ mkdir -p "$@.tmp" && \
+ cp "$(KDIR)/loader-$(word 1,$(1)).uImage" "$@.tmp/uImage" && \
+ mv "$@" "$@.tmp/rootfs" && \
+ cp "bin/pisen_wmb001n_factory-header.bin" "$@" && \
+ $(TAR) -cp --numeric-owner --owner=0 --group=0 --mode=a-s --sort=name \
+ $(if $(SOURCE_DATE_EPOCH),--mtime="@$(SOURCE_DATE_EPOCH)") \
+ -C "$@.tmp" . | gzip -9n >> "$@" && \
+ rm -rf "$@.tmp"
+endef
+
define Device/seama
KERNEL := kernel-bin | append-dtb | relocate-kernel | lzma
KERNEL_INITRAMFS := $$(KERNEL) | seama
@@ -775,6 +787,23 @@ define Device/netgear_wndr3700v2
endef
TARGET_DEVICES += netgear_wndr3700v2
+define Device/pisen_wmb001n
+ ATH_SOC := ar9341
+ DEVICE_VENDOR := PISEN
+ DEVICE_MODEL := WMB001N
+ IMAGE_SIZE := 14080k
+ DEVICE_PACKAGES := kmod-i2c-core kmod-i2c-gpio kmod-usb2
+ LOADER_TYPE := bin
+ LOADER_FLASH_OFFS := 0x20000
+ COMPILE := loader-$(1).bin loader-$(1).uImage
+ COMPILE/loader-$(1).bin := loader-okli-compile
+ COMPILE/loader-$(1).uImage := append-loader-okli $(1) | pad-to 64k | lzma | uImage lzma
+ KERNEL := kernel-bin | append-dtb | lzma | uImage lzma -M 0x4f4b4c49
+ IMAGES += factory.bin
+ IMAGE/factory.bin := $$(IMAGE/sysupgrade.bin) | pisen_wmb001n-factory $(1)
+endef
+TARGET_DEVICES += pisen_wmb001n
+
define Device/pisen_wmm003n
$(Device/tplink-8mlzma)
ATH_SOC := ar9331