From 12981e9be2443e5529c2de4bddd731e0fdc5e075 Mon Sep 17 00:00:00 2001 From: Vladimir Makarov Date: Fri, 29 Nov 2019 22:04:21 +0000 Subject: [PATCH] re PR rtl-optimization/92283 (454.calculix miscomparison since r276645 with -O2 -march=znver2) 2019-11-29 Vladimir Makarov PR rtl-optimization/92283 * lra.c (lra): Update reg notes after inheritance sub-pass and before constraint sub-pass. From-SVN: r278865 --- gcc/ChangeLog | 6 ++++++ gcc/lra.c | 7 ++++++- 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 98a93a5086e..630d388677c 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2019-11-29 Vladimir Makarov + + PR rtl-optimization/92283 + * lra.c (lra): Update reg notes after inheritance sub-pass and + before constraint sub-pass. + 2019-11-29 Richard Biener PR tree-optimization/91003 diff --git a/gcc/lra.c b/gcc/lra.c index ec20aed4492..42b58714d41 100644 --- a/gcc/lra.c +++ b/gcc/lra.c @@ -2473,7 +2473,7 @@ lra (FILE *f) But don't remove dead insns or change global live info as we can undo inheritance transformations after inheritance pseudo assigning. */ - lra_create_live_ranges (true, false); + lra_create_live_ranges (true, !lra_simple_p); live_p = true; /* If we don't spill non-reload and non-inheritance pseudos, there is no sense to run memory-memory move @@ -2514,6 +2514,11 @@ lra (FILE *f) } } while (fails_p); + if (! live_p) { + /* We need the correct reg notes for work of constraint sub-pass. */ + lra_create_live_ranges (true, true); + live_p = true; + } } /* Don't clear optional reloads bitmap until all constraints are satisfied as we need to differ them from regular reloads. */ -- 2.30.2