X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/81a817a5e3df246ca87520ee40a6ec00444fe5eb..a702c26fde6ee7159afa6804204ac1f4a81be468:/Makefile?ds=sidebyside diff --git a/Makefile b/Makefile index d7e458559..a5e03d1cb 100644 --- a/Makefile +++ b/Makefile @@ -1,167 +1,59 @@ # 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 +IS_TTY:=${shell tty -s && echo 1 || echo 0} +export TOPDIR LC_ALL LANG IS_TTY -#-------------------------------------------------------------- -# Just run 'make menuconfig', configure stuff, then run 'make'. -# You shouldn't need to mess with anything beyond this point... -#-------------------------------------------------------------- +world: -all: world +include $(TOPDIR)/include/host.mk -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) - -include $(TOPDIR)/include/verbose.mk - -OPENWRTVERSION:=$(RELEASE) -ifneq ($(VERSION),) - OPENWRTVERSION:=$(VERSION) ($(OPENWRTVERSION)) +ifneq ($(OPENWRT_BUILD),1) + override OPENWRT_BUILD=1 + export OPENWRT_BUILD + include $(TOPDIR)/include/debug.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 - -ifeq ($(FORCE),) - .config scripts/config/conf scripts/config/mconf: tmp/.prereq-build - world: tmp/.prereq-package tmp/.prereq-target -endif - -package/%/Makefile: ; -target/%/Makefile: ; - -tmp/.packageinfo: $(wildcard package/*/Makefile include/package*.mk include/kernel.mk) -tmp/.targetinfo: $(wildcard target/*/Makefile include/kernel*.mk) -tmp/.%info: - @mkdir -p tmp/info - @$(NO_TRACE_MAKE) -s -f include/scan.mk SCAN_TARGET="$*info" SCAN_DIR="$(patsubst target,target/linux,$*)" SCAN_NAME="$*" SCAN_DEPS="$^" SCAN_EXTRA="" - -tmpinfo-clean: FORCE - @-rm -rf tmp/.*info - -tmp/.config-%.in: tmp/.%info - @./scripts/metadata.pl $*_config < $< > $@ || rm -f $@ - - - -.config: ./scripts/config/conf tmp/.config-target.in tmp/.config-package.in - @[ -f .config ] || { \ - [ -e $(HOME)/.openwrt/defconfig ] && cp $(HOME)/.openwrt/defconfig .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-target.in tmp/.config-package.in FORCE - $< Config.in - -config-clean: FORCE - $(NO_TRACE_MAKE) -C scripts/config clean - -defconfig: scripts/config/conf tmp/.config-target.in tmp/.config-package.in FORCE - touch .config - $< -D .config Config.in - -oldconfig: scripts/config/conf tmp/.config-target.in tmp/.config-package.in FORCE - $< -o Config.in - -menuconfig: scripts/config/mconf tmp/.config-target.in tmp/.config-package.in FORCE - @if [ \! -f .config -a -e $(HOME)/.openwrt/defconfig ]; then \ - cp $(HOME)/.openwrt/defconfig .config; \ - fi - $< Config.in - -kernel_menuconfig: .config FORCE - -$(MAKE) target/linux-prepare - $(NO_TRACE_MAKE) -C target/linux menuconfig - - -package/% target/%: tmp/.packageinfo -toolchain/% package/% target/%: tmp/.targetinfo -package/% target/% tools/% toolchain/%: FORCE - $(MAKE) -C $(patsubst %/$*,%,$@) $* - - -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 $@ - -tmp/.prereq-%: include/prereq.mk tmp/.%info .config - @mkdir -p tmp - @rm -f tmp/.host.mk - @$(NO_TRACE_MAKE) -s -C $* prereq 2>/dev/null || { \ - echo "Prerequisite check failed. Use FORCE=1 to override."; \ - false; \ - } + 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-install) $(tools/stamp-install) $(BUILD_DIR)/.prepared +$(package/stamp-compile): $(target/stamp-compile) +$(target/stamp-install): $(package/stamp-compile) $(package/stamp-install) + +$(BUILD_DIR)/.prepared: Makefile + @mkdir -p $$(dirname $@) @touch $@ -prereq: tmp/.prereq-build tmp/.prereq-package tmp/.prereq-target FORCE - -download: .config FORCE - $(MAKE) tools/download - $(MAKE) toolchain/download - $(MAKE) package/download - $(MAKE) target/download - -world: .config FORCE - $(MAKE) tools/install - $(MAKE) toolchain/install - $(MAKE) target/compile - $(MAKE) package/compile - $(MAKE) package/install - $(MAKE) target/install - $(MAKE) package/index - clean: FORCE - rm -rf build_* bin tmp + rm -rf $(BUILD_DIR) $(BIN_DIR) + $(MAKE) target/linux/clean + rm -rf $(TMP_DIR) dirclean: clean - rm -rf staging_dir_* toolchain_build_* tool_build + rm -rf $(STAGING_DIR) $(STAGING_DIR_HOST) $(STAGING_DIR_TOOLCHAIN) $(BUILD_DIR_TOOLCHAIN) $(BUILD_DIR_HOST) -distclean: dirclean config-clean symlinkclean docclean - rm -rf dl +# check prerequisites before starting to build +prereq: $(package/stamp-prereq) $(target/stamp-prereq) ; -help: - cat README - -doc: - $(MAKE) -C docs/ openwrt.pdf - -docclean: - $(MAKE) -C docs/ clean +world: .config $(tools/stamp-install) $(toolchain/stamp-install) $(target/stamp-compile) $(package/stamp-cleanup) $(package/stamp-compile) $(package/stamp-install) $(package/stamp-rootfs-prepare) $(target/stamp-install) FORCE + $(MAKE) package/index -symlinkclean: - find package -type l -exec rm -f {} + +package/symlinks: + $(SCRIPT_DIR)/feeds.sh $(CONFIG_SOURCE_FEEDS) $(CONFIG_SOURCE_FEEDS_REV) -.SILENT: clean dirclean distclean symlinkclean config-clean download world help -FORCE: ; -.PHONY: FORCE help +endif