X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/6630372cc899d243b22de133f2aeec28c3fd5239..94040edc4564cd2419a4d0898fdece22d0d205ea:/include/image.mk diff --git a/include/image.mk b/include/image.mk index 84549c554..b09442877 100644 --- a/include/image.mk +++ b/include/image.mk @@ -8,6 +8,9 @@ include $(INCLUDE_DIR)/prereq.mk include $(INCLUDE_DIR)/kernel.mk include $(INCLUDE_DIR)/host.mk + +override MAKEFLAGS= +override MAKE:=$(SUBMAKE) KDIR:=$(BUILD_DIR)/linux-$(KERNEL)-$(BOARD) ifneq ($(CONFIG_BIG_ENDIAN),y) @@ -18,6 +21,8 @@ JFFS2OPTS := --pad --big-endian --squash SQUASHFS_OPTS := -be endif +JFFS2_BLOCKSIZE ?= 64k 128k + define add_jffs2_mark echo -ne '\xde\xad\xc0\xde' >> $(1) endef @@ -33,22 +38,15 @@ endef ifneq ($(CONFIG_TARGET_ROOTFS_INITRAMFS),y) ifeq ($(CONFIG_TARGET_ROOTFS_JFFS2),y) + define Image/mkfs/jffs2/sub + # FIXME: removing this line will cause strange behaviour in the foreach loop below + $(STAGING_DIR)/bin/mkfs.jffs2 $(JFFS2OPTS) -e $(patsubst %k,%KiB,$(1)) -o $(KDIR)/root.jffs2-$(1) -d $(BUILD_DIR)/root + $(call add_jffs2_mark,$(KDIR)/root.jffs2-$(1)) + $(call Image/Build,jffs2-$(1)) + endef define Image/mkfs/jffs2 rm -rf $(BUILD_DIR)/root/jffs - - $(STAGING_DIR)/bin/mkfs.jffs2 $(JFFS2OPTS) -e 0x10000 -o $(KDIR)/root.jffs2-64k -d $(BUILD_DIR)/root - $(STAGING_DIR)/bin/mkfs.jffs2 $(JFFS2OPTS) -e 0x20000 -o $(KDIR)/root.jffs2-128k -d $(BUILD_DIR)/root - $(STAGING_DIR)/bin/mkfs.jffs2 $(JFFS2OPTS) -e 0x40000 -o $(KDIR)/root.jffs2-256k -d $(BUILD_DIR)/root - - - # add End-of-Filesystem markers - $(call add_jffs2_mark,$(KDIR)/root.jffs2-64k) - $(call add_jffs2_mark,$(KDIR)/root.jffs2-128k) - $(call add_jffs2_mark,$(KDIR)/root.jffs2-256k) - - $(call Image/Build,jffs2-64k) - $(call Image/Build,jffs2-128k) - $(call Image/Build,jffs2-256k) + $(foreach SZ,$(JFFS2_BLOCKSIZE),$(call Image/mkfs/jffs2/sub,$(SZ))) endef endif @@ -99,14 +97,14 @@ define BuildImage download: prepare: ifneq ($(IB),1) - compile: compile-targets + compile: compile-targets FORCE $(call Build/Compile) else compile: endif ifneq ($(IB),1) - install: compile install-targets + install: compile install-targets FORCE $(call Image/Prepare) $(call Image/mkfs/prepare) $(call Image/BuildKernel)