aboutsummaryrefslogtreecommitdiff
path: root/gcc/lra-constraints.c
diff options
context:
space:
mode:
authorliuhongt <hongtao.liu@intel.com>2020-10-26 20:46:42 +0800
committerliuhongt <hongtao.liu@intel.com>2020-11-04 13:06:32 +0800
commit2e0aa43fc6ae689c595902310baec604e7e0d695 (patch)
tree31a62ed7fb7e9699e169f994db289b256d687411 /gcc/lra-constraints.c
parentdb8b3e148d5cc5358cd48886e5334bd50d2d3317 (diff)
downloadgcc-2e0aa43fc6ae689c595902310baec604e7e0d695.zip
gcc-2e0aa43fc6ae689c595902310baec604e7e0d695.tar.gz
gcc-2e0aa43fc6ae689c595902310baec604e7e0d695.tar.bz2
Don't extract memory from operand for normal memory constraint.
gcc/ChangeLog PR target/97540 * ira.c: (ira_setup_alts): Extract memory from operand only for special memory constraint. * recog.c (asm_operand_ok): Ditto. * lra-constraints.c (process_alt_operands): MEM_P is required for normal memory constraint. gcc/testsuite/ChangeLog * gcc.target/i386/pr97540.c: New test.
Diffstat (limited to 'gcc/lra-constraints.c')
-rw-r--r--gcc/lra-constraints.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/gcc/lra-constraints.c b/gcc/lra-constraints.c
index 22e7075..fbc47ba 100644
--- a/gcc/lra-constraints.c
+++ b/gcc/lra-constraints.c
@@ -2428,7 +2428,8 @@ process_alt_operands (int only_alternative)
break;
case CT_MEMORY:
- if (satisfies_memory_constraint_p (op, cn))
+ if (MEM_P (op)
+ && satisfies_memory_constraint_p (op, cn))
win = true;
else if (spilled_pseudo_p (op))
win = true;