target/sdk: strip host binaries before packing
[openwrt.git] / target / sdk / Makefile
index 60201c8..828cff5 100644 (file)
@@ -16,16 +16,28 @@ PKG_CPU:=$(word 1,$(subst -, ,$(shell $(HOSTCC) -dumpmachine)))
 
 SDK_NAME:=OpenWrt-SDK-$(BOARD)-for-$(PKG_OS)-$(PKG_CPU)-gcc-$(GCCV)_$(LIBC)-$(LIBCV)
 SDK_BUILD_DIR:=$(BUILD_DIR)/$(SDK_NAME)
+
+STAGING_SUBDIR_HOST := staging_dir/host
+STAGING_SUBDIR_TARGET := staging_dir/target-$(ARCH)$(ARCH_SUFFIX)_$(LIBC)-$(LIBCV)$(if $(CONFIG_arm),_eabi)
+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 \
+       $(STAGING_SUBDIR_TARGET)/usr/bin
 
 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_TARGET) \
+               $(STAGING_SUBDIR_TOOLCHAIN)
 
 SVN_PACKAGE_URL=$(shell svn info ../../package | awk '/^URL:/ { print $$2; }')
 
@@ -57,14 +69,29 @@ $(BIN_DIR)/$(SDK_NAME).tar.bz2: clean
        $(CP) $(INCLUDE_DIR) $(SCRIPT_DIR) $(TOPDIR)/docs $(SDK_BUILD_DIR)/
        $(TAR) -cf - -C $(TOPDIR) \
                $(foreach exclude,$(EXCLUDE_DIRS),--exclude="$(exclude)") \
-               --exclude="staging_dir/$(ARCH)" \
                $(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 \
                $(SDK_BUILD_DIR)/target/linux/*/files* \
                $(SDK_BUILD_DIR)/target/linux/*/patches*
+       ./convert-config.pl $(TOPDIR)/.config > $(SDK_BUILD_DIR)/Config-build.in
        $(CP) -L \
                $(TOPDIR)/LICENSE \
                $(TOPDIR)/rules.mk \
@@ -74,7 +101,6 @@ $(BIN_DIR)/$(SDK_NAME).tar.bz2: clean
                ./files/README.SDK \
                $(SDK_BUILD_DIR)/
        $(CP) \
-               ./files/package/rules.mk \
                $(TOPDIR)/package/Makefile \
                $(SDK_BUILD_DIR)/package/
        $(if $(SVN_PACKAGE_URL),echo "src-svn trunk $(SVN_PACKAGE_URL)" \