2016-07-20 13:44:50 +00:00
|
|
|
#
|
|
|
|
# This is free software, licensed under the GNU General Public License v2.
|
|
|
|
# See /LICENSE for more information.
|
|
|
|
#
|
|
|
|
include $(TOPDIR)/rules.mk
|
|
|
|
include $(INCLUDE_DIR)/image.mk
|
2016-07-20 13:44:51 +00:00
|
|
|
include $(INCLUDE_DIR)/host.mk
|
2016-07-20 13:44:50 +00:00
|
|
|
|
2016-07-22 09:12:34 +00:00
|
|
|
DEVICE_VARS += DEVICE_PROFILE IMAGE_SIZE DTB_SIZE
|
2016-07-20 13:44:50 +00:00
|
|
|
|
|
|
|
define Device/Default
|
2016-07-21 13:09:55 +00:00
|
|
|
PROFILES := Default
|
2016-07-20 13:44:51 +00:00
|
|
|
KERNEL_DEPENDS = $$(wildcard ../dts/$$(DEVICE_DTS).dts)
|
|
|
|
DEVICE_PROFILE :=
|
|
|
|
DEVICE_DTS :=
|
|
|
|
KERNEL_ENTRY := 0x00000000
|
|
|
|
KERNEL_LOADADDR := 0x00000000
|
2016-07-22 09:12:34 +00:00
|
|
|
DEVICE_DTS_DIR := ../dts
|
2016-07-20 13:44:51 +00:00
|
|
|
endef
|
|
|
|
|
|
|
|
define Build/dtb
|
|
|
|
$(call Image/BuildDTB,../dts/$(DEVICE_DTS).dts,$@.dtb,,--space $(DTB_SIZE))
|
|
|
|
endef
|
|
|
|
|
|
|
|
ifeq ($(SUBTARGET),nand)
|
|
|
|
|
|
|
|
define Image/cpiogz
|
|
|
|
( cd $(TARGET_DIR); find . | cpio -o -H newc | gzip -9n >$(KDIR_TMP)/$(IMG_PREFIX)-rootfs.cpio.gz )
|
|
|
|
endef
|
|
|
|
|
|
|
|
define Build/copy-file
|
|
|
|
cat "$(1)" > "$@"
|
|
|
|
endef
|
|
|
|
|
|
|
|
define Build/MerakiAdd-dtb
|
|
|
|
$(call Image/BuildDTB,../dts/$(DEVICE_DTS).dts,$@.dtb)
|
|
|
|
( \
|
|
|
|
dd if=$@.dtb bs=$(DTB_SIZE) conv=sync; \
|
|
|
|
dd if=$@ bs=$(BLOCKSIZE) conv=sync; \
|
|
|
|
) > $@.new
|
|
|
|
@mv $@.new $@
|
2016-07-20 13:44:50 +00:00
|
|
|
endef
|
2016-07-20 13:44:51 +00:00
|
|
|
|
|
|
|
define Build/MerakiAdd-initramfs
|
|
|
|
$(call Image/cpiogz)
|
|
|
|
|
|
|
|
-$(STAGING_DIR_HOST)/bin/mkimage -A $(LINUX_KARCH) -O linux -T ramdisk \
|
|
|
|
-C gzip -n "$(PROFILE) rootfs" \
|
|
|
|
-d $(KDIR_TMP)/$(IMG_PREFIX)-rootfs.cpio.gz \
|
|
|
|
$(KDIR_TMP)/$(IMG_PREFIX)-uramdisk.image.gz
|
|
|
|
|
|
|
|
( \
|
|
|
|
dd if=$@ bs=1k conv=sync; \
|
|
|
|
dd if=$(KDIR_TMP)/$(IMG_PREFIX)-uramdisk.image.gz bs=$(BLOCKSIZE) conv=sync; \
|
|
|
|
) > $@.new
|
|
|
|
@mv $@.new $@
|
|
|
|
endef
|
|
|
|
|
|
|
|
define Build/MerakiNAND
|
|
|
|
-$(STAGING_DIR_HOST)/bin/mkmerakifw \
|
|
|
|
-B $(DEVICE_PROFILE) -s \
|
|
|
|
-i $@ \
|
|
|
|
-o $@.new
|
|
|
|
@cp $@.new $@
|
|
|
|
endef
|
|
|
|
|
|
|
|
define Device/mr24
|
|
|
|
DEVICE_TITLE := Cisco Meraki MR24
|
|
|
|
DEVICE_PACKAGES := kmod-spi-gpio kmod-ath9k wpad-mini
|
|
|
|
DEVICE_PROFILE := MR24
|
|
|
|
DEVICE_DTS := MR24
|
|
|
|
BLOCKSIZE := 64512
|
|
|
|
IMAGES := sysupgrade.tar
|
|
|
|
DTB_SIZE := 64512
|
2016-09-02 20:35:03 +00:00
|
|
|
KERNEL_SIZE := 1984k
|
2016-07-20 13:44:51 +00:00
|
|
|
IMAGE_SIZE := 8191k
|
|
|
|
KERNEL := kernel-bin | lzma | uImage lzma | MerakiAdd-dtb | MerakiNAND
|
2016-09-02 20:35:03 +00:00
|
|
|
KERNEL_INITRAMFS := copy-file $(KDIR)/vmlinux | lzma | uImage lzma | \
|
|
|
|
check-size $$(KERNEL_SIZE) | \
|
|
|
|
MerakiAdd-dtb | pad-to 2047k | MerakiAdd-initramfs | \
|
|
|
|
MerakiNAND
|
2016-07-29 13:05:51 +00:00
|
|
|
IMAGE/sysupgrade.tar := sysupgrade-tar
|
2016-07-20 13:44:51 +00:00
|
|
|
endef
|
|
|
|
TARGET_DEVICES += mr24
|
2016-07-20 13:44:50 +00:00
|
|
|
|
apm821xx: add support for the Netgear Centria N900 WNDR4700/WNDR4720
This patch adds support for Netgear Centria N900 WNDR4700/WNDR4720
hardware highlights:
CPU: AMCC PowerPC APM82181 Rev. E at 1000 MHz (PLB=166, OPB=83, EBC=83 MHz)
Security support, Boot ROM Location NAND wo/ECC 2k page (8 bits)
32 kB I-Cache 32 kB D-Cache, 256 kB L2-Cache, 32 kB OnChip Memory
Board: AMCC APM82181 Evaluation Board, PCIE0/SATA1, 1*USB OTG
DRAM: 256 MB (ECC not enabled, 500 Mb/s, 32-bit, CL3)
NAND: 128 MiB (SLC, erase size: 128 KiB, page size: 2048, OOB size: 64)
ETH: Atheros AR8327N Gigabit Switch (4 x LAN, 1 x WAN)
USB: 2 x 3.0 (Renesas uPD720202K8-711-BAA-A, firmware not included)
SATA: 1 x SATA-II 3.5" Hard Drive Bay for HDDs (DesignWare SATA).
WLAN1: Atheros AR9380 5GHz 802.11an 3:3x3
WLAN2: Atheros AR9581 2.4GHz 802.11bgn 3:3x3
SDCARD: GL827L SD/MMC/MS Flash Card Reader (on internal dwc2 USB 2.0 host)
I2C: GMT G781 (i2c-0 @ 0x4d - lm90 compatible temperature sensor)
TC654 (i2c-0 @ 0x1b - Dual PWM fan Speed controller)
WARNING: The serial port needs a TTL/RS-232 v3.3 level converter!
INFO: Since this device only has a NAND chip. I opted for going with
root.squashfs in a UBI volume. There's no squashfs/jffs2 image.
This target produces three images.
a. netgear factory image
This image can be used to flash the Netgear WNDR4700 via the
firmware recovery mechanism and the web admin site.
The bootloader can be instructed to do a firmware recovery via the
# fw_recovery
command. It will start a tftp server and listen on 192.168.1.1
(the ipaddr variable in u-boot) for incoming, binary tftp clients.
The firmware recovery mechanism is also started if any of the flash
content which contains the kernel, device-tree definitions or the
(fake)rootfs fails to verify or load.
b. sysupgrade.tar image for sysupgrade
An sysupgrade will replace the entire current LEDE installation
with a newer version. This does include the kernel and the ubi rootfs
partition. The configuration can be carried over automatically as well
if desired.
simply copy the sysupgrade.tar to a the WNDR4700 running LEDE and run:
root@lede:~# sysupgrade sysupgrade.tar
and let it reboot.
Note: The devicetree flash area is NOT updated. Until the devicetree
definition is stable, this can lead to all sorts of hardware
detection problems! So make sure, if you experience issues: try
the fw_recovery. If you are unsure whenever this affects you:
test if you can reproduce your issue with the initramfs method.
As it will always have up-to-date device-tree definitions.
c. initramfs image for TFTP (for development and testing)
To use the initramfs method, follow the following steps:
1) Move the "lede-apm821xx-netgear-WNDR4700-initramfs-kernel.bin"
file to to the root directory of your TFTP server.
2) rename it to wndr4700.bin
3) On the WNDR4700 - Hit Enter during u-boot and insert:
# tftp 400000 wndr4700.bin; run addtty; bootm 400000 -
This will boot the LEDE image.
Note: The default tftp server is 192.168.1.7, if you want to change it:
# setenv serverip 192.168.8.7;
Note2: The default address for the WNDR4700 is 192.168.1.1:
# setenv ipaddr 192.168.8.8;
Note: Connect you tftp server on the last LAN port (not the WAN)
Note: The firmware for the USB 3.0 Host chip is not included anymore.
Therefore the two USB 3.0 ports will not work without the
uPD7070x-firmware package installed.
Signed-off-by: Christian Lamparter <chunkeey@gmail.com>
2016-07-20 13:44:57 +00:00
|
|
|
define Build/create-uImage-dtb
|
|
|
|
# flat_dt target expect FIT image - which WNDR4700's uboot doesn't support
|
|
|
|
-$(STAGING_DIR_HOST)/bin/mkimage -A $(LINUX_KARCH) \
|
|
|
|
-O linux -T kernel -C none \
|
|
|
|
-n '$(call toupper,$(LINUX_KARCH)) LEDE Linux-$(LINUX_VERSION)' \
|
2016-07-30 13:43:35 +00:00
|
|
|
-d $(IMAGE_KERNEL).dtb $@.new
|
apm821xx: add support for the Netgear Centria N900 WNDR4700/WNDR4720
This patch adds support for Netgear Centria N900 WNDR4700/WNDR4720
hardware highlights:
CPU: AMCC PowerPC APM82181 Rev. E at 1000 MHz (PLB=166, OPB=83, EBC=83 MHz)
Security support, Boot ROM Location NAND wo/ECC 2k page (8 bits)
32 kB I-Cache 32 kB D-Cache, 256 kB L2-Cache, 32 kB OnChip Memory
Board: AMCC APM82181 Evaluation Board, PCIE0/SATA1, 1*USB OTG
DRAM: 256 MB (ECC not enabled, 500 Mb/s, 32-bit, CL3)
NAND: 128 MiB (SLC, erase size: 128 KiB, page size: 2048, OOB size: 64)
ETH: Atheros AR8327N Gigabit Switch (4 x LAN, 1 x WAN)
USB: 2 x 3.0 (Renesas uPD720202K8-711-BAA-A, firmware not included)
SATA: 1 x SATA-II 3.5" Hard Drive Bay for HDDs (DesignWare SATA).
WLAN1: Atheros AR9380 5GHz 802.11an 3:3x3
WLAN2: Atheros AR9581 2.4GHz 802.11bgn 3:3x3
SDCARD: GL827L SD/MMC/MS Flash Card Reader (on internal dwc2 USB 2.0 host)
I2C: GMT G781 (i2c-0 @ 0x4d - lm90 compatible temperature sensor)
TC654 (i2c-0 @ 0x1b - Dual PWM fan Speed controller)
WARNING: The serial port needs a TTL/RS-232 v3.3 level converter!
INFO: Since this device only has a NAND chip. I opted for going with
root.squashfs in a UBI volume. There's no squashfs/jffs2 image.
This target produces three images.
a. netgear factory image
This image can be used to flash the Netgear WNDR4700 via the
firmware recovery mechanism and the web admin site.
The bootloader can be instructed to do a firmware recovery via the
# fw_recovery
command. It will start a tftp server and listen on 192.168.1.1
(the ipaddr variable in u-boot) for incoming, binary tftp clients.
The firmware recovery mechanism is also started if any of the flash
content which contains the kernel, device-tree definitions or the
(fake)rootfs fails to verify or load.
b. sysupgrade.tar image for sysupgrade
An sysupgrade will replace the entire current LEDE installation
with a newer version. This does include the kernel and the ubi rootfs
partition. The configuration can be carried over automatically as well
if desired.
simply copy the sysupgrade.tar to a the WNDR4700 running LEDE and run:
root@lede:~# sysupgrade sysupgrade.tar
and let it reboot.
Note: The devicetree flash area is NOT updated. Until the devicetree
definition is stable, this can lead to all sorts of hardware
detection problems! So make sure, if you experience issues: try
the fw_recovery. If you are unsure whenever this affects you:
test if you can reproduce your issue with the initramfs method.
As it will always have up-to-date device-tree definitions.
c. initramfs image for TFTP (for development and testing)
To use the initramfs method, follow the following steps:
1) Move the "lede-apm821xx-netgear-WNDR4700-initramfs-kernel.bin"
file to to the root directory of your TFTP server.
2) rename it to wndr4700.bin
3) On the WNDR4700 - Hit Enter during u-boot and insert:
# tftp 400000 wndr4700.bin; run addtty; bootm 400000 -
This will boot the LEDE image.
Note: The default tftp server is 192.168.1.7, if you want to change it:
# setenv serverip 192.168.8.7;
Note2: The default address for the WNDR4700 is 192.168.1.1:
# setenv ipaddr 192.168.8.8;
Note: Connect you tftp server on the last LAN port (not the WAN)
Note: The firmware for the USB 3.0 Host chip is not included anymore.
Therefore the two USB 3.0 ports will not work without the
uPD7070x-firmware package installed.
Signed-off-by: Christian Lamparter <chunkeey@gmail.com>
2016-07-20 13:44:57 +00:00
|
|
|
@mv $@.new $@
|
|
|
|
endef
|
|
|
|
|
|
|
|
define Build/append-fakerootfs
|
|
|
|
rm -rf $@.fakerootsquashfs $@.fakefs
|
|
|
|
|
|
|
|
# append a fake/empty rootfs to fool netgear's uboot
|
|
|
|
# CHECK_DNI_FIRMWARE_ROOTFS_INTEGRITY in do_chk_dniimg()
|
|
|
|
dd if=/dev/zero of=$@.fakerd bs=16 count=1 conv=sync
|
|
|
|
|
|
|
|
-$(STAGING_DIR_HOST)/bin/mkimage \
|
|
|
|
-A $(LINUX_KARCH) -O linux -T filesystem -C none \
|
|
|
|
-a 0x00000000 -e 0x00000000 \
|
|
|
|
-n '$(DEVICE_PROFILE) fakerootfs' \
|
|
|
|
-d $@.fakerd $@.fakefs
|
|
|
|
|
|
|
|
cat $@.fakefs >> $@
|
|
|
|
rm -rf $@.fakerootsquashfs $@.fakefs
|
|
|
|
endef
|
|
|
|
|
|
|
|
define Build/wndr4700-specialImage
|
|
|
|
rm -rf $@.fakerd $@.new
|
|
|
|
|
|
|
|
dd if=/dev/zero of=$@.fakerd bs=32 count=1 conv=sync
|
|
|
|
|
|
|
|
# Netgear used an old uboot that doesn't have FIT support.
|
|
|
|
# So we are stuck with either a full ext2/4 fs in a initrd.
|
|
|
|
# ... or we try to make the "multi" image approach to work
|
|
|
|
# for us.
|
|
|
|
#
|
|
|
|
# Sadly, the "multi" image has to consists of three
|
|
|
|
# "fixed" parts in the following "fixed" order:
|
|
|
|
# 1. The kernel which is in $@
|
|
|
|
# 2. The (fake) initrd which is in $@.fakerd
|
|
|
|
# 3. The device tree binary which is in $@.dtb
|
|
|
|
#
|
|
|
|
# Now, given that we use the function for the kernel which
|
|
|
|
# already has a initramfs image inside, we still have to
|
|
|
|
# add a "fake" initrd (which a mkimage header) in the second
|
|
|
|
# part of the legacy multi image. Since we need to put the
|
|
|
|
# device tree stuff into part 3.
|
|
|
|
|
|
|
|
-$(STAGING_DIR_HOST)/bin/mkimage -A $(LINUX_KARCH) -O linux -T multi \
|
|
|
|
-C $(1) -a $(KERNEL_LOADADDR) -e $(KERNEL_ENTRY) \
|
|
|
|
-n '$(DEVICE_PROFILE) initramfs' -d $@:$@.fakerd:$@.dtb $@.new
|
|
|
|
mv $@.new $@
|
|
|
|
rm -rf $@.fakerd
|
|
|
|
endef
|
|
|
|
|
|
|
|
define Device/WNDR4700
|
|
|
|
DEVICE_TITLE := Netgear Centria N900 WNDR4700/WNDR4720
|
|
|
|
DEVICE_PACKAGES := badblocks block-mount e2fsprogs \
|
|
|
|
kmod-ath9k kmod-dm kmod-fs-ext4 kmod-fs-vfat kmod-ledtrig-usbdev \
|
|
|
|
kmod-md-mod kmod-nls-cp437 kmod-nls-iso8859-1 kmod-nls-iso8859-15 \
|
|
|
|
kmod-nls-utf8 kmod-usb3 kmod-usb-dwc2 kmod-usb-storage \
|
|
|
|
partx-utils swconfig wpad-mini
|
|
|
|
DEVICE_NAME := wndr4700
|
|
|
|
DEVICE_PROFILE := wndr4700
|
|
|
|
DEVICE_DTS := wndr4700
|
|
|
|
PAGESIZE := 2048
|
|
|
|
SUBPAGESIZE := 512
|
|
|
|
BLOCKSIZE := 131072
|
|
|
|
DTB_SIZE := 131008
|
|
|
|
IMAGE_SIZE:=25559040
|
|
|
|
IMAGES := factory.img sysupgrade.tar
|
|
|
|
KERNEL_SIZE := 1920k
|
2016-07-30 13:43:35 +00:00
|
|
|
KERNEL := dtb | kernel-bin | lzma | uImage lzma | pad-offset $$(BLOCKSIZE) 64 | append-fakerootfs
|
apm821xx: add support for the Netgear Centria N900 WNDR4700/WNDR4720
This patch adds support for Netgear Centria N900 WNDR4700/WNDR4720
hardware highlights:
CPU: AMCC PowerPC APM82181 Rev. E at 1000 MHz (PLB=166, OPB=83, EBC=83 MHz)
Security support, Boot ROM Location NAND wo/ECC 2k page (8 bits)
32 kB I-Cache 32 kB D-Cache, 256 kB L2-Cache, 32 kB OnChip Memory
Board: AMCC APM82181 Evaluation Board, PCIE0/SATA1, 1*USB OTG
DRAM: 256 MB (ECC not enabled, 500 Mb/s, 32-bit, CL3)
NAND: 128 MiB (SLC, erase size: 128 KiB, page size: 2048, OOB size: 64)
ETH: Atheros AR8327N Gigabit Switch (4 x LAN, 1 x WAN)
USB: 2 x 3.0 (Renesas uPD720202K8-711-BAA-A, firmware not included)
SATA: 1 x SATA-II 3.5" Hard Drive Bay for HDDs (DesignWare SATA).
WLAN1: Atheros AR9380 5GHz 802.11an 3:3x3
WLAN2: Atheros AR9581 2.4GHz 802.11bgn 3:3x3
SDCARD: GL827L SD/MMC/MS Flash Card Reader (on internal dwc2 USB 2.0 host)
I2C: GMT G781 (i2c-0 @ 0x4d - lm90 compatible temperature sensor)
TC654 (i2c-0 @ 0x1b - Dual PWM fan Speed controller)
WARNING: The serial port needs a TTL/RS-232 v3.3 level converter!
INFO: Since this device only has a NAND chip. I opted for going with
root.squashfs in a UBI volume. There's no squashfs/jffs2 image.
This target produces three images.
a. netgear factory image
This image can be used to flash the Netgear WNDR4700 via the
firmware recovery mechanism and the web admin site.
The bootloader can be instructed to do a firmware recovery via the
# fw_recovery
command. It will start a tftp server and listen on 192.168.1.1
(the ipaddr variable in u-boot) for incoming, binary tftp clients.
The firmware recovery mechanism is also started if any of the flash
content which contains the kernel, device-tree definitions or the
(fake)rootfs fails to verify or load.
b. sysupgrade.tar image for sysupgrade
An sysupgrade will replace the entire current LEDE installation
with a newer version. This does include the kernel and the ubi rootfs
partition. The configuration can be carried over automatically as well
if desired.
simply copy the sysupgrade.tar to a the WNDR4700 running LEDE and run:
root@lede:~# sysupgrade sysupgrade.tar
and let it reboot.
Note: The devicetree flash area is NOT updated. Until the devicetree
definition is stable, this can lead to all sorts of hardware
detection problems! So make sure, if you experience issues: try
the fw_recovery. If you are unsure whenever this affects you:
test if you can reproduce your issue with the initramfs method.
As it will always have up-to-date device-tree definitions.
c. initramfs image for TFTP (for development and testing)
To use the initramfs method, follow the following steps:
1) Move the "lede-apm821xx-netgear-WNDR4700-initramfs-kernel.bin"
file to to the root directory of your TFTP server.
2) rename it to wndr4700.bin
3) On the WNDR4700 - Hit Enter during u-boot and insert:
# tftp 400000 wndr4700.bin; run addtty; bootm 400000 -
This will boot the LEDE image.
Note: The default tftp server is 192.168.1.7, if you want to change it:
# setenv serverip 192.168.8.7;
Note2: The default address for the WNDR4700 is 192.168.1.1:
# setenv ipaddr 192.168.8.8;
Note: Connect you tftp server on the last LAN port (not the WAN)
Note: The firmware for the USB 3.0 Host chip is not included anymore.
Therefore the two USB 3.0 ports will not work without the
uPD7070x-firmware package installed.
Signed-off-by: Christian Lamparter <chunkeey@gmail.com>
2016-07-20 13:44:57 +00:00
|
|
|
KERNEL_INITRAMFS := kernel-bin | gzip | dtb | wndr4700-specialImage gzip
|
2016-07-30 13:43:35 +00:00
|
|
|
IMAGE/factory.img := create-uImage-dtb | append-kernel | pad-to 2M | append-ubi | \
|
apm821xx: add support for the Netgear Centria N900 WNDR4700/WNDR4720
This patch adds support for Netgear Centria N900 WNDR4700/WNDR4720
hardware highlights:
CPU: AMCC PowerPC APM82181 Rev. E at 1000 MHz (PLB=166, OPB=83, EBC=83 MHz)
Security support, Boot ROM Location NAND wo/ECC 2k page (8 bits)
32 kB I-Cache 32 kB D-Cache, 256 kB L2-Cache, 32 kB OnChip Memory
Board: AMCC APM82181 Evaluation Board, PCIE0/SATA1, 1*USB OTG
DRAM: 256 MB (ECC not enabled, 500 Mb/s, 32-bit, CL3)
NAND: 128 MiB (SLC, erase size: 128 KiB, page size: 2048, OOB size: 64)
ETH: Atheros AR8327N Gigabit Switch (4 x LAN, 1 x WAN)
USB: 2 x 3.0 (Renesas uPD720202K8-711-BAA-A, firmware not included)
SATA: 1 x SATA-II 3.5" Hard Drive Bay for HDDs (DesignWare SATA).
WLAN1: Atheros AR9380 5GHz 802.11an 3:3x3
WLAN2: Atheros AR9581 2.4GHz 802.11bgn 3:3x3
SDCARD: GL827L SD/MMC/MS Flash Card Reader (on internal dwc2 USB 2.0 host)
I2C: GMT G781 (i2c-0 @ 0x4d - lm90 compatible temperature sensor)
TC654 (i2c-0 @ 0x1b - Dual PWM fan Speed controller)
WARNING: The serial port needs a TTL/RS-232 v3.3 level converter!
INFO: Since this device only has a NAND chip. I opted for going with
root.squashfs in a UBI volume. There's no squashfs/jffs2 image.
This target produces three images.
a. netgear factory image
This image can be used to flash the Netgear WNDR4700 via the
firmware recovery mechanism and the web admin site.
The bootloader can be instructed to do a firmware recovery via the
# fw_recovery
command. It will start a tftp server and listen on 192.168.1.1
(the ipaddr variable in u-boot) for incoming, binary tftp clients.
The firmware recovery mechanism is also started if any of the flash
content which contains the kernel, device-tree definitions or the
(fake)rootfs fails to verify or load.
b. sysupgrade.tar image for sysupgrade
An sysupgrade will replace the entire current LEDE installation
with a newer version. This does include the kernel and the ubi rootfs
partition. The configuration can be carried over automatically as well
if desired.
simply copy the sysupgrade.tar to a the WNDR4700 running LEDE and run:
root@lede:~# sysupgrade sysupgrade.tar
and let it reboot.
Note: The devicetree flash area is NOT updated. Until the devicetree
definition is stable, this can lead to all sorts of hardware
detection problems! So make sure, if you experience issues: try
the fw_recovery. If you are unsure whenever this affects you:
test if you can reproduce your issue with the initramfs method.
As it will always have up-to-date device-tree definitions.
c. initramfs image for TFTP (for development and testing)
To use the initramfs method, follow the following steps:
1) Move the "lede-apm821xx-netgear-WNDR4700-initramfs-kernel.bin"
file to to the root directory of your TFTP server.
2) rename it to wndr4700.bin
3) On the WNDR4700 - Hit Enter during u-boot and insert:
# tftp 400000 wndr4700.bin; run addtty; bootm 400000 -
This will boot the LEDE image.
Note: The default tftp server is 192.168.1.7, if you want to change it:
# setenv serverip 192.168.8.7;
Note2: The default address for the WNDR4700 is 192.168.1.1:
# setenv ipaddr 192.168.8.8;
Note: Connect you tftp server on the last LAN port (not the WAN)
Note: The firmware for the USB 3.0 Host chip is not included anymore.
Therefore the two USB 3.0 ports will not work without the
uPD7070x-firmware package installed.
Signed-off-by: Christian Lamparter <chunkeey@gmail.com>
2016-07-20 13:44:57 +00:00
|
|
|
netgear-dni | check-size $$$$(IMAGE_SIZE)
|
2016-07-29 13:05:51 +00:00
|
|
|
IMAGE/sysupgrade.tar := sysupgrade-tar
|
apm821xx: add support for the Netgear Centria N900 WNDR4700/WNDR4720
This patch adds support for Netgear Centria N900 WNDR4700/WNDR4720
hardware highlights:
CPU: AMCC PowerPC APM82181 Rev. E at 1000 MHz (PLB=166, OPB=83, EBC=83 MHz)
Security support, Boot ROM Location NAND wo/ECC 2k page (8 bits)
32 kB I-Cache 32 kB D-Cache, 256 kB L2-Cache, 32 kB OnChip Memory
Board: AMCC APM82181 Evaluation Board, PCIE0/SATA1, 1*USB OTG
DRAM: 256 MB (ECC not enabled, 500 Mb/s, 32-bit, CL3)
NAND: 128 MiB (SLC, erase size: 128 KiB, page size: 2048, OOB size: 64)
ETH: Atheros AR8327N Gigabit Switch (4 x LAN, 1 x WAN)
USB: 2 x 3.0 (Renesas uPD720202K8-711-BAA-A, firmware not included)
SATA: 1 x SATA-II 3.5" Hard Drive Bay for HDDs (DesignWare SATA).
WLAN1: Atheros AR9380 5GHz 802.11an 3:3x3
WLAN2: Atheros AR9581 2.4GHz 802.11bgn 3:3x3
SDCARD: GL827L SD/MMC/MS Flash Card Reader (on internal dwc2 USB 2.0 host)
I2C: GMT G781 (i2c-0 @ 0x4d - lm90 compatible temperature sensor)
TC654 (i2c-0 @ 0x1b - Dual PWM fan Speed controller)
WARNING: The serial port needs a TTL/RS-232 v3.3 level converter!
INFO: Since this device only has a NAND chip. I opted for going with
root.squashfs in a UBI volume. There's no squashfs/jffs2 image.
This target produces three images.
a. netgear factory image
This image can be used to flash the Netgear WNDR4700 via the
firmware recovery mechanism and the web admin site.
The bootloader can be instructed to do a firmware recovery via the
# fw_recovery
command. It will start a tftp server and listen on 192.168.1.1
(the ipaddr variable in u-boot) for incoming, binary tftp clients.
The firmware recovery mechanism is also started if any of the flash
content which contains the kernel, device-tree definitions or the
(fake)rootfs fails to verify or load.
b. sysupgrade.tar image for sysupgrade
An sysupgrade will replace the entire current LEDE installation
with a newer version. This does include the kernel and the ubi rootfs
partition. The configuration can be carried over automatically as well
if desired.
simply copy the sysupgrade.tar to a the WNDR4700 running LEDE and run:
root@lede:~# sysupgrade sysupgrade.tar
and let it reboot.
Note: The devicetree flash area is NOT updated. Until the devicetree
definition is stable, this can lead to all sorts of hardware
detection problems! So make sure, if you experience issues: try
the fw_recovery. If you are unsure whenever this affects you:
test if you can reproduce your issue with the initramfs method.
As it will always have up-to-date device-tree definitions.
c. initramfs image for TFTP (for development and testing)
To use the initramfs method, follow the following steps:
1) Move the "lede-apm821xx-netgear-WNDR4700-initramfs-kernel.bin"
file to to the root directory of your TFTP server.
2) rename it to wndr4700.bin
3) On the WNDR4700 - Hit Enter during u-boot and insert:
# tftp 400000 wndr4700.bin; run addtty; bootm 400000 -
This will boot the LEDE image.
Note: The default tftp server is 192.168.1.7, if you want to change it:
# setenv serverip 192.168.8.7;
Note2: The default address for the WNDR4700 is 192.168.1.1:
# setenv ipaddr 192.168.8.8;
Note: Connect you tftp server on the last LAN port (not the WAN)
Note: The firmware for the USB 3.0 Host chip is not included anymore.
Therefore the two USB 3.0 ports will not work without the
uPD7070x-firmware package installed.
Signed-off-by: Christian Lamparter <chunkeey@gmail.com>
2016-07-20 13:44:57 +00:00
|
|
|
NETGEAR_BOARD_ID := WNDR4700
|
|
|
|
NETGEAR_HW_ID := 29763875+128+256
|
|
|
|
endef
|
|
|
|
TARGET_DEVICES += WNDR4700
|
|
|
|
|
2016-07-20 13:44:54 +00:00
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(SUBTARGET),sata)
|
|
|
|
|
|
|
|
### Image scripts for the WD My Book Live Series ###
|
|
|
|
define Build/boot-script
|
|
|
|
$(STAGING_DIR_HOST)/bin/mkimage -A powerpc -T script -C none -n "$(PROFILE) Boot Script" \
|
|
|
|
-d mbl_boot.scr \
|
|
|
|
$@.scr
|
|
|
|
endef
|
|
|
|
|
|
|
|
define Build/boot-img
|
|
|
|
$(RM) -rf $@.bootdir
|
|
|
|
mkdir -p $@.bootdir/boot
|
|
|
|
|
|
|
|
$(CP) $@.scr $@.bootdir/boot/boot.scr
|
2016-07-30 13:43:35 +00:00
|
|
|
$(CP) $(IMAGE_KERNEL).dtb $@.bootdir/boot/$(DEVICE_DTB)
|
2016-07-30 12:19:11 +00:00
|
|
|
$(CP) $(IMAGE_KERNEL) $@.bootdir/boot/uImage
|
2016-07-20 13:44:54 +00:00
|
|
|
|
2016-09-08 18:14:42 +00:00
|
|
|
genext2fs --block-size $(BLOCKSIZE:%k=%Ki) --size-in-blocks $$((1024 * $(BOOT_SIZE))) --root $@.bootdir $@.boot
|
2016-07-20 13:44:54 +00:00
|
|
|
|
|
|
|
# convert it to revision 1 - needed for u-boot ext2load
|
|
|
|
$(STAGING_DIR_HOST)/bin/tune2fs -O filetype $@.boot
|
|
|
|
$(STAGING_DIR_HOST)/bin/e2fsck -pDf $@.boot > /dev/null
|
|
|
|
endef
|
|
|
|
|
|
|
|
define Build/hdd-img
|
2016-07-30 12:19:11 +00:00
|
|
|
./mbl_gen_hdd_img.sh $@ $@.boot $(IMAGE_ROOTFS)
|
2016-07-20 13:44:54 +00:00
|
|
|
$(if $(CONFIG_TARGET_IMAGES_GZIP),gzip -9n -c $@ > $(BIN_DIR)/$(notdir $@).gz)
|
|
|
|
endef
|
|
|
|
|
|
|
|
define Build/uRamdisk
|
2016-07-21 17:36:13 +00:00
|
|
|
$(STAGING_DIR_HOST)/bin/mkimage \
|
|
|
|
-A powerpc -T ramdisk -C gzip \
|
|
|
|
-n "$(DEVICE_NAME) rootfs" \
|
|
|
|
-d $@ $@.new
|
|
|
|
mv $@.new $@
|
2016-07-20 13:44:54 +00:00
|
|
|
endef
|
|
|
|
|
|
|
|
define Build/recovery-tar
|
|
|
|
sh ./mbl_gen_recovery_tar.sh \
|
|
|
|
--profile $(DEVICE_PROFILE) \
|
2016-07-30 12:19:11 +00:00
|
|
|
--dtb $(IMAGE_KERNEL).dtb \
|
2016-07-20 13:44:54 +00:00
|
|
|
--dtbname $(DEVICE_DTB) \
|
2016-07-30 12:19:11 +00:00
|
|
|
--kernel $(IMAGE_KERNEL) \
|
2016-07-21 17:36:13 +00:00
|
|
|
--rootfs $@ \
|
2016-07-20 13:44:54 +00:00
|
|
|
$@
|
|
|
|
endef
|
|
|
|
|
2016-07-30 13:43:35 +00:00
|
|
|
define Build/export-dtb
|
|
|
|
cp $(IMAGE_KERNEL).dtb $@
|
|
|
|
endef
|
|
|
|
|
2016-07-20 13:44:54 +00:00
|
|
|
define Device/MyBookLiveDefault
|
|
|
|
IMAGE_SIZE := 48m
|
|
|
|
BLOCKSIZE := 1024
|
|
|
|
DTB_SIZE := 16384
|
2016-07-21 17:36:13 +00:00
|
|
|
KERNEL := kernel-bin | dtb | gzip | uImage gzip
|
2016-07-20 13:44:54 +00:00
|
|
|
BOOT_SIZE := 8
|
2016-07-21 17:36:13 +00:00
|
|
|
IMAGES := rootfs.img recovery.tar kernel.dtb
|
2016-07-20 13:44:54 +00:00
|
|
|
DEVICE_DTB := apollo3g.dtb
|
2016-07-21 17:36:13 +00:00
|
|
|
FILESYSTEMS := ext4
|
2016-07-30 13:43:35 +00:00
|
|
|
IMAGE/kernel.dtb := export-dtb
|
|
|
|
IMAGE/rootfs.img := boot-script | boot-img | hdd-img
|
2016-07-21 17:36:13 +00:00
|
|
|
IMAGE/recovery.tar := append-rootfs | gzip | uRamdisk | recovery-tar
|
2016-07-20 13:44:54 +00:00
|
|
|
endef
|
|
|
|
|
|
|
|
define Device/MyBookLiveSingle
|
|
|
|
$(Device/MyBookLiveDefault)
|
|
|
|
DEVICE_TITLE := Western Digital My Book Live
|
|
|
|
DEVICE_DTS := apollo3g
|
|
|
|
DEVICE_PROFILE := apollo3g
|
|
|
|
endef
|
|
|
|
|
|
|
|
TARGET_DEVICES += MyBookLiveSingle
|
|
|
|
|
|
|
|
define Device/MyBookLiveDuo
|
|
|
|
$(Device/MyBookLiveDefault)
|
|
|
|
DEVICE_TITLE := Western Digital My Book Live Duo
|
|
|
|
DEVICE_PACKAGES := kmod-usb-dwc2 kmod-ledtrig-usbdev kmod-usb-storage kmod-fs-vfat wpad-mini
|
|
|
|
DEVICE_DTS := apollo3g-duo
|
|
|
|
DEVICE_PROFILE := ap2nc
|
|
|
|
endef
|
|
|
|
|
|
|
|
TARGET_DEVICES += MyBookLiveDuo
|
2016-07-20 13:44:51 +00:00
|
|
|
|
|
|
|
endif
|
2016-07-20 13:44:54 +00:00
|
|
|
|
|
|
|
$(eval $(call BuildImage))
|