https://gcc.gnu.org/bugzilla/show_bug.cgi?id=93996
--- Comment #9 from Martin Liška <marxin at gcc dot gnu.org> --- (In reply to Andrew Pinski from comment #7) > This seems to fix the issue (but I am not a scheduler expert and I am not > 100% sure about it): > diff --git a/gcc/haifa-sched.c b/gcc/haifa-sched.c > index 1d3de7b6a76..9ca986eabdd 100644 > --- a/gcc/haifa-sched.c > +++ b/gcc/haifa-sched.c > @@ -4239,6 +4239,8 @@ remove_notes (rtx_insn *head, rtx_insn *tail) > if (insn != tail) > { > remove_insn (insn); > + if (NOTE_P (next) && NOTE_KIND (next) == NOTE_INSN_BASIC_BLOCK) > + next = NEXT_INSN (next); > add_reg_note (next, REG_SAVE_NOTE, > GEN_INT (NOTE_INSN_EPILOGUE_BEG)); > break; There's one another test-case (also fixed with the suggested hunk): $ ./gcc/xgcc -Bgcc /home/marxin/Programming/gcc/gcc/testsuite/gcc.target/aarch64/pr71727-2.c -ftree-parallelize-loops=10 -O3 -fsched2-use-superblocks --param=max-predicted-iterations=0 --param=parloops-min-per-thread=2 -c -S during RTL pass: sched2 /home/marxin/Programming/gcc/gcc/testsuite/gcc.target/aarch64/pr71727-2.c: In function ‘foo._loopfn.0’: /home/marxin/Programming/gcc/gcc/testsuite/gcc.target/aarch64/pr71727-2.c:11:3: internal compiler error: in safe_as_a, at is-a.h:210 11 | for (sum = 0, count = 0; count < length; count++) { | ^ 0xb32326 rtx_insn* safe_as_a<rtx_insn*, rtx_def>(rtx_def*) /home/marxin/Programming/gcc2/gcc/is-a.h:210 0xb31bb3 NEXT_INSN(rtx_insn const*) /home/marxin/Programming/gcc2/gcc/rtl.h:1469 0x209466b schedule_ebb(rtx_insn*, rtx_insn*, bool) /home/marxin/Programming/gcc2/gcc/sched-ebb.c:486 0x2094cb1 schedule_ebbs() /home/marxin/Programming/gcc2/gcc/sched-ebb.c:655 0x11b703a rest_of_handle_sched2 /home/marxin/Programming/gcc2/gcc/sched-rgn.c:3744 0x11b7208 execute /home/marxin/Programming/gcc2/gcc/sched-rgn.c:3882