X-Git-Url: http://git.openwrt.org/?p=openwrt%2Fopenwrt.git;a=blobdiff_plain;f=include%2Fprereq-build.mk;h=ed652ca9a729a6bd8e9222012e9ef65bea04bd21;hp=306a6b3e38bd5855579c3f19cf2bca0cb7e35dff;hb=32c28a78f798dffb983a7f00342b471e5e4ac177;hpb=5dadc89b3a043bb280a5eeb0c198a56dbff34ba7 diff --git a/include/prereq-build.mk b/include/prereq-build.mk index 306a6b3e38..ed652ca9a7 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. @@ -20,10 +20,14 @@ $(eval $(call TestHostCommand,working-make, \ $(MAKE) -v | grep -E 'Make (3\.8[1-9]|3\.9[0-9]|[4-9]\.)')) $(eval $(call TestHostCommand,case-sensitive-fs, \ - OpenWrt can only be built on a case-sensitive filesystem, \ + 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, \ @@ -31,7 +35,8 @@ $(eval $(call SetupHostCommand,gcc, \ gcc49 --version | grep gcc, \ gcc48 --version | grep gcc, \ gcc47 --version | grep gcc, \ - gcc46 --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, \ @@ -45,7 +50,8 @@ $(eval $(call SetupHostCommand,g++, \ g++49 --version | grep g++, \ g++48 --version | grep g++, \ g++47 --version | grep g++, \ - g++46 --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, \ @@ -58,34 +64,29 @@ $(eval $(call TestHostCommand,ncurses, \ echo 'int main(int argc, char **argv) { initscr(); return 0; }' | \ gcc -include ncurses.h -x c -o $(TMP_DIR)/a.out - -lncurses)) +ifeq ($(HOST_OS),Linux) + zlib_link_flags := -Wl,-Bstatic -lz -Wl,-Bdynamic +else + zlib_link_flags := -lz +endif + $(eval $(call TestHostCommand,zlib, \ - Please install zlib. (Missing libz.so or zlib.h), \ + 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 - -lz)) + gcc -include zlib.h -x c -o $(TMP_DIR)/a.out - $(zlib_link_flags))) +# Xcode deprecated openssl, MacPorts doesn't work nicely for other packages +ifneq ($(HOST_OS),Darwin) $(eval $(call TestHostCommand,libssl, \ Please install the openssl library (with development headers), \ echo 'int main(int argc, char **argv) { SSL_library_init(); return 0; }' | \ - gcc -include openssl/ssl.h -x c -o $(TMP_DIR)/a.out - -lcrypto -lssl)) - -ifneq ($(HOST_STATIC_LINKING),) - $(eval $(call TestHostCommand,working-gcc-static, \ - Please install the static libc development package (glibc-static on CentOS/Fedora/RHEL)., \ - echo 'int main(int argc, char **argv) { return 0; }' | \ - gcc -x c $(HOST_STATIC_LINKING) -o $(TMP_DIR)/a.out -)) - - $(eval $(call TestHostCommand,working-g++-static, \ - Please install the static libstdc++ development package (libstdc++-static on CentOS/Fedora/RHEL)., \ - 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)) - - $(eval $(call TestHostCommand,zlib-static, \ - Please install a static zlib. (zlib-static on CentOS/Fedora/RHEL)., \ - 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)) + gcc $(HOST_CFLAGS) -include openssl/ssl.h -x c -o $(TMP_DIR)/a.out - -lcrypto -lssl $(HOST_LDFLAGS))) endif +$(eval $(call TestHostCommand,perl-thread-queue, \ + Please install the Perl Thread::Queue module, \ + perl -MThread::Queue -e 1)) + $(eval $(call SetupHostCommand,tar,Please install GNU 'tar', \ gtar --version 2>&1 | grep GNU, \ @@ -108,8 +109,8 @@ $(eval $(call SetupHostCommand,diff,Please install diffutils, \ diff --version 2>&1 | grep diff)) $(eval $(call SetupHostCommand,cp,Please install GNU fileutils, \ - gcp --help, \ - cp --help)) + gcp --help 2>&1 | grep 'Copy SOURCE', \ + cp --help 2>&1 | grep 'Copy SOURCE')) $(eval $(call SetupHostCommand,seq,, \ gseq --version, \ @@ -150,24 +151,23 @@ $(eval $(call SetupHostCommand,wget,Please install GNU 'wget', \ wget --version | grep GNU)) $(eval $(call SetupHostCommand,perl,Please install Perl 5.x, \ - perl --version | grep "perl 5")) + perl --version | grep "perl.*v5")) $(eval $(call SetupHostCommand,python,Please install Python 2.x, \ python2.7 -V 2>&1 | grep Python, \ python2 -V 2>&1 | grep Python, \ python -V 2>&1 | grep Python)) -$(eval $(call SetupHostCommand,svn,Please install the Subversion client, \ - svn --version | grep Subversion)) - -$(eval $(call SetupHostCommand,git,Please install Git (git-core) >= 1.6.5, \ - git clone --help | grep -- --recursive)) +$(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 SetupHostCommand,file,Please install the 'file' package, \ - file --version | grep file)) + file --version 2>&1 | grep file)) +ifneq ($(HOST_OS),Darwin) $(eval $(call SetupHostCommand,openssl,Please install the 'openssl' utility, \ - openssl version | grep OpenSSL)) + openssl version | grep '\(OpenSSL\|LibreSSL\)')) +endif # Install ldconfig stub