X-Git-Url: http://git.openwrt.org/?p=openwrt%2Fopenwrt.git;a=blobdiff_plain;f=Makefile;h=0a1f96a973d7c30fb991866c11a98f39e42bc604;hp=daadbeacf65a7bb4ecd22f745ef4a3d828dfcbaf;hb=d2ac07055275769d6e61ab8e47dbe099cb4d6486;hpb=945b4fb8d4d73ec465f9c87721d61a4ae42f1e47 diff --git a/Makefile b/Makefile index daadbeacf6..0a1f96a973 100644 --- a/Makefile +++ b/Makefile @@ -1,190 +1,103 @@ # Makefile for OpenWrt # -# Copyright (C) 2006 OpenWrt.org -# Copyright (C) 2006 by Felix Fietkau +# Copyright (C) 2007 OpenWrt.org # # This is free software, licensed under the GNU General Public License v2. # See /LICENSE for more information. # -RELEASE:=Kamikaze -#VERSION:=2.0 # uncomment for final release +TOPDIR:=${CURDIR} +LC_ALL:=C +LANG:=C +TZ:=UTC +export TOPDIR LC_ALL LANG TZ -#-------------------------------------------------------------- -# Just run 'make menuconfig', configure stuff, then run 'make'. -# You shouldn't need to mess with anything beyond this point... -#-------------------------------------------------------------- +empty:= +space:= $(empty) $(empty) +$(if $(findstring $(space),$(TOPDIR)),$(error ERROR: The path to the OpenWrt directory must not include any spaces)) -all: world +world: -SHELL:=/usr/bin/env bash -export LC_ALL=C -export LANG=C -export TOPDIR=${CURDIR} -ifeq ($(KBUILD_VERBOSE),99) - MAKE:=3>/dev/null $(MAKE) -endif -export IS_TTY=$(shell tty -s && echo 1 || echo 0) +export PATH:=$(TOPDIR)/staging_dir/host/bin:$(PATH) -include $(TOPDIR)/include/verbose.mk +ifneq ($(OPENWRT_BUILD),1) + _SINGLE=export MAKEFLAGS=$(space); -OPENWRTVERSION:=$(RELEASE) -ifneq ($(VERSION),) - OPENWRTVERSION:=$(VERSION) ($(OPENWRTVERSION)) + override OPENWRT_BUILD=1 + export OPENWRT_BUILD + GREP_OPTIONS= + export GREP_OPTIONS + include $(TOPDIR)/include/debug.mk + include $(TOPDIR)/include/depends.mk + include $(TOPDIR)/include/toplevel.mk else - REV:=$(shell LANG=C svn info | awk '/^Revision:/ { print$$2 }' ) - ifneq ($(REV),) - OPENWRTVERSION:=$(OPENWRTVERSION)/r$(REV) - endif -endif -export OPENWRTVERSION - -ifneq ($(shell ./scripts/timestamp.pl -p tmp/.pkginfo package scripts include),tmp/.pkginfo) - tmp/.pkginfo: FORCE -endif - -ifneq ($(shell ./scripts/timestamp.pl -p tmp/.targetinfo target/linux scripts include),tmp/.targetinfo) - tmp/.targetinfo: FORCE -endif - -ifeq ($(FORCE),) - .config scripts/config/conf scripts/config/mconf: tmp/.prereq-build - world: tmp/.prereq-packages tmp/.prereq-target -endif - -ifeq ($(IS_TTY),1) - define progress - printf "\033[M\r$(1)" >&2; - endef -endif - -define dumpinfo - @mkdir -p tmp - @echo -n Collecting $(2) info... - @-for dir in $(1)/*/; do \ - [ -f "$${dir}/Makefile" ] || continue; \ - $(call progress,Collecting $(2) info: $${dir%%/}) \ - echo Source-Makefile: $${dir}Makefile; \ - $(NO_TRACE_MAKE) --no-print-dir DUMP=1 -C $$dir 3>/dev/null || echo "ERROR: please fix $${dir}Makefile" >&2; \ - echo; \ - done > $@ - @($(call progress,Collecting $(2) info: done)) - @echo -endef - -tmp/.pkginfo: - $(call dumpinfo,package,package) - -tmp/.targetinfo: - $(call dumpinfo,target/linux,target) - -tmpinfo-clean: FORCE - @-rm -rf tmp/.pkginfo tmp/.targetinfo - -tmp/.config.in: tmp/.pkginfo - @./scripts/gen_package_config.pl < $< > $@ || rm -f $@ - -tmp/.config-target.in: tmp/.targetinfo - @./scripts/gen_target_config.pl < $< > $@ || rm -f $@ - -.config: ./scripts/config/conf tmp/.config.in tmp/.config-target.in - @[ -f .config ] || $(NO_TRACE_MAKE) menuconfig - @$< -D .config Config.in &> /dev/null - -scripts/config/mconf: - @$(MAKE) -C scripts/config all - -scripts/config/conf: - @$(MAKE) -C scripts/config conf - -config: scripts/config/conf tmp/.config.in tmp/.config-target.in FORCE - $< Config.in + include rules.mk + include $(INCLUDE_DIR)/depends.mk + include $(INCLUDE_DIR)/subdir.mk + include target/Makefile + include package/Makefile + include tools/Makefile + include toolchain/Makefile + +$(toolchain/stamp-compile): $(tools/stamp-compile) +$(target/stamp-compile): $(toolchain/stamp-compile) $(tools/stamp-compile) $(BUILD_DIR)/.prepared +$(package/stamp-compile): $(target/stamp-compile) $(package/stamp-cleanup) +$(package/stamp-install): $(package/stamp-compile) +$(target/stamp-install): $(package/stamp-compile) $(package/stamp-install) +check: $(tools/stamp-check) $(toolchain/stamp-check) $(package/stamp-check) + +printdb: + @true + +prepare: $(target/stamp-compile) -config-clean: FORCE - $(NO_TRACE_MAKE) -C scripts/config clean - -defconfig: scripts/config/conf tmp/.config.in tmp/.config-target.in FORCE - touch .config - $< -D .config Config.in - -oldconfig: scripts/config/conf tmp/.config.in tmp/.config-target.in FORCE - $< -o Config.in - -menuconfig: scripts/config/mconf tmp/.config.in tmp/.config-target.in FORCE - $< Config.in - -package/%: tmp/.pkginfo tmp/.targetinfo FORCE - $(MAKE) -C package $(patsubst package/%,%,$@) - -target/%: tmp/.pkginfo tmp/.targetinfo FORCE - $(MAKE) -C target $(patsubst target/%,%,$@) - -tools/%: FORCE - $(MAKE) -C tools $(patsubst tools/%,%,$@) - -toolchain/%: tmp/.targetinfo FORCE - $(MAKE) -C toolchain $(patsubst toolchain/%,%,$@) +clean: FORCE + rm -rf $(BUILD_DIR) $(STAGING_DIR) $(BIN_DIR) $(OUTPUT_DIR)/packages/$(ARCH_PACKAGES) $(BUILD_LOG_DIR) $(TOPDIR)/staging_dir/packages -tmp/.prereq-build: include/prereq-build.mk - @mkdir -p tmp - @rm -f tmp/.host.mk - @$(NO_TRACE_MAKE) -s -f $(TOPDIR)/include/prereq-build.mk prereq 2>/dev/null || { \ - echo "Prerequisite check failed. Use FORCE=1 to override."; \ - false; \ - } - @touch $@ +dirclean: clean + rm -rf $(STAGING_DIR_HOST) $(STAGING_DIR_HOSTPKG) $(TOOLCHAIN_DIR) $(BUILD_DIR_BASE)/host $(BUILD_DIR_BASE)/hostpkg $(BUILD_DIR_TOOLCHAIN) + rm -rf $(TMP_DIR) -tmp/.prereq-packages: include/prereq.mk tmp/.pkginfo .config - @mkdir -p tmp - @rm -f tmp/.host.mk - @$(NO_TRACE_MAKE) -s -C package prereq 2>/dev/null || { \ - echo "Prerequisite check failed. Use FORCE=1 to override."; \ - false; \ - } +ifndef DUMP_TARGET_DB +$(BUILD_DIR)/.prepared: Makefile + @mkdir -p $$(dirname $@) @touch $@ -tmp/.prereq-target: include/prereq.mk tmp/.targetinfo .config - @mkdir -p tmp - @rm -f tmp/.host.mk - @$(NO_TRACE_MAKE) -s -C target prereq 2>/dev/null || { \ - echo "Prerequisite check failed. Use FORCE=1 to override."; \ +tmp/.prereq_packages: .config + unset ERROR; \ + for package in $(sort $(prereq-y) $(prereq-m)); do \ + $(_SINGLE)$(NO_TRACE_MAKE) -s -r -C package/$$package prereq || ERROR=1; \ + done; \ + if [ -n "$$ERROR" ]; then \ + echo "Package prerequisite check failed."; \ false; \ - } - @touch $@ - -prereq: tmp/.prereq-build tmp/.prereq-packages tmp/.prereq-target FORCE - -download: .config FORCE - $(MAKE) tools/download - $(MAKE) toolchain/download - $(MAKE) package/download - $(MAKE) target/download + fi + touch $@ +endif -world: .config FORCE - $(MAKE) tools/install - $(MAKE) toolchain/install - $(MAKE) target/compile - $(MAKE) package/compile - $(MAKE) package/install - $(MAKE) target/install - $(MAKE) package/index +# check prerequisites before starting to build +prereq: $(target/stamp-prereq) tmp/.prereq_packages + @if [ ! -f "$(INCLUDE_DIR)/site/$(ARCH)" ]; then \ + echo 'ERROR: Missing site config for architecture "$(ARCH)" !'; \ + echo ' The missing file will cause configure scripts to fail during compilation.'; \ + echo ' Please provide a "$(INCLUDE_DIR)/site/$(ARCH)" file and restart the build.'; \ + exit 1; \ + fi -clean: FORCE - rm -rf build_* bin tmp +checksum: FORCE + $(call sha256sums,$(BIN_DIR)) -dirclean: clean - rm -rf staging_dir_* toolchain_build_* tool_build +diffconfig: FORCE + mkdir -p $(BIN_DIR) + $(SCRIPT_DIR)/diffconfig.sh > $(BIN_DIR)/config.seed -distclean: dirclean config-clean - rm -rf dl +prepare: .config $(tools/stamp-compile) $(toolchain/stamp-compile) + $(_SINGLE)$(SUBMAKE) -r diffconfig -help: - cat README +world: prepare $(target/stamp-compile) $(package/stamp-compile) $(package/stamp-install) $(target/stamp-install) FORCE + $(_SINGLE)$(SUBMAKE) -r package/index + $(_SINGLE)$(SUBMAKE) -r checksum -symlinks: - scripts/feeds.sh https://svn.openwrt.org/openwrt/packages +.PHONY: clean dirclean prereq prepare world package/symlinks package/symlinks-install package/symlinks-clean -.SILENT: clean dirclean distclean config-clean download world -FORCE: ; -.PHONY: FORCE help -%: ; +endif