X-Git-Url: https://git.archive.openwrt.org/?p=openwrt.git;a=blobdiff_plain;f=target%2Fsdk%2FMakefile;h=857a6b76f5213a7bc05bec6dff28b0f288617864;hp=376aef8eb0f5430e968dfbe763cf04d82e9440ba;hb=c11df91b49f1bfa49aceea1280762c94e55f4c4d;hpb=8a4bc6510d0aafc23dcd77bd5829575d918d7272 diff --git a/target/sdk/Makefile b/target/sdk/Makefile index 376aef8eb0..857a6b76f5 100644 --- a/target/sdk/Makefile +++ b/target/sdk/Makefile @@ -1,5 +1,5 @@ # -# Copyright (C) 2006-2008 OpenWrt.org +# Copyright (C) 2006-2014 OpenWrt.org # # This is free software, licensed under the GNU General Public License v2. # See /LICENSE for more information. @@ -8,26 +8,36 @@ include $(TOPDIR)/rules.mk include $(INCLUDE_DIR)/kernel.mk include $(INCLUDE_DIR)/host.mk +include $(INCLUDE_DIR)/version.mk override MAKEFLAGS= -PKG_OS:=$(word 2,$(subst -, ,$(shell $(HOSTCC) -dumpmachine))) -PKG_CPU:=$(word 1,$(subst -, ,$(shell $(HOSTCC) -dumpmachine))) - -SDK_NAME:=OpenWrt-SDK-$(BOARD)-for-$(PKG_OS)-$(PKG_CPU)-gcc-$(GCCV)_$(LIBC)-$(LIBCV) +SDK_NAME:=$(VERSION_DIST)-SDK-$(if $(CONFIG_VERSION_FILENAMES),$(VERSION_NUMBER)-)$(BOARD)$(if $(SUBTARGET),-$(SUBTARGET))$(if $(GCCV),_gcc-$(GCCV))$(DIR_SUFFIX).$(HOST_OS)-$(HOST_ARCH) SDK_BUILD_DIR:=$(BUILD_DIR)/$(SDK_NAME) + +STAGING_SUBDIR_HOST := staging_dir/host +STAGING_SUBDIR_TOOLCHAIN := staging_dir/toolchain-$(ARCH)$(ARCH_SUFFIX)_gcc-$(GCCV)_$(LIBC)-$(LIBCV)$(if $(CONFIG_arm),_eabi) + EXCLUDE_DIRS:=*/ccache \ */stamp \ */stampfiles \ */man \ */info \ + */root-* \ + initial \ + *.install.clean \ + *.install.flags \ + *.install \ + */doc SDK_DIRS = \ - staging_dir/host \ - staging_dir/target-$(ARCH)$(ARCH_SUFFIX)_$(LIBC)-$(LIBCV)$(if $(CONFIG_arm),_eabi) \ - staging_dir/toolchain-$(ARCH)$(ARCH_SUFFIX)_gcc-$(GCCV)_$(LIBC)-$(LIBCV)$(if $(CONFIG_arm),_eabi) \ + $(STAGING_SUBDIR_HOST) \ + $(STAGING_SUBDIR_TOOLCHAIN) -SVN_PACKAGE_URL=$(shell svn info ../../package | awk '/^URL:/ { print $$2; }') +BASE_FEED:=$(shell git config --get remote.origin.url 2>/dev/null | sed -ne 's/^/src-git base /p') +BASE_FEED:=$(if $(BASE_FEED),$(BASE_FEED),$(shell cd $(TOPDIR); LC_ALL=C git svn info 2>/dev/null | sed -ne 's/^URL: /src-gitsvn base /p')) +BASE_FEED:=$(if $(BASE_FEED),$(BASE_FEED),$(shell cd $(TOPDIR); LC_ALL=C svn info 2>/dev/null | sed -ne 's/^URL: /src-svn base /p')) +BASE_FEED:=$(if $(BASE_FEED),$(BASE_FEED),src-git base https://git.openwrt.org/$(filter-out unknown/ r%/,$(subst $(space),.,$(wordlist 1,2,$(subst .,$(space),$(VERSION_NUMBER))))/)openwrt.git) KDIR_BASE = $(patsubst $(TOPDIR)/%,%,$(LINUX_DIR)) @@ -37,6 +47,7 @@ KERNEL_FILES_ARCH = \ Kbuild.platforms \ */Platform \ include \ + */include \ scripts \ kernel/asm-offsets.s @@ -46,6 +57,7 @@ KERNEL_FILES_BASE := \ scripts \ include \ Module.symvers \ + modules.builtin \ $(addprefix arch/$(LINUX_KARCH)/,$(KERNEL_FILES_ARCH)) KERNEL_FILES := $(patsubst $(TOPDIR)/%,%,$(wildcard $(addprefix $(LINUX_DIR)/,$(KERNEL_FILES_BASE)))) @@ -56,9 +68,25 @@ $(BIN_DIR)/$(SDK_NAME).tar.bz2: clean mkdir -p $(SDK_BUILD_DIR)/dl $(SDK_BUILD_DIR)/package $(CP) $(INCLUDE_DIR) $(SCRIPT_DIR) $(TOPDIR)/docs $(SDK_BUILD_DIR)/ $(TAR) -cf - -C $(TOPDIR) \ + `cd $(TOPDIR); find $(KDIR_BASE) -name \*.ko` \ $(foreach exclude,$(EXCLUDE_DIRS),--exclude="$(exclude)") \ $(SDK_DIRS) $(KERNEL_FILES) | \ $(TAR) -xf - -C $(SDK_BUILD_DIR) + + @-( \ + find \ + $(SDK_BUILD_DIR)/$(STAGING_SUBDIR_HOST)/bin \ + $(SDK_BUILD_DIR)/$(STAGING_SUBDIR_HOST)/usr/bin \ + $(SDK_BUILD_DIR)/$(STAGING_SUBDIR_TOOLCHAIN)/bin \ + $(SDK_BUILD_DIR)/$(STAGING_SUBDIR_TOOLCHAIN)/*/bin \ + $(SDK_BUILD_DIR)/$(STAGING_SUBDIR_TOOLCHAIN)/libexec \ + -type f; \ + find \ + $(SDK_BUILD_DIR)/$(STAGING_SUBDIR_HOST)/lib \ + $(SDK_BUILD_DIR)/$(STAGING_SUBDIR_HOST)/usr/lib \ + -type f -name \*.so\* -or -name \*.a; \ + ) | xargs strip 2>/dev/null >/dev/null + mkdir -p $(SDK_BUILD_DIR)/target/linux $(CP) $(GENERIC_PLATFORM_DIR) $(PLATFORM_DIR) $(SDK_BUILD_DIR)/target/linux/ rm -rf \ @@ -71,17 +99,22 @@ $(BIN_DIR)/$(SDK_NAME).tar.bz2: clean $(TOPDIR)/.config \ ./files/Config.in \ ./files/Makefile \ + ./files/include/prepare.mk \ ./files/README.SDK \ $(SDK_BUILD_DIR)/ $(CP) \ $(TOPDIR)/package/Makefile \ $(SDK_BUILD_DIR)/package/ - $(if $(SVN_PACKAGE_URL),echo "src-svn trunk $(SVN_PACKAGE_URL)" \ - > $(SDK_BUILD_DIR)/feeds.conf.default,\ - -rm -f $(SDK_BUILD_DIR)/feeds.conf.default) - cat $(TOPDIR)/feeds.conf.default \ - >> $(SDK_BUILD_DIR)/feeds.conf.default + + -rm -f $(SDK_BUILD_DIR)/feeds.conf.default + $(if $(BASE_FEED),echo "$(BASE_FEED)" > $(SDK_BUILD_DIR)/feeds.conf.default) + if [ -f $(TOPDIR)/feeds.conf ]; then \ + cat $(TOPDIR)/feeds.conf >> $(SDK_BUILD_DIR)/feeds.conf.default; \ + else \ + cat $(TOPDIR)/feeds.conf.default >> $(SDK_BUILD_DIR)/feeds.conf.default; \ + fi $(SED) 's,^# REVISION:=.*,REVISION:=$(REVISION),g' $(SDK_BUILD_DIR)/include/version.mk + $(SED) '/LINUX_VERMAGIC:=/ { s,unknown,$(LINUX_VERMAGIC),g }' $(SDK_BUILD_DIR)/include/kernel.mk find $(SDK_BUILD_DIR) -name .git | $(XARGS) rm -rf find $(SDK_BUILD_DIR) -name .svn | $(XARGS) rm -rf find $(SDK_BUILD_DIR) -name CVS | $(XARGS) rm -rf