mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-04-03 08:11:52 +00:00
[opaque pointer types] Update LoadInst creation APIs to consistently
accept a return-type argument. Note: this also adds a new C API and soft-deprecates the old C API. Differential Revision: https://reviews.llvm.org/D56558 llvm-svn: 351123
This commit is contained in:
parent
325b175605
commit
f17c67ebda
@ -3597,8 +3597,12 @@ LLVMValueRef LLVMBuildAlloca(LLVMBuilderRef, LLVMTypeRef Ty, const char *Name);
|
||||
LLVMValueRef LLVMBuildArrayAlloca(LLVMBuilderRef, LLVMTypeRef Ty,
|
||||
LLVMValueRef Val, const char *Name);
|
||||
LLVMValueRef LLVMBuildFree(LLVMBuilderRef, LLVMValueRef PointerVal);
|
||||
// LLVMBuildLoad is deprecated in favor of LLVMBuildLoad2, in preparation for
|
||||
// opaque pointer types.
|
||||
LLVMValueRef LLVMBuildLoad(LLVMBuilderRef, LLVMValueRef PointerVal,
|
||||
const char *Name);
|
||||
LLVMValueRef LLVMBuildLoad2(LLVMBuilderRef, LLVMTypeRef Ty,
|
||||
LLVMValueRef PointerVal, const char *Name);
|
||||
LLVMValueRef LLVMBuildStore(LLVMBuilderRef, LLVMValueRef Val, LLVMValueRef Ptr);
|
||||
LLVMValueRef LLVMBuildGEP(LLVMBuilderRef B, LLVMValueRef Pointer,
|
||||
LLVMValueRef *Indices, unsigned NumIndices,
|
||||
|
@ -1352,22 +1352,35 @@ public:
|
||||
return Insert(new AllocaInst(Ty, DL.getAllocaAddrSpace(), ArraySize), Name);
|
||||
}
|
||||
|
||||
/// Provided to resolve 'CreateLoad(Ptr, "...")' correctly, instead of
|
||||
/// Provided to resolve 'CreateLoad(Ty, Ptr, "...")' correctly, instead of
|
||||
/// converting the string to 'bool' for the isVolatile parameter.
|
||||
LoadInst *CreateLoad(Value *Ptr, const char *Name) {
|
||||
return Insert(new LoadInst(Ptr), Name);
|
||||
}
|
||||
|
||||
LoadInst *CreateLoad(Value *Ptr, const Twine &Name = "") {
|
||||
return Insert(new LoadInst(Ptr), Name);
|
||||
LoadInst *CreateLoad(Type *Ty, Value *Ptr, const char *Name) {
|
||||
return Insert(new LoadInst(Ty, Ptr), Name);
|
||||
}
|
||||
|
||||
LoadInst *CreateLoad(Type *Ty, Value *Ptr, const Twine &Name = "") {
|
||||
return Insert(new LoadInst(Ty, Ptr), Name);
|
||||
}
|
||||
|
||||
LoadInst *CreateLoad(Type *Ty, Value *Ptr, bool isVolatile,
|
||||
const Twine &Name = "") {
|
||||
return Insert(new LoadInst(Ty, Ptr, Twine(), isVolatile), Name);
|
||||
}
|
||||
|
||||
// Deprecated [opaque pointer types]
|
||||
LoadInst *CreateLoad(Value *Ptr, const char *Name) {
|
||||
return CreateLoad(Ptr->getType()->getPointerElementType(), Ptr, Name);
|
||||
}
|
||||
|
||||
// Deprecated [opaque pointer types]
|
||||
LoadInst *CreateLoad(Value *Ptr, const Twine &Name = "") {
|
||||
return CreateLoad(Ptr->getType()->getPointerElementType(), Ptr, Name);
|
||||
}
|
||||
|
||||
// Deprecated [opaque pointer types]
|
||||
LoadInst *CreateLoad(Value *Ptr, bool isVolatile, const Twine &Name = "") {
|
||||
return Insert(new LoadInst(Ptr, nullptr, isVolatile), Name);
|
||||
return CreateLoad(Ptr->getType()->getPointerElementType(), Ptr, isVolatile,
|
||||
Name);
|
||||
}
|
||||
|
||||
StoreInst *CreateStore(Value *Val, Value *Ptr, bool isVolatile = false) {
|
||||
@ -1377,22 +1390,41 @@ public:
|
||||
/// Provided to resolve 'CreateAlignedLoad(Ptr, Align, "...")'
|
||||
/// correctly, instead of converting the string to 'bool' for the isVolatile
|
||||
/// parameter.
|
||||
LoadInst *CreateAlignedLoad(Value *Ptr, unsigned Align, const char *Name) {
|
||||
LoadInst *LI = CreateLoad(Ptr, Name);
|
||||
LoadInst *CreateAlignedLoad(Type *Ty, Value *Ptr, unsigned Align,
|
||||
const char *Name) {
|
||||
LoadInst *LI = CreateLoad(Ty, Ptr, Name);
|
||||
LI->setAlignment(Align);
|
||||
return LI;
|
||||
}
|
||||
LoadInst *CreateAlignedLoad(Type *Ty, Value *Ptr, unsigned Align,
|
||||
const Twine &Name = "") {
|
||||
LoadInst *LI = CreateLoad(Ty, Ptr, Name);
|
||||
LI->setAlignment(Align);
|
||||
return LI;
|
||||
}
|
||||
LoadInst *CreateAlignedLoad(Type *Ty, Value *Ptr, unsigned Align,
|
||||
bool isVolatile, const Twine &Name = "") {
|
||||
LoadInst *LI = CreateLoad(Ty, Ptr, isVolatile, Name);
|
||||
LI->setAlignment(Align);
|
||||
return LI;
|
||||
}
|
||||
|
||||
// Deprecated [opaque pointer types]
|
||||
LoadInst *CreateAlignedLoad(Value *Ptr, unsigned Align, const char *Name) {
|
||||
return CreateAlignedLoad(Ptr->getType()->getPointerElementType(), Ptr,
|
||||
Align, Name);
|
||||
}
|
||||
// Deprecated [opaque pointer types]
|
||||
LoadInst *CreateAlignedLoad(Value *Ptr, unsigned Align,
|
||||
const Twine &Name = "") {
|
||||
LoadInst *LI = CreateLoad(Ptr, Name);
|
||||
LI->setAlignment(Align);
|
||||
return LI;
|
||||
return CreateAlignedLoad(Ptr->getType()->getPointerElementType(), Ptr,
|
||||
Align, Name);
|
||||
}
|
||||
// Deprecated [opaque pointer types]
|
||||
LoadInst *CreateAlignedLoad(Value *Ptr, unsigned Align, bool isVolatile,
|
||||
const Twine &Name = "") {
|
||||
LoadInst *LI = CreateLoad(Ptr, isVolatile, Name);
|
||||
LI->setAlignment(Align);
|
||||
return LI;
|
||||
return CreateAlignedLoad(Ptr->getType()->getPointerElementType(), Ptr,
|
||||
Align, isVolatile, Name);
|
||||
}
|
||||
|
||||
StoreInst *CreateAlignedStore(Value *Val, Value *Ptr, unsigned Align,
|
||||
|
@ -175,47 +175,58 @@ protected:
|
||||
LoadInst *cloneImpl() const;
|
||||
|
||||
public:
|
||||
LoadInst(Value *Ptr, const Twine &NameStr, Instruction *InsertBefore);
|
||||
LoadInst(Value *Ptr, const Twine &NameStr, BasicBlock *InsertAtEnd);
|
||||
LoadInst(Type *Ty, Value *Ptr, const Twine &NameStr, bool isVolatile = false,
|
||||
LoadInst(Type *Ty, Value *Ptr, const Twine &NameStr = "",
|
||||
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,
|
||||
LoadInst(Type *Ty, Value *Ptr, const Twine &NameStr, BasicBlock *InsertAtEnd);
|
||||
LoadInst(Type *Ty, Value *Ptr, const Twine &NameStr, bool isVolatile,
|
||||
Instruction *InsertBefore = nullptr);
|
||||
LoadInst(Type *Ty, Value *Ptr, const Twine &NameStr, bool isVolatile,
|
||||
BasicBlock *InsertAtEnd);
|
||||
LoadInst(Value *Ptr, const Twine &NameStr, bool isVolatile, unsigned Align,
|
||||
Instruction *InsertBefore = nullptr)
|
||||
: LoadInst(cast<PointerType>(Ptr->getType())->getElementType(), Ptr,
|
||||
NameStr, isVolatile, Align, InsertBefore) {}
|
||||
LoadInst(Type *Ty, Value *Ptr, const Twine &NameStr, bool isVolatile,
|
||||
unsigned Align, Instruction *InsertBefore = nullptr);
|
||||
LoadInst(Value *Ptr, const Twine &NameStr, bool isVolatile,
|
||||
LoadInst(Type *Ty, Value *Ptr, const Twine &NameStr, bool isVolatile,
|
||||
unsigned Align, BasicBlock *InsertAtEnd);
|
||||
LoadInst(Value *Ptr, const Twine &NameStr, bool isVolatile, unsigned Align,
|
||||
AtomicOrdering Order, SyncScope::ID SSID = SyncScope::System,
|
||||
Instruction *InsertBefore = nullptr)
|
||||
: LoadInst(cast<PointerType>(Ptr->getType())->getElementType(), Ptr,
|
||||
NameStr, isVolatile, Align, Order, SSID, InsertBefore) {}
|
||||
LoadInst(Type *Ty, Value *Ptr, const Twine &NameStr, bool isVolatile,
|
||||
unsigned Align, AtomicOrdering Order,
|
||||
SyncScope::ID SSID = SyncScope::System,
|
||||
Instruction *InsertBefore = nullptr);
|
||||
LoadInst(Value *Ptr, const Twine &NameStr, bool isVolatile,
|
||||
LoadInst(Type *Ty, Value *Ptr, const Twine &NameStr, bool isVolatile,
|
||||
unsigned Align, AtomicOrdering Order, SyncScope::ID SSID,
|
||||
BasicBlock *InsertAtEnd);
|
||||
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,
|
||||
|
||||
// Deprecated [opaque pointer types]
|
||||
explicit LoadInst(Value *Ptr, const Twine &NameStr = "",
|
||||
Instruction *InsertBefore = nullptr)
|
||||
: LoadInst(cast<PointerType>(Ptr->getType())->getElementType(), Ptr,
|
||||
NameStr, isVolatile, InsertBefore) {}
|
||||
LoadInst(Value *Ptr, const char *NameStr, bool isVolatile,
|
||||
BasicBlock *InsertAtEnd);
|
||||
: LoadInst(Ptr->getType()->getPointerElementType(), Ptr, NameStr,
|
||||
InsertBefore) {}
|
||||
LoadInst(Value *Ptr, const Twine &NameStr, BasicBlock *InsertAtEnd)
|
||||
: LoadInst(Ptr->getType()->getPointerElementType(), Ptr, NameStr,
|
||||
InsertAtEnd) {}
|
||||
LoadInst(Value *Ptr, const Twine &NameStr, bool isVolatile,
|
||||
Instruction *InsertBefore = nullptr)
|
||||
: LoadInst(Ptr->getType()->getPointerElementType(), Ptr, NameStr,
|
||||
isVolatile, InsertBefore) {}
|
||||
LoadInst(Value *Ptr, const Twine &NameStr, bool isVolatile,
|
||||
BasicBlock *InsertAtEnd)
|
||||
: LoadInst(Ptr->getType()->getPointerElementType(), Ptr, NameStr,
|
||||
isVolatile, InsertAtEnd) {}
|
||||
LoadInst(Value *Ptr, const Twine &NameStr, bool isVolatile, unsigned Align,
|
||||
Instruction *InsertBefore = nullptr)
|
||||
: LoadInst(Ptr->getType()->getPointerElementType(), Ptr, NameStr,
|
||||
isVolatile, Align, InsertBefore) {}
|
||||
LoadInst(Value *Ptr, const Twine &NameStr, bool isVolatile, unsigned Align,
|
||||
BasicBlock *InsertAtEnd)
|
||||
: LoadInst(Ptr->getType()->getPointerElementType(), Ptr, NameStr,
|
||||
isVolatile, Align, InsertAtEnd) {}
|
||||
LoadInst(Value *Ptr, const Twine &NameStr, bool isVolatile, unsigned Align,
|
||||
AtomicOrdering Order, SyncScope::ID SSID = SyncScope::System,
|
||||
Instruction *InsertBefore = nullptr)
|
||||
: LoadInst(Ptr->getType()->getPointerElementType(), Ptr, NameStr,
|
||||
isVolatile, Align, Order, SSID, InsertBefore) {}
|
||||
LoadInst(Value *Ptr, const Twine &NameStr, bool isVolatile, unsigned Align,
|
||||
AtomicOrdering Order, SyncScope::ID SSID, BasicBlock *InsertAtEnd)
|
||||
: LoadInst(Ptr->getType()->getPointerElementType(), Ptr, NameStr,
|
||||
isVolatile, Align, Order, SSID, InsertAtEnd) {}
|
||||
|
||||
/// Return true if this is a load from a volatile memory location.
|
||||
bool isVolatile() const { return getSubclassDataFromInstruction() & 1; }
|
||||
|
@ -3346,7 +3346,15 @@ LLVMValueRef LLVMBuildFree(LLVMBuilderRef B, LLVMValueRef PointerVal) {
|
||||
|
||||
LLVMValueRef LLVMBuildLoad(LLVMBuilderRef B, LLVMValueRef PointerVal,
|
||||
const char *Name) {
|
||||
return wrap(unwrap(B)->CreateLoad(unwrap(PointerVal), Name));
|
||||
Value *V = unwrap(PointerVal);
|
||||
PointerType *Ty = cast<PointerType>(V->getType());
|
||||
|
||||
return wrap(unwrap(B)->CreateLoad(Ty->getElementType(), V, Name));
|
||||
}
|
||||
|
||||
LLVMValueRef LLVMBuildLoad2(LLVMBuilderRef B, LLVMTypeRef Ty,
|
||||
LLVMValueRef PointerVal, const char *Name) {
|
||||
return wrap(unwrap(B)->CreateLoad(unwrap(Ty), unwrap(PointerVal), Name));
|
||||
}
|
||||
|
||||
LLVMValueRef LLVMBuildStore(LLVMBuilderRef B, LLVMValueRef Val,
|
||||
|
@ -1138,28 +1138,30 @@ void LoadInst::AssertOK() {
|
||||
"Alignment required for atomic load");
|
||||
}
|
||||
|
||||
LoadInst::LoadInst(Value *Ptr, const Twine &Name, Instruction *InsertBef)
|
||||
: LoadInst(Ptr, Name, /*isVolatile=*/false, InsertBef) {}
|
||||
LoadInst::LoadInst(Type *Ty, Value *Ptr, const Twine &Name,
|
||||
Instruction *InsertBef)
|
||||
: LoadInst(Ty, Ptr, Name, /*isVolatile=*/false, InsertBef) {}
|
||||
|
||||
LoadInst::LoadInst(Value *Ptr, const Twine &Name, BasicBlock *InsertAE)
|
||||
: LoadInst(Ptr, Name, /*isVolatile=*/false, InsertAE) {}
|
||||
LoadInst::LoadInst(Type *Ty, Value *Ptr, const Twine &Name,
|
||||
BasicBlock *InsertAE)
|
||||
: LoadInst(Ty, Ptr, Name, /*isVolatile=*/false, InsertAE) {}
|
||||
|
||||
LoadInst::LoadInst(Type *Ty, Value *Ptr, const Twine &Name, bool isVolatile,
|
||||
Instruction *InsertBef)
|
||||
: LoadInst(Ty, Ptr, Name, isVolatile, /*Align=*/0, InsertBef) {}
|
||||
|
||||
LoadInst::LoadInst(Value *Ptr, const Twine &Name, bool isVolatile,
|
||||
LoadInst::LoadInst(Type *Ty, Value *Ptr, const Twine &Name, bool isVolatile,
|
||||
BasicBlock *InsertAE)
|
||||
: LoadInst(Ptr, Name, isVolatile, /*Align=*/0, InsertAE) {}
|
||||
: LoadInst(Ty, Ptr, Name, isVolatile, /*Align=*/0, InsertAE) {}
|
||||
|
||||
LoadInst::LoadInst(Type *Ty, Value *Ptr, const Twine &Name, bool isVolatile,
|
||||
unsigned Align, Instruction *InsertBef)
|
||||
: LoadInst(Ty, Ptr, Name, isVolatile, Align, AtomicOrdering::NotAtomic,
|
||||
SyncScope::System, InsertBef) {}
|
||||
|
||||
LoadInst::LoadInst(Value *Ptr, const Twine &Name, bool isVolatile,
|
||||
LoadInst::LoadInst(Type *Ty, Value *Ptr, const Twine &Name, bool isVolatile,
|
||||
unsigned Align, BasicBlock *InsertAE)
|
||||
: LoadInst(Ptr, Name, isVolatile, Align, AtomicOrdering::NotAtomic,
|
||||
: LoadInst(Ty, Ptr, Name, isVolatile, Align, AtomicOrdering::NotAtomic,
|
||||
SyncScope::System, InsertAE) {}
|
||||
|
||||
LoadInst::LoadInst(Type *Ty, Value *Ptr, const Twine &Name, bool isVolatile,
|
||||
@ -1174,12 +1176,11 @@ LoadInst::LoadInst(Type *Ty, Value *Ptr, const Twine &Name, bool isVolatile,
|
||||
setName(Name);
|
||||
}
|
||||
|
||||
LoadInst::LoadInst(Value *Ptr, const Twine &Name, bool isVolatile,
|
||||
unsigned Align, AtomicOrdering Order,
|
||||
SyncScope::ID SSID,
|
||||
LoadInst::LoadInst(Type *Ty, Value *Ptr, const Twine &Name, bool isVolatile,
|
||||
unsigned Align, AtomicOrdering Order, SyncScope::ID SSID,
|
||||
BasicBlock *InsertAE)
|
||||
: UnaryInstruction(cast<PointerType>(Ptr->getType())->getElementType(),
|
||||
Load, Ptr, InsertAE) {
|
||||
: UnaryInstruction(Ty, Load, Ptr, InsertAE) {
|
||||
assert(Ty == cast<PointerType>(Ptr->getType())->getElementType());
|
||||
setVolatile(isVolatile);
|
||||
setAlignment(Align);
|
||||
setAtomic(Order, SSID);
|
||||
@ -1187,48 +1188,6 @@ LoadInst::LoadInst(Value *Ptr, const Twine &Name, bool isVolatile,
|
||||
setName(Name);
|
||||
}
|
||||
|
||||
LoadInst::LoadInst(Value *Ptr, const char *Name, Instruction *InsertBef)
|
||||
: UnaryInstruction(cast<PointerType>(Ptr->getType())->getElementType(),
|
||||
Load, Ptr, InsertBef) {
|
||||
setVolatile(false);
|
||||
setAlignment(0);
|
||||
setAtomic(AtomicOrdering::NotAtomic);
|
||||
AssertOK();
|
||||
if (Name && Name[0]) setName(Name);
|
||||
}
|
||||
|
||||
LoadInst::LoadInst(Value *Ptr, const char *Name, BasicBlock *InsertAE)
|
||||
: UnaryInstruction(cast<PointerType>(Ptr->getType())->getElementType(),
|
||||
Load, Ptr, InsertAE) {
|
||||
setVolatile(false);
|
||||
setAlignment(0);
|
||||
setAtomic(AtomicOrdering::NotAtomic);
|
||||
AssertOK();
|
||||
if (Name && Name[0]) setName(Name);
|
||||
}
|
||||
|
||||
LoadInst::LoadInst(Type *Ty, Value *Ptr, const char *Name, bool isVolatile,
|
||||
Instruction *InsertBef)
|
||||
: UnaryInstruction(Ty, Load, Ptr, InsertBef) {
|
||||
assert(Ty == cast<PointerType>(Ptr->getType())->getElementType());
|
||||
setVolatile(isVolatile);
|
||||
setAlignment(0);
|
||||
setAtomic(AtomicOrdering::NotAtomic);
|
||||
AssertOK();
|
||||
if (Name && Name[0]) setName(Name);
|
||||
}
|
||||
|
||||
LoadInst::LoadInst(Value *Ptr, const char *Name, bool isVolatile,
|
||||
BasicBlock *InsertAE)
|
||||
: UnaryInstruction(cast<PointerType>(Ptr->getType())->getElementType(),
|
||||
Load, Ptr, InsertAE) {
|
||||
setVolatile(isVolatile);
|
||||
setAlignment(0);
|
||||
setAtomic(AtomicOrdering::NotAtomic);
|
||||
AssertOK();
|
||||
if (Name && Name[0]) setName(Name);
|
||||
}
|
||||
|
||||
void LoadInst::setAlignment(unsigned Align) {
|
||||
assert((Align & (Align-1)) == 0 && "Alignment is not a power of 2!");
|
||||
assert(Align <= MaximumAlignment &&
|
||||
@ -3879,7 +3838,7 @@ AllocaInst *AllocaInst::cloneImpl() const {
|
||||
}
|
||||
|
||||
LoadInst *LoadInst::cloneImpl() const {
|
||||
return new LoadInst(getOperand(0), Twine(), isVolatile(),
|
||||
return new LoadInst(getType(), getOperand(0), Twine(), isVolatile(),
|
||||
getAlignment(), getOrdering(), getSyncScopeID());
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user