aboutsummaryrefslogtreecommitdiffstats
path: root/include/kernel-build.mk
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@openwrt.org>2009-08-08 14:22:04 +0000
committerFelix Fietkau <nbd@openwrt.org>2009-08-08 14:22:04 +0000
commit131295ce36b90000dccd977c735cfa3e3c3f54bf (patch)
treedf21f6ee4ec1fd3d2c7111ab593dc88dc72a16cc /include/kernel-build.mk
parent21addab5ab6eba9c5484ca4e43282df2abb1d5cf (diff)
downloadmaster-187ad058-131295ce36b90000dccd977c735cfa3e3c3f54bf.tar.gz
master-187ad058-131295ce36b90000dccd977c735cfa3e3c3f54bf.tar.bz2
master-187ad058-131295ce36b90000dccd977c735cfa3e3c3f54bf.zip
add an optional config option for stripping all unnecessary symbol exports from the kernel image
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@17181 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'include/kernel-build.mk')
-rw-r--r--include/kernel-build.mk24
1 files changed, 23 insertions, 1 deletions
diff --git a/include/kernel-build.mk b/include/kernel-build.mk
index d48f8b9f53..e3e446ba58 100644
--- a/include/kernel-build.mk
+++ b/include/kernel-build.mk
@@ -54,6 +54,28 @@ define BuildKernel
$(Kernel/Prepare)
touch $$@
+ $(KERNEL_BUILD_DIR)/symtab.txt: FORCE
+ find $(LINUX_DIR) $(STAGING_DIR_ROOT)/lib/modules -name \*.ko | \
+ xargs $(TARGET_CROSS)nm | \
+ awk '$$$$1 == "U" { print $$$$2 } ' | \
+ sort -u > $$@
+
+ $(KERNEL_BUILD_DIR)/symtab.h: $(KERNEL_BUILD_DIR)/symtab.txt
+ ( \
+ echo '#define SYMTAB_KEEP \'; \
+ cat $(KERNEL_BUILD_DIR)/symtab.txt | \
+ awk '{print "*(__ksymtab." $$$$1 ") \\" }'; \
+ echo; \
+ echo '#define SYMTAB_KEEP_GPL \'; \
+ cat $(KERNEL_BUILD_DIR)/symtab.txt | \
+ awk '{print "*(__ksymtab_gpl." $$$$1 ") \\" }'; \
+ echo; \
+ echo '#define SYMTAB_KEEP_STR \'; \
+ cat $(KERNEL_BUILD_DIR)/symtab.txt | \
+ awk '{print "*(__ksymtab_strings." $$$$1 ") \\" }'; \
+ echo; \
+ ) > $$@
+
$(STAMP_CONFIGURED): $(STAMP_PREPARED) $(LINUX_CONFIG) $(GENERIC_LINUX_CONFIG) $(TOPDIR)/.config
$(Kernel/Configure)
touch $$@
@@ -62,7 +84,7 @@ define BuildKernel
$(Kernel/CompileModules)
touch $$@
- $(LINUX_DIR)/.image: $(STAMP_CONFIGURED) FORCE
+ $(LINUX_DIR)/.image: $(STAMP_CONFIGURED) $(if $(CONFIG_STRIP_KERNEL_EXPORTS),$(KERNEL_BUILD_DIR)/symtab.h) FORCE
$(Kernel/CompileImage)
touch $$@