Commit a44e0ebb by Kyrylo Tkachov Committed by Kyrylo Tkachov

[AArch64] PR target/69161: Don't use special predicate for CCmode comparisons in…

[AArch64] PR target/69161: Don't use special predicate for CCmode comparisons in expressions that require matching modes

	PR target/69161
	* config/aarch64/predicates.md (aarch64_comparison_operator_mode):
	New predicate.
	(aarch64_comparison_operator): Break overly long line into two.
	(aarch64_comparison_operation): Likewise.
	* config/aarch64/aarch64.md (cstorecc4): Use
	aarch64_comparison_operator_mode instead of
	aarch64_comparison_operator.
	(cstore<mode>4): Likewise.
	(aarch64_cstore<mode>): Likewise.
	(*cstoresi_insn_uxtw): Likewise.
	(cstore<mode>_neg): Likewise.
	(*cstoresi_neg_uxtw): Likewise.

	* gcc.c-torture/compile/pr69161.c: New test.

From-SVN: r233496
parent ac4bf407
2016-02-17 Kyrylo Tkachov <kyrylo.tkachov@arm.com> 2016-02-17 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
PR target/69161 PR target/69161
* config/aarch64/predicates.md (aarch64_comparison_operator_mode):
New predicate.
(aarch64_comparison_operator): Break overly long line into two.
(aarch64_comparison_operation): Likewise.
* config/aarch64/aarch64.md (cstorecc4): Use
aarch64_comparison_operator_mode instead of
aarch64_comparison_operator.
(cstore<mode>4): Likewise.
(aarch64_cstore<mode>): Likewise.
(*cstoresi_insn_uxtw): Likewise.
(cstore<mode>_neg): Likewise.
(*cstoresi_neg_uxtw): Likewise.
2016-02-17 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
PR target/69161
* config/arm/predicates.md (arm_comparison_operator_mode): * config/arm/predicates.md (arm_comparison_operator_mode):
New predicate. New predicate.
* config/arm/arm.md (*mov_scc): Use arm_comparison_operator_mode * config/arm/arm.md (*mov_scc): Use arm_comparison_operator_mode
......
...@@ -3039,7 +3039,7 @@ ...@@ -3039,7 +3039,7 @@
(define_expand "cstorecc4" (define_expand "cstorecc4"
[(set (match_operand:SI 0 "register_operand") [(set (match_operand:SI 0 "register_operand")
(match_operator 1 "aarch64_comparison_operator" (match_operator 1 "aarch64_comparison_operator_mode"
[(match_operand 2 "cc_register") [(match_operand 2 "cc_register")
(match_operand 3 "const0_operand")]))] (match_operand 3 "const0_operand")]))]
"" ""
...@@ -3051,7 +3051,7 @@ ...@@ -3051,7 +3051,7 @@
(define_expand "cstore<mode>4" (define_expand "cstore<mode>4"
[(set (match_operand:SI 0 "register_operand" "") [(set (match_operand:SI 0 "register_operand" "")
(match_operator:SI 1 "aarch64_comparison_operator" (match_operator:SI 1 "aarch64_comparison_operator_mode"
[(match_operand:GPF 2 "register_operand" "") [(match_operand:GPF 2 "register_operand" "")
(match_operand:GPF 3 "aarch64_fp_compare_operand" "")]))] (match_operand:GPF 3 "aarch64_fp_compare_operand" "")]))]
"" ""
...@@ -3064,7 +3064,7 @@ ...@@ -3064,7 +3064,7 @@
(define_insn "aarch64_cstore<mode>" (define_insn "aarch64_cstore<mode>"
[(set (match_operand:ALLI 0 "register_operand" "=r") [(set (match_operand:ALLI 0 "register_operand" "=r")
(match_operator:ALLI 1 "aarch64_comparison_operator" (match_operator:ALLI 1 "aarch64_comparison_operator_mode"
[(match_operand 2 "cc_register" "") (const_int 0)]))] [(match_operand 2 "cc_register" "") (const_int 0)]))]
"" ""
"cset\\t%<w>0, %m1" "cset\\t%<w>0, %m1"
...@@ -3109,7 +3109,7 @@ ...@@ -3109,7 +3109,7 @@
(define_insn "*cstoresi_insn_uxtw" (define_insn "*cstoresi_insn_uxtw"
[(set (match_operand:DI 0 "register_operand" "=r") [(set (match_operand:DI 0 "register_operand" "=r")
(zero_extend:DI (zero_extend:DI
(match_operator:SI 1 "aarch64_comparison_operator" (match_operator:SI 1 "aarch64_comparison_operator_mode"
[(match_operand 2 "cc_register" "") (const_int 0)])))] [(match_operand 2 "cc_register" "") (const_int 0)])))]
"" ""
"cset\\t%w0, %m1" "cset\\t%w0, %m1"
...@@ -3118,7 +3118,7 @@ ...@@ -3118,7 +3118,7 @@
(define_insn "cstore<mode>_neg" (define_insn "cstore<mode>_neg"
[(set (match_operand:ALLI 0 "register_operand" "=r") [(set (match_operand:ALLI 0 "register_operand" "=r")
(neg:ALLI (match_operator:ALLI 1 "aarch64_comparison_operator" (neg:ALLI (match_operator:ALLI 1 "aarch64_comparison_operator_mode"
[(match_operand 2 "cc_register" "") (const_int 0)])))] [(match_operand 2 "cc_register" "") (const_int 0)])))]
"" ""
"csetm\\t%<w>0, %m1" "csetm\\t%<w>0, %m1"
...@@ -3129,7 +3129,7 @@ ...@@ -3129,7 +3129,7 @@
(define_insn "*cstoresi_neg_uxtw" (define_insn "*cstoresi_neg_uxtw"
[(set (match_operand:DI 0 "register_operand" "=r") [(set (match_operand:DI 0 "register_operand" "=r")
(zero_extend:DI (zero_extend:DI
(neg:SI (match_operator:SI 1 "aarch64_comparison_operator" (neg:SI (match_operator:SI 1 "aarch64_comparison_operator_mode"
[(match_operand 2 "cc_register" "") (const_int 0)]))))] [(match_operand 2 "cc_register" "") (const_int 0)]))))]
"" ""
"csetm\\t%w0, %m1" "csetm\\t%w0, %m1"
......
...@@ -229,10 +229,19 @@ ...@@ -229,10 +229,19 @@
;; True for integer comparisons and for FP comparisons other than LTGT or UNEQ. ;; True for integer comparisons and for FP comparisons other than LTGT or UNEQ.
(define_special_predicate "aarch64_comparison_operator" (define_special_predicate "aarch64_comparison_operator"
(match_code "eq,ne,le,lt,ge,gt,geu,gtu,leu,ltu,unordered,ordered,unlt,unle,unge,ungt")) (match_code "eq,ne,le,lt,ge,gt,geu,gtu,leu,ltu,unordered,
ordered,unlt,unle,unge,ungt"))
;; Same as aarch64_comparison_operator but don't ignore the mode.
;; RTL SET operations require their operands source and destination have
;; the same modes, so we can't ignore the modes there. See PR target/69161.
(define_predicate "aarch64_comparison_operator_mode"
(match_code "eq,ne,le,lt,ge,gt,geu,gtu,leu,ltu,unordered,
ordered,unlt,unle,unge,ungt"))
(define_special_predicate "aarch64_comparison_operation" (define_special_predicate "aarch64_comparison_operation"
(match_code "eq,ne,le,lt,ge,gt,geu,gtu,leu,ltu,unordered,ordered,unlt,unle,unge,ungt") (match_code "eq,ne,le,lt,ge,gt,geu,gtu,leu,ltu,unordered,
ordered,unlt,unle,unge,ungt")
{ {
if (XEXP (op, 1) != const0_rtx) if (XEXP (op, 1) != const0_rtx)
return false; return false;
......
2016-02-17 Kyrylo Tkachov <kyrylo.tkachov@arm.com>
PR target/69161
* gcc.c-torture/compile/pr69161.c: New test.
2016-02-17 David Sherwood <david.sherwood@arm.com> 2016-02-17 David Sherwood <david.sherwood@arm.com>
PR target/69532 PR target/69532
......
/* PR target/69161. */
char a;
int b, c, d, e;
void
foo (void)
{
int f;
for (f = 0; f <= 4; f++)
{
for (d = 0; d < 20; d++)
{
__INTPTR_TYPE__ g = (__INTPTR_TYPE__) & c;
b &= (0 != g) > e;
}
e &= a;
}
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment