ar71xx: add support for GainStrong Oolite V5.2
authorPiotr Dymacz <pepe2k@gmail.com>
Thu, 15 Feb 2018 22:15:53 +0000 (23:15 +0100)
committerPiotr Dymacz <pepe2k@gmail.com>
Thu, 22 Feb 2018 17:53:22 +0000 (18:53 +0100)
GainStrong Oolite V5.2 is a small (39.5 x 78 mm), dual-band system on
module, based on Qualcomm QCA9531 + QCA9887. All QCA9531 SOC GPIOs are
available on castellated pins.

Specification:

- 650/400/200 MHz (CPU/DDR/AHB)
- 64/128 MB of RAM (DDR2)
- 16 MB of FLASH (SPI NOR)
- 5x 10/100 Mbps Ethernet (all ports available on castellated pins)
- 2T2R 2.4 GHz (QCA9531), with ext. PA and LNA
- 1T1R 5 GHz (QCA9887) with ext. FEM (SKY85710-11)
- 3x U.FL
- 1x USB 2.0

The dedicated development board includes 5 FE ports, USB 2.0 port, two
buttons (one directly connected to SOC reset input), header with all
GPIOs and several LEDs.

Flash instruction:

Vendor firmware is based on OpenWrt. LuCI or sysupgrade can be used to
flash OpenWrt firmware.

Signed-off-by: Piotr Dymacz <pepe2k@gmail.com>
13 files changed:
target/linux/ar71xx/base-files/etc/board.d/02_network
target/linux/ar71xx/base-files/etc/diag.sh
target/linux/ar71xx/base-files/etc/hotplug.d/firmware/11-ath10k-caldata
target/linux/ar71xx/base-files/lib/ar71xx.sh
target/linux/ar71xx/base-files/lib/upgrade/platform.sh
target/linux/ar71xx/config-4.4
target/linux/ar71xx/config-4.9
target/linux/ar71xx/files/arch/mips/ath79/Kconfig.openwrt
target/linux/ar71xx/files/arch/mips/ath79/Makefile
target/linux/ar71xx/files/arch/mips/ath79/mach-gs-oolite-v5-2.c [new file with mode: 0644]
target/linux/ar71xx/files/arch/mips/ath79/machtypes.h
target/linux/ar71xx/generic/config-default
target/linux/ar71xx/image/generic.mk

index 42b40e35ff986a320860c7ba785ea78e550dcef8..8f492cbf02d8d064646df5179f0d0b14867e5757 100755 (executable)
@@ -29,6 +29,8 @@ ar71xx_setup_interfaces()
        minibox-v1|\
        mynet-n600|\
        oolite-v1|\
+       oolite-v5.2|\
+       oolite-v5.2-dev|\
        qihoo-c301|\
        r602n|\
        rb-750|\
index 38df0c15d179926135b795d06560172dfda5b0bd..6b53ad03c7a682605eab502eef41b302044ab818 100644 (file)
@@ -205,6 +205,7 @@ get_status_led() {
                status_led="$board:blue:status"
                ;;
        e600g-v2|\
+       oolite-v5.2-dev|\
        wifi-pineapple-nano)
                status_led="$board:blue:system"
                ;;
index e6ea873e40b817473f3b321e1c638e9cc8235791..c93ce2a61477e6770172308e2269b10c2a5bdd44 100644 (file)
@@ -75,6 +75,8 @@ case "$FIRMWARE" in
        dlan-pro-1200-ac|\
        e1700ac-v2|\
        e600gac-v2|\
+       oolite-v5.2|\
+       oolite-v5.2-dev|\
        sr3200|\
        xd3200)
                ath10kcal_extract "art" 20480 2116
index 96b3e650f1fd3ad3fa292a7af12b7812437d2029..01ac29601d0485bbc3e6ac281778c06ee3dfb0ab 100755 (executable)
@@ -865,6 +865,12 @@ ar71xx_board_detect() {
        *"Packet Squirrel")
                name="packet-squirrel"
                ;;
+       *"Oolite V5.2")
+               name="oolite-v5.2"
+               ;;
+       *"Oolite V5.2-Dev")
+               name="oolite-v5.2-dev"
+               ;;
        *"PB42")
                name="pb42"
                ;;
index c73dbd49ecc99f7a8d251f02a7426e870b2df866..7738db33a7f5ccb5c53e606651a9f79eb741a6c4 100755 (executable)
@@ -399,6 +399,8 @@ platform_check_image() {
        omy-x1|\
        onion-omega|\
        oolite-v1|\
+       oolite-v5.2|\
+       oolite-v5.2-dev|\
        packet-squirrel|\
        re355|\
        re450|\
index d49cebf8125116e55473b2eef6d2b091c8d1f149..c55bdab0e8209401d309a1719bba3773833bf9da 100644 (file)
@@ -124,6 +124,7 @@ CONFIG_ATH79=y
 # CONFIG_ATH79_MACH_GL_MIFI is not set
 # CONFIG_ATH79_MACH_GL_USB150 is not set
 # CONFIG_ATH79_MACH_GS_OOLITE_V1 is not set
+# CONFIG_ATH79_MACH_GS_OOLITE_V5_2 is not set
 # CONFIG_ATH79_MACH_HIVEAP_121 is not set
 # CONFIG_ATH79_MACH_HIWIFI_HC6361 is not set
 # CONFIG_ATH79_MACH_HORNET_UB is not set
index c6c5cf3ce375e9e80da248ea7089950749294d2b..026d5bb61735041e72ada526eab009e077576cec 100644 (file)
@@ -122,6 +122,7 @@ CONFIG_ATH79=y
 # CONFIG_ATH79_MACH_GL_MIFI is not set
 # CONFIG_ATH79_MACH_GL_USB150 is not set
 # CONFIG_ATH79_MACH_GS_OOLITE_V1 is not set
+# CONFIG_ATH79_MACH_GS_OOLITE_V5_2 is not set
 # CONFIG_ATH79_MACH_HIVEAP_121 is not set
 # CONFIG_ATH79_MACH_HIWIFI_HC6361 is not set
 # CONFIG_ATH79_MACH_HORNET_UB is not set
index ed2d42e7f1a4356fff60ac1973891ca777e445dd..ec3c329d7a14c999a6e6242b450ebda00dc24e3d 100644 (file)
@@ -890,6 +890,17 @@ config ATH79_MACH_GS_OOLITE_V1
        select ATH79_DEV_USB
        select ATH79_DEV_WMAC
 
+config ATH79_MACH_GS_OOLITE_V5_2
+       bool "GainStrong Oolite V5.2 support"
+       select SOC_QCA953X
+       select ATH79_DEV_AP9X_PCI if PCI
+       select ATH79_DEV_ETH
+       select ATH79_DEV_GPIO_BUTTONS
+       select ATH79_DEV_LEDS_GPIO
+       select ATH79_DEV_M25P80
+       select ATH79_DEV_USB
+       select ATH79_DEV_WMAC
+
 config ATH79_MACH_HIVEAP_121
        bool "Aerohive HiveAP-121 support"
        select SOC_AR934X
index 54f4053b41f2b52ecf2602fb52f2ea524d2bd5c0..62d731720602d14b7fb24432bd05dce87269ec3f 100644 (file)
@@ -132,6 +132,7 @@ obj-$(CONFIG_ATH79_MACH_GL_INET)            += mach-gl-inet.o
 obj-$(CONFIG_ATH79_MACH_GL_MIFI)               += mach-gl-mifi.o
 obj-$(CONFIG_ATH79_MACH_GL_USB150)             += mach-gl-usb150.o
 obj-$(CONFIG_ATH79_MACH_GS_OOLITE_V1)          += mach-gs-oolite-v1.o
+obj-$(CONFIG_ATH79_MACH_GS_OOLITE_V5_2)                += mach-gs-oolite-v5-2.o
 obj-$(CONFIG_ATH79_MACH_HIVEAP_121)            += mach-hiveap-121.o
 obj-$(CONFIG_ATH79_MACH_HIWIFI_HC6361)         += mach-hiwifi-hc6361.o
 obj-$(CONFIG_ATH79_MACH_HORNET_UB)             += mach-hornet-ub.o
diff --git a/target/linux/ar71xx/files/arch/mips/ath79/mach-gs-oolite-v5-2.c b/target/linux/ar71xx/files/arch/mips/ath79/mach-gs-oolite-v5-2.c
new file mode 100644 (file)
index 0000000..64dc4f3
--- /dev/null
@@ -0,0 +1,111 @@
+/*
+ * GainStrong Oolite V5.2 module and development board support
+ *
+ * Copyright (C) 2018 Piotr Dymacz <pepe2k@gmail.com>
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 as published
+ * by the Free Software Foundation.
+ */
+
+#include <linux/gpio.h>
+#include <linux/platform_device.h>
+
+#include <asm/mach-ath79/ath79.h>
+#include <asm/mach-ath79/ar71xx_regs.h>
+
+#include "common.h"
+#include "dev-eth.h"
+#include "dev-gpio-buttons.h"
+#include "dev-leds-gpio.h"
+#include "dev-m25p80.h"
+#include "dev-usb.h"
+#include "dev-wmac.h"
+#include "machtypes.h"
+#include "pci.h"
+
+#define GS_OOLITE_V5_2_DEV_GPIO_BTN_RESET      17
+#define GS_OOLITE_V5_2_DEV_GPIO_LED_SYSTEM     13
+
+#define GS_KEYS_POLL_INTERVAL          20 /* msec */
+#define GS_KEYS_DEBOUNCE_INTERVAL      (3 * GS_KEYS_POLL_INTERVAL)
+
+#define GS_OOLITE_V5_2_WMAC_CALDATA_OFFSET     0x1000
+
+static const char *gs_oolite_v5_2_part_probes[] = {
+       "tp-link",
+       NULL,
+};
+
+static struct flash_platform_data gs_oolite_v5_2_flash_data = {
+       .part_probes = gs_oolite_v5_2_part_probes,
+};
+
+static struct gpio_led gs_oolite_v5_2_dev_gpio_leds[] __initdata = {
+       {
+               .name           = "oolite-v5.2-dev:blue:system",
+               .gpio           = GS_OOLITE_V5_2_DEV_GPIO_LED_SYSTEM,
+               .active_low     = 0,
+       },
+};
+
+static struct gpio_keys_button gs_oolite_v5_2_dev_gpio_keys[] __initdata = {
+       {
+               .desc                   = "reset",
+               .type                   = EV_KEY,
+               .code                   = KEY_RESTART,
+               .debounce_interval      = GS_KEYS_DEBOUNCE_INTERVAL,
+               .gpio                   = GS_OOLITE_V5_2_DEV_GPIO_BTN_RESET,
+               .active_low             = 1,
+       },
+};
+
+static void __init gs_oolite_v5_2_setup(void)
+{
+       u8 *art = (u8 *) KSEG1ADDR(0x1fff0000);
+
+       ath79_register_m25p80(&gs_oolite_v5_2_flash_data);
+
+       ath79_setup_ar933x_phy4_switch(false, false);
+
+       ath79_register_mdio(0, 0x0);
+
+       ath79_switch_data.phy4_mii_en = 1;
+       ath79_switch_data.phy_poll_mask |= BIT(4);
+
+       /* LAN */
+       ath79_eth1_data.duplex = DUPLEX_FULL;
+       ath79_eth1_data.phy_if_mode = PHY_INTERFACE_MODE_GMII;
+       ath79_init_mac(ath79_eth1_data.mac_addr, art + 6, 0);
+       ath79_register_eth(1);
+
+       /* WAN */
+       ath79_eth0_data.duplex = DUPLEX_FULL;
+       ath79_eth0_data.phy_if_mode = PHY_INTERFACE_MODE_MII;
+       ath79_eth0_data.phy_mask = BIT(4);
+       ath79_eth0_data.speed = SPEED_100;
+       ath79_init_mac(ath79_eth0_data.mac_addr, art, 0);
+       ath79_register_eth(0);
+
+       ath79_register_pci();
+       ath79_register_usb();
+       ath79_register_wmac(art + GS_OOLITE_V5_2_WMAC_CALDATA_OFFSET, NULL);
+}
+
+static void __init gs_oolite_v5_2_dev_setup(void)
+{
+       gs_oolite_v5_2_setup();
+
+       ath79_register_leds_gpio(-1, ARRAY_SIZE(gs_oolite_v5_2_dev_gpio_leds),
+                                gs_oolite_v5_2_dev_gpio_leds);
+
+       ath79_register_gpio_keys_polled(-1, GS_KEYS_POLL_INTERVAL,
+                                       ARRAY_SIZE(gs_oolite_v5_2_dev_gpio_keys),
+                                       gs_oolite_v5_2_dev_gpio_keys);
+}
+
+MIPS_MACHINE(ATH79_MACH_GS_OOLITE_V5_2, "OOLITE-V5-2",
+            "GainStrong Oolite V5.2", gs_oolite_v5_2_setup);
+
+MIPS_MACHINE(ATH79_MACH_GS_OOLITE_V5_2_DEV, "OOLITE-V5-2-DEV",
+            "GainStrong Oolite V5.2-Dev", gs_oolite_v5_2_dev_setup);
index b3250053a6fc1cc50c2f2ab5005ca6c1f213439d..46bc49458b976720a0731b56be6420f49fabd93f 100644 (file)
@@ -128,6 +128,8 @@ enum ath79_mach_type {
        ATH79_MACH_GL_USB150,                   /* GL.iNet GL-USB150 */
        ATH79_MACH_GS_MINIBOX_V1,               /* GainStrong MiniBox V1.0 */
        ATH79_MACH_GS_OOLITE_V1,                /* GainStrong Oolite V1.0 */
+       ATH79_MACH_GS_OOLITE_V5_2,              /* GainStrong Oolite V5.2 */
+       ATH79_MACH_GS_OOLITE_V5_2_DEV,          /* GainStrong Oolite V5.2-Dev */
        ATH79_MACH_HIVEAP_121,                  /* Aerohive HiveAP-121*/
        ATH79_MACH_HIWIFI_HC6361,               /* HiWiFi HC6361 */
        ATH79_MACH_HORNET_UB,                   /* ALFA Networks Hornet-UB */
index 658e120b96e117333e5a0133369febb335de3ba1..184087d38aae9724b9f416954cae6253e61b138f 100644 (file)
@@ -95,6 +95,7 @@ CONFIG_ATH79_MACH_GL_INET=y
 CONFIG_ATH79_MACH_GL_MIFI=y
 CONFIG_ATH79_MACH_GL_USB150=y
 CONFIG_ATH79_MACH_GS_OOLITE_V1=y
+CONFIG_ATH79_MACH_GS_OOLITE_V5_2=y
 CONFIG_ATH79_MACH_HIWIFI_HC6361=y
 CONFIG_ATH79_MACH_HORNET_UB=y
 CONFIG_ATH79_MACH_JA76PF=y
index e1cd21d9cf1e627ce9a60bc12fed4fa1f1fb9a84..37231e022893ed5e88a350b6e850f2d9b0282eee 100644 (file)
@@ -852,6 +852,25 @@ define Device/oolite-v1
 endef
 TARGET_DEVICES += oolite-v1
 
+define Device/oolite-v5.2
+  $(Device/tplink-16mlzma)
+  DEVICE_TITLE := GainStrong Oolite V5.2
+  DEVICE_PACKAGES := ath10k-firmware-qca9887 kmod-ath10k kmod-usb-core kmod-usb2
+  BOARDNAME := OOLITE-V5-2
+  DEVICE_PROFILE := OOLITEV52
+  TPLINK_HWID := 0x3C00010B
+  IMAGES := sysupgrade.bin
+endef
+TARGET_DEVICES += oolite-v5.2
+
+define Device/oolite-v5.2-dev
+  $(Device/oolite-v5.2)
+  DEVICE_TITLE := GainStrong Oolite V5.2-Dev (development board)
+  BOARDNAME := OOLITE-V5-2-DEV
+  DEVICE_PROFILE := OOLITEV52DEV
+endef
+TARGET_DEVICES += oolite-v5.2-dev
+
 define Device/omy-g1
   $(Device/tplink-16mlzma)
   DEVICE_TITLE := OMYlink OMY-G1