X-Git-Url: http://git.openwrt.org/?p=openwrt%2Fopenwrt.git;a=blobdiff_plain;f=include%2Fprereq-build.mk;h=7d96921a9c5f2d82f459b4c9b7c8aadf6fb2e2e4;hp=4a87c9211aff402f58ba34bc62661130030835a9;hb=6e48eb22b8d9039b27579283cbe46737a2f4ad80;hpb=35b34b20d447b06eb741523163df7aa3ff1f4ae0 diff --git a/include/prereq-build.mk b/include/prereq-build.mk index 4a87c9211a..7d96921a9c 100644 --- a/include/prereq-build.mk +++ b/include/prereq-build.mk @@ -1,4 +1,4 @@ -# +# # Copyright (C) 2006-2012 OpenWrt.org # # This is free software, licensed under the GNU General Public License v2. @@ -7,192 +7,155 @@ include $(TOPDIR)/rules.mk include $(INCLUDE_DIR)/prereq.mk -include $(INCLUDE_DIR)/host.mk -include $(INCLUDE_DIR)/host-build.mk +SHELL:=sh PKG_NAME:=Build dependency -define Require/non-root - [ "$$(shell whoami)" != "root" ] -endef -$(eval $(call Require,non-root, \ - Please do not compile as root. \ -)) # Required for the toolchain -define Require/working-make - $(MAKE) -v | awk '($$$$1 == "GNU") && ($$$$2 == "Make") && ($$$$3 >= "3.81") { print "ok" }' | grep ok > /dev/null -endef - -$(eval $(call Require,working-make, \ - Please install GNU make v3.81 or later. (This version has bugs) \ -)) - -define Require/case-sensitive-fs - rm -f $(TMP_DIR)/test.* - touch $(TMP_DIR)/test.fs - [ \! -f $(TMP_DIR)/test.FS ] -endef - -$(eval $(call Require,case-sensitive-fs, \ - OpenWrt can only be built on a case-sensitive filesystem \ -)) - -define Require/getopt - gnugetopt --help 2>&1 | grep long >/dev/null || \ - /usr/local/bin/getopt --help 2>&1 | grep long >/dev/null || \ - getopt --help 2>&1 | grep long >/dev/null -endef -$(eval $(call Require,getopt, \ - Please install GNU getopt \ -)) - -define Require/fileutils - gcp --help || cp --help -endef -$(eval $(call Require,fileutils, \ - Please install GNU fileutils \ -)) - -define Require/working-gcc +$(eval $(call TestHostCommand,working-make, \ + Please install GNU make v3.81 or later. (This version has bugs), \ + $(MAKE) -v | grep -E 'Make (3\.8[1-9]|3\.9[0-9]|[4-9]\.)')) + +$(eval $(call TestHostCommand,case-sensitive-fs, \ + LEDE can only be built on a case-sensitive filesystem, \ + rm -f $(TMP_DIR)/test.*; touch $(TMP_DIR)/test.fs; \ + test ! -f $(TMP_DIR)/test.FS)) + +$(eval $(call TestHostCommand,proper-umask, \ + Please build with umask 022 - other values produce broken packages, \ + umask | grep -xE 00[012][012])) + +$(eval $(call SetupHostCommand,gcc, \ + Please install the GNU C Compiler (gcc), \ + $(CC) --version | grep gcc, \ + gcc --version | grep gcc, \ + gcc49 --version | grep gcc, \ + gcc48 --version | grep gcc, \ + gcc47 --version | grep gcc, \ + gcc46 --version | grep gcc, \ + gcc --version | grep Apple.LLVM )) + +$(eval $(call TestHostCommand,working-gcc, \ + Please reinstall the GNU C Compiler - it appears to be broken, \ echo 'int main(int argc, char **argv) { return 0; }' | \ - gcc -x c -o $(TMP_DIR)/a.out - -endef - -$(eval $(call Require,working-gcc, \ - Please install the GNU C Compiler (gcc). \ -)) - -define Require/working-g++ + gcc -x c -o $(TMP_DIR)/a.out -)) + +$(eval $(call SetupHostCommand,g++, \ + Please install the GNU C++ Compiler (g++), \ + $(CXX) --version | grep g++, \ + g++ --version | grep g++, \ + g++49 --version | grep g++, \ + g++48 --version | grep g++, \ + g++47 --version | grep g++, \ + g++46 --version | grep g++, \ + g++ --version | grep Apple.LLVM )) + +$(eval $(call TestHostCommand,working-g++, \ + Please reinstall the GNU C++ Compiler - it appears to be broken, \ echo 'int main(int argc, char **argv) { return 0; }' | \ g++ -x c++ -o $(TMP_DIR)/a.out - -lstdc++ && \ - $(TMP_DIR)/a.out -endef - -$(eval $(call Require,working-g++, \ - Please install the GNU C++ Compiler (g++). \ -)) + $(TMP_DIR)/a.out)) -ifneq ($(HOST_STATIC_LINKING),) - define Require/working-gcc-static - echo 'int main(int argc, char **argv) { return 0; }' | \ - gcc -x c $(HOST_STATIC_LINKING) -o $(TMP_DIR)/a.out - - endef - - $(eval $(call Require,working-gcc-static, \ - Please install the static libc development package (glibc-static on CentOS/Fedora/RHEL). \ - )) - - define Require/working-g++-static - echo 'int main(int argc, char **argv) { return 0; }' | \ - g++ -x c++ $(HOST_STATIC_LINKING) -o $(TMP_DIR)/a.out - -lstdc++ && \ - $(TMP_DIR)/a.out - endef +$(eval $(call TestHostCommand,ncurses, \ + Please install ncurses. (Missing libncurses.so or ncurses.h), \ + echo 'int main(int argc, char **argv) { initscr(); return 0; }' | \ + gcc -include ncurses.h -x c -o $(TMP_DIR)/a.out - -lncurses)) - $(eval $(call Require,working-g++-static, \ - Please install the static libstdc++ development package (libstdc++-static on CentOS/Fedora/RHEL). \ - )) +ifeq ($(HOST_OS),Linux) + zlib_link_flags := -Wl,-Bstatic -lz -Wl,-Bdynamic +else + zlib_link_flags := -lz endif -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 TestHostCommand,zlib, \ + Please install a static zlib. (Missing libz.a or zlib.h), \ + echo 'int main(int argc, char **argv) { gzdopen(0, "rb"); return 0; }' | \ + gcc -include zlib.h -x c -o $(TMP_DIR)/a.out - $(zlib_link_flags))) -$(eval $(call Require,ncurses, \ - Please install ncurses. (Missing libncurses.so or ncurses.h) \ -)) +$(eval $(call TestHostCommand,perl-thread-queue, \ + Please install the Perl Thread::Queue module, \ + perl -MThread::Queue -e 1)) -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 SetupHostCommand,tar,Please install GNU 'tar', \ + gtar --version 2>&1 | grep GNU, \ + gnutar --version 2>&1 | grep GNU, \ + tar --version 2>&1 | grep GNU)) -$(eval $(call Require,zlib, \ - Please install zlib. (Missing libz.so or zlib.h) \ -)) +$(eval $(call SetupHostCommand,find,Please install GNU 'find', \ + gfind --version 2>&1 | grep GNU, \ + find --version 2>&1 | grep GNU)) -ifneq ($(HOST_STATIC_LINKING),) - define Require/zlib-static - echo 'int main(int argc, char **argv) { gzdopen(0, "rb"); return 0; }' | \ - gcc -include zlib.h -x c $(HOST_STATIC_LINKING) -o $(TMP_DIR)/a.out - -lz - endef - - $(eval $(call Require,zlib-static, \ - Please install a static zlib. (zlib-static on CentOS/Fedora/RHEL). \ - )) -endif +$(eval $(call SetupHostCommand,bash,Please install GNU 'bash', \ + bash --version 2>&1 | grep GNU)) -$(eval $(call RequireCommand,gawk, \ - Please install GNU awk. \ -)) +$(eval $(call SetupHostCommand,patch,Please install GNU 'patch', \ + gpatch --version 2>&1 | grep 'Free Software Foundation', \ + patch --version 2>&1 | grep 'Free Software Foundation')) -$(eval $(call RequireCommand,unzip, \ - Please install unzip. \ -)) +$(eval $(call SetupHostCommand,diff,Please install diffutils, \ + gdiff --version 2>&1 | grep diff, \ + diff --version 2>&1 | grep diff)) -$(eval $(call RequireCommand,bzip2, \ - Please install bzip2. \ -)) +$(eval $(call SetupHostCommand,cp,Please install GNU fileutils, \ + gcp --help 2>&1 | grep 'Copy SOURCE', \ + cp --help 2>&1 | grep 'Copy SOURCE')) -$(eval $(call RequireCommand,perl, \ - Please install perl. \ -)) +$(eval $(call SetupHostCommand,seq,, \ + gseq --version, \ + seq --version)) -$(eval $(call RequireCommand,$(PYTHON), \ - Please install python. \ -)) +$(eval $(call SetupHostCommand,awk,Please install GNU 'awk', \ + gawk --version 2>&1 | grep GNU, \ + awk --version 2>&1 | grep GNU)) -$(eval $(call RequireCommand,wget, \ - Please install wget. \ -)) +$(eval $(call SetupHostCommand,grep,Please install GNU 'grep', \ + ggrep --version 2>&1 | grep GNU, \ + grep --version 2>&1 | grep GNU)) -define Require/git - git --version | awk '($$$$1 == "git") && ($$$$2 == "version") && ($$$$3 >= "1.6.5") { print "ok" }' | grep ok > /dev/null -endef +$(eval $(call SetupHostCommand,getopt, \ + Please install an extended getopt version that supports --long, \ + gnugetopt -o t --long test -- --test | grep '^ *--test *--', \ + /usr/local/bin/getopt -o t --long test -- --test | grep '^ *--test *--', \ + getopt -o t --long test -- --test | grep '^ *--test *--')) -$(eval $(call Require,git, \ - Please install git (git-core) v1.6.5 or later. \ -)) +$(eval $(call SetupHostCommand,stat,Cannot find a file stat utility, \ + gnustat -c%s $(TOPDIR)/Makefile, \ + gstat -c%s $(TOPDIR)/Makefile, \ + stat -c%s $(TOPDIR)/Makefile)) -define Require/gnutar - $(TAR) --version 2>&1 | grep GNU > /dev/null -endef +$(eval $(call SetupHostCommand,unzip,Please install 'unzip', \ + unzip 2>&1 | grep zipfile, \ + unzip)) -$(eval $(call Require,gnutar, \ - Please install GNU tar. \ -)) +$(eval $(call SetupHostCommand,bzip2,Please install 'bzip2', \ + bzip2 --version &1 | grep Python, \ + python2 -V 2>&1 | grep Python, \ + python -V 2>&1 | grep Python)) -define Require/gnu-find - $(FIND) --version 2>/dev/null -endef +$(eval $(call SetupHostCommand,git,Please install Git (git-core) >= 1.7.12.2, \ + git --exec-path | xargs -I % -- grep -q -- --recursive %/git-submodule)) -$(eval $(call Require,gnu-find, \ - Please install GNU find \ -)) +$(eval $(call SetupHostCommand,file,Please install the 'file' package, \ + file --version 2>&1 | grep file)) -define Require/getopt-extended - getopt --long - - >/dev/null -endef +$(STAGING_DIR_HOST)/bin/mkhash: $(SCRIPT_DIR)/mkhash.c + mkdir -p $(dir $@) + $(CC) -O2 -I$(TOPDIR)/tools/include -o $@ $< -$(eval $(call Require,getopt-extended, \ - Please install an extended getopt version that supports --long \ -)) +prereq: $(STAGING_DIR_HOST)/bin/mkhash -$(eval $(call RequireCommand,file, \ - Please install the 'file' package. \ -)) +# Install ldconfig stub +$(eval $(call TestHostCommand,ldconfig-stub,Failed to install stub, \ + touch $(STAGING_DIR_HOST)/bin/ldconfig && \ + chmod +x $(STAGING_DIR_HOST)/bin/ldconfig))