mirror of
https://github.com/openwrt/openwrt.git
synced 2024-12-28 17:48:58 +00:00
7dff6a8c89
This patch adds sysupgrade, uboot-env and networking support for Methode uDPU device. Device features 4 partitions: ----------------------------------------- | boot | recovery | rootfs | misc | | (ext4) | (ext4) | (fsf2) | (f2fs) | _________________________________________ Idea was to use f2fs only but the u-boot currently lacks support so first 2 partition are ext4 to be u-boot readable, and this was a reason why custom build and sysupgrade sections were required. On the sysupgrade, boot and rootfs partitions are updated, firmare image and user configuration is saved on the misc partition and if the upgrade was successfull, recovery partition will be updated on after the reboot from preinit script. If the sysupgrade fails for any reason, device will fallback to recovery initramfs image. Signed-off-by: Vladimir Vid <vladimir.vid@sartura.hr>
126 lines
3.5 KiB
Makefile
126 lines
3.5 KiB
Makefile
#
|
|
# Copyright (C) 2012-2016 OpenWrt.org
|
|
# Copyright (C) 2016 LEDE-project.org
|
|
#
|
|
# This is free software, licensed under the GNU General Public License v2.
|
|
# See /LICENSE for more information.
|
|
#
|
|
|
|
JFFS2_BLOCKSIZE = 128k
|
|
|
|
include $(TOPDIR)/rules.mk
|
|
include $(INCLUDE_DIR)/image.mk
|
|
|
|
KERNEL_LOADADDR := 0x00008000
|
|
|
|
SIGNATURE:=$(shell printf "%.8s" $(SOURCE_DATE_EPOCH))
|
|
|
|
define Build/boot-scr
|
|
rm -f $@-boot.scr
|
|
sed \
|
|
-e 's#@ROOT@#$(SIGNATURE)#g' \
|
|
-e 's#@DTB@#$(firstword $(DEVICE_DTS))#g' \
|
|
$(BOOT_SCRIPT).bootscript > $@-new.bootscript
|
|
mkimage -A arm -O linux -T script -C none -a 0 -e 0 -d $@-new.bootscript $@-boot.scr
|
|
endef
|
|
|
|
define Build/boot-img
|
|
rm -f $@.boot
|
|
mkfs.fat -C $@.boot $$(( $(CONFIG_TARGET_KERNEL_PARTSIZE) * 1024 ))
|
|
$(foreach dts,$(DEVICE_DTS), mcopy -i $@.boot $(KDIR)/image-$(dts).dtb ::$(dts).dtb;)
|
|
mcopy -i $@.boot $(IMAGE_KERNEL) ::$(KERNEL_NAME)
|
|
-mcopy -i $@.boot $@-boot.scr ::boot.scr
|
|
endef
|
|
|
|
define Build/boot-img-ext4
|
|
rm -fR $@.boot
|
|
mkdir -p $@.boot
|
|
$(foreach dts,$(DEVICE_DTS), $(CP) $(KDIR)/image-$(dts).dtb $@.boot/$(dts).dtb;)
|
|
$(CP) $(IMAGE_KERNEL) $@.boot/$(KERNEL_NAME)
|
|
-$(CP) $@-boot.scr $@.boot/boot.scr
|
|
make_ext4fs -J -l $(CONFIG_TARGET_KERNEL_PARTSIZE)M $@.bootimg $@.boot
|
|
endef
|
|
|
|
define Build/sdcard-img
|
|
SIGNATURE="$(SIGNATURE)" \
|
|
./gen_mvebu_sdcard_img.sh $@ \
|
|
$(if $(UBOOT),$(STAGING_DIR_IMAGE)/$(UBOOT)) \
|
|
c $(CONFIG_TARGET_KERNEL_PARTSIZE) $@.boot \
|
|
83 $(CONFIG_TARGET_ROOTFS_PARTSIZE) $(IMAGE_ROOTFS)
|
|
endef
|
|
|
|
define Build/sdcard-img-ext4
|
|
SIGNATURE="$(SIGNATURE)" \
|
|
./gen_mvebu_sdcard_img.sh $@ \
|
|
$(if $(UBOOT),$(STAGING_DIR_IMAGE)/$(UBOOT)) \
|
|
83 $(CONFIG_TARGET_KERNEL_PARTSIZE) $@.bootimg \
|
|
83 $(CONFIG_TARGET_ROOTFS_PARTSIZE) $(IMAGE_ROOTFS)
|
|
endef
|
|
|
|
define Build/omnia-medkit-initramfs
|
|
$(TAR) -c -T /dev/null -f $@
|
|
rm -rf $(dir $(IMAGE_KERNEL))boot
|
|
mkdir -p $(dir $(IMAGE_KERNEL))boot/boot/
|
|
cp $(KDIR)/zImage-initramfs $(dir $(IMAGE_KERNEL))boot/boot/zImage
|
|
cp $(KDIR)/image-$(DEVICE_DTS).dtb $(dir $(IMAGE_KERNEL))boot/boot/dtb
|
|
$(TAR) -rp --numeric-owner --owner=0 --group=0 --sort=name \
|
|
$(if $(SOURCE_DATE_EPOCH),--mtime="@$(SOURCE_DATE_EPOCH)") \
|
|
--file=$@ -C $(dir $(IMAGE_KERNEL))boot/ .
|
|
endef
|
|
|
|
define Build/uDPU-firmware
|
|
(rm -fR $@-fw; mkdir -p $@-fw)
|
|
$(CP) $(BIN_DIR)/$(IMAGE_PREFIX)-initramfs.itb $@-fw/recovery.itb
|
|
$(CP) $@-boot.scr $@-fw/boot.scr
|
|
(cd $(TARGET_DIR); $(TAR) -cvzf $@-fw/rootfs.tgz .)
|
|
(cd $@.boot; $(TAR) -cvzf $@-fw/boot.tgz .)
|
|
(cd $@-fw; $(TAR) -cvzf $(KDIR_TMP)/$(IMAGE_PREFIX)-firmware.tgz .)
|
|
endef
|
|
|
|
define Device/Default
|
|
PROFILES := Default
|
|
BOARD_NAME = $$(DEVICE_DTS)
|
|
KERNEL_NAME := zImage
|
|
KERNEL := kernel-bin | append-dtb | uImage none
|
|
IMAGES := sysupgrade.bin
|
|
IMAGE/factory.img := append-kernel | pad-to $$$$(KERNEL_SIZE) | append-ubi | pad-to $$$$(PAGESIZE)
|
|
IMAGE/sysupgrade.bin := sysupgrade-tar | append-metadata
|
|
SUPPORTED_DEVICES = $(subst _,$(comma),$(1))
|
|
UBINIZE_OPTS := -E 5
|
|
UBOOT :=
|
|
BOOT_SCRIPT :=
|
|
endef
|
|
DEVICE_VARS += BOOT_SCRIPT UBOOT
|
|
|
|
define Device/Default-arm64
|
|
BOOT_SCRIPT := generic-arm64
|
|
DTS_DIR := $(DTS_DIR)/marvell
|
|
IMAGES := sdcard.img.gz
|
|
IMAGE/sdcard.img.gz := boot-scr | boot-img-ext4 | sdcard-img-ext4 | gzip | append-metadata
|
|
KERNEL_NAME := Image
|
|
KERNEL := kernel-bin
|
|
endef
|
|
|
|
define Device/NAND-128K
|
|
BLOCKSIZE := 128k
|
|
PAGESIZE := 2048
|
|
SUBPAGESIZE := 512
|
|
VID_HDR_OFFSET := 2048
|
|
endef
|
|
|
|
define Device/NAND-256K
|
|
BLOCKSIZE := 256k
|
|
PAGESIZE := 4096
|
|
endef
|
|
|
|
define Device/NAND-512K
|
|
BLOCKSIZE := 512k
|
|
PAGESIZE := 4096
|
|
endef
|
|
|
|
include cortex-a9.mk
|
|
include cortex-a53.mk
|
|
include cortex-a72.mk
|
|
|
|
$(eval $(call BuildImage))
|