2021-02-10 14:52:34 +01:00
|
|
|
# SPDX-License-Identifier: GPL-2.0-only
|
2013-07-12 13:46:27 +00:00
|
|
|
#
|
|
|
|
# Copyright (C) 2013 OpenWrt.org
|
2021-02-10 14:52:34 +01:00
|
|
|
|
2013-07-12 13:46:27 +00:00
|
|
|
include $(TOPDIR)/rules.mk
|
|
|
|
include $(INCLUDE_DIR)/image.mk
|
|
|
|
|
|
|
|
define Image/Prepare
|
|
|
|
rm -f $(KDIR)/fs_mark
|
|
|
|
echo -ne '\xde\xad\xc0\xde' > $(KDIR)/fs_mark
|
|
|
|
$(call prepare_generic_squashfs,$(KDIR)/fs_mark)
|
2014-10-16 20:48:56 +00:00
|
|
|
|
2015-04-21 08:20:00 +00:00
|
|
|
# For UBI we want only one extra block
|
|
|
|
rm -f $(KDIR)/ubi_mark
|
|
|
|
echo -ne '\xde\xad\xc0\xde' > $(KDIR)/ubi_mark
|
2013-07-12 13:46:27 +00:00
|
|
|
endef
|
|
|
|
|
2015-03-25 17:57:44 +00:00
|
|
|
define Build/lzma-d16
|
|
|
|
$(STAGING_DIR_HOST)/bin/lzma e $@ -d16 $(1) $@.new
|
2016-07-14 11:31:26 +02:00
|
|
|
mv $@.new $@
|
2014-10-16 21:33:34 +00:00
|
|
|
endef
|
|
|
|
|
2016-11-19 07:58:26 +01:00
|
|
|
# Similar to Build/tplink-safeloader but uses TRX instead of clean kernel
|
|
|
|
define Build/bcm53xx-tplink-safeloader
|
|
|
|
$(STAGING_DIR_HOST)/bin/trx \
|
|
|
|
-o $@.trx \
|
|
|
|
-m 33554432 \
|
|
|
|
-f $(IMAGE_KERNEL) -a 1024
|
|
|
|
$(STAGING_DIR_HOST)/bin/tplink-safeloader \
|
|
|
|
-B $(TPLINK_BOARD) \
|
|
|
|
-k $@.trx \
|
|
|
|
-r $@ \
|
|
|
|
-j \
|
|
|
|
-o $@.new
|
|
|
|
mv $@.new $@
|
|
|
|
rm $@.trx
|
|
|
|
endef
|
|
|
|
|
2017-01-29 01:05:55 +09:00
|
|
|
define Build/buffalo-wzr-header
|
|
|
|
$(eval product=$(word 1,$(1)))
|
|
|
|
$(eval region=$(word 2,$(1)))
|
|
|
|
( \
|
|
|
|
echo $(product)_$(BUFFALO_TAG_VERSION)_$(BUFFALO_TAG_MINOR)_$(region)_$(BUFFALO_TAG_PLATFORM); \
|
|
|
|
echo filelen=$$(stat -c%s $@); \
|
|
|
|
cat $@ \
|
|
|
|
) > $@.new
|
|
|
|
mv $@.new $@
|
|
|
|
endef
|
|
|
|
|
2017-03-24 18:25:23 +01:00
|
|
|
# TRX with only one (kernel) partition
|
|
|
|
define Build/trx
|
|
|
|
$(STAGING_DIR_HOST)/bin/trx \
|
|
|
|
-o $@.new \
|
|
|
|
-m 33554432 \
|
|
|
|
-f $@
|
|
|
|
mv $@.new $@
|
|
|
|
endef
|
|
|
|
|
2015-04-21 08:42:41 +00:00
|
|
|
define Build/trx-serial
|
2017-11-17 11:43:33 +01:00
|
|
|
$(STAGING_DIR_HOST)/bin/otrx create $@.new \
|
2016-07-30 14:19:11 +02:00
|
|
|
-f $(IMAGE_KERNEL) -a 1024 \
|
2016-07-08 14:22:29 +02:00
|
|
|
-f $@ -a 0x10000 -A $(KDIR)/fs_mark
|
|
|
|
mv $@.new $@
|
2015-04-21 08:42:41 +00:00
|
|
|
endef
|
|
|
|
|
2015-03-25 17:57:44 +00:00
|
|
|
define Build/trx-nand
|
2015-04-21 08:19:53 +00:00
|
|
|
# kernel: always use 4 MiB (-28 B or TRX header) to allow upgrades even
|
|
|
|
# if it grows up between releases
|
2015-04-21 08:20:00 +00:00
|
|
|
# root: UBI with one extra block containing UBI mark to trigger erasing
|
|
|
|
# rest of partition
|
2017-11-17 11:43:33 +01:00
|
|
|
$(STAGING_DIR_HOST)/bin/otrx create $@.new \
|
2016-07-30 14:19:11 +02:00
|
|
|
-f $(IMAGE_KERNEL) -a 0x20000 -b 0x400000 \
|
2016-07-08 14:22:29 +02:00
|
|
|
-f $@ \
|
2015-04-21 08:20:00 +00:00
|
|
|
-A $(KDIR)/ubi_mark -a 0x20000
|
2016-07-08 14:22:29 +02:00
|
|
|
mv $@.new $@
|
2013-07-12 13:46:27 +00:00
|
|
|
endef
|
|
|
|
|
2015-05-27 16:20:06 +00:00
|
|
|
define Build/asus-trx
|
|
|
|
$(STAGING_DIR_HOST)/bin/asustrx \
|
2020-03-02 22:03:09 +01:00
|
|
|
-p $(ASUS_PRODUCTID) -i $@ -o $@.new
|
2015-05-27 16:20:06 +00:00
|
|
|
mv $@.new $@
|
|
|
|
endef
|
|
|
|
|
2020-02-05 10:37:44 -07:00
|
|
|
define Build/luxul-lxl
|
|
|
|
$(STAGING_DIR_HOST)/bin/lxlfw create $@.new \
|
|
|
|
-i $@ \
|
|
|
|
-b $(LUXUL_BOARD)
|
|
|
|
mv $@.new $@
|
|
|
|
endef
|
|
|
|
|
2023-06-19 08:36:16 +02:00
|
|
|
# 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
|
|
|
|
|
2016-02-01 12:43:04 +00:00
|
|
|
define Build/seama-nand
|
|
|
|
# Seama entity
|
|
|
|
$(STAGING_DIR_HOST)/bin/oseama \
|
|
|
|
entity $@.entity \
|
|
|
|
-m "dev=/dev/mtdblock/7" \
|
|
|
|
-m "type=firmware" \
|
2016-07-30 14:19:11 +02:00
|
|
|
-f $(IMAGE_KERNEL) \
|
2016-02-01 12:43:04 +00:00
|
|
|
-b 0x400000 \
|
2016-07-08 14:22:29 +02:00
|
|
|
-f $@ \
|
2016-02-01 12:43:04 +00:00
|
|
|
-f $(KDIR)/ubi_mark
|
|
|
|
# Seama container
|
|
|
|
$(STAGING_DIR_HOST)/bin/seama \
|
|
|
|
-s $@ \
|
|
|
|
-m "signature=$(SIGNATURE)" \
|
|
|
|
-i $@.entity
|
|
|
|
endef
|
|
|
|
|
2022-12-16 21:52:27 +01:00
|
|
|
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
|
|
|
|
|
2024-03-27 23:59:46 +01:00
|
|
|
DTS_DIR := $(DTS_DIR)/broadcom
|
|
|
|
|
2020-03-02 22:03:09 +01:00
|
|
|
DEVICE_VARS += ASUS_PRODUCTID
|
2017-01-29 01:05:55 +09:00
|
|
|
DEVICE_VARS += BUFFALO_TAG_PLATFORM BUFFALO_TAG_VERSION BUFFALO_TAG_MINOR
|
2020-03-02 22:03:09 +01:00
|
|
|
DEVICE_VARS += SIGNATURE
|
|
|
|
DEVICE_VARS += NETGEAR_BOARD_ID NETGEAR_REGION TPLINK_BOARD
|
2020-02-05 10:37:44 -07:00
|
|
|
DEVICE_VARS += LUXUL_BOARD
|
2014-10-09 16:36:51 +00:00
|
|
|
|
2022-12-27 20:44:11 -08:00
|
|
|
IEEE8021X := wpad-basic-mbedtls
|
2017-05-22 12:50:53 +02:00
|
|
|
B43 := $(IEEE8021X) kmod-b43
|
|
|
|
BRCMFMAC_43602A1 := $(IEEE8021X) kmod-brcmfmac brcmfmac-firmware-43602a1-pcie
|
|
|
|
BRCMFMAC_4366B1 := $(IEEE8021X) kmod-brcmfmac brcmfmac-firmware-4366b1-pcie
|
2018-12-17 12:50:25 +01:00
|
|
|
BRCMFMAC_4366C0 := $(IEEE8021X) kmod-brcmfmac brcmfmac-firmware-4366c0-pcie
|
2016-10-01 16:22:43 +02:00
|
|
|
USB2_PACKAGES := kmod-usb-ohci kmod-usb2 kmod-phy-bcm-ns-usb2
|
2016-10-19 12:28:52 +02:00
|
|
|
USB2_PACKAGES += kmod-usb-ledtrig-usbport
|
2016-10-02 00:19:58 +02:00
|
|
|
USB3_PACKAGES := $(USB2_PACKAGES) kmod-usb3 kmod-phy-bcm-ns-usb3
|
2016-08-11 11:59:28 +02:00
|
|
|
|
2015-03-25 17:57:44 +00:00
|
|
|
define Device/Default
|
2023-09-30 22:22:13 +03:00
|
|
|
PROFILES = Generic $$(DEVICE_NAME)
|
2015-03-25 17:57:44 +00:00
|
|
|
# .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
|
2020-08-04 16:02:56 +02:00
|
|
|
DEVICE_DTS := $(patsubst %.dtb,%,$(notdir $(wildcard $(if $(IB),$(KDIR),$(DTS_DIR))/*-$(subst _,-,$(1)).dtb)))
|
2015-03-25 17:57:44 +00:00
|
|
|
KERNEL := kernel-bin | append-dtb | lzma-d16
|
2016-06-17 15:00:17 +01:00
|
|
|
KERNEL_DEPENDS = $$(wildcard $(DTS_DIR)/$$(DEVICE_DTS).dts)
|
2017-03-24 18:25:23 +01:00
|
|
|
KERNEL_INITRAMFS_SUFFIX := .trx
|
|
|
|
KERNEL_INITRAMFS := kernel-bin | append-dtb | lzma-d16 | trx
|
2015-03-25 17:57:44 +00:00
|
|
|
FILESYSTEMS := squashfs
|
2015-03-26 10:42:36 +00:00
|
|
|
KERNEL_NAME := zImage
|
2021-02-22 15:55:43 +01:00
|
|
|
DEVICE_IMG_NAME = $$(DEVICE_IMG_PREFIX)-$$(1).$$(2)
|
2015-03-25 17:57:44 +00:00
|
|
|
IMAGES := trx
|
2016-09-04 08:56:05 +02:00
|
|
|
BLOCKSIZE := 128k
|
2016-07-08 14:22:29 +02:00
|
|
|
PAGESIZE := 2048
|
|
|
|
IMAGE/trx := append-ubi | trx-nand
|
2014-10-09 16:36:05 +00:00
|
|
|
endef
|
|
|
|
|
2015-05-27 16:20:06 +00:00
|
|
|
define Device/asus
|
2020-03-02 22:03:09 +01:00
|
|
|
DEVICE_VENDOR := ASUS
|
2015-05-27 16:20:06 +00:00
|
|
|
IMAGES := trx
|
2016-07-08 14:22:29 +02:00
|
|
|
IMAGE/trx := append-ubi | trx-nand | asus-trx
|
2015-05-27 16:20:06 +00:00
|
|
|
endef
|
|
|
|
|
2023-08-10 15:23:09 +03:00
|
|
|
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
|
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/asus_rt-ac56u
|
2020-03-02 22:03:09 +01:00
|
|
|
$(call Device/asus)
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_MODEL := RT-AC56U
|
2017-05-22 12:50:53 +02:00
|
|
|
DEVICE_PACKAGES := $(B43) $(USB3_PACKAGES)
|
2020-03-02 22:03:09 +01:00
|
|
|
ASUS_PRODUCTID := RT-AC56U
|
2015-05-27 16:20:06 +00:00
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += asus_rt-ac56u
|
2015-05-27 16:20:06 +00:00
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/asus_rt-ac68u
|
2020-03-02 22:03:09 +01:00
|
|
|
$(call Device/asus)
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_MODEL := RT-AC68U
|
2016-08-11 11:59:28 +02:00
|
|
|
DEVICE_PACKAGES := $(USB3_PACKAGES)
|
2020-03-02 22:03:09 +01:00
|
|
|
ASUS_PRODUCTID := RT-AC68U
|
2015-09-26 22:57:33 +00:00
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += asus_rt-ac68u
|
2016-08-11 08:59:54 +02:00
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/asus_rt-ac87u
|
2020-03-02 22:03:09 +01:00
|
|
|
$(call Device/asus)
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_MODEL := RT-AC87U
|
2016-08-11 11:59:28 +02:00
|
|
|
DEVICE_PACKAGES := $(USB3_PACKAGES)
|
2020-03-02 22:03:09 +01:00
|
|
|
ASUS_PRODUCTID := RT-AC87U
|
2016-08-11 08:59:54 +02:00
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += asus_rt-ac87u
|
2016-08-11 08:59:54 +02:00
|
|
|
|
2021-11-12 18:56:15 +08:00
|
|
|
define Device/asus_rt-ac88u
|
|
|
|
$(call Device/asus)
|
|
|
|
DEVICE_MODEL := RT-AC88U
|
2022-10-18 11:54:20 +03:00
|
|
|
DEVICE_PACKAGES := $(BRCMFMAC_4366B1) $(BRCMFMAC_4366C0) $(USB3_PACKAGES)
|
2021-11-12 18:56:15 +08:00
|
|
|
ASUS_PRODUCTID := RT-AC88U
|
|
|
|
endef
|
|
|
|
TARGET_DEVICES += asus_rt-ac88u
|
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/asus_rt-n18u
|
2020-03-02 22:03:09 +01:00
|
|
|
$(call Device/asus)
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_MODEL := RT-N18U
|
2016-08-11 11:59:28 +02:00
|
|
|
DEVICE_PACKAGES := $(USB3_PACKAGES)
|
2020-03-02 22:03:09 +01:00
|
|
|
ASUS_PRODUCTID := RT-N18U
|
2016-08-11 08:59:54 +02:00
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += asus_rt-n18u
|
2015-09-26 22:57:33 +00:00
|
|
|
|
2017-03-24 18:25:23 +01:00
|
|
|
# Buffalo devices have TFTP recovery mode which can work nicely with initramfs
|
|
|
|
# kernels.
|
|
|
|
# We should have two initramfs images for Buffalo: plain initramfs kernel and
|
|
|
|
# TRX with initramfs kernel. It's not possible right now so let's just build
|
|
|
|
# plain initramfs kernel as it may be more useful.
|
|
|
|
define Device/buffalo/Default
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_VENDOR := Buffalo
|
2017-03-24 18:25:23 +01:00
|
|
|
KERNEL_INITRAMFS_SUFFIX = $$(KERNEL_SUFFIX)
|
|
|
|
KERNEL_INITRAMFS = $$(KERNEL)
|
|
|
|
endef
|
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/buffalo_wxr-1900dhp
|
2017-03-24 18:25:23 +01:00
|
|
|
$(call Device/buffalo/Default)
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_MODEL := WXR-1900DHP
|
2016-08-11 12:17:06 +02:00
|
|
|
DEVICE_PACKAGES := $(USB3_PACKAGES)
|
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += buffalo_wxr-1900dhp
|
2016-08-11 12:17:06 +02:00
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/buffalo_wzr-600dhp2
|
2017-03-24 18:25:23 +01:00
|
|
|
$(call Device/buffalo/Default)
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_MODEL := WZR-600DHP2
|
2017-05-22 12:50:53 +02:00
|
|
|
DEVICE_PACKAGES := $(B43) $(USB2_PACKAGES)
|
2016-08-11 12:17:06 +02:00
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += buffalo_wzr-600dhp2
|
2016-08-11 12:17:06 +02:00
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/buffalo_wzr-900dhp
|
2017-03-24 18:25:23 +01:00
|
|
|
$(call Device/buffalo/Default)
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_MODEL := WZR-900DHP
|
2017-05-22 12:50:53 +02:00
|
|
|
DEVICE_PACKAGES := $(B43) $(USB3_PACKAGES)
|
2017-01-29 01:05:55 +09:00
|
|
|
BUFFALO_TAG_PLATFORM := bcm
|
|
|
|
BUFFALO_TAG_VERSION := 9.99
|
|
|
|
BUFFALO_TAG_MINOR := 9.99
|
|
|
|
IMAGES += factory-DHP-EU.bin factory-DHP2-JP.bin
|
|
|
|
IMAGE/factory-DHP-EU.bin := \
|
|
|
|
append-ubi | trx-nand | buffalo-wzr-header WZR-900DHP EU | \
|
|
|
|
buffalo-enc WZR-900DHP $$(BUFFALO_TAG_VERSION) | \
|
|
|
|
buffalo-tag-dhp WZR-900DHP EU mlang20 | buffalo-enc-tag | \
|
|
|
|
buffalo-dhp-image
|
|
|
|
IMAGE/factory-DHP2-JP.bin := \
|
|
|
|
append-ubi | trx-nand | buffalo-wzr-header WZR-900DHP2 JP | \
|
|
|
|
buffalo-enc WZR-900DHP2 $$(BUFFALO_TAG_VERSION) | \
|
|
|
|
buffalo-tag-dhp WZR-900DHP2 JP jp | buffalo-enc-tag | \
|
|
|
|
buffalo-dhp-image
|
2016-08-11 12:17:06 +02:00
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += buffalo_wzr-900dhp
|
2016-08-11 12:17:06 +02:00
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/buffalo_wzr-1750dhp
|
2017-03-24 18:25:23 +01:00
|
|
|
$(call Device/buffalo/Default)
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_MODEL := WZR-1750DHP
|
2017-05-22 12:50:53 +02:00
|
|
|
DEVICE_PACKAGES := $(B43) $(USB3_PACKAGES)
|
2016-08-11 12:17:06 +02:00
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += buffalo_wzr-1750dhp
|
2016-08-11 12:17:06 +02:00
|
|
|
|
2016-02-01 12:43:04 +00:00
|
|
|
define Device/dlink
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_VENDOR := D-Link
|
2016-02-01 12:43:04 +00:00
|
|
|
IMAGES := bin
|
2016-07-08 14:22:29 +02:00
|
|
|
IMAGE/bin := append-ubi | seama-nand
|
2016-02-01 12:43:04 +00:00
|
|
|
endef
|
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/dlink_dir-885l
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_MODEL := DIR-885L
|
2016-09-13 11:03:02 +02:00
|
|
|
DEVICE_PACKAGES := $(BRCMFMAC_4366B1) $(USB3_PACKAGES)
|
2016-08-10 19:23:35 +02:00
|
|
|
$(Device/dlink)
|
|
|
|
SIGNATURE := wrgac42_dlink.2015_dir885l
|
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += dlink_dir-885l
|
2016-08-10 19:23:35 +02:00
|
|
|
|
2023-06-19 08:36:16 +02:00
|
|
|
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
|
|
|
|
|
2022-12-16 21:52:27 +01:00
|
|
|
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
|
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/linksys_ea6300-v1
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_VENDOR := Linksys
|
|
|
|
DEVICE_MODEL := EA6300
|
|
|
|
DEVICE_VARIANT := v1
|
2017-05-22 12:50:53 +02:00
|
|
|
DEVICE_PACKAGES := $(B43) $(USB3_PACKAGES)
|
2016-08-11 08:59:54 +02:00
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += linksys_ea6300-v1
|
2016-08-11 08:59:54 +02:00
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/linksys_ea6500-v2
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_VENDOR := Linksys
|
|
|
|
DEVICE_MODEL := EA6500
|
|
|
|
DEVICE_VARIANT := v2
|
2017-10-21 17:19:03 -07:00
|
|
|
DEVICE_PACKAGES := $(B43) $(USB3_PACKAGES)
|
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += linksys_ea6500-v2
|
2017-10-21 17:19:03 -07:00
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/linksys_ea9200
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_VENDOR := Linksys
|
|
|
|
DEVICE_MODEL := EA9200
|
|
|
|
DEVICE_VARIANT := v1
|
2017-03-12 16:24:13 +01:00
|
|
|
DEVICE_PACKAGES := $(BRCMFMAC_43602A1) $(USB3_PACKAGES)
|
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += linksys_ea9200
|
2017-03-12 16:24:13 +01:00
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/linksys_ea9500
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_VENDOR := Linksys
|
|
|
|
DEVICE_MODEL := EA9500
|
2017-03-12 16:24:13 +01:00
|
|
|
DEVICE_PACKAGES := $(BRCMFMAC_4366C0) $(USB3_PACKAGES)
|
|
|
|
DEVICE_DTS := bcm47094-linksys-panamera
|
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += linksys_ea9500
|
2017-03-12 16:24:13 +01:00
|
|
|
|
2020-02-05 10:37:44 -07:00
|
|
|
define Device/luxul
|
|
|
|
DEVICE_VENDOR := Luxul
|
|
|
|
IMAGES := lxl
|
|
|
|
IMAGE/lxl := append-ubi | trx-nand | luxul-lxl
|
|
|
|
endef
|
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/luxul_abr-4500
|
2020-02-05 10:37:44 -07:00
|
|
|
$(Device/luxul)
|
|
|
|
DEVICE_MODEL := ABR-4500
|
|
|
|
DEVICE_PACKAGES := $(USB3_PACKAGES)
|
|
|
|
LUXUL_BOARD := ABR-4500
|
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += luxul_abr-4500
|
2020-02-05 10:37:44 -07:00
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/luxul_xap-1610
|
2020-04-06 16:14:39 -07:00
|
|
|
$(Device/luxul)
|
|
|
|
DEVICE_MODEL := XAP-1610
|
|
|
|
DEVICE_PACKAGES := $(BRCMFMAC_4366C0)
|
|
|
|
IMAGE/lxl := append-rootfs | trx-serial | luxul-lxl
|
|
|
|
LUXUL_BOARD := XAP-1610
|
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += luxul_xap-1610
|
2020-04-06 16:14:39 -07:00
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/luxul_xbr-4500
|
2020-02-05 10:37:44 -07:00
|
|
|
$(Device/luxul)
|
|
|
|
DEVICE_MODEL := XBR-4500
|
|
|
|
DEVICE_PACKAGES := $(USB3_PACKAGES)
|
|
|
|
LUXUL_BOARD := XBR-4500
|
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += luxul_xbr-4500
|
2020-02-05 10:37:44 -07:00
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/luxul_xwr-3150
|
2020-04-06 16:14:39 -07:00
|
|
|
$(Device/luxul)
|
|
|
|
DEVICE_MODEL := XWR-3150
|
|
|
|
DEVICE_PACKAGES := $(BRCMFMAC_4366C0) $(USB3_PACKAGES)
|
|
|
|
DEVICE_DTS := bcm47094-luxul-xwr-3150-v1
|
|
|
|
LUXUL_BOARD := XWR-3150
|
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += luxul_xwr-3150
|
2020-04-06 16:14:39 -07:00
|
|
|
|
bcm53xx: add support for Meraki MR26
Meraki MR26 is an EOL wireless access point featuring a
PoE ethernet port and two dual-band 3x3 MIMO 802.11n
radios and 1x1 dual-band WIFI dedicated to scanning.
Thank you Amir for the unit and PSU.
Hardware info:
SOC : Broadcom BCM53015A1KFEBG (dual-core Cortex-A9 CPU at 800 MHz)
RAM : SK hynix Inc. H5TQ1G63EFR, 1 Gbit DDR3 SDRAM = 128 MiB
NAND : Spansion S34ML01G100TF100, 1 Gbit SLC NAND Flash = 128 MiB
ETH : 1 GBit Ethernet Port - PoE
WIFI1 : Broadcom BCM43431KMLG, BCM43431 802.11 abgn
WIFI1 : Broadcom BCM43431KMLG, BCM43431 802.11 abgn
WIFI3 : Broadcom BCM43428 abgn (1x1:1 - id: 43428)
BUTTON: one reset button
LEDS : RGB-LED
MISC : Atmel AT24C64 8KiB EEPROM (i2c - seems empty)
: Ti INA219 26V, 12-bit, i2c output current/voltage/power monitor
: TPS23754, High Power/High Efficiency PoE Interface+DC/DC Controller
SERIAL:
WARNING: The serial port needs a TTL/RS-232 3V3 level converter!
The Serial setting is 115200-8-N-1. The board has a populated
right angle 1x4 0.1" pinheader.
The pinout is: VCC (next to J3, has little white arrow), RX, TX, GND.
This flashing procedure for the MR26 was tested with firmware:
"22-143410M-gf25cbf5a-asa".
U-Boot 2012.10-00063-g83f9fe4 (Jun 04 2014 - 21:22:39)
A guide how to open up the device is available on the wiki:
<https://openwrt.org/toh/meraki/mr26>
Notes:
- The WIFI do work to a degree. Limited to 802.11bg in the 2.4GHz band.
- the WIFI macs are made up.
0. Create a separate Ethernet LAN which can't have access to the internet.
Ideally use 192.168.1.2 for your PC. The new OpenWrt firmware will setup
the network via DHCP Discovery, so make sure your PC is running
a DHCP-Server (i.e.: dnsmasq)
'# dnsmasq -i eth# -F 192.168.1.5,192.168.1.50
Download the openwrt-meraki-mr26 initramfs file from openwrt.org and
rename it to something simple like mr26.bin. Then put it into the tftp's
server directory.
1. Disassemble the MR26 device by removing all screws (4 screws are located
under the 4 rubber feets!) and prying open the plastic covers without
breaking the plastic retention clips. Once inside, remove the plastic
back casing. Be careful, there some "hidden" retention clips on both
sides of the LAN port, you need a light to see those. Next, you want to
remove all the screws on the outer metal shielding to get to the PCB.
It's not necessary to remove the antennas!
2. Connect the serial cable to the serial header and Ethernet patch cable
to the device.
4. Before connecting the power, get ready flood the serial console program
with the magic: xyzzy . This is necessary in order to get into the
u-boot prompt. Once Ready: connect power cable.
5. If you don't get the "u-boot>" prompt within the first few seconds,
you have to disconnect and reconnect the power cable and try again.
6. In the u-boot prompt enter:
setenv ipaddr 192.168.1.4
setenv serverip 192.168.1.2
tftpboot ${meraki_loadaddr} mr26.bin; bootm
this will boot a in-ram-only OpenWrt image.
7. Once it booted use sysupgrade to permanently install OpenWrt.
To do this: Download the latest sysupgrade.bin file and move
it to the device. Then use sysupgrade *sysupgrade.bin to install it.
WARNING: DO NOT DELETE the "storage" ubi volume!
Signed-off-by: Christian Lamparter <chunkeey@gmail.com>
2022-06-10 22:22:39 +02:00
|
|
|
define Device/meraki_mr26
|
|
|
|
DEVICE_VENDOR := Meraki
|
|
|
|
DEVICE_MODEL := MR26
|
2024-10-02 16:23:13 +02:00
|
|
|
DEVICE_PACKAGES := $(B43) kmod-hwmon-ina2xx kmod-leds-uleds nu801
|
bcm53xx: add support for Meraki MR26
Meraki MR26 is an EOL wireless access point featuring a
PoE ethernet port and two dual-band 3x3 MIMO 802.11n
radios and 1x1 dual-band WIFI dedicated to scanning.
Thank you Amir for the unit and PSU.
Hardware info:
SOC : Broadcom BCM53015A1KFEBG (dual-core Cortex-A9 CPU at 800 MHz)
RAM : SK hynix Inc. H5TQ1G63EFR, 1 Gbit DDR3 SDRAM = 128 MiB
NAND : Spansion S34ML01G100TF100, 1 Gbit SLC NAND Flash = 128 MiB
ETH : 1 GBit Ethernet Port - PoE
WIFI1 : Broadcom BCM43431KMLG, BCM43431 802.11 abgn
WIFI1 : Broadcom BCM43431KMLG, BCM43431 802.11 abgn
WIFI3 : Broadcom BCM43428 abgn (1x1:1 - id: 43428)
BUTTON: one reset button
LEDS : RGB-LED
MISC : Atmel AT24C64 8KiB EEPROM (i2c - seems empty)
: Ti INA219 26V, 12-bit, i2c output current/voltage/power monitor
: TPS23754, High Power/High Efficiency PoE Interface+DC/DC Controller
SERIAL:
WARNING: The serial port needs a TTL/RS-232 3V3 level converter!
The Serial setting is 115200-8-N-1. The board has a populated
right angle 1x4 0.1" pinheader.
The pinout is: VCC (next to J3, has little white arrow), RX, TX, GND.
This flashing procedure for the MR26 was tested with firmware:
"22-143410M-gf25cbf5a-asa".
U-Boot 2012.10-00063-g83f9fe4 (Jun 04 2014 - 21:22:39)
A guide how to open up the device is available on the wiki:
<https://openwrt.org/toh/meraki/mr26>
Notes:
- The WIFI do work to a degree. Limited to 802.11bg in the 2.4GHz band.
- the WIFI macs are made up.
0. Create a separate Ethernet LAN which can't have access to the internet.
Ideally use 192.168.1.2 for your PC. The new OpenWrt firmware will setup
the network via DHCP Discovery, so make sure your PC is running
a DHCP-Server (i.e.: dnsmasq)
'# dnsmasq -i eth# -F 192.168.1.5,192.168.1.50
Download the openwrt-meraki-mr26 initramfs file from openwrt.org and
rename it to something simple like mr26.bin. Then put it into the tftp's
server directory.
1. Disassemble the MR26 device by removing all screws (4 screws are located
under the 4 rubber feets!) and prying open the plastic covers without
breaking the plastic retention clips. Once inside, remove the plastic
back casing. Be careful, there some "hidden" retention clips on both
sides of the LAN port, you need a light to see those. Next, you want to
remove all the screws on the outer metal shielding to get to the PCB.
It's not necessary to remove the antennas!
2. Connect the serial cable to the serial header and Ethernet patch cable
to the device.
4. Before connecting the power, get ready flood the serial console program
with the magic: xyzzy . This is necessary in order to get into the
u-boot prompt. Once Ready: connect power cable.
5. If you don't get the "u-boot>" prompt within the first few seconds,
you have to disconnect and reconnect the power cable and try again.
6. In the u-boot prompt enter:
setenv ipaddr 192.168.1.4
setenv serverip 192.168.1.2
tftpboot ${meraki_loadaddr} mr26.bin; bootm
this will boot a in-ram-only OpenWrt image.
7. Once it booted use sysupgrade to permanently install OpenWrt.
To do this: Download the latest sysupgrade.bin file and move
it to the device. Then use sysupgrade *sysupgrade.bin to install it.
WARNING: DO NOT DELETE the "storage" ubi volume!
Signed-off-by: Christian Lamparter <chunkeey@gmail.com>
2022-06-10 22:22:39 +02:00
|
|
|
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
|
|
|
|
|
bcm53xx: add Cisco Meraki MR32
This patch adds support for Cisco Meraki MR32.
The unit was donated by Chris Blake. Thank you!
WARNING:
Only the 1x1:1 abgn Air Marshal WIPS wifi is currently supported by b43:
b43-phy2: Found PHY: Analog 9, Type 4 (N), Revision 16
b43-phy2: Found Radio: Manuf 0x17F, ID 0x2057, Revision 9, Version 1
b43-phy2: Loading firmware version 784.2 (2012-08-15 21:35:19)
and only as 802.11ABG!
while WIFI1 and WIFI2 (both BCM4352) are not:
b43-phy0: Broadcom 4352 WLAN found (core revision 42)
b43-phy0 ERROR: FOUND UNSUPPORTED PHY (Analog 12, Type 11 (AC), Revision 1)
Hardware Highlights:
SoC: Broadcom BCM53016A1 (1 GHz, 2 cores)
RAM: 128 MiB
NAND: 128 MiB Spansion S34ML01G2 (~114 MiB useable)
ETH: 1GBit Ethernet Port - PoE
WIFI1: Broadcom BCM43520 an+ac (2x2:2 - id: 0x4352)
WIFI2: Broadcom BCM43520 bgn (2x2:2 - id: 0x4352)
WIFI3: Broadcom BCM43428 abgn (1x1:1 - id: 43428)
BLE: Broadcom BCM20732 (ttyS1)
LEDS: 1 x Programmable RGB Status LED (driven by a PWM)
1 x White LED (GPIO)
1 x Orange LED Fault Indicator (GPIO)
2 x LAN Activity / Speed LEDs (On the RJ45 Port)
BUTTON: one Reset button
MISC: AT24C64 8KiB EEPROM (i2c - stores Ethernet MAC + Serial#!)
ina219 hardware monitor (i2c)
Kensington Lock
SERIAL:
WARNING: The serial port needs a TTL/RS-232 3V3 level converter!
The Serial setting is 115200-8-N-1. The board has a populated
right angle 1x4 0.1" pinheader.
The pinout is: VCC, RX, TX, GND. (Use a multimeter)
Flashing needs a serial adaptor (due to the lack of a working dropbear on
the original firmware).
This flashing procedure for the MR32 was tested with firmware:
"r23-149867:150252-aacharya".
0. Create a seperate Ethernet LAN which does not have access to the internet.
Ideally use 192.168.1.2 for your PC. Make sure to reserve 192.168.1.1 it
will be used later on by the OpenWrt firmware. The original Meraki firmware
will likely try to setup the network via DHCP Discovery, so make sure your
PC is running a DHCP-Server (i.e.: dnsmasq)
'# dnsmasq -i eth# -F 192.168.1.5,192.168.1.50
Furthermore, the PC needs a supported ssh/http/ftp server in order to
retrieve the initramfs + dtb file
1. Disassemble the MR32 device by removing all screws (4 screws are located
under the 4 rubber feets!) and prying open the plastic covers without
breaking the plastic retention clips. Once inside, remove all the screws
on the outer metal shielding to get to the PCB. It's not necessary to
remove the antennas!
2. Connect the serial cable to the serial header.
3. Partially reassemble the outer metal shielding to ensure that the SoC
has a proper heat sink.
4. Connect the Ethernet patch cable to the device and the power cable.
5. Wait for the device to boot and enter the root shell.
(rooting is not discussed in detail here please refer to
Chris Blake - "pwning the meraki mr18" blog post:
<https://servernetworktech.com/2016/02/pwning-the-meraki-mr18/>
(The same method works with the MR32's r23-149867:150252-aacharya)
Wait for the MR32 to enter the "<Meraki>" prompt and enter:
<Meraki> odm serial_num read
(Verify that it matches what's on the S/N Sticker on the back!)
<Meraki> odm serial_num write Q2XX-XXXX-XXXV
<Meraki> odm serial_num read
(Verify that the S/N has changed - and the LED start to flash)
now to flash the firmware:
<Meraki> odm firmware part.safe "http://192.168.1.2/mr32-initramfs.bin"
Once OpenWrt booted use sysupgrade to permanently install
OpenWrt. To do this: Download the latest sysupgrade.bin file
for the MR32 to the device and use sysupgrade *sysupgrade.bin
to install it.
WARNING: DO NOT DELETE the "storage" ubi volume!
To flash later MR32 Firmwares like r25-201804051805-G885d6d78-dhow-rel
requires in-circut-i2c tools to access the I2C EEPROM AT24C64 next to
the SoC. The idea is pretty much the same as from Step 5 from above:
Change the serial number to Q2XXXXXXXXXV (should be around 0x7c), then
attach a serial cable, ethernet (but make sure the device can't reach
the internet!) hit "s" (the small s!) during boot to enter the root-shell
and add the following commands to the /storage/config there:
serial_allow_odm true
serial_access_enabled true
serial_access_check false
valid_config true
and then hit exit to let it finish booting.
Signed-off-by: Christian Lamparter <chunkeey@gmail.com>
2020-08-29 23:48:00 +02:00
|
|
|
define Device/meraki_mr32
|
2020-12-13 16:14:35 +01:00
|
|
|
DEVICE_VENDOR := Meraki
|
bcm53xx: add Cisco Meraki MR32
This patch adds support for Cisco Meraki MR32.
The unit was donated by Chris Blake. Thank you!
WARNING:
Only the 1x1:1 abgn Air Marshal WIPS wifi is currently supported by b43:
b43-phy2: Found PHY: Analog 9, Type 4 (N), Revision 16
b43-phy2: Found Radio: Manuf 0x17F, ID 0x2057, Revision 9, Version 1
b43-phy2: Loading firmware version 784.2 (2012-08-15 21:35:19)
and only as 802.11ABG!
while WIFI1 and WIFI2 (both BCM4352) are not:
b43-phy0: Broadcom 4352 WLAN found (core revision 42)
b43-phy0 ERROR: FOUND UNSUPPORTED PHY (Analog 12, Type 11 (AC), Revision 1)
Hardware Highlights:
SoC: Broadcom BCM53016A1 (1 GHz, 2 cores)
RAM: 128 MiB
NAND: 128 MiB Spansion S34ML01G2 (~114 MiB useable)
ETH: 1GBit Ethernet Port - PoE
WIFI1: Broadcom BCM43520 an+ac (2x2:2 - id: 0x4352)
WIFI2: Broadcom BCM43520 bgn (2x2:2 - id: 0x4352)
WIFI3: Broadcom BCM43428 abgn (1x1:1 - id: 43428)
BLE: Broadcom BCM20732 (ttyS1)
LEDS: 1 x Programmable RGB Status LED (driven by a PWM)
1 x White LED (GPIO)
1 x Orange LED Fault Indicator (GPIO)
2 x LAN Activity / Speed LEDs (On the RJ45 Port)
BUTTON: one Reset button
MISC: AT24C64 8KiB EEPROM (i2c - stores Ethernet MAC + Serial#!)
ina219 hardware monitor (i2c)
Kensington Lock
SERIAL:
WARNING: The serial port needs a TTL/RS-232 3V3 level converter!
The Serial setting is 115200-8-N-1. The board has a populated
right angle 1x4 0.1" pinheader.
The pinout is: VCC, RX, TX, GND. (Use a multimeter)
Flashing needs a serial adaptor (due to the lack of a working dropbear on
the original firmware).
This flashing procedure for the MR32 was tested with firmware:
"r23-149867:150252-aacharya".
0. Create a seperate Ethernet LAN which does not have access to the internet.
Ideally use 192.168.1.2 for your PC. Make sure to reserve 192.168.1.1 it
will be used later on by the OpenWrt firmware. The original Meraki firmware
will likely try to setup the network via DHCP Discovery, so make sure your
PC is running a DHCP-Server (i.e.: dnsmasq)
'# dnsmasq -i eth# -F 192.168.1.5,192.168.1.50
Furthermore, the PC needs a supported ssh/http/ftp server in order to
retrieve the initramfs + dtb file
1. Disassemble the MR32 device by removing all screws (4 screws are located
under the 4 rubber feets!) and prying open the plastic covers without
breaking the plastic retention clips. Once inside, remove all the screws
on the outer metal shielding to get to the PCB. It's not necessary to
remove the antennas!
2. Connect the serial cable to the serial header.
3. Partially reassemble the outer metal shielding to ensure that the SoC
has a proper heat sink.
4. Connect the Ethernet patch cable to the device and the power cable.
5. Wait for the device to boot and enter the root shell.
(rooting is not discussed in detail here please refer to
Chris Blake - "pwning the meraki mr18" blog post:
<https://servernetworktech.com/2016/02/pwning-the-meraki-mr18/>
(The same method works with the MR32's r23-149867:150252-aacharya)
Wait for the MR32 to enter the "<Meraki>" prompt and enter:
<Meraki> odm serial_num read
(Verify that it matches what's on the S/N Sticker on the back!)
<Meraki> odm serial_num write Q2XX-XXXX-XXXV
<Meraki> odm serial_num read
(Verify that the S/N has changed - and the LED start to flash)
now to flash the firmware:
<Meraki> odm firmware part.safe "http://192.168.1.2/mr32-initramfs.bin"
Once OpenWrt booted use sysupgrade to permanently install
OpenWrt. To do this: Download the latest sysupgrade.bin file
for the MR32 to the device and use sysupgrade *sysupgrade.bin
to install it.
WARNING: DO NOT DELETE the "storage" ubi volume!
To flash later MR32 Firmwares like r25-201804051805-G885d6d78-dhow-rel
requires in-circut-i2c tools to access the I2C EEPROM AT24C64 next to
the SoC. The idea is pretty much the same as from Step 5 from above:
Change the serial number to Q2XXXXXXXXXV (should be around 0x7c), then
attach a serial cable, ethernet (but make sure the device can't reach
the internet!) hit "s" (the small s!) during boot to enter the root-shell
and add the following commands to the /storage/config there:
serial_allow_odm true
serial_access_enabled true
serial_access_check false
valid_config true
and then hit exit to let it finish booting.
Signed-off-by: Christian Lamparter <chunkeey@gmail.com>
2020-08-29 23:48:00 +02:00
|
|
|
DEVICE_MODEL := MR32
|
2024-10-02 16:23:13 +02:00
|
|
|
DEVICE_PACKAGES := $(B43) kmod-leds-pwm kmod-hwmon-ina2xx kmod-bluetooth
|
bcm53xx: add Cisco Meraki MR32
This patch adds support for Cisco Meraki MR32.
The unit was donated by Chris Blake. Thank you!
WARNING:
Only the 1x1:1 abgn Air Marshal WIPS wifi is currently supported by b43:
b43-phy2: Found PHY: Analog 9, Type 4 (N), Revision 16
b43-phy2: Found Radio: Manuf 0x17F, ID 0x2057, Revision 9, Version 1
b43-phy2: Loading firmware version 784.2 (2012-08-15 21:35:19)
and only as 802.11ABG!
while WIFI1 and WIFI2 (both BCM4352) are not:
b43-phy0: Broadcom 4352 WLAN found (core revision 42)
b43-phy0 ERROR: FOUND UNSUPPORTED PHY (Analog 12, Type 11 (AC), Revision 1)
Hardware Highlights:
SoC: Broadcom BCM53016A1 (1 GHz, 2 cores)
RAM: 128 MiB
NAND: 128 MiB Spansion S34ML01G2 (~114 MiB useable)
ETH: 1GBit Ethernet Port - PoE
WIFI1: Broadcom BCM43520 an+ac (2x2:2 - id: 0x4352)
WIFI2: Broadcom BCM43520 bgn (2x2:2 - id: 0x4352)
WIFI3: Broadcom BCM43428 abgn (1x1:1 - id: 43428)
BLE: Broadcom BCM20732 (ttyS1)
LEDS: 1 x Programmable RGB Status LED (driven by a PWM)
1 x White LED (GPIO)
1 x Orange LED Fault Indicator (GPIO)
2 x LAN Activity / Speed LEDs (On the RJ45 Port)
BUTTON: one Reset button
MISC: AT24C64 8KiB EEPROM (i2c - stores Ethernet MAC + Serial#!)
ina219 hardware monitor (i2c)
Kensington Lock
SERIAL:
WARNING: The serial port needs a TTL/RS-232 3V3 level converter!
The Serial setting is 115200-8-N-1. The board has a populated
right angle 1x4 0.1" pinheader.
The pinout is: VCC, RX, TX, GND. (Use a multimeter)
Flashing needs a serial adaptor (due to the lack of a working dropbear on
the original firmware).
This flashing procedure for the MR32 was tested with firmware:
"r23-149867:150252-aacharya".
0. Create a seperate Ethernet LAN which does not have access to the internet.
Ideally use 192.168.1.2 for your PC. Make sure to reserve 192.168.1.1 it
will be used later on by the OpenWrt firmware. The original Meraki firmware
will likely try to setup the network via DHCP Discovery, so make sure your
PC is running a DHCP-Server (i.e.: dnsmasq)
'# dnsmasq -i eth# -F 192.168.1.5,192.168.1.50
Furthermore, the PC needs a supported ssh/http/ftp server in order to
retrieve the initramfs + dtb file
1. Disassemble the MR32 device by removing all screws (4 screws are located
under the 4 rubber feets!) and prying open the plastic covers without
breaking the plastic retention clips. Once inside, remove all the screws
on the outer metal shielding to get to the PCB. It's not necessary to
remove the antennas!
2. Connect the serial cable to the serial header.
3. Partially reassemble the outer metal shielding to ensure that the SoC
has a proper heat sink.
4. Connect the Ethernet patch cable to the device and the power cable.
5. Wait for the device to boot and enter the root shell.
(rooting is not discussed in detail here please refer to
Chris Blake - "pwning the meraki mr18" blog post:
<https://servernetworktech.com/2016/02/pwning-the-meraki-mr18/>
(The same method works with the MR32's r23-149867:150252-aacharya)
Wait for the MR32 to enter the "<Meraki>" prompt and enter:
<Meraki> odm serial_num read
(Verify that it matches what's on the S/N Sticker on the back!)
<Meraki> odm serial_num write Q2XX-XXXX-XXXV
<Meraki> odm serial_num read
(Verify that the S/N has changed - and the LED start to flash)
now to flash the firmware:
<Meraki> odm firmware part.safe "http://192.168.1.2/mr32-initramfs.bin"
Once OpenWrt booted use sysupgrade to permanently install
OpenWrt. To do this: Download the latest sysupgrade.bin file
for the MR32 to the device and use sysupgrade *sysupgrade.bin
to install it.
WARNING: DO NOT DELETE the "storage" ubi volume!
To flash later MR32 Firmwares like r25-201804051805-G885d6d78-dhow-rel
requires in-circut-i2c tools to access the I2C EEPROM AT24C64 next to
the SoC. The idea is pretty much the same as from Step 5 from above:
Change the serial number to Q2XXXXXXXXXV (should be around 0x7c), then
attach a serial cable, ethernet (but make sure the device can't reach
the internet!) hit "s" (the small s!) during boot to enter the root-shell
and add the following commands to the /storage/config there:
serial_allow_odm true
serial_access_enabled true
serial_access_check false
valid_config true
and then hit exit to let it finish booting.
Signed-off-by: Christian Lamparter <chunkeey@gmail.com>
2020-08-29 23:48:00 +02:00
|
|
|
DEVICE_DTS := bcm53016-meraki-mr32
|
|
|
|
# Meraki FW r23 tries to resize the part.safe partition before it will
|
|
|
|
# flash the image. This is a bit of a problem, since resizing will fail
|
|
|
|
# if the partition is smaller than the old one.
|
|
|
|
KERNEL_LOADADDR := 0x00008000
|
|
|
|
KERNEL_INITRAMFS_SUFFIX := .bin
|
2021-07-19 14:21:44 +10:00
|
|
|
DEVICE_DTS_DELIMITER := @
|
|
|
|
DEVICE_DTS_CONFIG := config@1
|
bcm53xx: add Cisco Meraki MR32
This patch adds support for Cisco Meraki MR32.
The unit was donated by Chris Blake. Thank you!
WARNING:
Only the 1x1:1 abgn Air Marshal WIPS wifi is currently supported by b43:
b43-phy2: Found PHY: Analog 9, Type 4 (N), Revision 16
b43-phy2: Found Radio: Manuf 0x17F, ID 0x2057, Revision 9, Version 1
b43-phy2: Loading firmware version 784.2 (2012-08-15 21:35:19)
and only as 802.11ABG!
while WIFI1 and WIFI2 (both BCM4352) are not:
b43-phy0: Broadcom 4352 WLAN found (core revision 42)
b43-phy0 ERROR: FOUND UNSUPPORTED PHY (Analog 12, Type 11 (AC), Revision 1)
Hardware Highlights:
SoC: Broadcom BCM53016A1 (1 GHz, 2 cores)
RAM: 128 MiB
NAND: 128 MiB Spansion S34ML01G2 (~114 MiB useable)
ETH: 1GBit Ethernet Port - PoE
WIFI1: Broadcom BCM43520 an+ac (2x2:2 - id: 0x4352)
WIFI2: Broadcom BCM43520 bgn (2x2:2 - id: 0x4352)
WIFI3: Broadcom BCM43428 abgn (1x1:1 - id: 43428)
BLE: Broadcom BCM20732 (ttyS1)
LEDS: 1 x Programmable RGB Status LED (driven by a PWM)
1 x White LED (GPIO)
1 x Orange LED Fault Indicator (GPIO)
2 x LAN Activity / Speed LEDs (On the RJ45 Port)
BUTTON: one Reset button
MISC: AT24C64 8KiB EEPROM (i2c - stores Ethernet MAC + Serial#!)
ina219 hardware monitor (i2c)
Kensington Lock
SERIAL:
WARNING: The serial port needs a TTL/RS-232 3V3 level converter!
The Serial setting is 115200-8-N-1. The board has a populated
right angle 1x4 0.1" pinheader.
The pinout is: VCC, RX, TX, GND. (Use a multimeter)
Flashing needs a serial adaptor (due to the lack of a working dropbear on
the original firmware).
This flashing procedure for the MR32 was tested with firmware:
"r23-149867:150252-aacharya".
0. Create a seperate Ethernet LAN which does not have access to the internet.
Ideally use 192.168.1.2 for your PC. Make sure to reserve 192.168.1.1 it
will be used later on by the OpenWrt firmware. The original Meraki firmware
will likely try to setup the network via DHCP Discovery, so make sure your
PC is running a DHCP-Server (i.e.: dnsmasq)
'# dnsmasq -i eth# -F 192.168.1.5,192.168.1.50
Furthermore, the PC needs a supported ssh/http/ftp server in order to
retrieve the initramfs + dtb file
1. Disassemble the MR32 device by removing all screws (4 screws are located
under the 4 rubber feets!) and prying open the plastic covers without
breaking the plastic retention clips. Once inside, remove all the screws
on the outer metal shielding to get to the PCB. It's not necessary to
remove the antennas!
2. Connect the serial cable to the serial header.
3. Partially reassemble the outer metal shielding to ensure that the SoC
has a proper heat sink.
4. Connect the Ethernet patch cable to the device and the power cable.
5. Wait for the device to boot and enter the root shell.
(rooting is not discussed in detail here please refer to
Chris Blake - "pwning the meraki mr18" blog post:
<https://servernetworktech.com/2016/02/pwning-the-meraki-mr18/>
(The same method works with the MR32's r23-149867:150252-aacharya)
Wait for the MR32 to enter the "<Meraki>" prompt and enter:
<Meraki> odm serial_num read
(Verify that it matches what's on the S/N Sticker on the back!)
<Meraki> odm serial_num write Q2XX-XXXX-XXXV
<Meraki> odm serial_num read
(Verify that the S/N has changed - and the LED start to flash)
now to flash the firmware:
<Meraki> odm firmware part.safe "http://192.168.1.2/mr32-initramfs.bin"
Once OpenWrt booted use sysupgrade to permanently install
OpenWrt. To do this: Download the latest sysupgrade.bin file
for the MR32 to the device and use sysupgrade *sysupgrade.bin
to install it.
WARNING: DO NOT DELETE the "storage" ubi volume!
To flash later MR32 Firmwares like r25-201804051805-G885d6d78-dhow-rel
requires in-circut-i2c tools to access the I2C EEPROM AT24C64 next to
the SoC. The idea is pretty much the same as from Step 5 from above:
Change the serial number to Q2XXXXXXXXXV (should be around 0x7c), then
attach a serial cable, ethernet (but make sure the device can't reach
the internet!) hit "s" (the small s!) during boot to enter the root-shell
and add the following commands to the /storage/config there:
serial_allow_odm true
serial_access_enabled true
serial_access_check false
valid_config true
and then hit exit to let it finish booting.
Signed-off-by: Christian Lamparter <chunkeey@gmail.com>
2020-08-29 23:48:00 +02:00
|
|
|
KERNEL_INITRAMFS := kernel-bin | fit none $$(DTS_DIR)/$$(DEVICE_DTS).dtb | \
|
|
|
|
pad-to 10362880
|
|
|
|
KERNEL := kernel-bin | fit none $$(DTS_DIR)/$$(DEVICE_DTS).dtb
|
2021-07-19 14:21:44 +10:00
|
|
|
IMAGES += sysupgrade.bin
|
2021-01-23 22:03:51 +01:00
|
|
|
IMAGE/sysupgrade.bin := sysupgrade-tar | append-metadata
|
bcm53xx: add Cisco Meraki MR32
This patch adds support for Cisco Meraki MR32.
The unit was donated by Chris Blake. Thank you!
WARNING:
Only the 1x1:1 abgn Air Marshal WIPS wifi is currently supported by b43:
b43-phy2: Found PHY: Analog 9, Type 4 (N), Revision 16
b43-phy2: Found Radio: Manuf 0x17F, ID 0x2057, Revision 9, Version 1
b43-phy2: Loading firmware version 784.2 (2012-08-15 21:35:19)
and only as 802.11ABG!
while WIFI1 and WIFI2 (both BCM4352) are not:
b43-phy0: Broadcom 4352 WLAN found (core revision 42)
b43-phy0 ERROR: FOUND UNSUPPORTED PHY (Analog 12, Type 11 (AC), Revision 1)
Hardware Highlights:
SoC: Broadcom BCM53016A1 (1 GHz, 2 cores)
RAM: 128 MiB
NAND: 128 MiB Spansion S34ML01G2 (~114 MiB useable)
ETH: 1GBit Ethernet Port - PoE
WIFI1: Broadcom BCM43520 an+ac (2x2:2 - id: 0x4352)
WIFI2: Broadcom BCM43520 bgn (2x2:2 - id: 0x4352)
WIFI3: Broadcom BCM43428 abgn (1x1:1 - id: 43428)
BLE: Broadcom BCM20732 (ttyS1)
LEDS: 1 x Programmable RGB Status LED (driven by a PWM)
1 x White LED (GPIO)
1 x Orange LED Fault Indicator (GPIO)
2 x LAN Activity / Speed LEDs (On the RJ45 Port)
BUTTON: one Reset button
MISC: AT24C64 8KiB EEPROM (i2c - stores Ethernet MAC + Serial#!)
ina219 hardware monitor (i2c)
Kensington Lock
SERIAL:
WARNING: The serial port needs a TTL/RS-232 3V3 level converter!
The Serial setting is 115200-8-N-1. The board has a populated
right angle 1x4 0.1" pinheader.
The pinout is: VCC, RX, TX, GND. (Use a multimeter)
Flashing needs a serial adaptor (due to the lack of a working dropbear on
the original firmware).
This flashing procedure for the MR32 was tested with firmware:
"r23-149867:150252-aacharya".
0. Create a seperate Ethernet LAN which does not have access to the internet.
Ideally use 192.168.1.2 for your PC. Make sure to reserve 192.168.1.1 it
will be used later on by the OpenWrt firmware. The original Meraki firmware
will likely try to setup the network via DHCP Discovery, so make sure your
PC is running a DHCP-Server (i.e.: dnsmasq)
'# dnsmasq -i eth# -F 192.168.1.5,192.168.1.50
Furthermore, the PC needs a supported ssh/http/ftp server in order to
retrieve the initramfs + dtb file
1. Disassemble the MR32 device by removing all screws (4 screws are located
under the 4 rubber feets!) and prying open the plastic covers without
breaking the plastic retention clips. Once inside, remove all the screws
on the outer metal shielding to get to the PCB. It's not necessary to
remove the antennas!
2. Connect the serial cable to the serial header.
3. Partially reassemble the outer metal shielding to ensure that the SoC
has a proper heat sink.
4. Connect the Ethernet patch cable to the device and the power cable.
5. Wait for the device to boot and enter the root shell.
(rooting is not discussed in detail here please refer to
Chris Blake - "pwning the meraki mr18" blog post:
<https://servernetworktech.com/2016/02/pwning-the-meraki-mr18/>
(The same method works with the MR32's r23-149867:150252-aacharya)
Wait for the MR32 to enter the "<Meraki>" prompt and enter:
<Meraki> odm serial_num read
(Verify that it matches what's on the S/N Sticker on the back!)
<Meraki> odm serial_num write Q2XX-XXXX-XXXV
<Meraki> odm serial_num read
(Verify that the S/N has changed - and the LED start to flash)
now to flash the firmware:
<Meraki> odm firmware part.safe "http://192.168.1.2/mr32-initramfs.bin"
Once OpenWrt booted use sysupgrade to permanently install
OpenWrt. To do this: Download the latest sysupgrade.bin file
for the MR32 to the device and use sysupgrade *sysupgrade.bin
to install it.
WARNING: DO NOT DELETE the "storage" ubi volume!
To flash later MR32 Firmwares like r25-201804051805-G885d6d78-dhow-rel
requires in-circut-i2c tools to access the I2C EEPROM AT24C64 next to
the SoC. The idea is pretty much the same as from Step 5 from above:
Change the serial number to Q2XXXXXXXXXV (should be around 0x7c), then
attach a serial cable, ethernet (but make sure the device can't reach
the internet!) hit "s" (the small s!) during boot to enter the root-shell
and add the following commands to the /storage/config there:
serial_allow_odm true
serial_access_enabled true
serial_access_check false
valid_config true
and then hit exit to let it finish booting.
Signed-off-by: Christian Lamparter <chunkeey@gmail.com>
2020-08-29 23:48:00 +02:00
|
|
|
|
|
|
|
# The loader is specifically looking for fdt@2:
|
|
|
|
# [ 3.190000] find_itb_subimage: error finding fdt@2: FDT_ERR_NOTFOUND
|
|
|
|
# The image won't boot, if it isn't found. :(
|
|
|
|
DEVICE_FDT_NUM := 2
|
|
|
|
endef
|
|
|
|
TARGET_DEVICES += meraki_mr32
|
|
|
|
|
bcm53xx: add support for Cisco Meraki MX64/MX65
This commit adds support for the Cisco Meraki MX64 and MX65 devices which
use the Broadcom NSP SoC, which is compatible with the bcm53xx platform.
MX64 Hardware info:
- CPU: Broadcom BCM58625 Cortex A9 @ 1200Mhz
- RAM: 2 GB (4 x 4Gb SK Hynix H5TC4G83CFR)
- Storage: 1 GB (Micron MT29F8G08ABACA)
- Networking: BCM58625 internal switch (5x 1GbE ports)
- USB: 1x USB2.0
- Serial: Internal header
MX65 Hardware info:
- CPU: Broadcom BCM58625 Cortex A9 @ 1200Mhz
- RAM: 2 GB (4 x 4Gb SK Hynix H5TC4G83CFR)
- Storage: 1 GB (Micron MT29F8G08ABACA)
- Networking: BCM58625 switch (2x 1GbE ports, used for WAN ports 1 & 2)
2x Qualcomm QCA8337 switches (10x 1GbE ports, used for LAN ports 3-12)
- PSE: Broadcom BCM59111KMLG connected to LAN ports 11 & 12
- USB: 1x USB2.0
- Serial: Internal header
Notes:
- The Meraki provided GPL source are available at [2].
- Wireless capability on the MX64W and MX65W exists in the form of 2x
Broadcom BCM43520KMLG, which is not supported. These devices will work
otherwise as standard MX64 or MX65 devices.
- Early MX64 units use an A0 variant of the BCM958625 SoC which lacks
cache coherency and uses a different "secondary-boot-reg". As a
consequence a different device tree is needed.
- Installation of OpenWrt requires changing u-boot to a custom version.
This is due to the stock u-boot "nand read" command being limited to
load only 2MB, in spite of the bootkernel1 and bootkernel2 partitions
both being 3MB in the stock layout. It is also required to allow
booting via USB, enabling cache coherency and setting up the QCA
switches and Serdes link on the MX65. The modified sources for U-boot
are available for the MX64[3] and MX65[4].
- Initial work on this device used a small bootloader within the OEM
partition scheme. To allow booting of larger kernels, UBI and bootm
support has been added, along with ability to store env variables to
the NAND. The Shmoo and newly created env partitions have been moved
to the extra space available after the nvram data.
- Users who installed the previous non-UBI supporting bootloader will
need to convert to the new one before flashing a compatible image.
These steps are detailed below.
References:
[1] https://www.broadcom.com/products/embedded-and-networking-processors/c
ommunications/bcm5862x
[2] https://dl.meraki.net/wired-14-39-mx64-20190426.tar.bz2
[3] https://github.com/clayface/U-boot-MX64-20190430_MX64
[4] https://github.com/clayface/U-boot-MX64-20190430_MX65
Installation guide:
Initial installation steps:
1. Compile or obtain OpenWrt files for the MX64 or MX65, including
u-boot[3][4], initramfs and sysupgrade images.
2. A USB disk with DOS partition scheme and primary FAT partition is
required.
3. If installing onto an MX64, set up a local web server.
4. On the device, boot into diagnostic mode by holding reset when
powering on the device. Continue to hold reset until the orange LED
begins to flash white. On used units the white flash may be difficult
to see.
5. Plug an Ethernet cable into the first LAN port, set the host to
192.168.1.2 and confirm telnet connectivity to 192.168.1.1.
U-boot installation - MX64 Only:
1. Newer fw versions require extra steps to support OpenWrt. To check,
please connect via telnet and run:
`cat /sys/block/mtdblock0/ro`
If the result is 1, your mtd0 is locked will need to perform extra
steps 4 and 5 in this section. If the result is 0 then skip these.
2. Check which SoC is in use by running the following command:
`devmem 0x18000000`
If devmem is not found then try:
`devmem2 0x18000000`
If the output begins with anything between "0x3F00-0x3F03" you will
need to use the A0 release. For any other output, eg "0x3F04" or
higher, use the regular MX64 image.
3 Confirm the size of the device's boot(mtd0) partition. In most
cases it should be 0x100000 or larger. If this is the case, please
proceed to use the uboot_mx64 image. If the reported size is
0x80000, please use the uboot_mx64_small image, then follow the
later guide to change to the larger image.
`cat /proc/mtd`
Example output:
`# cat /proc/mtd
cat /proc/mtd
dev: size erasesize name
mtd0: 00100000 00040000 "boot"
mtd1: 00080000 00040000 "shmoo"
mtd2: 00300000 00040000 "bootkernel1"
mtd3: 00100000 00040000 "nvram"
mtd4: 00300000 00040000 "bootkernel2"
mtd5: 3f700000 00040000 "ubi"
mtd6: 40000000 00040000 "all"`
4. Set up a webserver to serve the appropriate uboot_mx64 from the
following location and verify the SHA512:
https://github.com/clayface/U-boot-MX64-20190430_MX64
5. (Only if mtd0 is locked) You will also need the mtd-rw.ko kernel
module to unlock the partition from the same repo. An mtd executable
is also needed to write the mtd block. Place these on the web server
as well.
6. (Only if mtd0 is locked) Use wget to retrieve the files on the MX64:
`wget http://192.168.1.2/mtd-rw.ko`
`insmod mtd-rw.ko i_want_a_brick=1`
and confirm the unlock is set with dmesg
`mtd-rw: mtd0: setting writeable flag`
7. Download the appropriate u-boot image according to step 3. If you
did not need to unlock the mtd0 partition then use dd to write the
file, with caution:
`wget http://192.168.1.2/uboot_mx64`
`dd if=uboot_mx64 of=/dev/mtdblock0`
If you needed to unlock the mtd0 partition using the mtd-rw module,
run these commands instead to install u-boot instead:
`wget http://192.168.1.2/mtd`
`chmod +x mtd`
`wget http://192.168.1.2/uboot_mx64`
`./mtd write uboot_mx64 /dev/mtd0`
8. Once this has successfully completed, power off the device. If you
did not need to install the small u-boot image, proceed to
"OpenWrt Installation". Otherwise proceed to "UBI supporting
bootloader installation".
U-boot installation - MX65 Only:
1. Obtain telnet access to the MX65.
2. Confirm the size of the device's boot(mtd0) partition. In most
cases it should be 0x100000 or larger. If this is the case, please
proceed to use the uboot_mx65 image. If the reported size is
0x80000, please use the uboot_mx65_small image, then follow the
later guide to change to the larger image.
`cat /proc/mtd`
3. Prepare a USB drive formatted to FAT. Download the appropriate
uboot_mx65 to the USB drive from the following location and verify
the SHA512:
https://github.com/clayface/U-boot-MX64-20190430_MX65
3. Once you have telnet access to the MX65, plug in the USB disk and
run the following commands, with caution. The USB disk should
automount but if it does not, you will need to power off and on
again with reset held. Depending on step 2, use the uboot_mx65 or
uboot_mx65_small image accordingly:
`cd /tmp/media/sda1`
`dd if=uboot_mx65 of=/dev/mtdblock0`
4. Once this has successfully completed, power off the device. If you
did not need to install the small u-boot image, proceed to
"OpenWrt Installation". Otherwise proceed to "UBI supporting
bootloader installation".
UBI supporting bootloader installation:
These steps need to be followed if the older u-boot image was
installed, either because the Meraki diagnostic partition scheme used
0x80000 as the mtd0 size, or because you installed the u-boot provided
while OpenWrt support was still under development. If using OpenWrt,
please make a backup before proceeding.
1. Obtain the relevant image from the MX64(A0) or MX65 u-boot repo:
`openwrt-bcm5862x-generic-meraki_XXXX-initramfs-kernel.bin`
2. With the USB drive already inserted, power on the device while
holding the reset button. A white/orange flashing pattern will
occur shortly after power on. Let go of the reset button. The
device is now booting into OpenWrt initramfs stored on the USB
disk.
3. Connect by SSH to 192.168.1.1 and flash the embedded u-boot image,
changing X as appropriate:
`mtd write /root/uboot_mx6X /dev/mtd0`
You do not need to reboot as this image can handle "Kernel-in-UBI"
OpenWrt installation.
4. You can proceed to obtain and flash the appropriate OpenWrt image
at "OpenWrt Installation" Step 3.
5. Reboot will take significantly longer due to Shmoo calibration. In
case the device does not come online after several minute, power-
cycle the device and see if it boots. If you see an orange/white
flashing pattern, this indicates UBI booting was not successful and
you will need to copy a new bcm53xx image to a USB disk before
booting it and attempting to install OpenWrt again - refer to
"OpenWrt Installation" step 1. Do not attempt to reflash u-boot in
this scenario.
OpenWrt Installation:
1. Having obtained an OpenWrt image, please copy the file
`openwrt-bcm53xx-generic-meraki_XXXX-initramfs.bin`
to the base directory of a FAT formatted USB drive using DOS
partition scheme ,where XXXX is mx64, mx64_a0 or mx65 depending on
which device you have.
2. With the USB drive already inserted, power on the device. Boot time
will be longer than usual while Shmoo calibration takes place. A
different white/orange flashing pattern will eventually occur to
indicate device is now booting into OpenWrt initramfs stored on the
USB disk.
3. Ensuring Ethernet is plugged into a LAN port with IP set in the
192.168.1.0/24 subnet excluding 192.168.1.1, use SCP to copy the
sysupgrade file to 192.168.1.1:/tmp, eg:
`scp openwrt-bcm53xx-generic-meraki_XXXX-squashfs.sysupgrade.bin\
192.168.1.1:/tmp`
4. Connect by SSH to 192.168.1.1 and run sysupgrade:
`sysupgrade \
/tmp/openwrt-bcm53xx-generic-meraki_XXXX-squashfs.sysupgrade.bin`
5. OpenWrt should now be installed on the device.
Signed-off-by: Matthew Hagan <mnhagan88@gmail.com>
[ Rebase kernel configuration for 6.6,
fix failsafe by making kmod-eeprom-at24 and kmod-dsa-qca8k built-in,
resolve conflicts,
add LED aliases,
fix eth0 MAC address at probe ]
TODO:
- fix multiple LED colors not applied despite aliases - due to custom
/etc/diag.sh
- fix race condition between preinit and probing of the DSA tree,
causing no network interface available in failsafe mode (in general
case - to allow moving drivers back to modules)
Signed-off-by: Lech Perczak <lech.perczak@gmail.com>
Link: https://github.com/openwrt/openwrt/pull/16634
Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
2021-09-06 22:42:35 +00:00
|
|
|
define Device/meraki_mx6x
|
|
|
|
KERNEL_IN_UBI := 1
|
|
|
|
KERNEL_LOADADDR := 0x60008000
|
|
|
|
DEVICE_PACKAGES := -oseama kmod-leds-pwm kmod-usb-ehci \
|
2024-10-24 23:46:44 +02:00
|
|
|
kmod-usb-ohci kmod-usb2
|
bcm53xx: add support for Cisco Meraki MX64/MX65
This commit adds support for the Cisco Meraki MX64 and MX65 devices which
use the Broadcom NSP SoC, which is compatible with the bcm53xx platform.
MX64 Hardware info:
- CPU: Broadcom BCM58625 Cortex A9 @ 1200Mhz
- RAM: 2 GB (4 x 4Gb SK Hynix H5TC4G83CFR)
- Storage: 1 GB (Micron MT29F8G08ABACA)
- Networking: BCM58625 internal switch (5x 1GbE ports)
- USB: 1x USB2.0
- Serial: Internal header
MX65 Hardware info:
- CPU: Broadcom BCM58625 Cortex A9 @ 1200Mhz
- RAM: 2 GB (4 x 4Gb SK Hynix H5TC4G83CFR)
- Storage: 1 GB (Micron MT29F8G08ABACA)
- Networking: BCM58625 switch (2x 1GbE ports, used for WAN ports 1 & 2)
2x Qualcomm QCA8337 switches (10x 1GbE ports, used for LAN ports 3-12)
- PSE: Broadcom BCM59111KMLG connected to LAN ports 11 & 12
- USB: 1x USB2.0
- Serial: Internal header
Notes:
- The Meraki provided GPL source are available at [2].
- Wireless capability on the MX64W and MX65W exists in the form of 2x
Broadcom BCM43520KMLG, which is not supported. These devices will work
otherwise as standard MX64 or MX65 devices.
- Early MX64 units use an A0 variant of the BCM958625 SoC which lacks
cache coherency and uses a different "secondary-boot-reg". As a
consequence a different device tree is needed.
- Installation of OpenWrt requires changing u-boot to a custom version.
This is due to the stock u-boot "nand read" command being limited to
load only 2MB, in spite of the bootkernel1 and bootkernel2 partitions
both being 3MB in the stock layout. It is also required to allow
booting via USB, enabling cache coherency and setting up the QCA
switches and Serdes link on the MX65. The modified sources for U-boot
are available for the MX64[3] and MX65[4].
- Initial work on this device used a small bootloader within the OEM
partition scheme. To allow booting of larger kernels, UBI and bootm
support has been added, along with ability to store env variables to
the NAND. The Shmoo and newly created env partitions have been moved
to the extra space available after the nvram data.
- Users who installed the previous non-UBI supporting bootloader will
need to convert to the new one before flashing a compatible image.
These steps are detailed below.
References:
[1] https://www.broadcom.com/products/embedded-and-networking-processors/c
ommunications/bcm5862x
[2] https://dl.meraki.net/wired-14-39-mx64-20190426.tar.bz2
[3] https://github.com/clayface/U-boot-MX64-20190430_MX64
[4] https://github.com/clayface/U-boot-MX64-20190430_MX65
Installation guide:
Initial installation steps:
1. Compile or obtain OpenWrt files for the MX64 or MX65, including
u-boot[3][4], initramfs and sysupgrade images.
2. A USB disk with DOS partition scheme and primary FAT partition is
required.
3. If installing onto an MX64, set up a local web server.
4. On the device, boot into diagnostic mode by holding reset when
powering on the device. Continue to hold reset until the orange LED
begins to flash white. On used units the white flash may be difficult
to see.
5. Plug an Ethernet cable into the first LAN port, set the host to
192.168.1.2 and confirm telnet connectivity to 192.168.1.1.
U-boot installation - MX64 Only:
1. Newer fw versions require extra steps to support OpenWrt. To check,
please connect via telnet and run:
`cat /sys/block/mtdblock0/ro`
If the result is 1, your mtd0 is locked will need to perform extra
steps 4 and 5 in this section. If the result is 0 then skip these.
2. Check which SoC is in use by running the following command:
`devmem 0x18000000`
If devmem is not found then try:
`devmem2 0x18000000`
If the output begins with anything between "0x3F00-0x3F03" you will
need to use the A0 release. For any other output, eg "0x3F04" or
higher, use the regular MX64 image.
3 Confirm the size of the device's boot(mtd0) partition. In most
cases it should be 0x100000 or larger. If this is the case, please
proceed to use the uboot_mx64 image. If the reported size is
0x80000, please use the uboot_mx64_small image, then follow the
later guide to change to the larger image.
`cat /proc/mtd`
Example output:
`# cat /proc/mtd
cat /proc/mtd
dev: size erasesize name
mtd0: 00100000 00040000 "boot"
mtd1: 00080000 00040000 "shmoo"
mtd2: 00300000 00040000 "bootkernel1"
mtd3: 00100000 00040000 "nvram"
mtd4: 00300000 00040000 "bootkernel2"
mtd5: 3f700000 00040000 "ubi"
mtd6: 40000000 00040000 "all"`
4. Set up a webserver to serve the appropriate uboot_mx64 from the
following location and verify the SHA512:
https://github.com/clayface/U-boot-MX64-20190430_MX64
5. (Only if mtd0 is locked) You will also need the mtd-rw.ko kernel
module to unlock the partition from the same repo. An mtd executable
is also needed to write the mtd block. Place these on the web server
as well.
6. (Only if mtd0 is locked) Use wget to retrieve the files on the MX64:
`wget http://192.168.1.2/mtd-rw.ko`
`insmod mtd-rw.ko i_want_a_brick=1`
and confirm the unlock is set with dmesg
`mtd-rw: mtd0: setting writeable flag`
7. Download the appropriate u-boot image according to step 3. If you
did not need to unlock the mtd0 partition then use dd to write the
file, with caution:
`wget http://192.168.1.2/uboot_mx64`
`dd if=uboot_mx64 of=/dev/mtdblock0`
If you needed to unlock the mtd0 partition using the mtd-rw module,
run these commands instead to install u-boot instead:
`wget http://192.168.1.2/mtd`
`chmod +x mtd`
`wget http://192.168.1.2/uboot_mx64`
`./mtd write uboot_mx64 /dev/mtd0`
8. Once this has successfully completed, power off the device. If you
did not need to install the small u-boot image, proceed to
"OpenWrt Installation". Otherwise proceed to "UBI supporting
bootloader installation".
U-boot installation - MX65 Only:
1. Obtain telnet access to the MX65.
2. Confirm the size of the device's boot(mtd0) partition. In most
cases it should be 0x100000 or larger. If this is the case, please
proceed to use the uboot_mx65 image. If the reported size is
0x80000, please use the uboot_mx65_small image, then follow the
later guide to change to the larger image.
`cat /proc/mtd`
3. Prepare a USB drive formatted to FAT. Download the appropriate
uboot_mx65 to the USB drive from the following location and verify
the SHA512:
https://github.com/clayface/U-boot-MX64-20190430_MX65
3. Once you have telnet access to the MX65, plug in the USB disk and
run the following commands, with caution. The USB disk should
automount but if it does not, you will need to power off and on
again with reset held. Depending on step 2, use the uboot_mx65 or
uboot_mx65_small image accordingly:
`cd /tmp/media/sda1`
`dd if=uboot_mx65 of=/dev/mtdblock0`
4. Once this has successfully completed, power off the device. If you
did not need to install the small u-boot image, proceed to
"OpenWrt Installation". Otherwise proceed to "UBI supporting
bootloader installation".
UBI supporting bootloader installation:
These steps need to be followed if the older u-boot image was
installed, either because the Meraki diagnostic partition scheme used
0x80000 as the mtd0 size, or because you installed the u-boot provided
while OpenWrt support was still under development. If using OpenWrt,
please make a backup before proceeding.
1. Obtain the relevant image from the MX64(A0) or MX65 u-boot repo:
`openwrt-bcm5862x-generic-meraki_XXXX-initramfs-kernel.bin`
2. With the USB drive already inserted, power on the device while
holding the reset button. A white/orange flashing pattern will
occur shortly after power on. Let go of the reset button. The
device is now booting into OpenWrt initramfs stored on the USB
disk.
3. Connect by SSH to 192.168.1.1 and flash the embedded u-boot image,
changing X as appropriate:
`mtd write /root/uboot_mx6X /dev/mtd0`
You do not need to reboot as this image can handle "Kernel-in-UBI"
OpenWrt installation.
4. You can proceed to obtain and flash the appropriate OpenWrt image
at "OpenWrt Installation" Step 3.
5. Reboot will take significantly longer due to Shmoo calibration. In
case the device does not come online after several minute, power-
cycle the device and see if it boots. If you see an orange/white
flashing pattern, this indicates UBI booting was not successful and
you will need to copy a new bcm53xx image to a USB disk before
booting it and attempting to install OpenWrt again - refer to
"OpenWrt Installation" step 1. Do not attempt to reflash u-boot in
this scenario.
OpenWrt Installation:
1. Having obtained an OpenWrt image, please copy the file
`openwrt-bcm53xx-generic-meraki_XXXX-initramfs.bin`
to the base directory of a FAT formatted USB drive using DOS
partition scheme ,where XXXX is mx64, mx64_a0 or mx65 depending on
which device you have.
2. With the USB drive already inserted, power on the device. Boot time
will be longer than usual while Shmoo calibration takes place. A
different white/orange flashing pattern will eventually occur to
indicate device is now booting into OpenWrt initramfs stored on the
USB disk.
3. Ensuring Ethernet is plugged into a LAN port with IP set in the
192.168.1.0/24 subnet excluding 192.168.1.1, use SCP to copy the
sysupgrade file to 192.168.1.1:/tmp, eg:
`scp openwrt-bcm53xx-generic-meraki_XXXX-squashfs.sysupgrade.bin\
192.168.1.1:/tmp`
4. Connect by SSH to 192.168.1.1 and run sysupgrade:
`sysupgrade \
/tmp/openwrt-bcm53xx-generic-meraki_XXXX-squashfs.sysupgrade.bin`
5. OpenWrt should now be installed on the device.
Signed-off-by: Matthew Hagan <mnhagan88@gmail.com>
[ Rebase kernel configuration for 6.6,
fix failsafe by making kmod-eeprom-at24 and kmod-dsa-qca8k built-in,
resolve conflicts,
add LED aliases,
fix eth0 MAC address at probe ]
TODO:
- fix multiple LED colors not applied despite aliases - due to custom
/etc/diag.sh
- fix race condition between preinit and probing of the DSA tree,
causing no network interface available in failsafe mode (in general
case - to allow moving drivers back to modules)
Signed-off-by: Lech Perczak <lech.perczak@gmail.com>
Link: https://github.com/openwrt/openwrt/pull/16634
Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
2021-09-06 22:42:35 +00:00
|
|
|
DEVICE_VENDOR := Cisco Meraki
|
|
|
|
KERNEL = kernel-bin | gzip | fit gzip $$(DTS_DIR)/$$(DEVICE_DTS).dtb
|
|
|
|
KERNEL_INITRAMFS := kernel-bin | gzip | fit gzip $$(DTS_DIR)/$$(DEVICE_DTS).dtb
|
|
|
|
KERNEL_INITRAMFS_SUFFIX := .bin
|
|
|
|
IMAGES := sysupgrade.bin
|
|
|
|
IMAGE/sysupgrade.bin := sysupgrade-tar | append-metadata
|
|
|
|
endef
|
|
|
|
|
|
|
|
define Device/meraki_mx64
|
|
|
|
$(call Device/meraki_mx6x)
|
|
|
|
DEVICE_MODEL := MX64
|
|
|
|
DEVICE_DTS_CONFIG := config@4
|
|
|
|
DEVICE_DTS := bcm958625-meraki-mx64
|
|
|
|
endef
|
|
|
|
TARGET_DEVICES += meraki_mx64
|
|
|
|
|
|
|
|
define Device/meraki_mx64_a0
|
|
|
|
$(call Device/meraki_mx64)
|
|
|
|
DEVICE_VARIANT := A0
|
|
|
|
DEVICE_DTS_CONFIG := config@2
|
|
|
|
DEVICE_DTS := bcm958625-meraki-mx64-a0
|
|
|
|
endef
|
|
|
|
TARGET_DEVICES += meraki_mx64_a0
|
|
|
|
|
|
|
|
define Device/meraki_mx65
|
|
|
|
$(call Device/meraki_mx6x)
|
|
|
|
DEVICE_MODEL := MX65
|
|
|
|
DEVICE_DTS_CONFIG := config@3
|
|
|
|
DEVICE_DTS := bcm958625-meraki-mx65
|
|
|
|
endef
|
|
|
|
TARGET_DEVICES += meraki_mx65
|
|
|
|
|
2015-03-25 17:57:44 +00:00
|
|
|
define Device/netgear
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_VENDOR := NETGEAR
|
2015-03-25 17:57:44 +00:00
|
|
|
IMAGES := chk
|
2016-07-08 14:22:29 +02:00
|
|
|
IMAGE/chk := append-ubi | trx-nand | netgear-chk
|
2015-08-14 13:03:36 +00:00
|
|
|
NETGEAR_REGION := 1
|
2014-09-22 08:04:26 +00:00
|
|
|
endef
|
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/netgear_r6250
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_MODEL := R6250
|
2017-05-22 12:50:53 +02:00
|
|
|
DEVICE_PACKAGES := $(B43) $(USB3_PACKAGES)
|
2015-03-25 17:57:44 +00:00
|
|
|
$(Device/netgear)
|
2015-08-14 13:03:36 +00:00
|
|
|
NETGEAR_BOARD_ID := U12H245T00_NETGEAR
|
2015-03-25 17:57:44 +00:00
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += netgear_r6250
|
2014-10-16 20:48:56 +00:00
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/netgear_r6300-v2
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_MODEL := R6300
|
|
|
|
DEVICE_VARIANT := v2
|
2017-05-22 12:50:53 +02:00
|
|
|
DEVICE_PACKAGES := $(B43) $(USB3_PACKAGES)
|
2015-03-25 17:57:44 +00:00
|
|
|
$(Device/netgear)
|
2015-08-14 13:03:36 +00:00
|
|
|
NETGEAR_BOARD_ID := U12H240T00_NETGEAR
|
2013-07-12 13:46:27 +00:00
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += netgear_r6300-v2
|
2013-07-12 13:46:27 +00:00
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/netgear_r7000
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_MODEL := R7000
|
2016-08-11 11:59:28 +02:00
|
|
|
DEVICE_PACKAGES := $(USB3_PACKAGES)
|
2016-08-11 08:59:54 +02:00
|
|
|
$(Device/netgear)
|
|
|
|
NETGEAR_BOARD_ID := U12H270T00_NETGEAR
|
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += netgear_r7000
|
2016-08-11 08:59:54 +02:00
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/netgear_r7900
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_MODEL := R7900
|
2016-09-13 11:03:02 +02:00
|
|
|
DEVICE_PACKAGES := $(BRCMFMAC_43602A1) $(USB3_PACKAGES)
|
2016-08-11 07:45:19 +02:00
|
|
|
$(Device/netgear)
|
|
|
|
NETGEAR_BOARD_ID := U12H315T30_NETGEAR
|
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += netgear_r7900
|
2016-08-11 07:45:19 +02:00
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/netgear_r8000
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_MODEL := R8000
|
2016-09-13 11:03:02 +02:00
|
|
|
DEVICE_PACKAGES := $(BRCMFMAC_43602A1) $(USB3_PACKAGES)
|
2015-03-25 17:57:44 +00:00
|
|
|
$(Device/netgear)
|
2015-08-14 13:03:36 +00:00
|
|
|
NETGEAR_BOARD_ID := U12H315T00_NETGEAR
|
2014-09-22 08:04:26 +00:00
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += netgear_r8000
|
2013-07-12 13:46:27 +00:00
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/netgear_r8500
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_MODEL := R8500
|
2016-09-13 11:03:02 +02:00
|
|
|
DEVICE_PACKAGES := $(BRCMFMAC_4366B1) $(USB3_PACKAGES)
|
2016-08-11 08:27:57 +02:00
|
|
|
$(Device/netgear)
|
|
|
|
NETGEAR_BOARD_ID := U12H334T00_NETGEAR
|
2020-07-28 20:47:33 +02:00
|
|
|
DEFAULT := n
|
2016-08-11 08:27:57 +02:00
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += netgear_r8500
|
2016-08-11 08:27:57 +02:00
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/smartrg_sr400ac
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_VENDOR := SmartRG
|
|
|
|
DEVICE_MODEL := SR400ac
|
2016-09-13 11:03:02 +02:00
|
|
|
DEVICE_PACKAGES := $(BRCMFMAC_43602A1) $(USB3_PACKAGES)
|
2015-05-13 20:01:15 +00:00
|
|
|
IMAGES := trx
|
2016-07-08 14:22:29 +02:00
|
|
|
IMAGE/trx := append-rootfs | trx-serial
|
2017-10-09 20:50:27 -07:00
|
|
|
KERNEL_INITRAMFS_SUFFIX := .bin
|
|
|
|
KERNEL_INITRAMFS := kernel-bin | append-dtb | lzma-d16
|
2015-05-13 20:01:15 +00:00
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += smartrg_sr400ac
|
2015-05-13 20:01:15 +00:00
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/phicomm_k3
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_VENDOR := PHICOMM
|
|
|
|
DEVICE_MODEL := K3
|
2023-06-22 00:33:16 +02:00
|
|
|
DEVICE_ALT0_VENDOR := Wavlink
|
|
|
|
DEVICE_ALT0_MODEL := QUANTUM DAX
|
|
|
|
DEVICE_ALT1_VENDOR := Wavlink
|
|
|
|
DEVICE_ALT1_MODEL := WL-WN538A8
|
2019-01-19 17:39:19 +00:00
|
|
|
DEVICE_PACKAGES := $(BRCMFMAC_4366C0) $(USB3_PACKAGES)
|
|
|
|
IMAGES := trx
|
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += phicomm_k3
|
2019-01-19 17:39:19 +00:00
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/tenda_ac9
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_VENDOR := Tenda
|
|
|
|
DEVICE_MODEL := AC9
|
2017-05-22 12:50:53 +02:00
|
|
|
DEVICE_PACKAGES := $(B43) $(USB2_PACKAGES)
|
2016-08-15 09:28:54 +02:00
|
|
|
IMAGES := trx
|
|
|
|
IMAGE/trx := append-rootfs | trx-serial
|
|
|
|
endef
|
2020-08-04 16:02:56 +02:00
|
|
|
TARGET_DEVICES += tenda_ac9
|
2016-08-15 09:28:54 +02:00
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/tplink_archer-c5-v2
|
2020-12-19 17:43:52 +01:00
|
|
|
DEVICE_VENDOR := TP-Link
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_MODEL := Archer C5
|
|
|
|
DEVICE_VARIANT := v2
|
2017-05-22 12:50:53 +02:00
|
|
|
DEVICE_PACKAGES := $(B43) $(USB2_PACKAGES)
|
2017-03-11 12:33:53 +01:00
|
|
|
IMAGES := bin
|
|
|
|
IMAGE/bin := append-rootfs | bcm53xx-tplink-safeloader
|
|
|
|
TPLINK_BOARD := ARCHER-C5-V2
|
treewide: mark devices as BROKEN instead of commenting out
This adds the newly introduced BROKEN flag to a bunch of devices
that previously just had TARGET_DEVICES commented out. By this, we
can select them in make menuconfig when BROKEN developer config option
is selected, instead of having to edit the code.
In contrast to DEFAULT := n, this is meant to cover devices that
don't boot or don't compile at all.
ath25: np25g, wpe53g
both disabled during kernel bump 3.18->4.4 without reason given
f89a20a89aeb ("ath25: update kernel from 3.18 to 4.4")
bcm53xx: linksys-ea6300-v1, linksys-ea9200, linksys-ea9500
broken due to insufficient/broken TRX support
55ff15cfd509 ("bcm53xx: disable building Linksys EA6300 V1 image")
cd0f9900a4cd ("bcm53xx: parepare for building more Linksys images")
bcm63xx: tplink-archer-c5-v2, tplink-archer-c9-v1
disabled when kernel 5.4 support was added, probably broken
50c6938b95a0 ("bcm53xx: add v5.4 support")
Signed-off-by: Petr Štetiar <ynezz@true.cz>
[limit to subset of devices, use BROKEN, adjust commit message/title]
Signed-off-by: Adrian Schmutzler <freifunk@adrianschmutzler.de>
2020-07-28 20:47:35 +02:00
|
|
|
BROKEN := y
|
2017-03-11 12:33:53 +01:00
|
|
|
endef
|
2021-07-19 14:21:44 +10:00
|
|
|
#TARGET_DEVICES += tplink_archer-c5-v2
|
2017-03-11 12:33:53 +01:00
|
|
|
|
2020-08-04 16:02:56 +02:00
|
|
|
define Device/tplink_archer-c9-v1
|
2020-12-19 17:43:52 +01:00
|
|
|
DEVICE_VENDOR := TP-Link
|
2019-07-11 00:01:32 +02:00
|
|
|
DEVICE_MODEL := Archer C9
|
|
|
|
DEVICE_VARIANT := v1
|
2016-11-19 07:58:26 +01:00
|
|
|
DEVICE_PACKAGES := $(USB3_PACKAGES)
|
|
|
|
IMAGES := bin
|
|
|
|
IMAGE/bin := append-rootfs | bcm53xx-tplink-safeloader
|
|
|
|
TPLINK_BOARD := ARCHERC9
|
treewide: mark devices as BROKEN instead of commenting out
This adds the newly introduced BROKEN flag to a bunch of devices
that previously just had TARGET_DEVICES commented out. By this, we
can select them in make menuconfig when BROKEN developer config option
is selected, instead of having to edit the code.
In contrast to DEFAULT := n, this is meant to cover devices that
don't boot or don't compile at all.
ath25: np25g, wpe53g
both disabled during kernel bump 3.18->4.4 without reason given
f89a20a89aeb ("ath25: update kernel from 3.18 to 4.4")
bcm53xx: linksys-ea6300-v1, linksys-ea9200, linksys-ea9500
broken due to insufficient/broken TRX support
55ff15cfd509 ("bcm53xx: disable building Linksys EA6300 V1 image")
cd0f9900a4cd ("bcm53xx: parepare for building more Linksys images")
bcm63xx: tplink-archer-c5-v2, tplink-archer-c9-v1
disabled when kernel 5.4 support was added, probably broken
50c6938b95a0 ("bcm53xx: add v5.4 support")
Signed-off-by: Petr Štetiar <ynezz@true.cz>
[limit to subset of devices, use BROKEN, adjust commit message/title]
Signed-off-by: Adrian Schmutzler <freifunk@adrianschmutzler.de>
2020-07-28 20:47:35 +02:00
|
|
|
BROKEN := y
|
2016-11-19 07:58:26 +01:00
|
|
|
endef
|
2021-07-19 14:21:44 +10:00
|
|
|
#TARGET_DEVICES += tplink_archer-c9-v1
|
2016-11-19 07:58:26 +01:00
|
|
|
|
2013-07-12 13:46:27 +00:00
|
|
|
$(eval $(call BuildImage))
|