diff options
| author | Eric Botcazou <ebotcazou@adacore.com> | 2016-12-14 08:34:15 +0000 |
|---|---|---|
| committer | Eric Botcazou <ebotcazou@gcc.gnu.org> | 2016-12-14 08:34:15 +0000 |
| commit | 164f063463d64a1575841d6735ba0298605c4626 (patch) | |
| tree | bfb574cb2d86464e1c68ee835b1cd19a067945b5 /gcc/lra-constraints.c | |
| parent | 253c0172bb2c525b784355d75ac484b03fa7273b (diff) | |
| download | gcc-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/lra-constraints.c')
| -rw-r--r-- | gcc/lra-constraints.c | 6 |
1 files changed, 5 insertions, 1 deletions
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))) |
