build: centralize fakeroot code
This patch moves the fakeroot code required by some devices to `image-commands.mk`. Create the fakeroot on the fly by using the undocumented -s (skip copy) parameter of mkimage. Signed-off-by: Joseph C. Lehner <joseph.c.lehner@gmail.com> [remove unused NETGEAR_KERNEL_MAGIC, remove workarounds to have a dummy rootfs for mkimage] Signed-off-by: Mathias Kresin <dev@kresin.me>
This commit is contained in:
parent
c1eae7a7b8
commit
7d00cfe9bb
5 changed files with 19 additions and 32 deletions
|
@ -62,6 +62,18 @@ define Build/netgear-dni
|
||||||
mv $@.new $@
|
mv $@.new $@
|
||||||
endef
|
endef
|
||||||
|
|
||||||
|
# append a fake/empty rootfs uImage header, to fool the bootloaders
|
||||||
|
# rootfs integrity check
|
||||||
|
define Build/append-uImage-fakeroot-hdr
|
||||||
|
rm -f $@.fakeroot
|
||||||
|
$(STAGING_DIR_HOST)/bin/mkimage \
|
||||||
|
-A $(LINUX_KARCH) -O linux -T filesystem -C none \
|
||||||
|
-n '$(call toupper,$(LINUX_KARCH)) LEDE fakeroot' \
|
||||||
|
-s \
|
||||||
|
$@.fakeroot
|
||||||
|
cat $@.fakeroot >> $@
|
||||||
|
endef
|
||||||
|
|
||||||
define Build/tplink-safeloader
|
define Build/tplink-safeloader
|
||||||
-$(STAGING_DIR_HOST)/bin/tplink-safeloader \
|
-$(STAGING_DIR_HOST)/bin/tplink-safeloader \
|
||||||
-B $(TPLINK_BOARD_NAME) \
|
-B $(TPLINK_BOARD_NAME) \
|
||||||
|
@ -143,10 +155,6 @@ define Build/append-rootfs
|
||||||
dd if=$(IMAGE_ROOTFS) >> $@
|
dd if=$(IMAGE_ROOTFS) >> $@
|
||||||
endef
|
endef
|
||||||
|
|
||||||
define Build/append-file
|
|
||||||
cat "$(1)" >> "$@"
|
|
||||||
endef
|
|
||||||
|
|
||||||
define Build/append-ubi
|
define Build/append-ubi
|
||||||
sh $(TOPDIR)/scripts/ubinize-image.sh \
|
sh $(TOPDIR)/scripts/ubinize-image.sh \
|
||||||
$(if $(UBOOTENV_IN_UBI),--uboot-env) \
|
$(if $(UBOOTENV_IN_UBI),--uboot-env) \
|
||||||
|
|
|
@ -129,23 +129,6 @@ define Build/create-uImage-dtb
|
||||||
@mv $@.new $@
|
@mv $@.new $@
|
||||||
endef
|
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
|
define Build/wndr4700-specialImage
|
||||||
rm -rf $@.fakerd $@.new
|
rm -rf $@.fakerd $@.new
|
||||||
|
|
||||||
|
@ -192,7 +175,8 @@ define Device/WNDR4700
|
||||||
IMAGE_SIZE := 24960k
|
IMAGE_SIZE := 24960k
|
||||||
IMAGES := factory.img sysupgrade.tar kernel.dtb
|
IMAGES := factory.img sysupgrade.tar kernel.dtb
|
||||||
KERNEL_SIZE := 1920k
|
KERNEL_SIZE := 1920k
|
||||||
KERNEL := dtb | kernel-bin | lzma | uImage lzma | pad-offset $$(BLOCKSIZE) 64 | append-fakerootfs
|
KERNEL := dtb | kernel-bin | lzma | uImage lzma | pad-offset $$(BLOCKSIZE) 64 | \
|
||||||
|
append-uImage-fakeroot-hdr
|
||||||
KERNEL_INITRAMFS := kernel-bin | gzip | dtb | wndr4700-specialImage gzip
|
KERNEL_INITRAMFS := kernel-bin | gzip | dtb | wndr4700-specialImage gzip
|
||||||
IMAGE/factory.img := create-uImage-dtb | append-kernel | pad-to 2M | append-ubi | \
|
IMAGE/factory.img := create-uImage-dtb | append-kernel | pad-to 2M | append-ubi | \
|
||||||
netgear-dni | check-size $$$$(IMAGE_SIZE)
|
netgear-dni | check-size $$$$(IMAGE_SIZE)
|
||||||
|
|
|
@ -9,12 +9,6 @@ KERNEL_LOADADDR := 0x42208000
|
||||||
|
|
||||||
define Image/Prepare
|
define Image/Prepare
|
||||||
$(CP) $(LINUX_DIR)/vmlinux $(KDIR)/$(IMG_PREFIX)-vmlinux.elf
|
$(CP) $(LINUX_DIR)/vmlinux $(KDIR)/$(IMG_PREFIX)-vmlinux.elf
|
||||||
mkimage -A arm -O linux -T filesystem -C none \
|
|
||||||
-a $(KERNEL_LOADADDR) -e $(KERNEL_LOADADDR) \
|
|
||||||
-n 'ARM OpenWrt fakeroot' \
|
|
||||||
-s $(KDIR_TMP)/root.dummy-uImage.tmp
|
|
||||||
echo -ne '\xff' > $(KDIR_TMP)/root.dummy
|
|
||||||
cat $(KDIR_TMP)/root.dummy $(KDIR_TMP)/root.dummy-uImage.tmp > $(KDIR)/root.dummy
|
|
||||||
endef
|
endef
|
||||||
|
|
||||||
define Image/BuildKernel
|
define Image/BuildKernel
|
||||||
|
@ -64,7 +58,8 @@ define Device/DniImage
|
||||||
FILESYSTEMS := squashfs
|
FILESYSTEMS := squashfs
|
||||||
KERNEL_SUFFIX := -uImage
|
KERNEL_SUFFIX := -uImage
|
||||||
KERNEL_INITRAMFS := kernel-bin | append-dtb | uImage none
|
KERNEL_INITRAMFS := kernel-bin | append-dtb | uImage none
|
||||||
KERNEL = kernel-bin | append-dtb | pad-to $$$$(($$(KERNEL_SIZE)-2*64-1)) | uImage none | append-file $(KDIR)/root.dummy
|
KERNEL = kernel-bin | append-dtb | uImage none | pad-offset $$(KERNEL_SIZE) 64 | \
|
||||||
|
append-uImage-fakeroot-hdr
|
||||||
KERNEL_NAME := zImage
|
KERNEL_NAME := zImage
|
||||||
NETGEAR_BOARD_ID :=
|
NETGEAR_BOARD_ID :=
|
||||||
NETGEAR_HW_ID :=
|
NETGEAR_HW_ID :=
|
||||||
|
@ -161,7 +156,7 @@ define Device/EA8500
|
||||||
BLOCKSIZE := 128k
|
BLOCKSIZE := 128k
|
||||||
KERNEL_SIZE := 3072k
|
KERNEL_SIZE := 3072k
|
||||||
FILESYSTEMS := squashfs
|
FILESYSTEMS := squashfs
|
||||||
KERNEL = kernel-bin | append-dtb | uImage none | append-file $(KDIR)/root.dummy
|
KERNEL = kernel-bin | append-dtb | uImage none | append-uImage-fakeroot-hdr
|
||||||
PROFILES += $$(DEVICE_NAME)
|
PROFILES += $$(DEVICE_NAME)
|
||||||
BOARD_NAME := ea8500
|
BOARD_NAME := ea8500
|
||||||
UBINIZE_OPTS := -E 5
|
UBINIZE_OPTS := -E 5
|
||||||
|
|
|
@ -58,7 +58,7 @@ define Device/ex2700
|
||||||
BLOCKSIZE := 4k
|
BLOCKSIZE := 4k
|
||||||
IMAGE_SIZE := $(ralink_default_fw_size_4M)
|
IMAGE_SIZE := $(ralink_default_fw_size_4M)
|
||||||
IMAGES += factory.bin
|
IMAGES += factory.bin
|
||||||
KERNEL := $(KERNEL_DTB) | uImage lzma | pad-offset 64k 64 | append-file netgear-fake-uImage-hdr.bin
|
KERNEL := $(KERNEL_DTB) | uImage lzma | pad-offset 64k 64 | append-uImage-fakeroot-hdr
|
||||||
IMAGE/factory.bin := $$(sysupgrade_bin) | check-size $$$$(IMAGE_SIZE) | \
|
IMAGE/factory.bin := $$(sysupgrade_bin) | check-size $$$$(IMAGE_SIZE) | \
|
||||||
netgear-dni
|
netgear-dni
|
||||||
DEVICE_TITLE := Netgear EX2700
|
DEVICE_TITLE := Netgear EX2700
|
||||||
|
@ -71,7 +71,7 @@ define Device/wn3000rpv3
|
||||||
DTS := WN3000RPV3
|
DTS := WN3000RPV3
|
||||||
BLOCKSIZE := 4k
|
BLOCKSIZE := 4k
|
||||||
IMAGES += factory.bin
|
IMAGES += factory.bin
|
||||||
KERNEL := $(KERNEL_DTB) | uImage lzma | pad-offset 64k 64 | append-file netgear-fake-uImage-hdr.bin
|
KERNEL := $(KERNEL_DTB) | uImage lzma | pad-offset 64k 64 | append-uImage-fakeroot-hdr
|
||||||
IMAGE/factory.bin := $$(sysupgrade_bin) | check-size $$$$(IMAGE_SIZE) | \
|
IMAGE/factory.bin := $$(sysupgrade_bin) | check-size $$$$(IMAGE_SIZE) | \
|
||||||
netgear-dni
|
netgear-dni
|
||||||
DEVICE_TITLE := Netgear WN3000RPv3
|
DEVICE_TITLE := Netgear WN3000RPv3
|
||||||
|
|
Binary file not shown.
Loading…
Reference in a new issue