From 99a5c6b06a2fe10489db7f474db3af8441b7585c Mon Sep 17 00:00:00 2001 From: Matthew Fortune Date: Wed, 10 Sep 2014 10:52:39 +0000 Subject: [PATCH] MIPS: Do not reload unallocated FP_REGS pseudos via GR_REGS gcc/ * config/mips/mips.c (mips_secondary_reload_class): Handle regno < 0 case. From-SVN: r215120 --- gcc/ChangeLog | 5 +++++ gcc/config/mips/mips.c | 5 +++-- 2 files changed, 8 insertions(+), 2 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 4f9d1cf5492..154b9daa0a0 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2014-09-10 Matthew Fortune + + * config/mips/mips.c (mips_secondary_reload_class): Handle + regno < 0 case. + 2014-09-10 Robert Suchanek * lra-lives.c (process_bb_lives): Replace assignment with bitwise OR diff --git a/gcc/config/mips/mips.c b/gcc/config/mips/mips.c index 646bb4dc7eb..d1d4defd8e5 100644 --- a/gcc/config/mips/mips.c +++ b/gcc/config/mips/mips.c @@ -12143,8 +12143,9 @@ mips_secondary_reload_class (enum reg_class rclass, if (reg_class_subset_p (rclass, FP_REGS)) { - if (MEM_P (x) - && (GET_MODE_SIZE (mode) == 4 || GET_MODE_SIZE (mode) == 8)) + if (regno < 0 + || (MEM_P (x) + && (GET_MODE_SIZE (mode) == 4 || GET_MODE_SIZE (mode) == 8))) /* In this case we can use lwc1, swc1, ldc1 or sdc1. We'll use pairs of lwc1s and swc1s if ldc1 and sdc1 are not supported. */ return NO_REGS; -- 2.30.2