summaryrefslogtreecommitdiffstats
path: root/llvm
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2003-05-14 17:51:05 +0000
committerChris Lattner <sabre@nondot.org>2003-05-14 17:51:05 +0000
commit55ed6561a1f1ecdf20435b2ec7d879dee95f7d75 (patch)
treed0d52a604d36288a7cf81aa6ab771400bab5b752 /llvm
parent15285abcbe5c65327b362e3a78f94a92b16d4a8d (diff)
downloadbcm5719-llvm-55ed6561a1f1ecdf20435b2ec7d879dee95f7d75.tar.gz
bcm5719-llvm-55ed6561a1f1ecdf20435b2ec7d879dee95f7d75.zip
Remove unnecessary casts
llvm-svn: 6201
Diffstat (limited to 'llvm')
-rw-r--r--llvm/lib/VMCore/ConstantHandling.cpp4
-rw-r--r--llvm/lib/VMCore/Constants.cpp23
2 files changed, 14 insertions, 13 deletions
diff --git a/llvm/lib/VMCore/ConstantHandling.cpp b/llvm/lib/VMCore/ConstantHandling.cpp
index db8cc4487c1..d5f98bd201e 100644
--- a/llvm/lib/VMCore/ConstantHandling.cpp
+++ b/llvm/lib/VMCore/ConstantHandling.cpp
@@ -91,7 +91,7 @@ Constant *ConstantFoldCastInstruction(const Constant *V, const Type *DestTy) {
if (const ConstantExpr *CE = dyn_cast<ConstantExpr>(V))
if (CE->getOpcode() == Instruction::Cast) {
- Constant *Op = (Constant*)cast<Constant>(CE->getOperand(0));
+ Constant *Op = const_cast<Constant*>(CE->getOperand(0));
// Try to not produce a cast of a cast, which is almost always redundant.
if (!Op->getType()->isFloatingPoint() &&
!CE->getType()->isFloatingPoint() &&
@@ -166,7 +166,7 @@ Constant *ConstantFoldGetElementPtr(const Constant *C,
dyn_cast<ArrayType>(cast<PointerType>(C->getType())->getElementType()))
if (CAT->getElementType() == SAT->getElementType())
return ConstantExpr::getGetElementPtr(
- (Constant*)cast<Constant>(CE->getOperand(0)), IdxList);
+ (Constant*)CE->getOperand(0), IdxList);
return 0;
}
diff --git a/llvm/lib/VMCore/Constants.cpp b/llvm/lib/VMCore/Constants.cpp
index 499452c4251..04d46e58673 100644
--- a/llvm/lib/VMCore/Constants.cpp
+++ b/llvm/lib/VMCore/Constants.cpp
@@ -411,30 +411,31 @@ void ConstantPointerRef::replaceUsesOfWithOnConstant(Value *From, Value *To) {
}
}
-void ConstantExpr::replaceUsesOfWithOnConstant(Value *From, Value *To) {
- assert(isa<Constant>(To) && "Cannot make Constant refer to non-constant!");
+void ConstantExpr::replaceUsesOfWithOnConstant(Value *From, Value *ToV) {
+ assert(isa<Constant>(ToV) && "Cannot make Constant refer to non-constant!");
+ Constant *To = cast<Constant>(ToV);
Constant *Replacement = 0;
if (getOpcode() == Instruction::GetElementPtr) {
std::vector<Constant*> Indices;
- Constant *Pointer = cast<Constant>(getOperand(0));
+ Constant *Pointer = getOperand(0);
Indices.reserve(getNumOperands()-1);
- if (Pointer == From) Pointer = cast<Constant>(To);
+ if (Pointer == From) Pointer = To;
for (unsigned i = 1, e = getNumOperands(); i != e; ++i) {
- Constant *Val = cast<Constant>(getOperand(i));
- if (Val == From) Val = cast<Constant>(To);
+ Constant *Val = getOperand(i);
+ if (Val == From) Val = To;
Indices.push_back(Val);
}
Replacement = ConstantExpr::getGetElementPtr(Pointer, Indices);
} else if (getOpcode() == Instruction::Cast) {
assert(getOperand(0) == From && "Cast only has one use!");
- Replacement = ConstantExpr::getCast(cast<Constant>(To), getType());
+ Replacement = ConstantExpr::getCast(To, getType());
} else if (getNumOperands() == 2) {
- Constant *C1 = cast<Constant>(getOperand(0));
- Constant *C2 = cast<Constant>(getOperand(1));
- if (C1 == From) C1 = cast<Constant>(To);
- if (C2 == From) C2 = cast<Constant>(To);
+ Constant *C1 = getOperand(0);
+ Constant *C2 = getOperand(1);
+ if (C1 == From) C1 = To;
+ if (C2 == From) C2 = To;
Replacement = ConstantExpr::get(getOpcode(), C1, C2);
} else {
assert(0 && "Unknown ConstantExpr type!");
OpenPOWER on IntegriCloud