aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorEric Botcazou <ebotcazou@adacore.com>2016-12-14 08:34:15 +0000
committerEric Botcazou <ebotcazou@gcc.gnu.org>2016-12-14 08:34:15 +0000
commit164f063463d64a1575841d6735ba0298605c4626 (patch)
treebfb574cb2d86464e1c68ee835b1cd19a067945b5 /gcc
parent253c0172bb2c525b784355d75ac484b03fa7273b (diff)
downloadgcc-164f063463d64a1575841d6735ba0298605c4626.zip
gcc-164f063463d64a1575841d6735ba0298605c4626.tar.gz
gcc-164f063463d64a1575841d6735ba0298605c4626.tar.bz2
lra-constraints.c (process_address_1): Do not attempt to decompose addresses for MEMs that satisfy fixed-form constraints.
* lra-constraints.c (process_address_1): Do not attempt to decompose addresses for MEMs that satisfy fixed-form constraints. From-SVN: r243632
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/lra-constraints.c6
2 files changed, 10 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 17a3361..24c6672 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2016-12-14 Eric Botcazou <ebotcazou@adacore.com>
+
+ * lra-constraints.c (process_address_1): Do not attempt to decompose
+ addresses for MEMs that satisfy fixed-form constraints.
+
2016-12-14 Richard Biener <rguenther@suse.de>
PR tree-optimization/78788
diff --git a/gcc/lra-constraints.c b/gcc/lra-constraints.c
index e661aef..f7009ea 100644
--- a/gcc/lra-constraints.c
+++ b/gcc/lra-constraints.c
@@ -3080,7 +3080,11 @@ process_address_1 (int nop, bool check_only_p,
if (insn_extra_address_constraint (cn))
decompose_lea_address (&ad, curr_id->operand_loc[nop]);
- else if (MEM_P (op))
+ /* Do not attempt to decompose arbitrary addresses generated by combine
+ for asm operands with loose constraints, e.g 'X'. */
+ else if (MEM_P (op)
+ && !(get_constraint_type (cn) == CT_FIXED_FORM
+ && constraint_satisfied_p (op, cn)))
decompose_mem_address (&ad, op);
else if (GET_CODE (op) == SUBREG
&& MEM_P (SUBREG_REG (op)))