aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@openwrt.org>2009-09-22 18:00:35 +0000
committerFelix Fietkau <nbd@openwrt.org>2009-09-22 18:00:35 +0000
commite065ef25a6a6938293a72fc4be821987cdc72d56 (patch)
tree070ddc486c2b954e51053c75a8ff9998b6c096da
parent75679f70fc46f0426e452c350dfd693de97ee792 (diff)
downloadupstream-e065ef25a6a6938293a72fc4be821987cdc72d56.tar.gz
upstream-e065ef25a6a6938293a72fc4be821987cdc72d56.tar.bz2
upstream-e065ef25a6a6938293a72fc4be821987cdc72d56.zip
when using -O2 instead of -Os, get rid of the two optimizations that are causing most of the extra bloat. brings kernel size close to the -Os size again
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@17679 3c298f89-4303-0410-b956-a3cf2f4a3e73
-rw-r--r--target/linux/generic-2.6/patches-2.6.28/004-extra_optimization.patch9
-rw-r--r--target/linux/generic-2.6/patches-2.6.30/004-extra_optimization.patch9
-rw-r--r--target/linux/generic-2.6/patches-2.6.31/004-extra_optimization.patch9
3 files changed, 27 insertions, 0 deletions
diff --git a/target/linux/generic-2.6/patches-2.6.28/004-extra_optimization.patch b/target/linux/generic-2.6/patches-2.6.28/004-extra_optimization.patch
index d6866899c3..8827ed0c3d 100644
--- a/target/linux/generic-2.6/patches-2.6.28/004-extra_optimization.patch
+++ b/target/linux/generic-2.6/patches-2.6.28/004-extra_optimization.patch
@@ -1,5 +1,14 @@
--- a/Makefile
+++ b/Makefile
+@@ -512,7 +512,7 @@ all: vmlinux
+ ifdef CONFIG_CC_OPTIMIZE_FOR_SIZE
+ KBUILD_CFLAGS += -Os
+ else
+-KBUILD_CFLAGS += -O2
++KBUILD_CFLAGS += -O2 -fno-reorder-blocks -fno-tree-ch
+ endif
+
+ include $(srctree)/arch/$(SRCARCH)/Makefile
@@ -549,6 +549,9 @@ endif
NOSTDINC_FLAGS += -nostdinc -isystem $(shell $(CC) -print-file-name=include)
CHECKFLAGS += $(NOSTDINC_FLAGS)
diff --git a/target/linux/generic-2.6/patches-2.6.30/004-extra_optimization.patch b/target/linux/generic-2.6/patches-2.6.30/004-extra_optimization.patch
index 018e673e20..0b5174cbbd 100644
--- a/target/linux/generic-2.6/patches-2.6.30/004-extra_optimization.patch
+++ b/target/linux/generic-2.6/patches-2.6.30/004-extra_optimization.patch
@@ -1,5 +1,14 @@
--- a/Makefile
+++ b/Makefile
+@@ -529,7 +529,7 @@ all: vmlinux
+ ifdef CONFIG_CC_OPTIMIZE_FOR_SIZE
+ KBUILD_CFLAGS += -Os
+ else
+-KBUILD_CFLAGS += -O2
++KBUILD_CFLAGS += -O2 -fno-reorder-blocks -fno-tree-ch
+ endif
+
+ include $(srctree)/arch/$(SRCARCH)/Makefile
@@ -567,6 +567,9 @@ endif
NOSTDINC_FLAGS += -nostdinc -isystem $(shell $(CC) -print-file-name=include)
CHECKFLAGS += $(NOSTDINC_FLAGS)
diff --git a/target/linux/generic-2.6/patches-2.6.31/004-extra_optimization.patch b/target/linux/generic-2.6/patches-2.6.31/004-extra_optimization.patch
index 333acb612b..e0ba51598e 100644
--- a/target/linux/generic-2.6/patches-2.6.31/004-extra_optimization.patch
+++ b/target/linux/generic-2.6/patches-2.6.31/004-extra_optimization.patch
@@ -1,5 +1,14 @@
--- a/Makefile
+++ b/Makefile
+@@ -521,7 +521,7 @@ all: vmlinux
+ ifdef CONFIG_CC_OPTIMIZE_FOR_SIZE
+ KBUILD_CFLAGS += -Os
+ else
+-KBUILD_CFLAGS += -O2
++KBUILD_CFLAGS += -O2 -fno-reorder-blocks -fno-tree-ch
+ endif
+
+ include $(srctree)/arch/$(SRCARCH)/Makefile
@@ -559,6 +559,9 @@ endif
NOSTDINC_FLAGS += -nostdinc -isystem $(shell $(CC) -print-file-name=include)
CHECKFLAGS += $(NOSTDINC_FLAGS)