X-Git-Url: https://git.archive.openwrt.org/?a=blobdiff_plain;f=include%2Ftoplevel.mk;h=19ed8cb1d9daa55c90e544c01543753ee5d25e13;hb=7d9a07b8551f0a3ec2e5a24c31ea1a60ecac2cad;hp=2ee1518b8a8b4aff4121843aa6112c57ec5d0f9e;hpb=b4c7c3f80440ca4ff23283be6da8fb48ebe4b679;p=openwrt.git diff --git a/include/toplevel.mk b/include/toplevel.mk index 2ee1518b8a..19ed8cb1d9 100644 --- a/include/toplevel.mk +++ b/include/toplevel.mk @@ -1,13 +1,12 @@ # Makefile for OpenWrt # -# Copyright (C) 2007 OpenWrt.org +# Copyright (C) 2007-2012 OpenWrt.org # # This is free software, licensed under the GNU General Public License v2. # See /LICENSE for more information. # -RELEASE:=Kamikaze -SHELL:=/usr/bin/env bash +RELEASE:=Barrier Breaker PREP_MK= OPENWRT_BUILD= QUIET=0 include $(TOPDIR)/include/verbose.mk @@ -18,19 +17,27 @@ else REVISION:=$(shell $(TOPDIR)/scripts/getver.sh) endif +HOSTCC ?= gcc OPENWRTVERSION:=$(RELEASE)$(if $(REVISION), ($(REVISION))) export RELEASE export REVISION export OPENWRTVERSION export IS_TTY=$(shell tty -s && echo 1 || echo 0) -export LD_LIBRARY_PATH:=$(if $(LD_LIBRARY_PATH),$(LD_LIBRARY_PATH):)$(STAGING_DIR_HOST)/lib -export DYLD_LIBRARY_PATH:=$(if $(DYLD_LIBRARY_PATH),$(DYLD_LIBRARY_PATH):)$(STAGING_DIR_HOST)/lib +export LD_LIBRARY_PATH:=$(subst ::,:,$(if $(LD_LIBRARY_PATH),$(LD_LIBRARY_PATH):)$(STAGING_DIR_HOST)/lib) +export DYLD_LIBRARY_PATH:=$(subst ::,:,$(if $(DYLD_LIBRARY_PATH),$(DYLD_LIBRARY_PATH):)$(STAGING_DIR_HOST)/lib) +export GIT_CONFIG_PARAMETERS='core.autocrlf=false' +export MAKE_JOBSERVER=$(filter --jobserver%,$(MAKEFLAGS)) # prevent perforce from messing with the patch utility -export P4PORT= -export P4USER= -export P4CONFIG= -export P4CLIENT= +unexport P4PORT P4USER P4CONFIG P4CLIENT + +# prevent user defaults for quilt from interfering +unexport QUILT_PATCHES QUILT_PATCH_OPTS + +unexport C_INCLUDE_PATH CROSS_COMPILE ARCH + +# prevent distro default LPATH from interfering +unexport LPATH # make sure that a predefined CFLAGS variable does not disturb packages export CFLAGS= @@ -42,11 +49,15 @@ endif SCAN_COOKIE?=$(shell echo $$$$) export SCAN_COOKIE +SUBMAKE:=umask 022; $(SUBMAKE) + +ULIMIT_FIX=_limit=`ulimit -n`; [ "$$_limit" = "unlimited" -o "$$_limit" -ge 1024 ] || ulimit -n 1024; + prepare-mk: FORCE ; prepare-tmpinfo: FORCE mkdir -p tmp/info - $(_SINGLE)$(NO_TRACE_MAKE) -j1 -r -s -f include/scan.mk SCAN_TARGET="packageinfo" SCAN_DIR="package" SCAN_NAME="package" SCAN_DEPS="$(TOPDIR)/include/package*.mk" SCAN_DEPTH=5 SCAN_EXTRA="" + $(_SINGLE)$(NO_TRACE_MAKE) -j1 -r -s -f include/scan.mk SCAN_TARGET="packageinfo" SCAN_DIR="package" SCAN_NAME="package" SCAN_DEPS="$(TOPDIR)/include/package*.mk $(TOPDIR)/overlay/*/*.mk" SCAN_DEPTH=5 SCAN_EXTRA="" $(_SINGLE)$(NO_TRACE_MAKE) -j1 -r -s -f include/scan.mk SCAN_TARGET="targetinfo" SCAN_DIR="target/linux" SCAN_NAME="target" SCAN_DEPS="profiles/*.mk $(TOPDIR)/include/kernel*.mk $(TOPDIR)/include/target.mk" SCAN_DEPTH=2 SCAN_EXTRA="" SCAN_MAKEOPTS="TARGET_BUILD=1" for type in package target; do \ f=tmp/.$${type}info; t=tmp/.config-$${type}.in; \ @@ -62,12 +73,12 @@ prepare-tmpinfo: FORCE fi scripts/config/mconf: - @$(_SINGLE)$(SUBMAKE) -s -C scripts/config all + @$(_SINGLE)$(SUBMAKE) -s -C scripts/config all CC="$(HOSTCC)" $(eval $(call rdep,scripts/config,scripts/config/mconf)) scripts/config/conf: - @$(_SINGLE)$(SUBMAKE) -s -C scripts/config conf + @$(_SINGLE)$(SUBMAKE) -s -C scripts/config conf CC="$(HOSTCC)" config: scripts/config/conf prepare-tmpinfo FORCE $< Config.in @@ -90,9 +101,9 @@ menuconfig: scripts/config/mconf prepare-tmpinfo FORCE prepare_kernel_conf: .config FORCE -ifeq ($(wildcard staging_dir/host/bin/sed),) +ifeq ($(wildcard staging_dir/host/bin/quilt),) prepare_kernel_conf: - @+$(SUBMAKE) -r tools/sed/install + @+$(SUBMAKE) -r tools/quilt/install else prepare_kernel_conf: ; endif @@ -103,6 +114,9 @@ kernel_oldconfig: prepare_kernel_conf kernel_menuconfig: prepare_kernel_conf $(_SINGLE)$(NO_TRACE_MAKE) -C target/linux menuconfig +kernel_nconfig: prepare_kernel_conf + $(_SINGLE)$(NO_TRACE_MAKE) -C target/linux nconfig + tmp/.prereq-build: include/prereq-build.mk mkdir -p tmp rm -f tmp/.host.mk @@ -112,6 +126,9 @@ tmp/.prereq-build: include/prereq-build.mk } touch $@ +printdb: FORCE + @$(_SINGLE)$(NO_TRACE_MAKE) -p $@ V=99 DUMP_TARGET_DB=1 2>&1 + download: .config FORCE @+$(SUBMAKE) tools/download @+$(SUBMAKE) toolchain/download @@ -127,7 +144,14 @@ prereq:: prepare-tmpinfo .config %:: @+$(PREP_MK) $(NO_TRACE_MAKE) -r -s prereq - @+$(SUBMAKE) -r $@ + @( \ + cp .config tmp/.config; \ + ./scripts/config/conf -D tmp/.config -w tmp/.config Config.in > /dev/null 2>&1; \ + if ./scripts/kconfig.pl '>' .config tmp/.config | grep -q CONFIG; then \ + echo "WARNING: your configuration is out of sync. Please run make menuconfig, oldconfig or defconfig!"; \ + fi \ + ) + @+$(ULIMIT_FIX) $(SUBMAKE) -r $@ help: cat README