X-Git-Url: http://git.openwrt.org/?p=openwrt%2Fopenwrt.git;a=blobdiff_plain;f=target%2Flinux%2Fmvebu%2Fimage%2FMakefile;h=823552d4f824fe052f7ca008db1bf2bbbcb0bc50;hp=191dc27a007527b0fb5e8b417acccbd1185e1755;hb=9f3f61a0d968fbe7b93899f948f3c34612683ba6;hpb=96c793f529105a80953a586568efbe0142ea7625 diff --git a/target/linux/mvebu/image/Makefile b/target/linux/mvebu/image/Makefile index 191dc27a00..823552d4f8 100644 --- a/target/linux/mvebu/image/Makefile +++ b/target/linux/mvebu/image/Makefile @@ -1,190 +1,257 @@ # -# Copyright (C) 2012-2015 OpenWrt.org +# 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 -LOADADDR:=0x00008000 +KERNEL_LOADADDR := 0x00008000 -JFFS2_BLOCKSIZE = 128k +SIGNATURE:=$(shell printf "%.8s" $(SOURCE_DATE_EPOCH)) + +define Build/dtb + $(call Image/BuildDTB,$(DTS_DIR)/$(DEVICE_DTS).dts,$@.dtb) +endef + +# SD-Card Images: +# these values are optimized for a 4GB labeled sdcard that actually holds 7744512 sectors of 512 byte +# MBR: 2048 sectors +# Partition 1: 32768 sectors +# Partition 2: 98304 sectors (configurable) + +define Build/boot-scr + rm -f $@-boot.scr + mkimage -A arm -O linux -T script -C none -a 0 -e 0 -d $(DEVICE_NAME).bootscript $@-boot.scr +endef + +define Build/boot-img + rm -f $@.boot + mkfs.fat -C $@.boot 16384 + $(foreach dts,$(DEVICE_DTS), mcopy -i $@.boot $(DTS_DIR)/$(dts).dtb ::$(dts).dtb;) + mcopy -i $@.boot $(IMAGE_KERNEL) ::zImage + -mcopy -i $@.boot $@-boot.scr ::boot.scr +endef + +define Build/sdcard-img + if [ -n "$(UBOOT)" ]; then UBOOT="$(STAGING_DIR_IMAGE)/$(UBOOT)"; fi; \ + ROOTFS_SIZE=$$(( $(CONFIG_TARGET_ROOTFS_PARTSIZE) * 1024 * 2 )); \ + SIGNATURE="$(SIGNATURE)" \ + ./gen_mvebu_sdcard_img.sh $@ \ + $$UBOOT \ + c 32768 $@.boot \ + 83 $$ROOTFS_SIZE $(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 $(DTS_DIR)/$(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 Device/Default + PROFILES := Default + DEVICE_DTS := $(1) + BOARD_NAME = $$(DEVICE_DTS) + KERNEL_NAME := zImage + KERNEL := kernel-bin | append-dtb | uImage none + SUPPORTED_DEVICES = $$(DEVICE_DTS) +endef + +define Device/UBI + IMAGES := sysupgrade.bin + IMAGE/sysupgrade.bin := sysupgrade-tar | append-metadata +endef + +define Device/UBI-factory + $(Device/UBI) + UBINIZE_OPTS := -E 5 + IMAGES += factory.img + IMAGE/factory.img := append-kernel | pad-to $$$$(KERNEL_SIZE) | append-ubi | pad-to $$$$(PAGESIZE) +endef + +define Device/NAND-128K + $(Device/UBI) + BLOCKSIZE := 128k + PAGESIZE := 2048 + SUBPAGESIZE := 512 + VID_HDR_OFFSET := 2048 +endef + +define Device/NAND-256K + $(Device/UBI) + BLOCKSIZE := 256k + PAGESIZE := 4096 +endef + +define Device/NAND-512K + $(Device/UBI) + BLOCKSIZE := 512k + PAGESIZE := 4096 +endef + +define Device/linksys + DEVICE_TITLE := Linksys $(1) + DEVICE_PACKAGES := kmod-mwlwifi wpad-mini swconfig +endef + +define Device/armada-385-linksys + $(Device/NAND-128K) + $(Device/UBI-factory) + KERNEL_SIZE := 6144k +endef + +define Device/linksys-wrt1200ac + $(call Device/linksys,WRT1200AC (Caiman)) + $(Device/armada-385-linksys) + DEVICE_DTS := armada-385-linksys-caiman + DEVICE_PACKAGES += mwlwifi-firmware-88w8864 +endef +TARGET_DEVICES += linksys-wrt1200ac + +define Device/linksys-wrt1900acv2 + $(call Device/linksys,WRT1900ACv2 (Cobra)) + $(Device/armada-385-linksys) + DEVICE_DTS := armada-385-linksys-cobra + DEVICE_PACKAGES += mwlwifi-firmware-88w8864 +endef +TARGET_DEVICES += linksys-wrt1900acv2 + +define Device/linksys-wrt3200acm + $(call Device/linksys,WRT3200ACM (Rango)) + $(Device/armada-385-linksys) + DEVICE_DTS := armada-385-linksys-rango + DEVICE_PACKAGES += kmod-btmrvl kmod-mwifiex-sdio mwlwifi-firmware-88w8964 +endef +TARGET_DEVICES += linksys-wrt3200acm + +define Device/linksys-wrt1900acs + $(call Device/linksys,WRT1900ACS (Shelby)) + $(Device/armada-385-linksys) + DEVICE_DTS := armada-385-linksys-shelby + DEVICE_PACKAGES += mwlwifi-firmware-88w8864 +endef +TARGET_DEVICES += linksys-wrt1900acs + +define Device/linksys-wrt1900ac + $(call Device/linksys,WRT1900AC (Mamba)) + DEVICE_DTS := armada-xp-linksys-mamba + DEVICE_PACKAGES += mwlwifi-firmware-88w8864 + $(Device/NAND-128K) + $(Device/UBI-factory) + KERNEL_SIZE := 3072k +endef +TARGET_DEVICES += linksys-wrt1900ac + +define Device/openblocks-ax3-4 + $(Device/UBI-factory) + DEVICE_DTS := armada-xp-openblocks-ax3-4 + SUPPORTED_DEVICES := $(1) + BLOCKSIZE := 128k + PAGESIZE := 1 + IMAGE/factory.img := append-kernel | pad-to $$(BLOCKSIZE) | append-ubi + DEVICE_TITLE := Plat'Home OpenBlocks AX3 +endef +TARGET_DEVICES += openblocks-ax3-4 + +define Device/armada-385-db-ap + $(Device/NAND-256K) + $(Device/UBI-factory) + KERNEL_SIZE := 8192k + DEVICE_TITLE := Marvell Armada 385 DB AP (DB-88F6820-AP) +endef +TARGET_DEVICES += armada-385-db-ap + +define Device/marvell-nand + $(Device/NAND-512K) + DEVICE_TITLE := Marvell Armada $(1) +endef + +define Device/armada-370-db + $(call Device/marvell-nand,370 DB (DB-88F6710-BP-DDR3)) +endef +TARGET_DEVICES += armada-370-db + +define Device/armada-370-rd + $(call Device/marvell-nand,370 RD (RD-88F6710-A1)) +endef +TARGET_DEVICES += armada-370-rd + +define Device/armada-xp-db + $(call Device/marvell-nand,XP DB (DB-78460-BP)) +endef +TARGET_DEVICES += armada-xp-db + +define Device/armada-xp-gp + $(call Device/marvell-nand,XP GP (DB-MV784MP-GP)) +endef +TARGET_DEVICES += armada-xp-gp + +define Device/armada-388-rd + DEVICE_TITLE := Marvell Armada 388 RD (RD-88F6820-AP) + IMAGES := firmware.bin + IMAGE/firmware.bin := append-kernel | pad-to 256k | append-rootfs | pad-rootfs +endef +TARGET_DEVICES += armada-388-rd + +define Device/armada-388-clearfog-pro + KERNEL_INSTALL := 1 + KERNEL := kernel-bin + DEVICE_TITLE := SolidRun ClearFog Pro + DEVICE_PACKAGES := mkf2fs e2fsprogs swconfig kmod-fs-vfat kmod-nls-cp437 kmod-nls-iso8859-1 + IMAGES := sdcard.img.gz + IMAGE/sdcard.img.gz := boot-scr | boot-img | sdcard-img | gzip | append-metadata + DEVICE_DTS := armada-388-clearfog-pro armada-388-clearfog-base + SUPPORTED_DEVICES := armada-388-clearfog-pro armada-388-clearfog + UBOOT := clearfog-u-boot-spl.kwb +endef +TARGET_DEVICES += armada-388-clearfog-pro + +define Device/armada-388-clearfog-base + KERNEL_INSTALL := 1 + KERNEL := kernel-bin + DEVICE_TITLE := SolidRun ClearFog Base + DEVICE_PACKAGES := mkf2fs e2fsprogs kmod-fs-vfat kmod-nls-cp437 kmod-nls-iso8859-1 + IMAGES := sdcard.img.gz + IMAGE/sdcard.img.gz := boot-scr | boot-img | sdcard-img | gzip | append-metadata + DEVICE_DTS := armada-388-clearfog-pro armada-388-clearfog-base + UBOOT := clearfog-u-boot-spl.kwb +endef +TARGET_DEVICES += armada-388-clearfog-base -KDIR_TMP:=$(KDIR)/tmp - - -UIMAGE:=$(BIN_DIR)/$(IMG_PREFIX)-uImage - -define Image/Build/DTB - cp $(KDIR)/zImage$(2) $(KDIR)/zImage$(2)-$(1); - cat $(DTS_DIR)/$(1).dtb >> $(KDIR)/zImage$(2)-$(1); - $(call Image/BuildKernel/MkuImage, \ - none, $(LOADADDR), $(LOADADDR), \ - $(KDIR)/zImage$(2)-$(1), $(KDIR)/uImage$(2)-$(1)) -# The next line will be dropped, migrate your board to use a single firmware file - cp $(KDIR)/uImage$(2)-$(1) $(UIMAGE)$(2)-$(1); -endef - -# $(1): Profile Name -# $(2): DTB Name -# $(3): Erase Block Size -# $(4): Page Size -# $(5): Sub-Page Size (optional) -# $(6): VID offset (optional) -define NANDProfile - define Image/BuildKernel/Profile/$(1) - $(call Image/Build/DTB,$(2)) - ifneq ($(CONFIG_TARGET_ROOTFS_INITRAMFS),) - $(call Image/Build/Profile,$(1)/Initramfs) - endif - endef - - define Image/Build/Profile/$(1)/BuildSysupgrade - $(call Image/Build/SysupgradeNAND,$(2),$$(1),$(KDIR)/uImage-$(2)) - endef - - define Image/Build/Profile/$(1)/Initramfs - $(call Image/Build/DTB,$(2),-initramfs) - endef - - define Image/Build/Profile/$(1)/squashfs - $(call Image/Build/UbinizeImage,$(2),,squashfs, -p $(3) -m $(4) $(if $(5),-s $(5)) $(if $(6),-O $(6))) -# The next line will be dropped, migrate your board to use a single firmware file - cp $(KDIR)/$$(IMG_PREFIX)-$(2)-squashfs-ubinized.bin $(BIN_DIR) - endef - - PROFILES_LIST += $(1) -endef - -# $(1): Profile Name -# $(2): DTB Name -# $(3): Erase Block Size -define UBINORProfile - define Image/BuildKernel/Profile/$(1) - $(call Image/Build/DTB,$(2)) - ifneq ($(CONFIG_TARGET_ROOTFS_INITRAMFS),) - $(call Image/Build/Profile,$(1)/Initramfs) - endif - endef - - define Image/Build/Profile/$(1)/Initramfs - $(call Image/Build/DTB,$(2),-initramfs) - endef - - define Image/Build/Profile/$(1)/squashfs - $(call Image/Build/UbinizeImage,$(2),,squashfs, -p $(3) -m 1) - endef - - PROFILES_LIST += $(1) -endef - -# $(1): Profile Name -# $(2): DTB Name -# $(3): Erase Block Size -define NORProfile - define Image/BuildKernel/Profile/$(1) - $(call Image/Build/DTB,$(2)) - ifneq ($(CONFIG_TARGET_ROOTFS_INITRAMFS),) - $(call Image/Build/Profile,$(1)/Initramfs) - endif - endef - - define Image/Build/Profile/$(1)/Initramfs - $(call Image/Build/DTB,$(2),-initramfs) - endef - - define Image/Build/Profile/$(1)/squashfs - ( \ - dd if=$(KDIR)/uImage-$(2) bs=$(3) conv=sync; \ - dd if=$(KDIR)/root.squashfs bs=$(3) conv=sync; \ - ) > $$(BIN_DIR)/$$(IMG_PREFIX)-$(2)-squashfs-firmware.bin - endef - - PROFILES_LIST += $(1) -endef - -# $(1): Profile Name -# $(2): Sub Profiles list -define MultiProfile - define Image/BuildKernel/Profile/$(1) - $(foreach profile, $(2), - $(call Image/BuildKernel/Profile/$(profile))) - endef - - define Image/Build/Profile/$(1)/BuildSysupgrade - $(foreach profile, $(2), - $(call Image/Build/Profile/$(profile)/BuildSysupgrade,$$(1))) - endef - - define Image/Build/Profile/$(1)/Initramfs - $(foreach profile, $(2), - $(call Image/Build/Profile/$(profile)/Initramfs)) - endef - - define Image/Build/Profile/$(1)/squashfs - $(foreach profile, $(2), - $(call Image/Build/Profile/$(profile)/squashfs)) - endef -endef - -# Boards with NAND, without subpages -$(eval $(call NANDProfile,370-DB,armada-370-db,512KiB,4096)) -$(eval $(call NANDProfile,370-RD,armada-370-rd,512KiB,4096)) -$(eval $(call NANDProfile,385-DB-AP,armada-385-db-ap,256KiB,4096)) -$(eval $(call NANDProfile,Mirabox,armada-370-mirabox,512KiB,4096)) -$(eval $(call NANDProfile,XP-DB,armada-xp-db,512KiB,4096)) -$(eval $(call NANDProfile,XP-GP,armada-xp-gp,512KiB,4096)) - -# Boards with NAND, with subpages -$(eval $(call NANDProfile,Mamba,armada-xp-linksys-mamba,128KiB,2048,512,2048)) - -# Boards with large NOR, where we want to use UBI -$(eval $(call UBINORProfile,OpenBlocks-AX-3-4,armada-xp-openblocks-ax3-4,128KiB)) - -# Boards with small NOR, where UBI doesn't make sense -$(eval $(call NORProfile,385-RD,armada-385-rd,256KiB)) - -define Image/Build/Profile/Mamba/squashfs - $(call Image/Build/UbinizeImage,armada-xp-linksys-mamba,,squashfs, -p 128KiB -m 2048 -s 512 -O 2048) - ( \ - dd if=$(KDIR)/uImage-armada-xp-linksys-mamba bs=3072k conv=sync; \ - dd if=$(KDIR)/$(IMG_PREFIX)-armada-xp-linksys-mamba-squashfs-ubinized.bin \ - bs=2048 conv=sync; \ - ) > $(BIN_DIR)/$(IMG_PREFIX)-armada-xp-linksys-mamba-squashfs-factory.img -endef - -define Image/Build/Profile/385-DB-AP/squashfs - $(call Image/Build/UbinizeImage,armada-385-db-ap,,squashfs, -p 256KiB -m 4096) - ( \ - dd if=$(KDIR)/uImage-armada-385-db-ap bs=8M conv=sync; \ - dd if=$(KDIR)/$(IMG_PREFIX)-armada-385-db-ap-squashfs-ubinized.bin \ - bs=4096 conv=sync; \ - ) > $(BIN_DIR)/$(IMG_PREFIX)-armada-385-db-ap-squashfs-factory.img -endef - -# The Default profile should build everything -$(eval $(call MultiProfile,Default,$(PROFILES_LIST))) - -define Image/BuildKernel - $(call Image/BuildKernel/Profile/$(PROFILE)) -endef - -define Image/Build/squashfs - # Align the squashfs image size before calling the profiles, - # otherwise the size would keep growing - $(call prepare_generic_squashfs,$(KDIR)/root.squashfs) - $(call Image/Build/Profile/$(PROFILE)/squashfs) +define Device/globalscale-mirabox + $(Device/NAND-512K) + DEVICE_DTS := armada-370-mirabox + SUPPORTED_DEVICES := mirabox + DEVICE_TITLE := Globalscale Mirabox endef - -define Image/Build - $(call Image/Build/$(1)) -# The next line will be dropped, migrate your board to use a single firmware file - dd if=$(KDIR)/root.$(1) of=$(BIN_DIR)/$(IMG_PREFIX)-root.$(1) bs=128k conv=sync - $(call Image/Build/Profile/$(PROFILE)/BuildSysupgrade,$(1)) -ifneq ($(CONFIG_TARGET_ROOTFS_INITRAMFS),) - $(call Image/Build/Profile/$(PROFILE)/Initramfs) -endif +TARGET_DEVICES += globalscale-mirabox + +define Device/turris-omnia + KERNEL_INSTALL := 1 + KERNEL := kernel-bin + KERNEL_INITRAMFS := kernel-bin + DEVICE_TITLE := Turris Omnia + DEVICE_PACKAGES := \ + mkf2fs e2fsprogs kmod-fs-vfat kmod-nls-cp437 kmod-nls-iso8859-1 \ + wpad-mini kmod-ath9k kmod-ath10k ath10k-firmware-qca988x + IMAGES := $$(IMAGE_PREFIX)-sysupgrade.img.gz omnia-medkit-$$(IMAGE_PREFIX)-initramfs.tar.gz + IMAGE/$$(IMAGE_PREFIX)-sysupgrade.img.gz := boot-img | sdcard-img | gzip | append-metadata + IMAGE/omnia-medkit-$$(IMAGE_PREFIX)-initramfs.tar.gz := omnia-medkit-initramfs | gzip + IMAGE_NAME = $$(2) + DEVICE_DTS := armada-385-turris-omnia + UBOOT := endef +TARGET_DEVICES += turris-omnia $(eval $(call BuildImage))