mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-13 04:38:24 +00:00
land David Blaikie's patch to de-constify Type, with a few tweaks.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@135375 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -51,7 +51,7 @@ static void SetValue(Value *V, GenericValue Val, ExecutionContext &SF) {
|
||||
break
|
||||
|
||||
static void executeFAddInst(GenericValue &Dest, GenericValue Src1,
|
||||
GenericValue Src2, const Type *Ty) {
|
||||
GenericValue Src2, Type *Ty) {
|
||||
switch (Ty->getTypeID()) {
|
||||
IMPLEMENT_BINARY_OPERATOR(+, Float);
|
||||
IMPLEMENT_BINARY_OPERATOR(+, Double);
|
||||
@ -62,7 +62,7 @@ static void executeFAddInst(GenericValue &Dest, GenericValue Src1,
|
||||
}
|
||||
|
||||
static void executeFSubInst(GenericValue &Dest, GenericValue Src1,
|
||||
GenericValue Src2, const Type *Ty) {
|
||||
GenericValue Src2, Type *Ty) {
|
||||
switch (Ty->getTypeID()) {
|
||||
IMPLEMENT_BINARY_OPERATOR(-, Float);
|
||||
IMPLEMENT_BINARY_OPERATOR(-, Double);
|
||||
@ -73,7 +73,7 @@ static void executeFSubInst(GenericValue &Dest, GenericValue Src1,
|
||||
}
|
||||
|
||||
static void executeFMulInst(GenericValue &Dest, GenericValue Src1,
|
||||
GenericValue Src2, const Type *Ty) {
|
||||
GenericValue Src2, Type *Ty) {
|
||||
switch (Ty->getTypeID()) {
|
||||
IMPLEMENT_BINARY_OPERATOR(*, Float);
|
||||
IMPLEMENT_BINARY_OPERATOR(*, Double);
|
||||
@ -84,7 +84,7 @@ static void executeFMulInst(GenericValue &Dest, GenericValue Src1,
|
||||
}
|
||||
|
||||
static void executeFDivInst(GenericValue &Dest, GenericValue Src1,
|
||||
GenericValue Src2, const Type *Ty) {
|
||||
GenericValue Src2, Type *Ty) {
|
||||
switch (Ty->getTypeID()) {
|
||||
IMPLEMENT_BINARY_OPERATOR(/, Float);
|
||||
IMPLEMENT_BINARY_OPERATOR(/, Double);
|
||||
@ -95,7 +95,7 @@ static void executeFDivInst(GenericValue &Dest, GenericValue Src1,
|
||||
}
|
||||
|
||||
static void executeFRemInst(GenericValue &Dest, GenericValue Src1,
|
||||
GenericValue Src2, const Type *Ty) {
|
||||
GenericValue Src2, Type *Ty) {
|
||||
switch (Ty->getTypeID()) {
|
||||
case Type::FloatTyID:
|
||||
Dest.FloatVal = fmod(Src1.FloatVal, Src2.FloatVal);
|
||||
@ -125,7 +125,7 @@ static void executeFRemInst(GenericValue &Dest, GenericValue Src1,
|
||||
break;
|
||||
|
||||
static GenericValue executeICMP_EQ(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
switch (Ty->getTypeID()) {
|
||||
IMPLEMENT_INTEGER_ICMP(eq,Ty);
|
||||
@ -138,7 +138,7 @@ static GenericValue executeICMP_EQ(GenericValue Src1, GenericValue Src2,
|
||||
}
|
||||
|
||||
static GenericValue executeICMP_NE(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
switch (Ty->getTypeID()) {
|
||||
IMPLEMENT_INTEGER_ICMP(ne,Ty);
|
||||
@ -151,7 +151,7 @@ static GenericValue executeICMP_NE(GenericValue Src1, GenericValue Src2,
|
||||
}
|
||||
|
||||
static GenericValue executeICMP_ULT(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
switch (Ty->getTypeID()) {
|
||||
IMPLEMENT_INTEGER_ICMP(ult,Ty);
|
||||
@ -164,7 +164,7 @@ static GenericValue executeICMP_ULT(GenericValue Src1, GenericValue Src2,
|
||||
}
|
||||
|
||||
static GenericValue executeICMP_SLT(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
switch (Ty->getTypeID()) {
|
||||
IMPLEMENT_INTEGER_ICMP(slt,Ty);
|
||||
@ -177,7 +177,7 @@ static GenericValue executeICMP_SLT(GenericValue Src1, GenericValue Src2,
|
||||
}
|
||||
|
||||
static GenericValue executeICMP_UGT(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
switch (Ty->getTypeID()) {
|
||||
IMPLEMENT_INTEGER_ICMP(ugt,Ty);
|
||||
@ -190,7 +190,7 @@ static GenericValue executeICMP_UGT(GenericValue Src1, GenericValue Src2,
|
||||
}
|
||||
|
||||
static GenericValue executeICMP_SGT(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
switch (Ty->getTypeID()) {
|
||||
IMPLEMENT_INTEGER_ICMP(sgt,Ty);
|
||||
@ -203,7 +203,7 @@ static GenericValue executeICMP_SGT(GenericValue Src1, GenericValue Src2,
|
||||
}
|
||||
|
||||
static GenericValue executeICMP_ULE(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
switch (Ty->getTypeID()) {
|
||||
IMPLEMENT_INTEGER_ICMP(ule,Ty);
|
||||
@ -216,7 +216,7 @@ static GenericValue executeICMP_ULE(GenericValue Src1, GenericValue Src2,
|
||||
}
|
||||
|
||||
static GenericValue executeICMP_SLE(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
switch (Ty->getTypeID()) {
|
||||
IMPLEMENT_INTEGER_ICMP(sle,Ty);
|
||||
@ -229,7 +229,7 @@ static GenericValue executeICMP_SLE(GenericValue Src1, GenericValue Src2,
|
||||
}
|
||||
|
||||
static GenericValue executeICMP_UGE(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
switch (Ty->getTypeID()) {
|
||||
IMPLEMENT_INTEGER_ICMP(uge,Ty);
|
||||
@ -242,7 +242,7 @@ static GenericValue executeICMP_UGE(GenericValue Src1, GenericValue Src2,
|
||||
}
|
||||
|
||||
static GenericValue executeICMP_SGE(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
switch (Ty->getTypeID()) {
|
||||
IMPLEMENT_INTEGER_ICMP(sge,Ty);
|
||||
@ -256,7 +256,7 @@ static GenericValue executeICMP_SGE(GenericValue Src1, GenericValue Src2,
|
||||
|
||||
void Interpreter::visitICmpInst(ICmpInst &I) {
|
||||
ExecutionContext &SF = ECStack.back();
|
||||
const Type *Ty = I.getOperand(0)->getType();
|
||||
Type *Ty = I.getOperand(0)->getType();
|
||||
GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
|
||||
GenericValue Src2 = getOperandValue(I.getOperand(1), SF);
|
||||
GenericValue R; // Result
|
||||
@ -286,7 +286,7 @@ void Interpreter::visitICmpInst(ICmpInst &I) {
|
||||
break
|
||||
|
||||
static GenericValue executeFCMP_OEQ(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
switch (Ty->getTypeID()) {
|
||||
IMPLEMENT_FCMP(==, Float);
|
||||
@ -299,7 +299,7 @@ static GenericValue executeFCMP_OEQ(GenericValue Src1, GenericValue Src2,
|
||||
}
|
||||
|
||||
static GenericValue executeFCMP_ONE(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
switch (Ty->getTypeID()) {
|
||||
IMPLEMENT_FCMP(!=, Float);
|
||||
@ -313,7 +313,7 @@ static GenericValue executeFCMP_ONE(GenericValue Src1, GenericValue Src2,
|
||||
}
|
||||
|
||||
static GenericValue executeFCMP_OLE(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
switch (Ty->getTypeID()) {
|
||||
IMPLEMENT_FCMP(<=, Float);
|
||||
@ -326,7 +326,7 @@ static GenericValue executeFCMP_OLE(GenericValue Src1, GenericValue Src2,
|
||||
}
|
||||
|
||||
static GenericValue executeFCMP_OGE(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
switch (Ty->getTypeID()) {
|
||||
IMPLEMENT_FCMP(>=, Float);
|
||||
@ -339,7 +339,7 @@ static GenericValue executeFCMP_OGE(GenericValue Src1, GenericValue Src2,
|
||||
}
|
||||
|
||||
static GenericValue executeFCMP_OLT(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
switch (Ty->getTypeID()) {
|
||||
IMPLEMENT_FCMP(<, Float);
|
||||
@ -352,7 +352,7 @@ static GenericValue executeFCMP_OLT(GenericValue Src1, GenericValue Src2,
|
||||
}
|
||||
|
||||
static GenericValue executeFCMP_OGT(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
switch (Ty->getTypeID()) {
|
||||
IMPLEMENT_FCMP(>, Float);
|
||||
@ -377,49 +377,49 @@ static GenericValue executeFCMP_OGT(GenericValue Src1, GenericValue Src2,
|
||||
|
||||
|
||||
static GenericValue executeFCMP_UEQ(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
IMPLEMENT_UNORDERED(Ty, Src1, Src2)
|
||||
return executeFCMP_OEQ(Src1, Src2, Ty);
|
||||
}
|
||||
|
||||
static GenericValue executeFCMP_UNE(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
IMPLEMENT_UNORDERED(Ty, Src1, Src2)
|
||||
return executeFCMP_ONE(Src1, Src2, Ty);
|
||||
}
|
||||
|
||||
static GenericValue executeFCMP_ULE(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
IMPLEMENT_UNORDERED(Ty, Src1, Src2)
|
||||
return executeFCMP_OLE(Src1, Src2, Ty);
|
||||
}
|
||||
|
||||
static GenericValue executeFCMP_UGE(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
IMPLEMENT_UNORDERED(Ty, Src1, Src2)
|
||||
return executeFCMP_OGE(Src1, Src2, Ty);
|
||||
}
|
||||
|
||||
static GenericValue executeFCMP_ULT(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
IMPLEMENT_UNORDERED(Ty, Src1, Src2)
|
||||
return executeFCMP_OLT(Src1, Src2, Ty);
|
||||
}
|
||||
|
||||
static GenericValue executeFCMP_UGT(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
IMPLEMENT_UNORDERED(Ty, Src1, Src2)
|
||||
return executeFCMP_OGT(Src1, Src2, Ty);
|
||||
}
|
||||
|
||||
static GenericValue executeFCMP_ORD(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
if (Ty->isFloatTy())
|
||||
Dest.IntVal = APInt(1,(Src1.FloatVal == Src1.FloatVal &&
|
||||
@ -431,7 +431,7 @@ static GenericValue executeFCMP_ORD(GenericValue Src1, GenericValue Src2,
|
||||
}
|
||||
|
||||
static GenericValue executeFCMP_UNO(GenericValue Src1, GenericValue Src2,
|
||||
const Type *Ty) {
|
||||
Type *Ty) {
|
||||
GenericValue Dest;
|
||||
if (Ty->isFloatTy())
|
||||
Dest.IntVal = APInt(1,(Src1.FloatVal != Src1.FloatVal ||
|
||||
@ -444,7 +444,7 @@ static GenericValue executeFCMP_UNO(GenericValue Src1, GenericValue Src2,
|
||||
|
||||
void Interpreter::visitFCmpInst(FCmpInst &I) {
|
||||
ExecutionContext &SF = ECStack.back();
|
||||
const Type *Ty = I.getOperand(0)->getType();
|
||||
Type *Ty = I.getOperand(0)->getType();
|
||||
GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
|
||||
GenericValue Src2 = getOperandValue(I.getOperand(1), SF);
|
||||
GenericValue R; // Result
|
||||
@ -475,7 +475,7 @@ void Interpreter::visitFCmpInst(FCmpInst &I) {
|
||||
}
|
||||
|
||||
static GenericValue executeCmpInst(unsigned predicate, GenericValue Src1,
|
||||
GenericValue Src2, const Type *Ty) {
|
||||
GenericValue Src2, Type *Ty) {
|
||||
GenericValue Result;
|
||||
switch (predicate) {
|
||||
case ICmpInst::ICMP_EQ: return executeICMP_EQ(Src1, Src2, Ty);
|
||||
@ -520,7 +520,7 @@ static GenericValue executeCmpInst(unsigned predicate, GenericValue Src1,
|
||||
|
||||
void Interpreter::visitBinaryOperator(BinaryOperator &I) {
|
||||
ExecutionContext &SF = ECStack.back();
|
||||
const Type *Ty = I.getOperand(0)->getType();
|
||||
Type *Ty = I.getOperand(0)->getType();
|
||||
GenericValue Src1 = getOperandValue(I.getOperand(0), SF);
|
||||
GenericValue Src2 = getOperandValue(I.getOperand(1), SF);
|
||||
GenericValue R; // Result
|
||||
@ -585,7 +585,7 @@ void Interpreter::exitCalled(GenericValue GV) {
|
||||
/// care of switching to the normal destination BB, if we are returning
|
||||
/// from an invoke.
|
||||
///
|
||||
void Interpreter::popStackAndReturnValueToCaller(const Type *RetTy,
|
||||
void Interpreter::popStackAndReturnValueToCaller(Type *RetTy,
|
||||
GenericValue Result) {
|
||||
// Pop the current stack frame.
|
||||
ECStack.pop_back();
|
||||
@ -613,7 +613,7 @@ void Interpreter::popStackAndReturnValueToCaller(const Type *RetTy,
|
||||
|
||||
void Interpreter::visitReturnInst(ReturnInst &I) {
|
||||
ExecutionContext &SF = ECStack.back();
|
||||
const Type *RetTy = Type::getVoidTy(I.getContext());
|
||||
Type *RetTy = Type::getVoidTy(I.getContext());
|
||||
GenericValue Result;
|
||||
|
||||
// Save away the return value... (if we are not 'ret void')
|
||||
@ -663,7 +663,7 @@ void Interpreter::visitBranchInst(BranchInst &I) {
|
||||
void Interpreter::visitSwitchInst(SwitchInst &I) {
|
||||
ExecutionContext &SF = ECStack.back();
|
||||
GenericValue CondVal = getOperandValue(I.getOperand(0), SF);
|
||||
const Type *ElTy = I.getOperand(0)->getType();
|
||||
Type *ElTy = I.getOperand(0)->getType();
|
||||
|
||||
// Check to see if any of the cases match...
|
||||
BasicBlock *Dest = 0;
|
||||
@ -730,7 +730,7 @@ void Interpreter::SwitchToNewBasicBlock(BasicBlock *Dest, ExecutionContext &SF){
|
||||
void Interpreter::visitAllocaInst(AllocaInst &I) {
|
||||
ExecutionContext &SF = ECStack.back();
|
||||
|
||||
const Type *Ty = I.getType()->getElementType(); // Type to be allocated
|
||||
Type *Ty = I.getType()->getElementType(); // Type to be allocated
|
||||
|
||||
// Get the number of elements being allocated by the array...
|
||||
unsigned NumElements =
|
||||
@ -767,7 +767,7 @@ GenericValue Interpreter::executeGEPOperation(Value *Ptr, gep_type_iterator I,
|
||||
uint64_t Total = 0;
|
||||
|
||||
for (; I != E; ++I) {
|
||||
if (const StructType *STy = dyn_cast<StructType>(*I)) {
|
||||
if (StructType *STy = dyn_cast<StructType>(*I)) {
|
||||
const StructLayout *SLO = TD.getStructLayout(STy);
|
||||
|
||||
const ConstantInt *CPU = cast<ConstantInt>(I.getOperand());
|
||||
@ -775,7 +775,7 @@ GenericValue Interpreter::executeGEPOperation(Value *Ptr, gep_type_iterator I,
|
||||
|
||||
Total += SLO->getElementOffset(Index);
|
||||
} else {
|
||||
const SequentialType *ST = cast<SequentialType>(*I);
|
||||
SequentialType *ST = cast<SequentialType>(*I);
|
||||
// Get the index number for the array... which must be long type...
|
||||
GenericValue IdxGV = getOperandValue(I.getOperand(), SF);
|
||||
|
||||
@ -929,34 +929,34 @@ void Interpreter::visitAShr(BinaryOperator &I) {
|
||||
SetValue(&I, Dest, SF);
|
||||
}
|
||||
|
||||
GenericValue Interpreter::executeTruncInst(Value *SrcVal, const Type *DstTy,
|
||||
GenericValue Interpreter::executeTruncInst(Value *SrcVal, Type *DstTy,
|
||||
ExecutionContext &SF) {
|
||||
GenericValue Dest, Src = getOperandValue(SrcVal, SF);
|
||||
const IntegerType *DITy = cast<IntegerType>(DstTy);
|
||||
IntegerType *DITy = cast<IntegerType>(DstTy);
|
||||
unsigned DBitWidth = DITy->getBitWidth();
|
||||
Dest.IntVal = Src.IntVal.trunc(DBitWidth);
|
||||
return Dest;
|
||||
}
|
||||
|
||||
GenericValue Interpreter::executeSExtInst(Value *SrcVal, const Type *DstTy,
|
||||
GenericValue Interpreter::executeSExtInst(Value *SrcVal, Type *DstTy,
|
||||
ExecutionContext &SF) {
|
||||
GenericValue Dest, Src = getOperandValue(SrcVal, SF);
|
||||
const IntegerType *DITy = cast<IntegerType>(DstTy);
|
||||
IntegerType *DITy = cast<IntegerType>(DstTy);
|
||||
unsigned DBitWidth = DITy->getBitWidth();
|
||||
Dest.IntVal = Src.IntVal.sext(DBitWidth);
|
||||
return Dest;
|
||||
}
|
||||
|
||||
GenericValue Interpreter::executeZExtInst(Value *SrcVal, const Type *DstTy,
|
||||
GenericValue Interpreter::executeZExtInst(Value *SrcVal, Type *DstTy,
|
||||
ExecutionContext &SF) {
|
||||
GenericValue Dest, Src = getOperandValue(SrcVal, SF);
|
||||
const IntegerType *DITy = cast<IntegerType>(DstTy);
|
||||
IntegerType *DITy = cast<IntegerType>(DstTy);
|
||||
unsigned DBitWidth = DITy->getBitWidth();
|
||||
Dest.IntVal = Src.IntVal.zext(DBitWidth);
|
||||
return Dest;
|
||||
}
|
||||
|
||||
GenericValue Interpreter::executeFPTruncInst(Value *SrcVal, const Type *DstTy,
|
||||
GenericValue Interpreter::executeFPTruncInst(Value *SrcVal, Type *DstTy,
|
||||
ExecutionContext &SF) {
|
||||
GenericValue Dest, Src = getOperandValue(SrcVal, SF);
|
||||
assert(SrcVal->getType()->isDoubleTy() && DstTy->isFloatTy() &&
|
||||
@ -965,7 +965,7 @@ GenericValue Interpreter::executeFPTruncInst(Value *SrcVal, const Type *DstTy,
|
||||
return Dest;
|
||||
}
|
||||
|
||||
GenericValue Interpreter::executeFPExtInst(Value *SrcVal, const Type *DstTy,
|
||||
GenericValue Interpreter::executeFPExtInst(Value *SrcVal, Type *DstTy,
|
||||
ExecutionContext &SF) {
|
||||
GenericValue Dest, Src = getOperandValue(SrcVal, SF);
|
||||
assert(SrcVal->getType()->isFloatTy() && DstTy->isDoubleTy() &&
|
||||
@ -974,9 +974,9 @@ GenericValue Interpreter::executeFPExtInst(Value *SrcVal, const Type *DstTy,
|
||||
return Dest;
|
||||
}
|
||||
|
||||
GenericValue Interpreter::executeFPToUIInst(Value *SrcVal, const Type *DstTy,
|
||||
GenericValue Interpreter::executeFPToUIInst(Value *SrcVal, Type *DstTy,
|
||||
ExecutionContext &SF) {
|
||||
const Type *SrcTy = SrcVal->getType();
|
||||
Type *SrcTy = SrcVal->getType();
|
||||
uint32_t DBitWidth = cast<IntegerType>(DstTy)->getBitWidth();
|
||||
GenericValue Dest, Src = getOperandValue(SrcVal, SF);
|
||||
assert(SrcTy->isFloatingPointTy() && "Invalid FPToUI instruction");
|
||||
@ -988,9 +988,9 @@ GenericValue Interpreter::executeFPToUIInst(Value *SrcVal, const Type *DstTy,
|
||||
return Dest;
|
||||
}
|
||||
|
||||
GenericValue Interpreter::executeFPToSIInst(Value *SrcVal, const Type *DstTy,
|
||||
GenericValue Interpreter::executeFPToSIInst(Value *SrcVal, Type *DstTy,
|
||||
ExecutionContext &SF) {
|
||||
const Type *SrcTy = SrcVal->getType();
|
||||
Type *SrcTy = SrcVal->getType();
|
||||
uint32_t DBitWidth = cast<IntegerType>(DstTy)->getBitWidth();
|
||||
GenericValue Dest, Src = getOperandValue(SrcVal, SF);
|
||||
assert(SrcTy->isFloatingPointTy() && "Invalid FPToSI instruction");
|
||||
@ -1002,7 +1002,7 @@ GenericValue Interpreter::executeFPToSIInst(Value *SrcVal, const Type *DstTy,
|
||||
return Dest;
|
||||
}
|
||||
|
||||
GenericValue Interpreter::executeUIToFPInst(Value *SrcVal, const Type *DstTy,
|
||||
GenericValue Interpreter::executeUIToFPInst(Value *SrcVal, Type *DstTy,
|
||||
ExecutionContext &SF) {
|
||||
GenericValue Dest, Src = getOperandValue(SrcVal, SF);
|
||||
assert(DstTy->isFloatingPointTy() && "Invalid UIToFP instruction");
|
||||
@ -1014,7 +1014,7 @@ GenericValue Interpreter::executeUIToFPInst(Value *SrcVal, const Type *DstTy,
|
||||
return Dest;
|
||||
}
|
||||
|
||||
GenericValue Interpreter::executeSIToFPInst(Value *SrcVal, const Type *DstTy,
|
||||
GenericValue Interpreter::executeSIToFPInst(Value *SrcVal, Type *DstTy,
|
||||
ExecutionContext &SF) {
|
||||
GenericValue Dest, Src = getOperandValue(SrcVal, SF);
|
||||
assert(DstTy->isFloatingPointTy() && "Invalid SIToFP instruction");
|
||||
@ -1027,7 +1027,7 @@ GenericValue Interpreter::executeSIToFPInst(Value *SrcVal, const Type *DstTy,
|
||||
|
||||
}
|
||||
|
||||
GenericValue Interpreter::executePtrToIntInst(Value *SrcVal, const Type *DstTy,
|
||||
GenericValue Interpreter::executePtrToIntInst(Value *SrcVal, Type *DstTy,
|
||||
ExecutionContext &SF) {
|
||||
uint32_t DBitWidth = cast<IntegerType>(DstTy)->getBitWidth();
|
||||
GenericValue Dest, Src = getOperandValue(SrcVal, SF);
|
||||
@ -1037,7 +1037,7 @@ GenericValue Interpreter::executePtrToIntInst(Value *SrcVal, const Type *DstTy,
|
||||
return Dest;
|
||||
}
|
||||
|
||||
GenericValue Interpreter::executeIntToPtrInst(Value *SrcVal, const Type *DstTy,
|
||||
GenericValue Interpreter::executeIntToPtrInst(Value *SrcVal, Type *DstTy,
|
||||
ExecutionContext &SF) {
|
||||
GenericValue Dest, Src = getOperandValue(SrcVal, SF);
|
||||
assert(DstTy->isPointerTy() && "Invalid PtrToInt instruction");
|
||||
@ -1050,10 +1050,10 @@ GenericValue Interpreter::executeIntToPtrInst(Value *SrcVal, const Type *DstTy,
|
||||
return Dest;
|
||||
}
|
||||
|
||||
GenericValue Interpreter::executeBitCastInst(Value *SrcVal, const Type *DstTy,
|
||||
GenericValue Interpreter::executeBitCastInst(Value *SrcVal, Type *DstTy,
|
||||
ExecutionContext &SF) {
|
||||
|
||||
const Type *SrcTy = SrcVal->getType();
|
||||
Type *SrcTy = SrcVal->getType();
|
||||
GenericValue Dest, Src = getOperandValue(SrcVal, SF);
|
||||
if (DstTy->isPointerTy()) {
|
||||
assert(SrcTy->isPointerTy() && "Invalid BitCast");
|
||||
@ -1155,7 +1155,7 @@ void Interpreter::visitVAArgInst(VAArgInst &I) {
|
||||
GenericValue Dest;
|
||||
GenericValue Src = ECStack[VAList.UIntPairVal.first]
|
||||
.VarArgs[VAList.UIntPairVal.second];
|
||||
const Type *Ty = I.getType();
|
||||
Type *Ty = I.getType();
|
||||
switch (Ty->getTypeID()) {
|
||||
case Type::IntegerTyID: Dest.IntVal = Src.IntVal;
|
||||
IMPLEMENT_VAARG(Pointer);
|
||||
@ -1222,7 +1222,7 @@ GenericValue Interpreter::getConstantExprValue (ConstantExpr *CE,
|
||||
GenericValue Op0 = getOperandValue(CE->getOperand(0), SF);
|
||||
GenericValue Op1 = getOperandValue(CE->getOperand(1), SF);
|
||||
GenericValue Dest;
|
||||
const Type * Ty = CE->getOperand(0)->getType();
|
||||
Type * Ty = CE->getOperand(0)->getType();
|
||||
switch (CE->getOpcode()) {
|
||||
case Instruction::Add: Dest.IntVal = Op0.IntVal + Op1.IntVal; break;
|
||||
case Instruction::Sub: Dest.IntVal = Op0.IntVal - Op1.IntVal; break;
|
||||
|
Reference in New Issue
Block a user