diff options
author | Dan Gohman <gohman@apple.com> | 2007-07-26 16:06:08 +0000 |
---|---|---|
committer | Dan Gohman <gohman@apple.com> | 2007-07-26 16:06:08 +0000 |
commit | 6e853bc73f3bbf3248cb8edee6ee636d60b213a0 (patch) | |
tree | 325f7c96b3ddfe06fa744c1ccaefd5067ba8b4a6 /llvm/lib/VMCore/Instruction.cpp | |
parent | eb47d9213cc86a739231c8ece6afab35c859f0d4 (diff) | |
download | bcm5719-llvm-6e853bc73f3bbf3248cb8edee6ee636d60b213a0.tar.gz bcm5719-llvm-6e853bc73f3bbf3248cb8edee6ee636d60b213a0.zip |
Move the GET_SIDE_EFFECT_INFO logic from isInstructionTriviallyDead
to Instruction::mayWriteToMemory, fixing a FIXME, and helping
various places that call mayWriteToMemory directly.
llvm-svn: 40533
Diffstat (limited to 'llvm/lib/VMCore/Instruction.cpp')
-rw-r--r-- | llvm/lib/VMCore/Instruction.cpp | 16 |
1 files changed, 12 insertions, 4 deletions
diff --git a/llvm/lib/VMCore/Instruction.cpp b/llvm/lib/VMCore/Instruction.cpp index feff59dff9f..a3687530de9 100644 --- a/llvm/lib/VMCore/Instruction.cpp +++ b/llvm/lib/VMCore/Instruction.cpp @@ -197,6 +197,15 @@ bool Instruction::isSameOperationAs(Instruction *I) const { return true; } +// IntrinsicOnlyReadsMemory - Return true if the specified intrinsic doesn't +// have any side-effects or if it only reads memory. +static bool IntrinsicOnlyReadsMemory(unsigned IntrinsicID) { +#define GET_SIDE_EFFECT_INFO +#include "llvm/Intrinsics.gen" +#undef GET_SIDE_EFFECT_INFO + return false; +} + /// mayWriteToMemory - Return true if this instruction may modify memory. /// bool Instruction::mayWriteToMemory() const { @@ -208,11 +217,10 @@ bool Instruction::mayWriteToMemory() const { case Instruction::VAArg: return true; case Instruction::Call: - //if (const IntrinsicInst *II = dyn_cast<IntrinsicInst>(this)) { + if (const IntrinsicInst *II = dyn_cast<IntrinsicInst>(this)) { // If the intrinsic doesn't write memory, it is safe. - // FIXME: this is obviously supposed to determine which intrinsics - // don't write to memory, but hasn't been implemented yet. - //} + return !IntrinsicOnlyReadsMemory(II->getIntrinsicID()); + } return true; case Instruction::Load: return cast<LoadInst>(this)->isVolatile(); |