summaryrefslogtreecommitdiffstats
path: root/llvm/lib/VMCore/Instruction.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2004-11-30 02:51:53 +0000
committerChris Lattner <sabre@nondot.org>2004-11-30 02:51:53 +0000
commit0b6ebd8d105015d18a69786355ef59617297aa5c (patch)
tree5891b2504f6dd5cedb94433c7abaf9a45e6de0a5 /llvm/lib/VMCore/Instruction.cpp
parent889e91d58dfcd95a09ab8d393248617041b9da1a (diff)
downloadbcm5719-llvm-0b6ebd8d105015d18a69786355ef59617297aa5c.tar.gz
bcm5719-llvm-0b6ebd8d105015d18a69786355ef59617297aa5c.zip
Add method
llvm-svn: 18368
Diffstat (limited to 'llvm/lib/VMCore/Instruction.cpp')
-rw-r--r--llvm/lib/VMCore/Instruction.cpp29
1 files changed, 27 insertions, 2 deletions
diff --git a/llvm/lib/VMCore/Instruction.cpp b/llvm/lib/VMCore/Instruction.cpp
index 17970ac9ba9..696b12e27b1 100644
--- a/llvm/lib/VMCore/Instruction.cpp
+++ b/llvm/lib/VMCore/Instruction.cpp
@@ -11,14 +11,14 @@
//
//===----------------------------------------------------------------------===//
+#include "llvm/Instructions.h"
#include "llvm/Function.h"
#include "llvm/SymbolTable.h"
#include "llvm/Type.h"
#include "llvm/Support/LeakDetector.h"
using namespace llvm;
-void Instruction::init()
-{
+void Instruction::init() {
// Make sure that we get added to a basicblock
LeakDetector::addGarbageObject(this);
}
@@ -134,6 +134,31 @@ const char *Instruction::getOpcodeName(unsigned OpCode) {
return 0;
}
+/// isIdenticalTo - Return true if the specified instruction is exactly
+/// identical to the current one. This means that all operands match and any
+/// extra information (e.g. load is volatile) agree.
+bool Instruction::isIdenticalTo(Instruction *I) const {
+ if (getOpcode() != I->getOpcode() ||
+ getNumOperands() != I->getNumOperands() ||
+ getType() != I->getType())
+ return false;
+
+ // We have two instructions of identical opcode and #operands. Check to see
+ // if all operands are the same.
+ for (unsigned i = 0, e = getNumOperands(); i != e; ++i)
+ if (getOperand(i) != I->getOperand(i))
+ return false;
+
+ // Check special state that is a part of some instructions.
+ if (const LoadInst *LI = dyn_cast<LoadInst>(this))
+ return LI->isVolatile() == cast<LoadInst>(I)->isVolatile();
+ if (const StoreInst *SI = dyn_cast<StoreInst>(this))
+ return SI->isVolatile() == cast<StoreInst>(I)->isVolatile();
+ if (const VANextInst *VAN = dyn_cast<VANextInst>(this))
+ return VAN->getArgType() == cast<VANextInst>(I)->getArgType();
+ return true;
+}
+
/// isAssociative - Return true if the instruction is associative:
///
OpenPOWER on IntegriCloud