X-Git-Url: http://git.openwrt.org/?p=openwrt%2Fsvn-archive%2Farchive.git;a=blobdiff_plain;f=openwrt%2FMakefile;h=2fdc7647d42cfc2da3f556a2b3d34a51ed5fb6ab;hp=c2e628051aec229c9ac5d82e72f2d06b1d7573dc;hb=6b5084c9d5c30db925a16913db07c928072f85fa;hpb=fd2e6d8e86a89adc7f3c13a40de251cfe4e15e78 diff --git a/openwrt/Makefile b/openwrt/Makefile index c2e628051a..2fdc7647d4 100644 --- a/openwrt/Makefile +++ b/openwrt/Makefile @@ -1,5 +1,6 @@ -# Makefile for buildroot2 +# Makefile for OpenWrt # +# Copyright (C) 2005 by Felix Fietkau # Copyright (C) 1999-2004 by Erik Andersen # # This program is free software; you can redistribute it and/or modify @@ -21,40 +22,32 @@ # Just run 'make menuconfig', configure stuff, then run 'make'. # You shouldn't need to mess with anything beyond this point... #-------------------------------------------------------------- -TOPDIR=./ +TOPDIR=${shell pwd} +export TOPDIR + +ifneq ($(DEVELOPER),) +CONFIG_CONFIG_IN = Config.in.devel +else CONFIG_CONFIG_IN = Config.in +endif CONFIG_DEFCONFIG = .defconfig CONFIG = package/config noconfig_targets := menuconfig config oldconfig randconfig \ - defconfig allyesconfig allnoconfig release tags + defconfig allyesconfig allnoconfig tags # Pull in the user's configuration file ifeq ($(filter $(noconfig_targets),$(MAKECMDGOALS)),) --include $(TOPDIR).config -endif - -ifeq ($(BR2_TAR_VERBOSITY),y) -TAR_OPTIONS=-xvf -else -TAR_OPTIONS=-xf +-include $(TOPDIR)/.config endif ifeq ($(strip $(BR2_HAVE_DOT_CONFIG)),y) +include $(TOPDIR)/rules.mk -############################################################# -# -# The list of stuff to build for the target toolchain -# along with the packages to build for the target. -# -############################################################## -TARGETS:=host-sed linux-headers uclibc-configured binutils gcc uclibc-target-utils -include toolchain/Makefile.in -include toolchain/*/Makefile.in -include package/Makefile.in -include package/*/Makefile.in -include target/Makefile.in -include target/*/Makefile.in +all: world + +.NOTPARALLEL: +.PHONY: all world clean dirclean distclean image_clean target_clean source configtest ############################################################# # @@ -63,74 +56,64 @@ include target/*/Makefile.in # ############################################################# - - -all: world - # In this section, we need .config include .config.cmd -TARGETS_CLEAN:=$(patsubst %,%-clean,$(TARGETS)) -TARGETS_SOURCE:=$(patsubst %,%-source,$(TARGETS)) - -world: $(DL_DIR) $(BUILD_DIR) $(STAGING_DIR) $(TARGET_DIR) $(TARGETS) +world: $(DL_DIR) $(BUILD_DIR) configtest + $(MAKE) toolchain/install target/compile package/compile root_clean package/install target/install package_index + @$(TRACE) Build complete. -.PHONY: all world clean distclean source $(TARGETS) \ - $(TARGETS_CLEAN) $(TARGETS_DIRCLEAN) $(TARGETS_SOURCE) \ - $(DL_DIR) $(BUILD_DIR) $(TOOL_BUILD_DIR) $(STAGING_DIR) +configtest: + -cp .config .config.test + -scripts/configtest.pl -include toolchain/*/*.mk -include package/*/*.mk -include target/*/*.mk +package_index: + (cd $(PACKAGE_DIR); $(STAGING_DIR)/usr/bin/ipkg-make-index . > Packages) -############################################################# -# -# staging and target directories do NOT list these as -# dependancies anywhere else -# -############################################################# $(DL_DIR): @mkdir -p $(DL_DIR) $(BUILD_DIR): @mkdir -p $(BUILD_DIR) -$(TOOL_BUILD_DIR): - @mkdir -p $(TOOL_BUILD_DIR) +source: toolchain/source package/source target/source -$(STAGING_DIR): - @mkdir -p $(STAGING_DIR)/lib - @mkdir -p $(STAGING_DIR)/include - @mkdir -p $(STAGING_DIR)/$(REAL_GNU_TARGET_NAME) - @ln -sf ../lib $(STAGING_DIR)/$(REAL_GNU_TARGET_NAME)/lib +package/%: + @$(TRACE) $@ + $(MAKE) -C package $(patsubst package/%,%,$@) -$(TARGET_DIR): - @mkdir -p $(TARGET_DIR) - cp -a target/default/target_skeleton/* $(TARGET_DIR)/ - -find $(TARGET_DIR) -type d -name CVS -exec rm -rf {} \; > /dev/null 2>&1 +target/%: + @$(TRACE) $@ + $(MAKE) -C target $(patsubst target/%,%,$@) -source: $(TARGETS_SOURCE) +toolchain/%: + @$(TRACE) $@ + $(MAKE) -C toolchain $(patsubst toolchain/%,%,$@) ############################################################# # # Cleanup and misc junk # ############################################################# -clean: - rm -rf $(BUILD_DIR) $(IMAGE).* - @$(MAKE) -C $(CONFIG) clean +root_clean: + @$(TRACE) root_clean + rm -rf $(BUILD_DIR)/linux-*/root $(BUILD_DIR)/root + +target_clean: root_clean + rm -f $(STAMP_DIR)/.*-compile + rm -f $(STAMP_DIR)/.*-install + rm -rf $(BIN_DIR) -distclean: clean - rm -rf $(DL_DIR) $(TOOL_BUILD_DIR) .config +clean: dirclean -sourceball: +dirclean: + @$(TRACE) dirclean + @$(MAKE) -C $(CONFIG) clean rm -rf $(BUILD_DIR) - set -e; \ - cd ..; \ - rm -f buildroot.tar.bz2; \ - tar -cvf buildroot.tar buildroot; \ - bzip2 -9 buildroot.tar; \ +distclean: dirclean + rm -rf $(STAMP_DIR) $(DL_DIR) $(TOOL_BUILD_DIR) $(STAGING_DIR) + rm -f .config* .tmpconfig.h else # ifeq ($(strip $(BR2_HAVE_DOT_CONFIG)),y) @@ -145,47 +128,51 @@ $(CONFIG)/conf: cp $(CONFIG_DEFCONFIG) .config; \ fi $(CONFIG)/mconf: - $(MAKE) -C $(CONFIG) ncurses conf mconf + $(MAKE) -C $(CONFIG) -@if [ ! -f .config ] ; then \ cp $(CONFIG_DEFCONFIG) .config; \ fi menuconfig: $(CONFIG)/mconf + -touch .config + -cp .config .config.test @$(CONFIG)/mconf $(CONFIG_CONFIG_IN) + -./scripts/configtest.pl config: $(CONFIG)/conf + -touch .config + -cp .config .config.test @$(CONFIG)/conf $(CONFIG_CONFIG_IN) + -./scripts/configtest.pl oldconfig: $(CONFIG)/conf + -touch .config + -cp .config .config.test @$(CONFIG)/conf -o $(CONFIG_CONFIG_IN) + -./scripts/configtest.pl randconfig: $(CONFIG)/conf + -touch .config + -cp .config .config.test @$(CONFIG)/conf -r $(CONFIG_CONFIG_IN) + -./scripts/configtest.pl allyesconfig: $(CONFIG)/conf - #@$(CONFIG)/conf -y $(CONFIG_CONFIG_IN) - #sed -i -e "s/^CONFIG_DEBUG.*/# CONFIG_DEBUG is not set/" .config + -touch .config + -cp .config .config.test @$(CONFIG)/conf -o $(CONFIG_CONFIG_IN) + -./scripts/configtest.pl allnoconfig: $(CONFIG)/conf + -touch .config + -cp .config .config.test @$(CONFIG)/conf -n $(CONFIG_CONFIG_IN) + -./scripts/configtest.pl defconfig: $(CONFIG)/conf + -touch .config + -cp .config .config.test @$(CONFIG)/conf -d $(CONFIG_CONFIG_IN) - -############################################################# -# -# Cleanup and misc junk -# -############################################################# -clean: - @$(MAKE) -C $(CONFIG) clean - -distclean: clean + -./scripts/configtest.pl endif # ifeq ($(strip $(BR2_HAVE_DOT_CONFIG)),y) - -.PHONY: dummy subdirs release distclean clean config oldconfig \ - menuconfig tags check test depend - -