[openwrt/openwrt] ar71xx: Add support for D-Link DAP-1330 a1

LEDE Commits lede-commits at lists.infradead.org
Thu Apr 5 06:29:07 PDT 2018


neoraider pushed a commit to openwrt/openwrt.git, branch master:
https://git.lede-project.org/d265a8f2ca49a67a46493cf57de7c265855b317f

commit d265a8f2ca49a67a46493cf57de7c265855b317f
Author: Nicolò Veronese <nicveronese at gmail.com>
AuthorDate: Fri Jun 16 12:12:25 2017 +0000

    ar71xx: Add support for D-Link DAP-1330 a1
    
    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 <nicveronese at gmail.com>
---
 target/linux/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 +
 .../ar71xx/files/arch/mips/ath79/Kconfig.openwrt   |   9 ++
 target/linux/ar71xx/files/arch/mips/ath79/Makefile |   1 +
 .../files/arch/mips/ath79/mach-dap-1330-a1.c       | 146 +++++++++++++++++++++
 .../linux/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(+)

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 7a8ed9a..2a0af3c 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 6ea4fb0..b5d07cd 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 a7c2ccb..3586cc9 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 2b15dec..4b71a19 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 c55bdab..e6882c2 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 026d5bb..e78b16c 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 ec3c329..20c5385 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 62d7317..d549dd3 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 0000000..9c50bc7
--- /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 <nicveronese at gmail.com>
+ * Copyright (c) 2017 Federico Cappon <dududede371 at gmail.com>
+ *
+ * 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 <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-wmac.h"
+#include "machtypes.h"
+#include "nvram.h"
+
+#include <linux/kernel.h>
+#include <linux/vmalloc.h>
+#include <linux/errno.h>
+#include <linux/init.h>
+#include <linux/string.h>
+
+#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 de7298f..f57ce6a 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 184087d..088824d 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 8dd1b47..b009be0 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



More information about the lede-commits mailing list