Browse Source

Create package index and do other image preparations just once

Matthias Schiffer 11 years ago
parent
commit
bc7c4c7060
3 changed files with 18 additions and 15 deletions
  1. 2 3
      Makefile
  2. 9 12
      builder/Makefile
  3. 7 0
      builder/Makefile.image

+ 2 - 3
Makefile

@@ -41,9 +41,8 @@ prepare:
 	$(GLUON_OPENWRTDIR)/scripts/feeds install -a
 
 	echo -e "CONFIG_TARGET_$(BOARD)=y\nCONFIG_TARGET_ROOTFS_JFFS2=n\n$(subst ${ },\n,$(patsubst %,CONFIG_PACKAGE_%=m,$(GLUON_PACKAGES) $(PROFILE_PACKAGES)))" > $(GLUON_OPENWRTDIR)/.config
-	$(MAKE) -C $(GLUON_OPENWRTDIR) defconfig prepare
-	$(MAKE) -C $(GLUON_BUILDERDIR) kernel
-	$(MAKE) -C $(GLUON_OPENWRTDIR) package/compile
+	$(MAKE) -C $(GLUON_OPENWRTDIR) defconfig prepare package/compile
+	$(MAKE) -C $(GLUON_BUILDERDIR) prepare
 
 	touch $(prepared_stamp)
 

+ 9 - 12
builder/Makefile

@@ -71,22 +71,18 @@ PACKAGES:=
 
 include $(INCLUDE_DIR)/kernel-build.mk
 
-kernel: FORCE
+prepare: FORCE
 	$(Kernel/CompileImage)
+	$(MAKE) -C $(TOPDIR)/target/linux/$(BOARD)/image -f $(GLUON_BUILDERDIR)/Makefile.image prepare
+	$(MAKE) package_index
 
 _call_image:
 	echo 'Building images for $(BOARD)$(if $($(USER_PROFILE)_NAME), - $($(USER_PROFILE)_NAME))'
 	echo 'Packages: $(BUILD_PACKAGES)'
 	echo
 	rm -rf $(TARGET_DIR)
-	mkdir -p $(TARGET_DIR) $(BIN_DIR) $(TMP_DIR)
-	if [ ! -f "$(PACKAGE_DIR)/Packages" ] || [ ! -f "$(PACKAGE_DIR)/Packages.gz" ] || [ "`find $(PACKAGE_DIR) -cnewer $(PACKAGE_DIR)/Packages.gz`" ]; then \
-		echo "Package list missing or not up-to-date, generating it.";\
-		$(MAKE) package_index; \
-	else \
-		mkdir -p $(TARGET_DIR)/tmp; \
-		$(OPKG) update; \
-	fi
+	mkdir -p $(TARGET_DIR) $(BIN_DIR) $(TMP_DIR) $(TARGET_DIR)/tmp
+	$(OPKG) update
 	$(MAKE) package_install
 ifneq ($(USER_FILES),)
 	$(MAKE) copy_files
@@ -97,11 +93,9 @@ endif
 package_index: FORCE
 	@echo
 	@echo Building package index...
-	@mkdir -p $(TOPDIR)/tmp $(TOPDIR)/dl $(TARGET_DIR)/tmp
 	(cd $(PACKAGE_DIR); $(SCRIPT_DIR)/ipkg-make-index.sh . > Packages && \
 		gzip -9c Packages > Packages.gz \
 	) >/dev/null 2>/dev/null
-	$(OPKG) update
 
 package_install: FORCE
 	@echo
@@ -139,10 +133,13 @@ package_postinst: FORCE
 	)
 	$(if $(CONFIG_CLEAN_IPKG),rm -rf $(TARGET_DIR)/usr/lib/opkg)
 
+include $(INCLUDE_DIR)/image.mk
+
 build_image: FORCE
 	@echo
 	@echo Building images...
-	$(NO_TRACE_MAKE) -C $(TOPDIR)/target/linux/$(BOARD)/image install TARGET_BUILD=1 IMG_PREFIX="gluon-$(BOARD)$(if $(SUBTARGET),-$(SUBTARGET))" \
+	$(call Image/mkfs/prepare)
+	$(NO_TRACE_MAKE) -C $(TOPDIR)/target/linux/$(BOARD)/image install TARGET_BUILD=1 IB=1 IMG_PREFIX="gluon-$(BOARD)$(if $(SUBTARGET),-$(SUBTARGET))" \
 		$(if $(USER_PROFILE),PROFILE="$(USER_PROFILE)")
 
 image:

+ 7 - 0
builder/Makefile.image

@@ -0,0 +1,7 @@
+override BuildImage :=
+
+# The Makefile included here is $(TOPDIR)/target/linux/$(BOARD)/image/Makefile
+include Makefile
+
+prepare: FORCE
+	$(call Image/Prepare)