mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-13 22:24:07 +00:00
remove the pointless check of MemoryUseIntrinsic from
is trivially dead, since these have side effects. This makes the (misnamed) MemoryUseIntrinsic class dead, so remove it. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@120382 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -55,7 +55,7 @@ namespace llvm {
|
|||||||
return isa<CallInst>(V) && classof(cast<CallInst>(V));
|
return isa<CallInst>(V) && classof(cast<CallInst>(V));
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/// DbgInfoIntrinsic - This is the common base class for debug info intrinsics
|
/// DbgInfoIntrinsic - This is the common base class for debug info intrinsics
|
||||||
///
|
///
|
||||||
class DbgInfoIntrinsic : public IntrinsicInst {
|
class DbgInfoIntrinsic : public IntrinsicInst {
|
||||||
@ -297,29 +297,6 @@ namespace llvm {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/// MemoryUseIntrinsic - This is the common base class for the memory use
|
|
||||||
/// marker intrinsics.
|
|
||||||
///
|
|
||||||
class MemoryUseIntrinsic : public IntrinsicInst {
|
|
||||||
public:
|
|
||||||
|
|
||||||
// Methods for support type inquiry through isa, cast, and dyn_cast:
|
|
||||||
static inline bool classof(const MemoryUseIntrinsic *) { return true; }
|
|
||||||
static inline bool classof(const IntrinsicInst *I) {
|
|
||||||
switch (I->getIntrinsicID()) {
|
|
||||||
case Intrinsic::lifetime_start:
|
|
||||||
case Intrinsic::lifetime_end:
|
|
||||||
case Intrinsic::invariant_start:
|
|
||||||
case Intrinsic::invariant_end:
|
|
||||||
return true;
|
|
||||||
default: return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
static inline bool classof(const Value *V) {
|
|
||||||
return isa<IntrinsicInst>(V) && classof(cast<IntrinsicInst>(V));
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -209,9 +209,6 @@ bool llvm::isInstructionTriviallyDead(Instruction *I) {
|
|||||||
// We don't want debug info removed by anything this general.
|
// We don't want debug info removed by anything this general.
|
||||||
if (isa<DbgInfoIntrinsic>(I)) return false;
|
if (isa<DbgInfoIntrinsic>(I)) return false;
|
||||||
|
|
||||||
// Likewise for memory use markers.
|
|
||||||
if (isa<MemoryUseIntrinsic>(I)) return false;
|
|
||||||
|
|
||||||
if (!I->mayHaveSideEffects()) return true;
|
if (!I->mayHaveSideEffects()) return true;
|
||||||
|
|
||||||
// Special case intrinsics that "may have side effects" but can be deleted
|
// Special case intrinsics that "may have side effects" but can be deleted
|
||||||
|
Reference in New Issue
Block a user