From 716ca530e1c4515d8683c9d5be3d56b301758b66 Mon Sep 17 00:00:00 2001 From: James <> Date: Wed, 4 Nov 2015 11:49:21 +0000 Subject: trunk-47381 --- target/sdk/Config.in | 9 +++ target/sdk/Makefile | 130 ++++++++++++++++++++++++++++++++++++ target/sdk/convert-config.pl | 41 ++++++++++++ target/sdk/files/Config.in | 7 ++ target/sdk/files/Makefile | 59 ++++++++++++++++ target/sdk/files/README.SDK | 7 ++ target/sdk/files/include/prepare.mk | 17 +++++ 7 files changed, 270 insertions(+) create mode 100644 target/sdk/Config.in create mode 100644 target/sdk/Makefile create mode 100755 target/sdk/convert-config.pl create mode 100644 target/sdk/files/Config.in create mode 100644 target/sdk/files/Makefile create mode 100644 target/sdk/files/README.SDK create mode 100644 target/sdk/files/include/prepare.mk (limited to 'target/sdk') diff --git a/target/sdk/Config.in b/target/sdk/Config.in new file mode 100644 index 0000000..28c6f3e --- /dev/null +++ b/target/sdk/Config.in @@ -0,0 +1,9 @@ +config SDK + bool "Build the OpenWrt SDK" + depends on !EXTERNAL_TOOLCHAIN + help + This is essentially a stripped-down version of the buildroot + with a precompiled toolchain. It can be used to develop and + test packages for OpenWrt before including them in the buildroot + + diff --git a/target/sdk/Makefile b/target/sdk/Makefile new file mode 100644 index 0000000..d81c237 --- /dev/null +++ b/target/sdk/Makefile @@ -0,0 +1,130 @@ +# +# Copyright (C) 2006-2014 OpenWrt.org +# +# This is free software, licensed under the GNU General Public License v2. +# See /LICENSE for more information. +# + +include $(TOPDIR)/rules.mk +include $(INCLUDE_DIR)/kernel.mk +include $(INCLUDE_DIR)/host.mk +include $(INCLUDE_DIR)/version.mk + +override MAKEFLAGS= + +SDK_NAME:=OpenWrt-SDK-$(if $(CONFIG_VERSION_FILENAMES),$(VERSION_NUMBER)-)$(BOARD)$(if $(SUBTARGET),-$(SUBTARGET))_gcc-$(GCCV)$(DIR_SUFFIX).$(HOST_OS)-$(HOST_ARCH) +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 + +SDK_DIRS = \ + $(STAGING_SUBDIR_HOST) \ + $(STAGING_SUBDIR_TARGET) \ + $(STAGING_SUBDIR_TOOLCHAIN) + +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')) + +KDIR_BASE = $(patsubst $(TOPDIR)/%,%,$(LINUX_DIR)) + +KERNEL_FILES_ARCH = \ + Makefile* \ + module.lds \ + Kbuild.platforms \ + */Platform \ + include \ + */include \ + scripts \ + kernel/asm-offsets.s + +KERNEL_FILES_BASE := \ + .config \ + Makefile \ + scripts \ + include \ + Module.symvers \ + $(addprefix arch/$(LINUX_KARCH)/,$(KERNEL_FILES_ARCH)) + +KERNEL_FILES := $(patsubst $(TOPDIR)/%,%,$(wildcard $(addprefix $(LINUX_DIR)/,$(KERNEL_FILES_BASE)))) + +all: compile + +$(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) \ + $(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 \ + $(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 \ + $(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/ + + -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 + (cd $(BUILD_DIR); \ + tar cfj $@ $(SDK_NAME); \ + ) + +download: +prepare: +compile: $(BIN_DIR)/$(SDK_NAME).tar.bz2 +install: compile + +clean: + rm -rf $(SDK_BUILD_DIR) $(BIN_DIR)/$(SDK_NAME).tar.bz2 diff --git a/target/sdk/convert-config.pl b/target/sdk/convert-config.pl new file mode 100755 index 0000000..e701b42 --- /dev/null +++ b/target/sdk/convert-config.pl @@ -0,0 +1,41 @@ +#!/usr/bin/env perl +use strict; + +print <) { + chomp; + next if /^CONFIG_SIGNED_PACKAGES/; + next unless /^CONFIG_([^=]+)=(.*)$/; + + my $var = $1; + my $val = $2; + my $type; + + next if $var eq 'ALL'; + + if ($val eq 'y') { + $type = "bool"; + } elsif ($val eq 'm') { + $type = "tristate"; + } elsif ($val =~ /^".*"$/) { + $type = "string"; + } elsif ($val =~ /^\d+$/) { + $type = "int"; + } else { + warn "WARNING: no type found for symbol CONFIG_$var=$val\n"; + next; + } + + print <