mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-24 11:42:57 +01:00
Give RemoveRegOperandFromRegInfo a comment and move the
code out of line. llvm-svn: 69124
This commit is contained in:
parent
427e9aade9
commit
c9b68844d6
@ -427,18 +427,9 @@ private:
|
||||
/// explicitly nulled out.
|
||||
void AddRegOperandToRegInfo(MachineRegisterInfo *RegInfo);
|
||||
|
||||
void RemoveRegOperandFromRegInfo() {
|
||||
assert(isOnRegUseList() && "Reg operand is not on a use list");
|
||||
// Unlink this from the doubly linked list of operands.
|
||||
MachineOperand *NextOp = Contents.Reg.Next;
|
||||
*Contents.Reg.Prev = NextOp;
|
||||
if (NextOp) {
|
||||
assert(NextOp->getReg() == getReg() && "Corrupt reg use/def chain!");
|
||||
NextOp->Contents.Reg.Prev = Contents.Reg.Prev;
|
||||
}
|
||||
Contents.Reg.Prev = 0;
|
||||
Contents.Reg.Next = 0;
|
||||
}
|
||||
/// RemoveRegOperandFromRegInfo - Remove this register operand from the
|
||||
/// MachineRegisterInfo it is linked with.
|
||||
void RemoveRegOperandFromRegInfo();
|
||||
};
|
||||
|
||||
inline std::ostream &operator<<(std::ostream &OS, const MachineOperand &MO) {
|
||||
|
@ -68,6 +68,21 @@ void MachineOperand::AddRegOperandToRegInfo(MachineRegisterInfo *RegInfo) {
|
||||
*Head = this;
|
||||
}
|
||||
|
||||
/// RemoveRegOperandFromRegInfo - Remove this register operand from the
|
||||
/// MachineRegisterInfo it is linked with.
|
||||
void MachineOperand::RemoveRegOperandFromRegInfo() {
|
||||
assert(isOnRegUseList() && "Reg operand is not on a use list");
|
||||
// Unlink this from the doubly linked list of operands.
|
||||
MachineOperand *NextOp = Contents.Reg.Next;
|
||||
*Contents.Reg.Prev = NextOp;
|
||||
if (NextOp) {
|
||||
assert(NextOp->getReg() == getReg() && "Corrupt reg use/def chain!");
|
||||
NextOp->Contents.Reg.Prev = Contents.Reg.Prev;
|
||||
}
|
||||
Contents.Reg.Prev = 0;
|
||||
Contents.Reg.Next = 0;
|
||||
}
|
||||
|
||||
void MachineOperand::setReg(unsigned Reg) {
|
||||
if (getReg() == Reg) return; // No change.
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user