summaryrefslogtreecommitdiff
path: root/gcc/config/arm/arm-ldmstm.ml
diff options
context:
space:
mode:
authorCharles Baylis <charles.baylis@linaro.org>2013-12-19 16:54:16 +0000
committerChristophe Lyon <clyon@gcc.gnu.org>2013-12-19 17:54:16 +0100
commit9f178d6abb7c472d5a749152002005a87098a352 (patch)
tree20c3ced122c1f525c6a23c6c32622ca2b37cb170 /gcc/config/arm/arm-ldmstm.ml
parent0315864862b264c7f7dbb8fcc66aadc2e563f195 (diff)
downloadgcc-9f178d6abb7c472d5a749152002005a87098a352.tar.gz
re PR target/59142 (internal compiler error while compiling OpenCV 2.4.7)
2013-12-19 Charles Baylis <charles.baylis@linaro.org> PR target/59142 gcc/ * config/arm/arm-ldmstm.ml: Use low_register_operand for Thumb patterns. * config/arm/ldmstm.md: Regenerate. From-SVN: r206125
Diffstat (limited to 'gcc/config/arm/arm-ldmstm.ml')
-rw-r--r--gcc/config/arm/arm-ldmstm.ml7
1 files changed, 5 insertions, 2 deletions
diff --git a/gcc/config/arm/arm-ldmstm.ml b/gcc/config/arm/arm-ldmstm.ml
index 0ec5e193b54..682aa2c8ee3 100644
--- a/gcc/config/arm/arm-ldmstm.ml
+++ b/gcc/config/arm/arm-ldmstm.ml
@@ -67,10 +67,13 @@ let destreg nregs first op_type thumb =
Printf.sprintf ("(match_operand:SI %d \"s_register_operand\" \"%s%s\")")
(nregs + 1) (inout_constr op_type) (constr thumb)
+let reg_predicate thumb =
+ if thumb then "low_register_operand" else "arm_hard_general_register_operand"
+
let write_ldm_set thumb nregs offset opnr first =
let indent = " " in
Printf.printf "%s" (if first then " [" else indent);
- Printf.printf "(set (match_operand:SI %d \"arm_hard_general_register_operand\" \"\")\n" opnr;
+ Printf.printf "(set (match_operand:SI %d \"%s\" \"\")\n" opnr (reg_predicate thumb);
Printf.printf "%s (mem:SI " indent;
begin if offset != 0 then Printf.printf "(plus:SI " end;
Printf.printf "%s" (destreg nregs first IN thumb);
@@ -84,7 +87,7 @@ let write_stm_set thumb nregs offset opnr first =
begin if offset != 0 then Printf.printf "(plus:SI " end;
Printf.printf "%s" (destreg nregs first IN thumb);
begin if offset != 0 then Printf.printf " (const_int %d))" offset end;
- Printf.printf ")\n%s (match_operand:SI %d \"arm_hard_general_register_operand\" \"\"))" indent opnr
+ Printf.printf ")\n%s (match_operand:SI %d \"%s\" \"\"))" indent opnr (reg_predicate thumb)
let write_ldm_peep_set extra_indent nregs opnr first =
let indent = " " ^ extra_indent in