public inbox for gcc-cvs@sourceware.org
help / color / mirror / Atom feed
* [gcc r12-7817] [PR104971] LRA: check live hard regs to remove a dead insn
@ 2022-03-25 16:31 Vladimir Makarov
0 siblings, 0 replies; only message in thread
From: Vladimir Makarov @ 2022-03-25 16:31 UTC (permalink / raw)
To: gcc-cvs
https://gcc.gnu.org/g:25725506b85f478076770942d76799c54310c696
commit r12-7817-g25725506b85f478076770942d76799c54310c696
Author: Vladimir N. Makarov <vmakarov@redhat.com>
Date: Fri Mar 25 12:22:08 2022 -0400
[PR104971] LRA: check live hard regs to remove a dead insn
LRA removes insn modifying sp for given PR test set. We should also have
checked living hard regs to prevent this. The patch fixes this.
gcc/ChangeLog:
PR middle-end/104971
* lra-lives.cc (process_bb_lives): Check hard_regs_live for hard
regs to clear remove_p flag.
Diff:
---
gcc/lra-lives.cc | 5 ++++-
1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/gcc/lra-lives.cc b/gcc/lra-lives.cc
index 796f00629b4..a755464ee81 100644
--- a/gcc/lra-lives.cc
+++ b/gcc/lra-lives.cc
@@ -724,7 +724,10 @@ process_bb_lives (basic_block bb, int &curr_point, bool dead_insn_p)
bool remove_p = true;
for (reg = curr_id->regs; reg != NULL; reg = reg->next)
- if (reg->type != OP_IN && sparseset_bit_p (pseudos_live, reg->regno))
+ if (reg->type != OP_IN
+ && (reg->regno < FIRST_PSEUDO_REGISTER
+ ? TEST_HARD_REG_BIT (hard_regs_live, reg->regno)
+ : sparseset_bit_p (pseudos_live, reg->regno)))
{
remove_p = false;
break;
^ permalink raw reply [flat|nested] only message in thread
only message in thread, other threads:[~2022-03-25 16:31 UTC | newest]
Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2022-03-25 16:31 [gcc r12-7817] [PR104971] LRA: check live hard regs to remove a dead insn Vladimir Makarov
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).