Add an isSSA() flag to MachineRegisterInfo.
authorJakob Stoklund Olesen <stoklund@2pi.dk>
Fri, 29 Jul 2011 22:51:22 +0000 (22:51 +0000)
committerJakob Stoklund Olesen <stoklund@2pi.dk>
Fri, 29 Jul 2011 22:51:22 +0000 (22:51 +0000)
commit73e7dced3892f2abb4344526147d4df0f62aee61
tree50421d085c033990e15663273d045974402d7c95
parent05bce0beee87512e52428d4b80f5a8e79a949576
Add an isSSA() flag to MachineRegisterInfo.

This flag is true from isel to register allocation when the machine
function is required to be in SSA form.  The TwoAddressInstructionPass
and PHIElimination passes clear the flag.

The SSA flag wil be used by the machine code verifier to check for SSA
form, and eventually an assertion can enforce it in +Asserts builds.
This will catch the common target error of creating machine code with
multiple defs of a virtual register.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@136532 91177308-0d34-0410-b5e6-96231b3b80d8
include/llvm/CodeGen/MachineRegisterInfo.h
lib/CodeGen/MachineRegisterInfo.cpp
lib/CodeGen/PHIElimination.cpp
lib/CodeGen/TwoAddressInstructionPass.cpp