From d265a8f2ca49a67a46493cf57de7c265855b317f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Nicol=C3=B2=20Veronese?= Date: Fri, 16 Jun 2017 12:12:25 +0000 Subject: [PATCH] ar71xx: Add support for D-Link DAP-1330 a1 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit D-Link DAP-1330 rev. A1 is a wall-plug N300 Wi-Fi range extender, based on Qualcomm/Atheros QCA9533 v2. Short specification: - 650/393/216 MHz (CPU/DDR/AHB) - 1x 10/100 Mbps Ethernet - 64 MB of RAM (DDR1) - 8 MB of FLASH - 2T2R 2.4 GHz - 2x external antennas - 6x LED (2 are bi-color), 2x button - 4 pin on pcb (looking from eth port and from left to right tx,rx,gnd,vcc) Flash instruction: use "factory" image directly in vendor GUI. This device has a recovery system that assign the ip addr of env variable "serverip" via dhcp to a pc, and the "ipaddr" value to itself. The recovery it's triggered by a not bootable firmware, or pressing the reset button during the bootloader startup (first 30 seconds). The recovery uses a http page to restore the firmware, and it's checking the firmware image header, so use the "factory" image to restore or the original firmware. You can access vendor firmware over serial using: - login: root - password: linuxrocks Image was tested only in EU version of the device, but should work also with the same device version sold in other countries. Signed-off-by: Nicolò Veronese --- .../ar71xx/base-files/etc/board.d/01_leds | 7 + target/linux/ar71xx/base-files/etc/diag.sh | 1 + target/linux/ar71xx/base-files/lib/ar71xx.sh | 3 + .../ar71xx/base-files/lib/upgrade/platform.sh | 1 + target/linux/ar71xx/config-4.4 | 1 + target/linux/ar71xx/config-4.9 | 1 + .../files/arch/mips/ath79/Kconfig.openwrt | 9 ++ .../ar71xx/files/arch/mips/ath79/Makefile | 1 + .../files/arch/mips/ath79/mach-dap-1330-a1.c | 146 ++++++++++++++++++ .../ar71xx/files/arch/mips/ath79/machtypes.h | 1 + target/linux/ar71xx/generic/config-default | 1 + target/linux/ar71xx/image/generic.mk | 22 +++ 12 files changed, 194 insertions(+) create mode 100644 target/linux/ar71xx/files/arch/mips/ath79/mach-dap-1330-a1.c diff --git a/target/linux/ar71xx/base-files/etc/board.d/01_leds b/target/linux/ar71xx/base-files/etc/board.d/01_leds index 7a8ed9afe53..2a0af3c4090 100755 --- a/target/linux/ar71xx/base-files/etc/board.d/01_leds +++ b/target/linux/ar71xx/base-files/etc/board.d/01_leds @@ -298,6 +298,13 @@ fritz300e) ucidef_set_led_rssi "rssimediumhigh" "RSSIMEDIUMHIGH" "$board:green:rssi3" "wlan0" "60" "100" ucidef_set_led_rssi "rssihigh" "RSSIHIGH" "$board:green:rssi4" "wlan0" "80" "100" ;; +dap-1330-a1) + ucidef_set_rssimon "wlan0" "2000000" "2" + ucidef_set_led_rssi "wifi-low" "wifi-low" "d-link:red:wifi" "wlan0" "1" "29" + ucidef_set_led_rssi "wifi-medium" "wifi-medium" "d-link:green:wifi" "wlan0" "30" "100" + ucidef_set_led_rssi "wifi-high" "wifi-high" "d-link:green:signal1" "wlan0" "50" "100" + ucidef_set_led_rssi "wifi-max" "wifi-max" "d-link:green:signal2" "wlan0" "70" "100" + ;; dap-2695-a1) ucidef_set_led_default "power" "POWER" "d-link:green:power" "1" ucidef_set_led_default "diag" "DIAG" "d-link:red:power" "0" diff --git a/target/linux/ar71xx/base-files/etc/diag.sh b/target/linux/ar71xx/base-files/etc/diag.sh index 6ea4fb085c9..b5d07cddfc1 100644 --- a/target/linux/ar71xx/base-files/etc/diag.sh +++ b/target/linux/ar71xx/base-files/etc/diag.sh @@ -162,6 +162,7 @@ get_status_led() { cr5000) status_led="pcs:amber:power" ;; + dap-1330-a1|\ dgl-5500-a1|\ dhp-1565-a1|\ dir-505-a1|\ diff --git a/target/linux/ar71xx/base-files/lib/ar71xx.sh b/target/linux/ar71xx/base-files/lib/ar71xx.sh index a7c2ccb52eb..3586cc99abf 100755 --- a/target/linux/ar71xx/base-files/lib/ar71xx.sh +++ b/target/linux/ar71xx/base-files/lib/ar71xx.sh @@ -557,6 +557,9 @@ ar71xx_board_detect() { *"CR5000") name="cr5000" ;; + *"DAP-1330 Rev. A1") + name="dap-1330-a1" + ;; *"DAP-2695 rev. A1") name="dap-2695-a1" ;; diff --git a/target/linux/ar71xx/base-files/lib/upgrade/platform.sh b/target/linux/ar71xx/base-files/lib/upgrade/platform.sh index 2b15dec5bec..4b71a19a9c9 100755 --- a/target/linux/ar71xx/base-files/lib/upgrade/platform.sh +++ b/target/linux/ar71xx/base-files/lib/upgrade/platform.sh @@ -219,6 +219,7 @@ platform_check_image() { cpe505n|\ cpe830|\ cpe870|\ + dap-1330-a1|\ dgl-5500-a1|\ dhp-1565-a1|\ dir-505-a1|\ diff --git a/target/linux/ar71xx/config-4.4 b/target/linux/ar71xx/config-4.4 index c55bdab0e82..e6882c2a676 100644 --- a/target/linux/ar71xx/config-4.4 +++ b/target/linux/ar71xx/config-4.4 @@ -80,6 +80,7 @@ CONFIG_ATH79=y # CONFIG_ATH79_MACH_CPE870 is not set # CONFIG_ATH79_MACH_CR3000 is not set # CONFIG_ATH79_MACH_CR5000 is not set +# CONFIG_ATH79_MACH_DAP_1330_A1 is not set # CONFIG_ATH79_MACH_DAP_2695_A1 is not set # CONFIG_ATH79_MACH_DB120 is not set # CONFIG_ATH79_MACH_DGL_5500_A1 is not set diff --git a/target/linux/ar71xx/config-4.9 b/target/linux/ar71xx/config-4.9 index 026d5bb6173..e78b16cd193 100644 --- a/target/linux/ar71xx/config-4.9 +++ b/target/linux/ar71xx/config-4.9 @@ -78,6 +78,7 @@ CONFIG_ATH79=y # CONFIG_ATH79_MACH_CPE870 is not set # CONFIG_ATH79_MACH_CR3000 is not set # CONFIG_ATH79_MACH_CR5000 is not set +# CONFIG_ATH79_MACH_DAP_1330_A1 is not set # CONFIG_ATH79_MACH_DAP_2695_A1 is not set # CONFIG_ATH79_MACH_DB120 is not set # CONFIG_ATH79_MACH_DGL_5500_A1 is not set diff --git a/target/linux/ar71xx/files/arch/mips/ath79/Kconfig.openwrt b/target/linux/ar71xx/files/arch/mips/ath79/Kconfig.openwrt index ec3c329d7a1..20c5385179f 100644 --- a/target/linux/ar71xx/files/arch/mips/ath79/Kconfig.openwrt +++ b/target/linux/ar71xx/files/arch/mips/ath79/Kconfig.openwrt @@ -2300,6 +2300,15 @@ config ATH79_MACH_QIHOO_C301 select ATH79_DEV_USB select ATH79_NVRAM +config ATH79_MACH_DAP_1330_A1 + bool "D-Link DAP-1330 rev. A1 support" + select SOC_QCA953X + select ATH79_DEV_ETH + select ATH79_DEV_GPIO_BUTTONS + select ATH79_DEV_LEDS_GPIO + select ATH79_DEV_M25P80 + select ATH79_DEV_WMAC + config ATH79_MACH_DAP_2695_A1 bool "D-Link DAP-2695 rev. A1 support" select SOC_QCA955X diff --git a/target/linux/ar71xx/files/arch/mips/ath79/Makefile b/target/linux/ar71xx/files/arch/mips/ath79/Makefile index 62d73172060..d549dd39b7c 100644 --- a/target/linux/ar71xx/files/arch/mips/ath79/Makefile +++ b/target/linux/ar71xx/files/arch/mips/ath79/Makefile @@ -89,6 +89,7 @@ obj-$(CONFIG_ATH79_MACH_CPE830) += mach-ap90q.o obj-$(CONFIG_ATH79_MACH_CPE870) += mach-cpe870.o obj-$(CONFIG_ATH79_MACH_CR3000) += mach-cr3000.o obj-$(CONFIG_ATH79_MACH_CR5000) += mach-cr5000.o +obj-$(CONFIG_ATH79_MACH_DAP_1330_A1) += mach-dap-1330-a1.o obj-$(CONFIG_ATH79_MACH_DAP_2695_A1) += mach-dap-2695-a1.o obj-$(CONFIG_ATH79_MACH_DB120) += mach-db120.o obj-$(CONFIG_ATH79_MACH_DGL_5500_A1) += mach-dgl-5500-a1.o diff --git a/target/linux/ar71xx/files/arch/mips/ath79/mach-dap-1330-a1.c b/target/linux/ar71xx/files/arch/mips/ath79/mach-dap-1330-a1.c new file mode 100644 index 00000000000..9c50bc7e9b1 --- /dev/null +++ b/target/linux/ar71xx/files/arch/mips/ath79/mach-dap-1330-a1.c @@ -0,0 +1,146 @@ +/* + * D-Link DAP-1330 + * + * Copyright (c) 2013-2015 The Linux Foundation. All rights reserved. + * Copyright (c) 2017 Nicolò Veronese + * Copyright (c) 2017 Federico Cappon + * + * Permission to use, copy, modify, and/or distribute this software for any + * purpose with or without fee is hereby granted, provided that the above + * copyright notice and this permission notice appear in all copies. + * + * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES + * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR + * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES + * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN + * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF + * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. + * + */ + +#include +#include + +#include +#include + +#include "common.h" +#include "dev-eth.h" +#include "dev-gpio-buttons.h" +#include "dev-leds-gpio.h" +#include "dev-m25p80.h" +#include "dev-wmac.h" +#include "machtypes.h" +#include "nvram.h" + +#include +#include +#include +#include +#include + +#define DAP_1330_GPIO_LED_GREEN_POWER 13 +#define DAP_1330_GPIO_LED_RED_POWER 3 +#define DAP_1330_GPIO_LED_GREEN_WIFI 14 +#define DAP_1330_GPIO_LED_RED_WIFI 11 +#define DAP_1330_GPIO_LED_SIGNAL1 15 +#define DAP_1330_GPIO_LED_SIGNAL2 16 + +#define DAP_1330_GPIO_BTN_WPS 2 +#define DAP_1330_GPIO_BTN_RESET 17 + +#define DAP_1330_KEYS_POLL_INTERVAL 20 /* msecs */ +#define DAP_1330_KEYS_DEBOUNCE_INTERVAL (3 * DAP_1330_KEYS_POLL_INTERVAL) + +#define DAP1330_MAC_ADDR 0x1f020001 + +#define DAP1330_WMAC_CALDATA_ADDR 0x1f010000 +#define DAP_1330_WMAC_CALDATA_OFFSET 0x1000 + +static struct gpio_led dap_1330_leds_gpio[] __initdata = { + { + .name = "d-link:green:power", + .gpio = DAP_1330_GPIO_LED_GREEN_POWER, + .active_low = 1, + }, + { + .name = "d-link:red:power", + .gpio = DAP_1330_GPIO_LED_RED_POWER, + .active_low = 1, + }, + { + .name = "d-link:green:wifi", + .gpio = DAP_1330_GPIO_LED_GREEN_WIFI, + .active_low = 1, + }, + { + .name = "d-link:red:wifi", + .gpio = DAP_1330_GPIO_LED_RED_WIFI, + .active_low = 1, + }, + { + .name = "d-link:green:signal1", + .gpio = DAP_1330_GPIO_LED_SIGNAL1, + .active_low = 1, + }, + { + .name = "d-link:green:signal2", + .gpio = DAP_1330_GPIO_LED_SIGNAL2, + .active_low = 1, + } +}; + +static struct gpio_keys_button dap_1330_gpio_keys[] __initdata = { + { + .desc = "WPS button", + .type = EV_KEY, + .code = KEY_WPS_BUTTON, + .debounce_interval = DAP_1330_KEYS_DEBOUNCE_INTERVAL, + .gpio = DAP_1330_GPIO_BTN_WPS, + .active_low = 1, + }, + { + .desc = "Reset button", + .type = EV_KEY, + .code = KEY_RESTART, + .debounce_interval = DAP_1330_KEYS_DEBOUNCE_INTERVAL, + .gpio = DAP_1330_GPIO_BTN_RESET, + .active_low = 1, + } +}; + +static void __init dap_1330_setup(void) +{ + u8 *art = (u8 *) KSEG1ADDR(DAP1330_WMAC_CALDATA_ADDR); + u8 *mac_ptr = (u8 *) KSEG1ADDR(DAP1330_MAC_ADDR); + u8 mac[ETH_ALEN]; + + ath79_parse_ascii_mac((char *) mac_ptr, mac); + + ath79_register_m25p80(NULL); + + ath79_register_leds_gpio(-1, ARRAY_SIZE(dap_1330_leds_gpio), + dap_1330_leds_gpio); + + ath79_register_gpio_keys_polled(-1, DAP_1330_KEYS_POLL_INTERVAL, + ARRAY_SIZE(dap_1330_gpio_keys), + dap_1330_gpio_keys); + + ath79_register_wmac(art + DAP_1330_WMAC_CALDATA_OFFSET, mac); + + ath79_register_mdio(0, 0x0); + + ath79_init_mac(ath79_eth1_data.mac_addr, mac, 0); + + /* LAN ports */ + ath79_eth1_data.phy_if_mode = PHY_INTERFACE_MODE_GMII; + ath79_eth1_data.speed = SPEED_1000; + ath79_eth1_data.duplex = DUPLEX_FULL; + ath79_switch_data.phy_poll_mask |= BIT(4); + ath79_switch_data.phy4_mii_en = 1; + ath79_register_eth(1); +} + +MIPS_MACHINE(ATH79_MACH_DAP_1330_A1, "DAP-1330-A1", + "D-Link DAP-1330 Rev. A1", dap_1330_setup); diff --git a/target/linux/ar71xx/files/arch/mips/ath79/machtypes.h b/target/linux/ar71xx/files/arch/mips/ath79/machtypes.h index de7298f41cd..f57ce6aac02 100644 --- a/target/linux/ar71xx/files/arch/mips/ath79/machtypes.h +++ b/target/linux/ar71xx/files/arch/mips/ath79/machtypes.h @@ -78,6 +78,7 @@ enum ath79_mach_type { ATH79_MACH_CPE870, /* YunCore CPE870 */ ATH79_MACH_CR3000, /* PowerCloud CR3000 */ ATH79_MACH_CR5000, /* PowerCloud CR5000 */ + ATH79_MACH_DAP_1330_A1, /* D-Link DAP-1330 rev. A1 */ ATH79_MACH_DAP_2695_A1, /* D-Link DAP-2695 rev. A1 */ ATH79_MACH_DB120, /* Atheros DB120 reference board */ ATH79_MACH_DGL_5500_A1, /* D-link DGL-5500 rev. A1 */ diff --git a/target/linux/ar71xx/generic/config-default b/target/linux/ar71xx/generic/config-default index 184087d38aa..088824d31de 100644 --- a/target/linux/ar71xx/generic/config-default +++ b/target/linux/ar71xx/generic/config-default @@ -55,6 +55,7 @@ CONFIG_ATH79_MACH_CPE830=y CONFIG_ATH79_MACH_CPE870=y CONFIG_ATH79_MACH_CR3000=y CONFIG_ATH79_MACH_CR5000=y +CONFIG_ATH79_MACH_DAP_1330_A1=y CONFIG_ATH79_MACH_DAP_2695_A1=y CONFIG_ATH79_MACH_DB120=y CONFIG_ATH79_MACH_DGL_5500_A1=y diff --git a/target/linux/ar71xx/image/generic.mk b/target/linux/ar71xx/image/generic.mk index 8dd1b476825..b009be00c95 100644 --- a/target/linux/ar71xx/image/generic.mk +++ b/target/linux/ar71xx/image/generic.mk @@ -32,6 +32,16 @@ define Build/mkwrggimg mv $@.imghdr $@ endef +define Build/mkdapimg2 + $(STAGING_DIR_HOST)/bin/mkdapimg2 \ + -i $@ -o $@.new \ + -s $(DAP_SIGNATURE) \ + -v $(VERSION_DIST)-$(firstword $(subst -, ,$(REVISION))) \ + -r Default \ + $(if $(1),-k $(1)) + mv $@.new $@ +endef + define Build/netgear-squashfs rm -rf $@.fs $@.squashfs mkdir -p $@.fs/image @@ -1129,6 +1139,18 @@ define Device/qihoo-c301 endef TARGET_DEVICES += qihoo-c301 +define Device/dap-1330-a1 + DEVICE_TITLE := D-Link DAP-1330 rev. A1 + DEVICE_PACKAGES := rssileds + BOARDNAME := DAP-1330-A1 + IMAGES := factory.img sysupgrade.bin + IMAGE_SIZE := 7936k + IMAGE/factory.img := append-kernel | pad-to $$$$(BLOCKSIZE) | append-rootfs | pad-rootfs | check-size $$$$(IMAGE_SIZE) | mkdapimg2 917504 + MTDPARTS := spi0.0:64k(u-boot)ro,64k(art)ro,64k(mp)ro,64k(config)ro,7936k(firmware) + DAP_SIGNATURE := HONEYBEE-FIRMWARE-DAP-1330 +endef +TARGET_DEVICES += dap-1330-a1 + define Device/dap-2695-a1 DEVICE_TITLE := D-Link DAP-2695 rev. A1 DEVICE_PACKAGES := ath10k-firmware-qca988x kmod-ath10k