mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-23 19:23:23 +01:00
[opaque pointer type] Pass explicit type to Load instruction creation in AutoUpgrade
llvm-svn: 237838
This commit is contained in:
parent
4ae19d2fd4
commit
7aa3cb67dd
@ -993,6 +993,9 @@ public:
|
||||
LoadInst *CreateLoad(Value *Ptr, const Twine &Name = "") {
|
||||
return Insert(new LoadInst(Ptr), Name);
|
||||
}
|
||||
LoadInst *CreateLoad(Type *Ty, Value *Ptr, const Twine &Name = "") {
|
||||
return Insert(new LoadInst(Ty, Ptr), Name);
|
||||
}
|
||||
LoadInst *CreateLoad(Value *Ptr, bool isVolatile, const Twine &Name = "") {
|
||||
return Insert(new LoadInst(Ptr, nullptr, isVolatile), Name);
|
||||
}
|
||||
|
@ -177,8 +177,12 @@ protected:
|
||||
public:
|
||||
LoadInst(Value *Ptr, const Twine &NameStr, Instruction *InsertBefore);
|
||||
LoadInst(Value *Ptr, const Twine &NameStr, BasicBlock *InsertAtEnd);
|
||||
LoadInst(Value *Ptr, const Twine &NameStr, bool isVolatile = false,
|
||||
LoadInst(Type *Ty, Value *Ptr, const Twine &NameStr, bool isVolatile = false,
|
||||
Instruction *InsertBefore = nullptr);
|
||||
LoadInst(Value *Ptr, const Twine &NameStr, bool isVolatile = false,
|
||||
Instruction *InsertBefore = nullptr)
|
||||
: LoadInst(cast<PointerType>(Ptr->getType())->getElementType(), Ptr,
|
||||
NameStr, isVolatile, InsertBefore) {}
|
||||
LoadInst(Value *Ptr, const Twine &NameStr, bool isVolatile,
|
||||
BasicBlock *InsertAtEnd);
|
||||
LoadInst(Value *Ptr, const Twine &NameStr, bool isVolatile, unsigned Align,
|
||||
@ -205,9 +209,13 @@ public:
|
||||
|
||||
LoadInst(Value *Ptr, const char *NameStr, Instruction *InsertBefore);
|
||||
LoadInst(Value *Ptr, const char *NameStr, BasicBlock *InsertAtEnd);
|
||||
LoadInst(Type *Ty, Value *Ptr, const char *NameStr = nullptr,
|
||||
bool isVolatile = false, Instruction *InsertBefore = nullptr);
|
||||
explicit LoadInst(Value *Ptr, const char *NameStr = nullptr,
|
||||
bool isVolatile = false,
|
||||
Instruction *InsertBefore = nullptr);
|
||||
Instruction *InsertBefore = nullptr)
|
||||
: LoadInst(cast<PointerType>(Ptr->getType())->getElementType(), Ptr,
|
||||
NameStr, isVolatile, InsertBefore) {}
|
||||
LoadInst(Value *Ptr, const char *NameStr, bool isVolatile,
|
||||
BasicBlock *InsertAtEnd);
|
||||
|
||||
|
@ -431,7 +431,7 @@ void llvm::UpgradeIntrinsicCall(CallInst *CI, Function *NewFn) {
|
||||
unsigned EltNum = VecTy->getVectorNumElements();
|
||||
Value *Cast = Builder.CreateBitCast(CI->getArgOperand(0),
|
||||
EltTy->getPointerTo());
|
||||
Value *Load = Builder.CreateLoad(Cast);
|
||||
Value *Load = Builder.CreateLoad(EltTy, Cast);
|
||||
Type *I32Ty = Type::getInt32Ty(C);
|
||||
Rep = UndefValue::get(VecTy);
|
||||
for (unsigned I = 0; I < EltNum; ++I)
|
||||
@ -439,10 +439,10 @@ void llvm::UpgradeIntrinsicCall(CallInst *CI, Function *NewFn) {
|
||||
ConstantInt::get(I32Ty, I));
|
||||
} else if (Name == "llvm.x86.avx2.vbroadcasti128") {
|
||||
// Replace vbroadcasts with a vector shuffle.
|
||||
Value *Op = Builder.CreatePointerCast(
|
||||
CI->getArgOperand(0),
|
||||
PointerType::getUnqual(VectorType::get(Type::getInt64Ty(C), 2)));
|
||||
Value *Load = Builder.CreateLoad(Op);
|
||||
Type *VT = VectorType::get(Type::getInt64Ty(C), 2);
|
||||
Value *Op = Builder.CreatePointerCast(CI->getArgOperand(0),
|
||||
PointerType::getUnqual(VT));
|
||||
Value *Load = Builder.CreateLoad(VT, Op);
|
||||
const int Idxs[4] = { 0, 1, 0, 1 };
|
||||
Rep = Builder.CreateShuffleVector(Load, UndefValue::get(Load->getType()),
|
||||
Idxs);
|
||||
|
@ -931,9 +931,9 @@ LoadInst::LoadInst(Value *Ptr, const Twine &Name, Instruction *InsertBef)
|
||||
LoadInst::LoadInst(Value *Ptr, const Twine &Name, BasicBlock *InsertAE)
|
||||
: LoadInst(Ptr, Name, /*isVolatile=*/false, InsertAE) {}
|
||||
|
||||
LoadInst::LoadInst(Value *Ptr, const Twine &Name, bool isVolatile,
|
||||
LoadInst::LoadInst(Type *Ty, Value *Ptr, const Twine &Name, bool isVolatile,
|
||||
Instruction *InsertBef)
|
||||
: LoadInst(Ptr, Name, isVolatile, /*Align=*/0, InsertBef) {}
|
||||
: LoadInst(Ty, Ptr, Name, isVolatile, /*Align=*/0, InsertBef) {}
|
||||
|
||||
LoadInst::LoadInst(Value *Ptr, const Twine &Name, bool isVolatile,
|
||||
BasicBlock *InsertAE)
|
||||
@ -994,10 +994,10 @@ LoadInst::LoadInst(Value *Ptr, const char *Name, BasicBlock *InsertAE)
|
||||
if (Name && Name[0]) setName(Name);
|
||||
}
|
||||
|
||||
LoadInst::LoadInst(Value *Ptr, const char *Name, bool isVolatile,
|
||||
LoadInst::LoadInst(Type *Ty, Value *Ptr, const char *Name, bool isVolatile,
|
||||
Instruction *InsertBef)
|
||||
: UnaryInstruction(cast<PointerType>(Ptr->getType())->getElementType(),
|
||||
Load, Ptr, InsertBef) {
|
||||
: UnaryInstruction(Ty, Load, Ptr, InsertBef) {
|
||||
assert(Ty == cast<PointerType>(Ptr->getType())->getElementType());
|
||||
setVolatile(isVolatile);
|
||||
setAlignment(0);
|
||||
setAtomic(NotAtomic);
|
||||
|
@ -494,7 +494,7 @@ void Verifier::visitGlobalVariable(const GlobalVariable &GV) {
|
||||
GV.getName() == "llvm.compiler.used")) {
|
||||
Assert(!GV.hasInitializer() || GV.hasAppendingLinkage(),
|
||||
"invalid linkage for intrinsic global variable", &GV);
|
||||
Type *GVType = GV.getType()->getElementType();
|
||||
Type *GVType = GV.getValueType();
|
||||
if (ArrayType *ATy = dyn_cast<ArrayType>(GVType)) {
|
||||
PointerType *PTy = dyn_cast<PointerType>(ATy->getElementType());
|
||||
Assert(PTy, "wrong type for intrinsic global variable", &GV);
|
||||
|
Loading…
Reference in New Issue
Block a user