aboutsummaryrefslogtreecommitdiff
path: root/gcc/lra-assigns.c
diff options
context:
space:
mode:
authorBernd Schmidt <bernds@redhat.com>2017-03-25 01:12:04 +0000
committerBernd Schmidt <bernds@gcc.gnu.org>2017-03-25 01:12:04 +0000
commit5da906ca43feb6e83cd3cdb11d59d76548005cad (patch)
treee9f003ff186d9814acb1738ac09b863f2d1584da /gcc/lra-assigns.c
parent199855f60367c12d831416ecd4b367b5d0222f67 (diff)
downloadgcc-5da906ca43feb6e83cd3cdb11d59d76548005cad.zip
gcc-5da906ca43feb6e83cd3cdb11d59d76548005cad.tar.gz
gcc-5da906ca43feb6e83cd3cdb11d59d76548005cad.tar.bz2
re PR target/80160 (operand has impossible constraints)
PR rtl-optimization/80160 PR rtl-optimization/80159 * lra-assigns.c (must_not_spill_p): Tighten new test to also take reg_alternate_class into account. * gcc.target/i386/pr80160.c: New test. From-SVN: r246473
Diffstat (limited to 'gcc/lra-assigns.c')
-rw-r--r--gcc/lra-assigns.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/gcc/lra-assigns.c b/gcc/lra-assigns.c
index 75bb630..e4cc43a 100644
--- a/gcc/lra-assigns.c
+++ b/gcc/lra-assigns.c
@@ -908,7 +908,8 @@ must_not_spill_p (unsigned spill_regno)
does not solve the general case where existing reloads fully
cover a limited register class. */
if (!bitmap_bit_p (&non_reload_pseudos, spill_regno)
- && reg_class_size [reg_preferred_class (spill_regno)] == 1)
+ && reg_class_size [reg_preferred_class (spill_regno)] == 1
+ && reg_alternate_class (spill_regno) == NO_REGS)
return true;
return false;
}