From: Chris Lattner Date: Fri, 20 Oct 2006 22:39:59 +0000 (+0000) Subject: implement MachineOperand::isIdenticalTo X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=8ace2cd034be10c09be51daf08c3dda327f54262;p=oota-llvm.git implement MachineOperand::isIdenticalTo git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@31088 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/MachineInstr.cpp b/lib/CodeGen/MachineInstr.cpp index 182e664e675..9affc696c1b 100644 --- a/lib/CodeGen/MachineInstr.cpp +++ b/lib/CodeGen/MachineInstr.cpp @@ -97,6 +97,35 @@ bool MachineInstr::OperandsComplete() const { return false; } +/// isIdenticalTo - Return true if this operand is identical to the specified +/// operand. +bool MachineOperand::isIdenticalTo(const MachineOperand &Other) const { + if (getType() != Other.getType()) return false; + + switch (getType()) { + default: assert(0 && "Unrecognized operand type"); + case MachineOperand::MO_Register: + return getReg() == Other.getReg() && isDef() == Other.isDef(); + case MachineOperand::MO_Immediate: + return getImm() == Other.getImm(); + case MachineOperand::MO_MachineBasicBlock: + return getMBB() == Other.getMBB(); + case MachineOperand::MO_FrameIndex: + return getFrameIndex() == Other.getFrameIndex(); + case MachineOperand::MO_ConstantPoolIndex: + return getConstantPoolIndex() == Other.getConstantPoolIndex() && + getOffset() == Other.getOffset(); + case MachineOperand::MO_JumpTableIndex: + return getJumpTableIndex() == Other.getJumpTableIndex(); + case MachineOperand::MO_GlobalAddress: + return getGlobal() == Other.getGlobal() && getOffset() == Other.getOffset(); + case MachineOperand::MO_ExternalSymbol: + return getSymbolName() == Other.getSymbolName() && + getOffset() == Other.getOffset(); + } +} + + void MachineInstr::dump() const { std::cerr << " " << *this; }