From 01ba833e17aeea179d0034792bf7dce1d22a750e Mon Sep 17 00:00:00 2001 From: Yvan Roux Date: Tue, 13 Oct 2015 13:22:01 +0200 Subject: gcc/ Backport from trunk r226253. 2015-07-27 Wilco Dijkstra * gcc/config/aarch64/aarch64.md (aarch64_lshr_sisd_or_int_3): Place integer variant first. (aarch64_ashr_sisd_or_int_3): Likewise. Change-Id: If119d9605e334be3a74f61aeffc6d320094bf6ea --- gcc/config/aarch64/aarch64.md | 27 ++++++++++++++------------- 1 file changed, 14 insertions(+), 13 deletions(-) (limited to 'gcc') diff --git a/gcc/config/aarch64/aarch64.md b/gcc/config/aarch64/aarch64.md index 35812702f5e..fe7e2152f5e 100644 --- a/gcc/config/aarch64/aarch64.md +++ b/gcc/config/aarch64/aarch64.md @@ -3534,17 +3534,18 @@ ;; Logical right shift using SISD or Integer instruction (define_insn "*aarch64_lshr_sisd_or_int_3" - [(set (match_operand:GPI 0 "register_operand" "=w,&w,r") + [(set (match_operand:GPI 0 "register_operand" "=r,w,&w,&w") (lshiftrt:GPI - (match_operand:GPI 1 "register_operand" "w,w,r") - (match_operand:QI 2 "aarch64_reg_or_shift_imm_" "Us,w,rUs")))] + (match_operand:GPI 1 "register_operand" "r,w,w,w") + (match_operand:QI 2 "aarch64_reg_or_shift_imm_" "rUs,Us,w,0")))] "" "@ + lsr\t%0, %1, %2 ushr\t%0, %1, %2 # - lsr\t%0, %1, %2" - [(set_attr "simd" "yes,yes,no") - (set_attr "type" "neon_shift_imm,neon_shift_reg,shift_reg")] + #" + [(set_attr "simd" "no,yes,yes,yes") + (set_attr "type" "shift_reg,neon_shift_imm,neon_shift_reg,neon_shift_reg")] ) (define_split @@ -3579,18 +3580,18 @@ ;; Arithmetic right shift using SISD or Integer instruction (define_insn "*aarch64_ashr_sisd_or_int_3" - [(set (match_operand:GPI 0 "register_operand" "=w,&w,&w,r") + [(set (match_operand:GPI 0 "register_operand" "=r,w,&w,&w") (ashiftrt:GPI - (match_operand:GPI 1 "register_operand" "w,w,w,r") - (match_operand:QI 2 "aarch64_reg_or_shift_imm_di" "Us,w,0,rUs")))] + (match_operand:GPI 1 "register_operand" "r,w,w,w") + (match_operand:QI 2 "aarch64_reg_or_shift_imm_di" "rUs,Us,w,0")))] "" "@ + asr\t%0, %1, %2 sshr\t%0, %1, %2 # - # - asr\t%0, %1, %2" - [(set_attr "simd" "yes,yes,yes,no") - (set_attr "type" "neon_shift_imm,neon_shift_reg,neon_shift_reg,shift_reg")] + #" + [(set_attr "simd" "no,yes,yes,yes") + (set_attr "type" "shift_reg,neon_shift_imm,neon_shift_reg,neon_shift_reg")] ) (define_split -- cgit v1.2.3