add support for per-package prereq checks, run global prereq checks before (menu-)config
SVN-Revision: 4318
This commit is contained in:
parent
55fd1cd74e
commit
45e7d06393
@ -31,14 +31,17 @@ export OPENWRTVERSION
|
|||||||
|
|
||||||
all: world
|
all: world
|
||||||
|
|
||||||
.pkginfo: FORCE
|
|
||||||
ifneq ($(shell ./scripts/timestamp.pl -p .pkginfo package Makefile),.pkginfo)
|
ifneq ($(shell ./scripts/timestamp.pl -p .pkginfo package Makefile),.pkginfo)
|
||||||
|
.pkginfo: FORCE
|
||||||
|
.config: FORCE
|
||||||
|
endif
|
||||||
|
|
||||||
|
.pkginfo:
|
||||||
@echo Collecting package info...
|
@echo Collecting package info...
|
||||||
@-for dir in package/*/; do \
|
@-for dir in package/*/; do \
|
||||||
echo Source-Makefile: $${dir}Makefile; \
|
echo Source-Makefile: $${dir}Makefile; \
|
||||||
$(NO_TRACE_MAKE) --no-print-dir DUMP=1 -C $$dir 2>&- || true; \
|
$(NO_TRACE_MAKE) --no-print-dir DUMP=1 -C $$dir 2>&- || true; \
|
||||||
done > $@
|
done > $@
|
||||||
endif
|
|
||||||
|
|
||||||
.config.in: .pkginfo
|
.config.in: .pkginfo
|
||||||
@./scripts/gen_menuconfig.pl < $< > $@ || rm -f $@
|
@./scripts/gen_menuconfig.pl < $< > $@ || rm -f $@
|
||||||
@ -77,18 +80,25 @@ target/%: .pkginfo FORCE
|
|||||||
toolchain/%: FORCE
|
toolchain/%: FORCE
|
||||||
$(MAKE) -C toolchain $(patsubst toolchain/%,%,$@)
|
$(MAKE) -C toolchain $(patsubst toolchain/%,%,$@)
|
||||||
|
|
||||||
.config: ./scripts/config/conf FORCE
|
.config: ./scripts/config/conf
|
||||||
@[ -f .config ] || $(NO_TRACE_MAKE) menuconfig
|
@[ -f .config ] || $(NO_TRACE_MAKE) menuconfig
|
||||||
@$< -D .config Config.in &> /dev/null
|
@$< -D .config Config.in &> /dev/null
|
||||||
|
|
||||||
.prereq: $(TOPDIR)/include/prereq.mk .pkginfo
|
.prereq-build: $(TOPDIR)/include/prereq-build.mk
|
||||||
@$(NO_TRACE_MAKE) -s -f $(TOPDIR)/include/prereq.mk prereq 2>/dev/null || { \
|
@$(NO_TRACE_MAKE) -s -f $(TOPDIR)/include/prereq-build.mk prereq 2>/dev/null || { \
|
||||||
echo "Prerequisite check failed. Use FORCE=1 to override."; \
|
echo "Prerequisite check failed. Use FORCE=1 to override."; \
|
||||||
false; \
|
false; \
|
||||||
}
|
}
|
||||||
@touch $@
|
@touch $@
|
||||||
|
|
||||||
prereq: .prereq FORCE
|
.prereq-packages: $(TOPDIR)/include/prereq.mk .pkginfo .config
|
||||||
|
@$(NO_TRACE_MAKE) -s -C package prereq 2>/dev/null || { \
|
||||||
|
echo "Prerequisite check failed. Use FORCE=1 to override."; \
|
||||||
|
false; \
|
||||||
|
}
|
||||||
|
@touch $@
|
||||||
|
|
||||||
|
prereq: .prereq-build .prereq-packages FORCE
|
||||||
|
|
||||||
download: .config FORCE
|
download: .config FORCE
|
||||||
$(MAKE) toolchain/download
|
$(MAKE) toolchain/download
|
||||||
@ -96,7 +106,8 @@ download: .config FORCE
|
|||||||
$(MAKE) target/download
|
$(MAKE) target/download
|
||||||
|
|
||||||
ifeq ($(FORCE),)
|
ifeq ($(FORCE),)
|
||||||
world: .prereq
|
.config ./scripts/config/conf ./scripts/config/mconf: .prereq-build
|
||||||
|
world: .prereq-packages
|
||||||
endif
|
endif
|
||||||
|
|
||||||
world: .config FORCE
|
world: .config FORCE
|
||||||
|
@ -10,6 +10,8 @@ else
|
|||||||
all: compile
|
all: compile
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
include $(INCLUDE_DIR)/prereq.mk
|
||||||
|
|
||||||
define Build/DefaultTargets
|
define Build/DefaultTargets
|
||||||
ifeq ($(DUMP),)
|
ifeq ($(DUMP),)
|
||||||
ifeq ($(CONFIG_AUTOREBUILD),y)
|
ifeq ($(CONFIG_AUTOREBUILD),y)
|
||||||
|
88
openwrt/include/prereq-build.mk
Normal file
88
openwrt/include/prereq-build.mk
Normal file
@ -0,0 +1,88 @@
|
|||||||
|
#
|
||||||
|
# Copyright (C) 2006 OpenWrt.org
|
||||||
|
#
|
||||||
|
# This is free software, licensed under the GNU General Public License v2.
|
||||||
|
# See /LICENSE for more information.
|
||||||
|
#
|
||||||
|
|
||||||
|
include $(TOPDIR)/rules.mk
|
||||||
|
include $(INCLUDE_DIR)/prereq.mk
|
||||||
|
|
||||||
|
# Required for the toolchain
|
||||||
|
define Require/working-make
|
||||||
|
echo 'all: test' > $(TMP_DIR)/check.mk
|
||||||
|
echo 'e0 = $$$$(foreach s,foobar,$$$$(eval $$$$s:))' >> $(TMP_DIR)/check.mk
|
||||||
|
echo 'e1 = $$$$(foreach s,foobar, $$$$(eval $$$$s:))' >> $(TMP_DIR)/check.mk
|
||||||
|
echo 'test: $$$$(strip $$$$(e0)) $$$$(strip $$$$(e1))' >> $(TMP_DIR)/check.mk
|
||||||
|
$(NO_TRACE_MAKE) -f $(TMP_DIR)/check.mk
|
||||||
|
endef
|
||||||
|
|
||||||
|
$(eval $(call Require,working-make, \
|
||||||
|
Your make version is buggy. Please install GNU make v3.81 or later. \
|
||||||
|
))
|
||||||
|
|
||||||
|
define Require/working-gcc
|
||||||
|
echo 'int main(int argc, char **argv) { return 0; }' | \
|
||||||
|
gcc -x c -o $(TMP_DIR)/a.out -
|
||||||
|
endef
|
||||||
|
|
||||||
|
$(eval $(call Require,working-gcc, \
|
||||||
|
No working GNU C Compiler (gcc) was found on your system. \
|
||||||
|
))
|
||||||
|
|
||||||
|
define Require/working-g++
|
||||||
|
echo 'int main(int argc, char **argv) { return 0; }' | \
|
||||||
|
g++ -x c++ -o $(TMP_DIR)/a.out -lstdc++ -
|
||||||
|
endef
|
||||||
|
|
||||||
|
$(eval $(call Require,working-g++, \
|
||||||
|
No working GNU C++ Compiler (g++) was found on your system. \
|
||||||
|
))
|
||||||
|
|
||||||
|
define Require/ncurses
|
||||||
|
echo 'int main(int argc, char **argv) { initscr(); return 0; }' | \
|
||||||
|
gcc -include ncurses.h -x c -o $(TMP_DIR)/a.out -lncurses -
|
||||||
|
endef
|
||||||
|
|
||||||
|
$(eval $(call Require,ncurses, \
|
||||||
|
No ncurses development files were not found on your system. \
|
||||||
|
))
|
||||||
|
|
||||||
|
|
||||||
|
define Require/zlib
|
||||||
|
echo 'int main(int argc, char **argv) { gzdopen(0, "rb"); return 0; }' | \
|
||||||
|
gcc -include zlib.h -x c -o $(TMP_DIR)/a.out -lz -
|
||||||
|
endef
|
||||||
|
|
||||||
|
$(eval $(call Require,zlib, \
|
||||||
|
No zlib development files were not found on your system. \
|
||||||
|
))
|
||||||
|
|
||||||
|
|
||||||
|
$(eval $(call RequireCommand,bison, \
|
||||||
|
Please install GNU bison. \
|
||||||
|
))
|
||||||
|
|
||||||
|
$(eval $(call RequireCommand,flex, \
|
||||||
|
Please install flex. \
|
||||||
|
))
|
||||||
|
|
||||||
|
$(eval $(call RequireCommand,python, \
|
||||||
|
Please install python. \
|
||||||
|
))
|
||||||
|
|
||||||
|
$(eval $(call RequireCommand,unzip, \
|
||||||
|
Please install unzip. \
|
||||||
|
))
|
||||||
|
|
||||||
|
$(eval $(call RequireCommand,bzip2, \
|
||||||
|
Please install bzip2. \
|
||||||
|
))
|
||||||
|
|
||||||
|
$(eval $(call RequireCommand,patch, \
|
||||||
|
Please install patch. \
|
||||||
|
))
|
||||||
|
|
||||||
|
$(eval $(call RequireCommand,perl, \
|
||||||
|
Please install perl. \
|
||||||
|
))
|
@ -5,14 +5,12 @@
|
|||||||
# See /LICENSE for more information.
|
# See /LICENSE for more information.
|
||||||
#
|
#
|
||||||
|
|
||||||
include $(TOPDIR)/rules.mk
|
|
||||||
|
|
||||||
$(TMP_DIR):
|
$(TMP_DIR):
|
||||||
mkdir -p $@
|
mkdir -p $@
|
||||||
|
|
||||||
prereq:
|
prereq:
|
||||||
echo
|
|
||||||
if [ -f $(TMP_DIR)/.prereq-error ]; then \
|
if [ -f $(TMP_DIR)/.prereq-error ]; then \
|
||||||
|
echo; \
|
||||||
cat $(TMP_DIR)/.prereq-error; \
|
cat $(TMP_DIR)/.prereq-error; \
|
||||||
echo; \
|
echo; \
|
||||||
rm -rf $(TMP_DIR); \
|
rm -rf $(TMP_DIR); \
|
||||||
@ -29,7 +27,7 @@ define Require
|
|||||||
|
|
||||||
prereq-$(1): $(TMP_DIR) FORCE
|
prereq-$(1): $(TMP_DIR) FORCE
|
||||||
echo -n "Checking '$(1)'... "
|
echo -n "Checking '$(1)'... "
|
||||||
if $(NO_TRACE_MAKE) -f $(INCLUDE_DIR)/prereq.mk check-$(1) >/dev/null 2>/dev/null; then \
|
if $(NO_TRACE_MAKE) -f $(firstword $(MAKEFILE_LIST)) check-$(1) >/dev/null 2>/dev/null; then \
|
||||||
echo 'ok.'; \
|
echo 'ok.'; \
|
||||||
else \
|
else \
|
||||||
echo 'failed.'; \
|
echo 'failed.'; \
|
||||||
@ -53,81 +51,3 @@ define RequireCommand
|
|||||||
$$(eval $$(call Require,$(1),$(2)))
|
$$(eval $$(call Require,$(1),$(2)))
|
||||||
endef
|
endef
|
||||||
|
|
||||||
# Required for the toolchain
|
|
||||||
define Require/working-make
|
|
||||||
echo 'all: test' > $(TMP_DIR)/check.mk
|
|
||||||
echo 'e0 = $$$$(foreach s,foobar,$$$$(eval $$$$s:))' >> $(TMP_DIR)/check.mk
|
|
||||||
echo 'e1 = $$$$(foreach s,foobar, $$$$(eval $$$$s:))' >> $(TMP_DIR)/check.mk
|
|
||||||
echo 'test: $$$$(strip $$$$(e0)) $$$$(strip $$$$(e1))' >> $(TMP_DIR)/check.mk
|
|
||||||
$(NO_TRACE_MAKE) -f $(TMP_DIR)/check.mk
|
|
||||||
endef
|
|
||||||
|
|
||||||
$(eval $(call Require,working-make, \
|
|
||||||
Your make version is buggy. Please install GNU make v3.81 or later. \
|
|
||||||
))
|
|
||||||
|
|
||||||
define Require/working-gcc
|
|
||||||
echo 'int main(int argc, char **argv) { return 0; }' | \
|
|
||||||
gcc -x c -o $(TMP_DIR)/a.out -
|
|
||||||
endef
|
|
||||||
|
|
||||||
$(eval $(call Require,working-gcc, \
|
|
||||||
No working GNU C Compiler (gcc) was found on your system. \
|
|
||||||
))
|
|
||||||
|
|
||||||
define Require/working-g++
|
|
||||||
echo 'int main(int argc, char **argv) { return 0; }' | \
|
|
||||||
g++ -x c++ -o $(TMP_DIR)/a.out -lstdc++ -
|
|
||||||
endef
|
|
||||||
|
|
||||||
$(eval $(call Require,working-g++, \
|
|
||||||
No working GNU C++ Compiler (g++) was found on your system. \
|
|
||||||
))
|
|
||||||
|
|
||||||
define Require/ncurses
|
|
||||||
echo 'int main(int argc, char **argv) { initscr(); return 0; }' | \
|
|
||||||
gcc -include ncurses.h -x c -o $(TMP_DIR)/a.out -lncurses -
|
|
||||||
endef
|
|
||||||
|
|
||||||
$(eval $(call Require,ncurses, \
|
|
||||||
No ncurses development files were not found on your system. \
|
|
||||||
))
|
|
||||||
|
|
||||||
|
|
||||||
define Require/zlib
|
|
||||||
echo 'int main(int argc, char **argv) { gzdopen(0, "rb"); return 0; }' | \
|
|
||||||
gcc -include zlib.h -x c -o $(TMP_DIR)/a.out -lz -
|
|
||||||
endef
|
|
||||||
|
|
||||||
$(eval $(call Require,zlib, \
|
|
||||||
No zlib development files were not found on your system. \
|
|
||||||
))
|
|
||||||
|
|
||||||
|
|
||||||
$(eval $(call RequireCommand,bison, \
|
|
||||||
Please install GNU bison. \
|
|
||||||
))
|
|
||||||
|
|
||||||
$(eval $(call RequireCommand,flex, \
|
|
||||||
Please install flex. \
|
|
||||||
))
|
|
||||||
|
|
||||||
$(eval $(call RequireCommand,python, \
|
|
||||||
Please install python. \
|
|
||||||
))
|
|
||||||
|
|
||||||
$(eval $(call RequireCommand,unzip, \
|
|
||||||
Please install unzip. \
|
|
||||||
))
|
|
||||||
|
|
||||||
$(eval $(call RequireCommand,bzip2, \
|
|
||||||
Please install bzip2. \
|
|
||||||
))
|
|
||||||
|
|
||||||
$(eval $(call RequireCommand,patch, \
|
|
||||||
Please install patch. \
|
|
||||||
))
|
|
||||||
|
|
||||||
$(eval $(call RequireCommand,perl, \
|
|
||||||
Please install perl. \
|
|
||||||
))
|
|
||||||
|
@ -10,13 +10,17 @@ include $(TOPDIR)/rules.mk
|
|||||||
include $(TOPDIR)/.config
|
include $(TOPDIR)/.config
|
||||||
include $(TOPDIR)/.pkgdeps
|
include $(TOPDIR)/.pkgdeps
|
||||||
|
|
||||||
SOURCE_PACKAGES:=$(patsubst %,%-download,$(package-y) $(package-m))
|
PREREQ_PACKAGES:=$(patsubst %,%-prereq,$(package-y) $(package-m))
|
||||||
|
DOWNLOAD_PACKAGES:=$(patsubst %,%-download,$(package-y) $(package-m))
|
||||||
COMPILE_PACKAGES:=$(patsubst %,%-compile,$(package-y) $(package-m))
|
COMPILE_PACKAGES:=$(patsubst %,%-compile,$(package-y) $(package-m))
|
||||||
INSTALL_PACKAGES:=$(patsubst %,%-install,$(package-y))
|
INSTALL_PACKAGES:=$(patsubst %,%-install,$(package-y))
|
||||||
|
|
||||||
$(STAMP_DIR) $(TARGET_DIR):
|
$(STAMP_DIR) $(TARGET_DIR):
|
||||||
mkdir -p $@
|
mkdir -p $@
|
||||||
|
|
||||||
|
%-prereq: $(STAMP_DIR) $(TARGET_DIR)
|
||||||
|
$(MAKE) -C $(patsubst %-prereq,%,$@) prereq MAKEFLAGS="$(BUILD_MAKEFLAGS)"
|
||||||
|
|
||||||
%-download: $(STAMP_DIR) $(TARGET_DIR)
|
%-download: $(STAMP_DIR) $(TARGET_DIR)
|
||||||
$(MAKE) -C $(patsubst %-download,%,$@) download MAKEFLAGS="$(BUILD_MAKEFLAGS)"
|
$(MAKE) -C $(patsubst %-download,%,$@) download MAKEFLAGS="$(BUILD_MAKEFLAGS)"
|
||||||
|
|
||||||
@ -41,7 +45,8 @@ $(TOPDIR)/.pkgdeps: $(TOPDIR)/.pkginfo
|
|||||||
|
|
||||||
all: compile
|
all: compile
|
||||||
clean: $(patsubst %,%-clean,$(package-) $(package-y) $(package-m))
|
clean: $(patsubst %,%-clean,$(package-) $(package-y) $(package-m))
|
||||||
download: $(SOURCE_PACKAGES)
|
prereq: $(PREREQ_PACKAGES)
|
||||||
|
download: $(DOWNLOAD_PACKAGES)
|
||||||
compile-targets: $(COMPILE_PACKAGES)
|
compile-targets: $(COMPILE_PACKAGES)
|
||||||
compile:
|
compile:
|
||||||
$(MAKE) -j$(CONFIG_JLEVEL) compile-targets
|
$(MAKE) -j$(CONFIG_JLEVEL) compile-targets
|
||||||
|
@ -22,8 +22,8 @@ include $(INCLUDE_DIR)/package.mk
|
|||||||
|
|
||||||
ifneq ($(DUMP),1)
|
ifneq ($(DUMP),1)
|
||||||
TARGET:=-$(BOARD)-$(KERNEL)
|
TARGET:=-$(BOARD)-$(KERNEL)
|
||||||
UCLIBC_VERSION:=${shell cat $(STAGING_DIR)/uclibc_version}
|
UCLIBC_VERSION:=${shell cat $(STAGING_DIR)/uclibc_version 2>/dev/null}
|
||||||
LIBGCC_VERSION:=${shell cat $(STAGING_DIR)/gcc_version}
|
LIBGCC_VERSION:=${shell cat $(STAGING_DIR)/gcc_version 2>/dev/null}
|
||||||
else
|
else
|
||||||
UCLIBC_VERSION:=<UCLIBC_VERSION>
|
UCLIBC_VERSION:=<UCLIBC_VERSION>
|
||||||
LIBGCC_VERSION:=<LIBGCC_VERSION>
|
LIBGCC_VERSION:=<LIBGCC_VERSION>
|
||||||
|
Loading…
Reference in New Issue
Block a user