mvebu: Add subtarget for Cortex A9 build
[openwrt/openwrt.git] / target / linux / mvebu / image / Makefile
index a8fc4de..6e012a6 100644 (file)
 #
-# Copyright (C) 2012-2014 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
-
-JFFS2_BLOCKSIZE = 128k
+KERNEL_LOADADDR := 0x00008000
 
-KDIR_TMP:=$(KDIR)/tmp
+SIGNATURE:=$(shell printf "%.8s" $(SOURCE_DATE_EPOCH))
 
+define Build/dtb
+       $(call Image/BuildDTB,$(DTS_DIR)/$(DEVICE_DTS).dts,$@.dtb)
+endef
 
-UIMAGE:=$(BIN_DIR)/$(IMG_PREFIX)-uImage
+# 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 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))
-       cp $(KDIR)/uImage$(2)-$(1) $(UIMAGE)$(2)-$(1);
+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
 
-# $(1): Profile Name
-# $(2): DTB Name
-# $(3): Erase Block Size
-# $(4): Page Size
-# $(5): Sub-Page Size (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)))
-       cp $(KDIR)/$$(IMG_PREFIX)-$(2)-squashfs-ubinized.bin $(BIN_DIR)
-  endef
-
-  PROFILES_LIST += $(1)
+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
 
-# $(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)
+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
 
-# $(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)
+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
 
-# $(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
+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
 
-# Boards with NAND, with subpages
-$(eval $(call NANDProfile,370-DB,armada-370-db,128KiB,2048,512))
-$(eval $(call NANDProfile,370-RD,armada-370-rd,128KiB,2048,512))
-$(eval $(call NANDProfile,Mamba,armada-xp-mamba,128KiB,2048,512))
-$(eval $(call NANDProfile,Mirabox,armada-370-mirabox,128KiB,2048,512))
-$(eval $(call NANDProfile,OpenBlocks-AX-3-4,armada-xp-openblocks-ax3-4,128KiB,2048,512))
-$(eval $(call NANDProfile,XP-DB,armada-xp-db,128KiB,2048,512))
-$(eval $(call NANDProfile,XP-GP,armada-xp-gp,128KiB,2048,512))
-
-define Image/Build/Profile/Mamba/squashfs
-       $(call Image/Build/UbinizeImage,armada-xp-mamba,,squashfs, -p 128KiB -m 2048 -s 512)
-       ( \
-               dd if=$(KDIR)/uImage-armada-xp-mamba bs=3072k conv=sync; \
-               dd if=$(KDIR)/$(IMG_PREFIX)-armada-xp-mamba-squashfs-ubinized.bin \
-               bs=2048 conv=sync; \
-       ) > $(BIN_DIR)/$(IMG_PREFIX)-armada-xp-mamba-squashfs-factory.img
+define Device/UBI
+  IMAGES := sysupgrade.bin
+  IMAGE/sysupgrade.bin := sysupgrade-tar | append-metadata
 endef
 
-$(eval $(call MultiProfile,Generic,$(PROFILES_LIST)))
-$(eval $(call MultiProfile,Evalboards,$(PROFILES_LIST)))
+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 Image/BuildKernel
-       $(call Image/BuildKernel/Profile/$(PROFILE))
+define Device/NAND-128K
+  $(Device/UBI)
+  BLOCKSIZE := 128k
+  PAGESIZE := 2048
+  SUBPAGESIZE := 512
+  VID_HDR_OFFSET := 2048
 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/NAND-256K
+  $(Device/UBI)
+  BLOCKSIZE := 256k
+  PAGESIZE := 4096
 endef
 
-define Image/Build
-       $(call Image/Build/$(1))
-       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
+define Device/NAND-512K
+  $(Device/UBI)
+  BLOCKSIZE := 512k
+  PAGESIZE := 4096
 endef
 
+include cortex-a9.mk
+
 $(eval $(call BuildImage))