This reduces the number of spills in some cases, like the new testcase phi-backedge-split.ll. It seems like it helps the allocator generate better code for PHIs where the operand is another PHI, since the implied COPY shouldn't really exist on any path other than the backedge.
It's possible the heuristic could be improved here; it seems like this makes the code slightly worse in a couple of the x86 regression tests, like CodeGen/X86/madd.ll. But I'm not really sure what else makes sense to check here; I mean, I could check if the predecessor vreg is specifically a PHI, but that seems hacky.
I'm not confident this is the best way to solve the spilling inefficiency I see in phi-backedge-split.ll, but I'm not sure what the alternative would look like.
I believe this should be target dependent. I.e., we should get that through a target API.
We can keep the option for testing though.