X-Git-Url: http://git.openwrt.org/?p=openwrt%2Fopenwrt.git;a=blobdiff_plain;f=include%2Ftoplevel.mk;h=a623be9f2e69c3592ebe70275f8ffbdb15167c6c;hp=4510df28161bf969801cd75ceef971cc4d4bccc8;hb=c463728b2d35651fd4cec9ec0379cdfd210a65b1;hpb=a97d6b0c9514743b0285b4a65d60b1da1563da1c diff --git a/include/toplevel.mk b/include/toplevel.mk index 4510df2816..a623be9f2e 100644 --- a/include/toplevel.mk +++ b/include/toplevel.mk @@ -1,15 +1,16 @@ # 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 +export IS_TTY=$(shell tty -s && echo 1 || echo 0) + include $(TOPDIR)/include/verbose.mk ifeq ($(SDK),1) @@ -18,13 +19,15 @@ 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 unexport P4PORT P4USER P4CONFIG P4CLIENT @@ -32,6 +35,11 @@ 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,6 +50,10 @@ 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 @@ -62,12 +74,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 @@ -77,10 +89,16 @@ config-clean: FORCE defconfig: scripts/config/conf prepare-tmpinfo FORCE touch .config - $< -D .config Config.in + @if [ -e $(HOME)/.openwrt/defconfig ]; then cp $(HOME)/.openwrt/defconfig .config; fi + $< --defconfig=.config Config.in + +confdefault-y=allyes +confdefault-m=allmod +confdefault-n=allno +confdefault:=$(confdefault-$(CONFDEFAULT)) oldconfig: scripts/config/conf prepare-tmpinfo FORCE - $< -$(if $(CONFDEFAULT),$(CONFDEFAULT),o) Config.in + $< --$(if $(confdefault),$(confdefault),old)config Config.in menuconfig: scripts/config/mconf prepare-tmpinfo FORCE if [ \! -e .config -a -e $(HOME)/.openwrt/defconfig ]; then \ @@ -90,9 +108,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 @@ -115,6 +133,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 @@ -130,7 +151,14 @@ prereq:: prepare-tmpinfo .config %:: @+$(PREP_MK) $(NO_TRACE_MAKE) -r -s prereq - @+$(SUBMAKE) -r $@ + @( \ + cp .config tmp/.config; \ + ./scripts/config/conf --defconfig=tmp/.config -w tmp/.config Config.in > /dev/null 2>&1; \ + if ./scripts/kconfig.pl '>' .config tmp/.config | grep -q CONFIG; then \ + printf "$(_R)WARNING: your configuration is out of sync. Please run make menuconfig, oldconfig or defconfig!$(_N)\n" >&2; \ + fi \ + ) + @+$(ULIMIT_FIX) $(SUBMAKE) -r $@ help: cat README