diff options
Diffstat (limited to 'recipes-devtools/gcc/gcc-4.5/linaro/gcc-4.5-linaro-r99338.patch')
-rw-r--r-- | recipes-devtools/gcc/gcc-4.5/linaro/gcc-4.5-linaro-r99338.patch | 111 |
1 files changed, 111 insertions, 0 deletions
diff --git a/recipes-devtools/gcc/gcc-4.5/linaro/gcc-4.5-linaro-r99338.patch b/recipes-devtools/gcc/gcc-4.5/linaro/gcc-4.5-linaro-r99338.patch new file mode 100644 index 0000000000..632e80caf7 --- /dev/null +++ b/recipes-devtools/gcc/gcc-4.5/linaro/gcc-4.5-linaro-r99338.patch | |||
@@ -0,0 +1,111 @@ | |||
1 | 2009-06-23 Kazu Hirata <kazu@codesourcery.com> | ||
2 | |||
3 | Issue #4613 | ||
4 | gcc/ | ||
5 | * config/arm/arm.c (arm_rtx_costs_1): Teach that the cost of MLS | ||
6 | is the same as its underlying multiplication. | ||
7 | * config/arm/arm.md (two splitters): New. | ||
8 | * config/arm/predicates.md (binary_operator): New. | ||
9 | |||
10 | 2010-07-26 Julian Brown <julian@codesourcery.com> | ||
11 | |||
12 | Merge from Sourcery G++ 4.4: | ||
13 | |||
14 | 2008-09-08 Daniel Jacobowitz <dan@codesourcery.com> | ||
15 | |||
16 | gcc/ | ||
17 | |||
18 | === modified file 'gcc/config/arm/arm.c' | ||
19 | --- old/gcc/config/arm/arm.c 2010-08-12 11:33:54 +0000 | ||
20 | +++ new/gcc/config/arm/arm.c 2010-08-12 13:35:39 +0000 | ||
21 | @@ -6604,6 +6604,19 @@ | ||
22 | return true; | ||
23 | } | ||
24 | |||
25 | + /* MLS is just as expensive as its underlying multiplication. | ||
26 | + Exclude a shift by a constant, which is expressed as a | ||
27 | + multiplication. */ | ||
28 | + if (TARGET_32BIT && arm_arch_thumb2 | ||
29 | + && GET_CODE (XEXP (x, 1)) == MULT | ||
30 | + && ! (GET_CODE (XEXP (XEXP (x, 1), 1)) == CONST_INT | ||
31 | + && ((INTVAL (XEXP (XEXP (x, 1), 1)) & | ||
32 | + (INTVAL (XEXP (XEXP (x, 1), 1)) - 1)) == 0))) | ||
33 | + { | ||
34 | + /* The cost comes from the cost of the multiply. */ | ||
35 | + return false; | ||
36 | + } | ||
37 | + | ||
38 | /* Fall through */ | ||
39 | |||
40 | case PLUS: | ||
41 | |||
42 | === modified file 'gcc/config/arm/arm.md' | ||
43 | --- old/gcc/config/arm/arm.md 2010-08-12 11:33:54 +0000 | ||
44 | +++ new/gcc/config/arm/arm.md 2010-08-12 13:35:39 +0000 | ||
45 | @@ -1355,6 +1355,49 @@ | ||
46 | (set_attr "predicable" "yes")] | ||
47 | ) | ||
48 | |||
49 | +; The combiner cannot combine the first and last insns in the | ||
50 | +; following sequence because of the intervening insn, so help the | ||
51 | +; combiner with this splitter. The combiner does attempt to split | ||
52 | +; this particular combination but does not know this exact split. | ||
53 | +; Note that the combiner puts the constant at the outermost operation | ||
54 | +; as a part of canonicalization. | ||
55 | +; | ||
56 | +; mul r3, r2, r1 | ||
57 | +; <add/sub> r3, r3, <constant> | ||
58 | +; add r3, r3, r4 | ||
59 | + | ||
60 | +(define_split | ||
61 | + [(set (match_operand:SI 0 "s_register_operand" "") | ||
62 | + (match_operator:SI 1 "plusminus_operator" | ||
63 | + [(plus:SI (mult:SI (match_operand:SI 2 "s_register_operand" "") | ||
64 | + (match_operand:SI 3 "s_register_operand" "")) | ||
65 | + (match_operand:SI 4 "s_register_operand" "")) | ||
66 | + (match_operand:SI 5 "arm_immediate_operand" "")]))] | ||
67 | + "TARGET_32BIT" | ||
68 | + [(set (match_dup 0) | ||
69 | + (plus:SI (mult:SI (match_dup 2) (match_dup 3)) | ||
70 | + (match_dup 4))) | ||
71 | + (set (match_dup 0) | ||
72 | + (match_op_dup:SI 1 [(match_dup 0) (match_dup 5)]))] | ||
73 | + "") | ||
74 | + | ||
75 | +; Likewise for MLS. MLS is available only on select architectures. | ||
76 | + | ||
77 | +(define_split | ||
78 | + [(set (match_operand:SI 0 "s_register_operand" "") | ||
79 | + (match_operator:SI 1 "plusminus_operator" | ||
80 | + [(minus:SI (match_operand:SI 2 "s_register_operand" "") | ||
81 | + (mult:SI (match_operand:SI 3 "s_register_operand" "") | ||
82 | + (match_operand:SI 4 "s_register_operand" ""))) | ||
83 | + (match_operand:SI 5 "arm_immediate_operand" "")]))] | ||
84 | + "TARGET_32BIT && arm_arch_thumb2" | ||
85 | + [(set (match_dup 0) | ||
86 | + (minus:SI (match_dup 2) | ||
87 | + (mult:SI (match_dup 3) (match_dup 4)))) | ||
88 | + (set (match_dup 0) | ||
89 | + (match_op_dup:SI 1 [(match_dup 0) (match_dup 5)]))] | ||
90 | + "") | ||
91 | + | ||
92 | (define_insn "*mulsi3addsi_compare0" | ||
93 | [(set (reg:CC_NOOV CC_REGNUM) | ||
94 | (compare:CC_NOOV | ||
95 | |||
96 | === modified file 'gcc/config/arm/predicates.md' | ||
97 | --- old/gcc/config/arm/predicates.md 2010-08-10 13:31:21 +0000 | ||
98 | +++ new/gcc/config/arm/predicates.md 2010-08-12 13:35:39 +0000 | ||
99 | @@ -197,6 +197,11 @@ | ||
100 | (and (match_code "plus,minus,ior,xor,and") | ||
101 | (match_test "mode == GET_MODE (op)"))) | ||
102 | |||
103 | +;; True for plus/minus operators | ||
104 | +(define_special_predicate "plusminus_operator" | ||
105 | + (and (match_code "plus,minus") | ||
106 | + (match_test "mode == GET_MODE (op)"))) | ||
107 | + | ||
108 | ;; True for logical binary operators. | ||
109 | (define_special_predicate "logical_binary_operator" | ||
110 | (and (match_code "ior,xor,and") | ||
111 | |||