mv $@.new $@
endef
+# Outputs a lzma compressed U-Boot that start at 0x00008000
+# just like the D-Link boot loaders expect
+define Build/dlink-uboot-bin
+ $(STAGING_DIR_HOST)/bin/lzma e $(STAGING_DIR_IMAGE)/$(DEVICE_NAME)-u-boot.bin -d16 $@
+endef
+
define Build/seama-nand
# Seama entity
$(STAGING_DIR_HOST)/bin/oseama \
-i $@.entity
endef
+define Build/dwl8610ap-image
+ mkdir -p $@.tmptar
+ # The DWL8610AP pretends to be a Broadcom reference design
+ echo "bcm953012er" > $@.tmptar/board
+ echo "LVL7" > $@.tmptar/model
+ # Something high beyond what D-Link has put out
+ echo "5.0.0.0" > $@.tmptar/version
+ # Create rootfs.bin, this is just a NAND image including everything
+ cp $@ $@.tmptar/rootfs.bin
+ # Hash the rootfs.bin
+ cat $@.tmptar/rootfs.bin | md5sum > $@.tmptar/rootfs.md5
+ cd $@.tmptar && tar -c -f $@.new *
+ rm -rf $@.tmptar
+ mv $@.new $@
+endef
+
+ifneq ($(KERNEL),5.15)
+ifneq ($(KERNEL),6.1)
+DTS_DIR := $(DTS_DIR)/broadcom
+endif
+endif
+
DEVICE_VARS += ASUS_PRODUCTID
DEVICE_VARS += BUFFALO_TAG_PLATFORM BUFFALO_TAG_VERSION BUFFALO_TAG_MINOR
DEVICE_VARS += SIGNATURE
DEVICE_VARS += NETGEAR_BOARD_ID NETGEAR_REGION TPLINK_BOARD
DEVICE_VARS += LUXUL_BOARD
-IEEE8021X := wpad-basic-wolfssl
+IEEE8021X := wpad-basic-mbedtls
B43 := $(IEEE8021X) kmod-b43
BRCMFMAC_43602A1 := $(IEEE8021X) kmod-brcmfmac brcmfmac-firmware-43602a1-pcie
BRCMFMAC_4366B1 := $(IEEE8021X) kmod-brcmfmac brcmfmac-firmware-4366b1-pcie
USB3_PACKAGES := $(USB2_PACKAGES) kmod-usb3 kmod-phy-bcm-ns-usb3
define Device/Default
+ PROFILES = Generic $$(DEVICE_NAME)
# .dtb files are prefixed by SoC type, e.g. bcm4708- which is not included in device/image names
# extract the full dtb name based on the device info
DEVICE_DTS := $(patsubst %.dtb,%,$(notdir $(wildcard $(if $(IB),$(KDIR),$(DTS_DIR))/*-$(subst _,-,$(1)).dtb)))
IMAGE/trx := append-ubi | trx-nand | asus-trx
endef
+define Device/asus_rt-ac3100
+ $(call Device/asus)
+ DEVICE_MODEL := RT-AC3100
+ DEVICE_PACKAGES := $(BRCMFMAC_4366B1) $(BRCMFMAC_4366C0) $(USB3_PACKAGES)
+ ASUS_PRODUCTID := RT-AC3100
+endef
+TARGET_DEVICES += asus_rt-ac3100
+
define Device/asus_rt-ac56u
$(call Device/asus)
DEVICE_MODEL := RT-AC56U
endef
TARGET_DEVICES += asus_rt-ac87u
+define Device/asus_rt-ac88u
+ $(call Device/asus)
+ DEVICE_MODEL := RT-AC88U
+ DEVICE_PACKAGES := $(BRCMFMAC_4366B1) $(BRCMFMAC_4366C0) $(USB3_PACKAGES)
+ ASUS_PRODUCTID := RT-AC88U
+endef
+TARGET_DEVICES += asus_rt-ac88u
+
define Device/asus_rt-n18u
$(call Device/asus)
DEVICE_MODEL := RT-N18U
endef
TARGET_DEVICES += dlink_dir-885l
-# Linksys devices are disabled due to problem with 2 TRX partitions
+define Device/dlink_dir-890l
+ DEVICE_VENDOR := D-Link
+ DEVICE_MODEL := DIR-890L
+ DEVICE_PACKAGES := $(BRCMFMAC_43602A1) $(USB2_PACKAGES) $(USB3_PACKAGES)
+ # Layout: U-boot (128kb max) followed by kernel and appended DTB.
+ # This is done because the boot loader will only read the first 2 MB
+ # from the flash and decompress the LZMA it finds there after the
+ # SEAMA header. Since the compressed kernel will not fit in 2 MB,
+ # we put U-Boot there and let U-Boot read and execute the kernel.
+ KERNEL := dlink-uboot-bin | pad-to 128k | append-kernel | append-dtb
+ $(Device/dlink)
+ SIGNATURE := wrgac36_dlink.2013gui_dir890
+endef
+TARGET_DEVICES += dlink_dir-890l
+
+define Device/dlink_dwl-8610ap
+ DEVICE_VENDOR := D-Link
+ DEVICE_MODEL := DWL-8610AP
+ DEVICE_PACKAGES := $(B43)
+ IMAGES := factory.tar
+ IMAGE/factory.tar := append-ubi | trx-nand | dwl8610ap-image
+endef
+TARGET_DEVICES += dlink_dwl-8610ap
+
define Device/linksys_ea6300-v1
DEVICE_VENDOR := Linksys
DEVICE_MODEL := EA6300
DEVICE_VARIANT := v1
DEVICE_PACKAGES := $(B43) $(USB3_PACKAGES)
- BROKEN := y
endef
TARGET_DEVICES += linksys_ea6300-v1
DEVICE_MODEL := EA9200
DEVICE_VARIANT := v1
DEVICE_PACKAGES := $(BRCMFMAC_43602A1) $(USB3_PACKAGES)
- BROKEN := y
endef
TARGET_DEVICES += linksys_ea9200
endef
TARGET_DEVICES += luxul_xwr-3150
+define Device/meraki_mr26
+ DEVICE_VENDOR := Meraki
+ DEVICE_MODEL := MR26
+ DEVICE_PACKAGES := $(B43) kmod-i2c-bcm-iproc kmod-eeprom-at24 \
+ kmod-hwmon-ina2xx kmod-leds-uleds nu801
+ DEVICE_DTS := bcm53015-meraki-mr26
+# resize the initramfs to fit the size of the existing part.safe.
+ KERNEL_LOADADDR := 0x00008000
+ KERNEL_INITRAMFS_SUFFIX := .bin
+ KERNEL_INITRAMFS := kernel-bin | append-dtb | gzip | uImage gzip | pad-to 9310208
+# LZMA is not supported by the uboot
+ KERNEL := kernel-bin | append-dtb | gzip | uImage gzip
+ IMAGES += sysupgrade.bin
+ IMAGE/sysupgrade.bin := sysupgrade-tar | append-metadata
+endef
+TARGET_DEVICES += meraki_mr26
+
define Device/meraki_mr32
DEVICE_VENDOR := Meraki
DEVICE_MODEL := MR32
- DEVICE_PACKAGES := $(B43) kmod-i2c-bcm-iproc kmod-i2c-gpio kmod-eeprom-at24 \
+ DEVICE_PACKAGES := $(B43) kmod-i2c-bcm-iproc kmod-eeprom-at24 \
kmod-leds-pwm kmod-hwmon-ina2xx kmod-bluetooth
DEVICE_DTS := bcm53016-meraki-mr32
# Meraki FW r23 tries to resize the part.safe partition before it will
pad-to 10362880
KERNEL := kernel-bin | fit none $$(DTS_DIR)/$$(DEVICE_DTS).dtb
IMAGES += sysupgrade.bin
-# Currently the only device that uses the new image check
IMAGE/sysupgrade.bin := sysupgrade-tar | append-metadata
# The loader is specifically looking for fdt@2:
define Device/phicomm_k3
DEVICE_VENDOR := PHICOMM
DEVICE_MODEL := K3
+ DEVICE_ALT0_VENDOR := Wavlink
+ DEVICE_ALT0_MODEL := QUANTUM DAX
+ DEVICE_ALT1_VENDOR := Wavlink
+ DEVICE_ALT1_MODEL := WL-WN538A8
DEVICE_PACKAGES := $(BRCMFMAC_4366C0) $(USB3_PACKAGES)
IMAGES := trx
endef