From d34501d3c7bad3bdefd898b6a3ce65db03e4e4e6 Mon Sep 17 00:00:00 2001 From: "Yann E. MORIN\"" Date: Sat, 9 Oct 2010 23:28:39 +0200 Subject: cc/gcc: add 4.4.5 Add 4.4.5, propagate patchset from 4.4.4. Signed-off-by: "Yann E. MORIN" --- patches/gcc/4.4.5/190-flatten-switch-stmt-00.patch | 24 ++++++++++++++++++++++ 1 file changed, 24 insertions(+) create mode 100644 patches/gcc/4.4.5/190-flatten-switch-stmt-00.patch (limited to 'patches/gcc/4.4.5/190-flatten-switch-stmt-00.patch') diff --git a/patches/gcc/4.4.5/190-flatten-switch-stmt-00.patch b/patches/gcc/4.4.5/190-flatten-switch-stmt-00.patch new file mode 100644 index 00000000..d4d68fe4 --- /dev/null +++ b/patches/gcc/4.4.5/190-flatten-switch-stmt-00.patch @@ -0,0 +1,24 @@ +diff -durN gcc-4.4.5.orig/gcc/stmt.c gcc-4.4.5/gcc/stmt.c +--- gcc-4.4.5.orig/gcc/stmt.c 2010-03-08 12:46:28.000000000 +0100 ++++ gcc-4.4.5/gcc/stmt.c 2010-10-09 23:01:01.000000000 +0200 +@@ -2377,7 +2377,11 @@ + use_cost_table + = (TREE_CODE (orig_type) != ENUMERAL_TYPE + && estimate_case_costs (case_list)); +- balance_case_nodes (&case_list, NULL); ++ /* When optimizing for size, we want a straight list to avoid ++ jumps as much as possible. This basically creates an if-else ++ chain. */ ++ if (!optimize_size) ++ balance_case_nodes (&case_list, NULL); + emit_case_nodes (index, case_list, default_label, index_type); + if (default_label) + emit_jump (default_label); +@@ -2943,6 +2947,7 @@ + { + if (!node_has_low_bound (node, index_type)) + { ++ if (!optimize_size) /* don't jl to the .default_label. */ + emit_cmp_and_jump_insns (index, + convert_modes + (mode, imode, -- cgit v1.2.3