[PATCH] D119973: RegAllocGreedy: Fix last chance recolor assert in impossible case
Matt Arsenault via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Fri Mar 18 09:14:51 PDT 2022
arsenm added a comment.
In D119973#3392342 <https://reviews.llvm.org/D119973#3392342>, @qcolombet wrote:
> The complicated cases are indeed not well tested since it is very hard to hit them. I was hoping Matt's fix would avoid falling in one of them, while not preventing actual success. Looks like it wasn't the case.
>
>> So e.g. if one of the evicted vregs get splitted, then the allocator may end up in a corrupted state after the physreg is restored to the splitted vreg. The vreg may then have an empty live range but still have a physreg allocated, and this may later lead to a number of different assertions and crashes.
>
> Is this what is happening here?
> Would it be enough to drop the attempted recolored vreg when it has an empty range? (At this point, its live-range should be covered by the new split vregs)
I'm still working on debugging this. I sort of see what's happening, but not really. At the point of failure, it's trying to unassign and reassign a register which was added to FixedRegisters after the initial interference check. It seems like the interference check needs to account for registers which will be added to FixedRegisters in the recursive calls. At the points those points are made, the ultimate parent register isn't in FixedRegisters for some reason.
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D119973/new/
https://reviews.llvm.org/D119973
More information about the llvm-commits
mailing list