mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-24 03:49:45 +00:00
[opaque pointer types] Pass function types to CallInst creation.
This cleans up all CallInst creation in LLVM to explicitly pass a function type rather than deriving it from the pointer's element-type. Differential Revision: https://reviews.llvm.org/D57170 llvm-svn: 352909
This commit is contained in:
parent
005463fb13
commit
31a2057127
@ -1521,7 +1521,7 @@ public:
|
||||
/// performs validation and error handling, returns the function. Otherwise,
|
||||
/// returns nullptr. Must be previously inserted by insertSSPDeclarations.
|
||||
/// Should be used only when getIRStackGuard returns nullptr.
|
||||
virtual Value *getSSPStackGuardCheck(const Module &M) const;
|
||||
virtual Function *getSSPStackGuardCheck(const Module &M) const;
|
||||
|
||||
protected:
|
||||
Value *getDefaultSafeStackPointerLocation(IRBuilder<> &IRB,
|
||||
|
@ -1177,7 +1177,7 @@ static bool CombineUAddWithOverflow(CmpInst *CI) {
|
||||
#endif
|
||||
|
||||
Module *M = CI->getModule();
|
||||
Value *F = Intrinsic::getDeclaration(M, Intrinsic::uadd_with_overflow, Ty);
|
||||
Function *F = Intrinsic::getDeclaration(M, Intrinsic::uadd_with_overflow, Ty);
|
||||
|
||||
auto *InsertPt = AddI->hasOneUse() ? CI : AddI;
|
||||
|
||||
|
@ -498,7 +498,7 @@ bool IntrinsicLowering::LowerToByteSwap(CallInst *CI) {
|
||||
|
||||
// Okay, we can do this xform, do so now.
|
||||
Module *M = CI->getModule();
|
||||
Constant *Int = Intrinsic::getDeclaration(M, Intrinsic::bswap, Ty);
|
||||
Function *Int = Intrinsic::getDeclaration(M, Intrinsic::bswap, Ty);
|
||||
|
||||
Value *Op = CI->getArgOperand(0);
|
||||
Op = CallInst::Create(Int, Op, CI->getName(), CI);
|
||||
|
@ -2283,27 +2283,26 @@ void SelectionDAGBuilder::visitSPDescriptorParent(StackProtectorDescriptor &SPD,
|
||||
GuardVal = TLI.emitStackGuardXorFP(DAG, GuardVal, dl);
|
||||
|
||||
// Retrieve guard check function, nullptr if instrumentation is inlined.
|
||||
if (const Value *GuardCheck = TLI.getSSPStackGuardCheck(M)) {
|
||||
if (const Function *GuardCheckFn = TLI.getSSPStackGuardCheck(M)) {
|
||||
// The target provides a guard check function to validate the guard value.
|
||||
// Generate a call to that function with the content of the guard slot as
|
||||
// argument.
|
||||
auto *Fn = cast<Function>(GuardCheck);
|
||||
FunctionType *FnTy = Fn->getFunctionType();
|
||||
FunctionType *FnTy = GuardCheckFn->getFunctionType();
|
||||
assert(FnTy->getNumParams() == 1 && "Invalid function signature");
|
||||
|
||||
TargetLowering::ArgListTy Args;
|
||||
TargetLowering::ArgListEntry Entry;
|
||||
Entry.Node = GuardVal;
|
||||
Entry.Ty = FnTy->getParamType(0);
|
||||
if (Fn->hasAttribute(1, Attribute::AttrKind::InReg))
|
||||
if (GuardCheckFn->hasAttribute(1, Attribute::AttrKind::InReg))
|
||||
Entry.IsInReg = true;
|
||||
Args.push_back(Entry);
|
||||
|
||||
TargetLowering::CallLoweringInfo CLI(DAG);
|
||||
CLI.setDebugLoc(getCurSDLoc())
|
||||
.setChain(DAG.getEntryNode())
|
||||
.setCallee(Fn->getCallingConv(), FnTy->getReturnType(),
|
||||
getValue(GuardCheck), std::move(Args));
|
||||
.setChain(DAG.getEntryNode())
|
||||
.setCallee(GuardCheckFn->getCallingConv(), FnTy->getReturnType(),
|
||||
getValue(GuardCheckFn), std::move(Args));
|
||||
|
||||
std::pair<SDValue, SDValue> Result = TLI.LowerCallTo(CLI);
|
||||
DAG.setRoot(Result.second);
|
||||
|
@ -413,15 +413,14 @@ bool StackProtector::InsertStackProtectors() {
|
||||
// Generate epilogue instrumentation. The epilogue intrumentation can be
|
||||
// function-based or inlined depending on which mechanism the target is
|
||||
// providing.
|
||||
if (Value* GuardCheck = TLI->getSSPStackGuardCheck(*M)) {
|
||||
if (Function *GuardCheck = TLI->getSSPStackGuardCheck(*M)) {
|
||||
// Generate the function-based epilogue instrumentation.
|
||||
// The target provides a guard check function, generate a call to it.
|
||||
IRBuilder<> B(RI);
|
||||
LoadInst *Guard = B.CreateLoad(AI, true, "Guard");
|
||||
CallInst *Call = B.CreateCall(GuardCheck, {Guard});
|
||||
llvm::Function *Function = cast<llvm::Function>(GuardCheck);
|
||||
Call->setAttributes(Function->getAttributes());
|
||||
Call->setCallingConv(Function->getCallingConv());
|
||||
Call->setAttributes(GuardCheck->getAttributes());
|
||||
Call->setCallingConv(GuardCheck->getCallingConv());
|
||||
} else {
|
||||
// Generate the epilogue with inline instrumentation.
|
||||
// If we do not support SelectionDAG based tail calls, generate IR level
|
||||
|
@ -1663,7 +1663,7 @@ Value *TargetLoweringBase::getSDagStackGuard(const Module &M) const {
|
||||
return M.getNamedValue("__stack_chk_guard");
|
||||
}
|
||||
|
||||
Value *TargetLoweringBase::getSSPStackGuardCheck(const Module &M) const {
|
||||
Function *TargetLoweringBase::getSSPStackGuardCheck(const Module &M) const {
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
|
@ -235,13 +235,14 @@ void makeStub(Function &F, Value &ImplPointer) {
|
||||
assert(F.isDeclaration() && "Can't turn a definition into a stub.");
|
||||
assert(F.getParent() && "Function isn't in a module.");
|
||||
Module &M = *F.getParent();
|
||||
FunctionType *FTy = F.getFunctionType();
|
||||
BasicBlock *EntryBlock = BasicBlock::Create(M.getContext(), "entry", &F);
|
||||
IRBuilder<> Builder(EntryBlock);
|
||||
LoadInst *ImplAddr = Builder.CreateLoad(&ImplPointer);
|
||||
std::vector<Value*> CallArgs;
|
||||
for (auto &A : F.args())
|
||||
CallArgs.push_back(&A);
|
||||
CallInst *Call = Builder.CreateCall(ImplAddr, CallArgs);
|
||||
CallInst *Call = Builder.CreateCall(FTy, ImplAddr, CallArgs);
|
||||
Call->setTailCall();
|
||||
Call->setAttributes(F.getAttributes());
|
||||
if (F.getReturnType()->isVoidTy())
|
||||
|
@ -71,7 +71,7 @@ Value *IRBuilderBase::getCastedInt8PtrValue(Value *Ptr) {
|
||||
return BCI;
|
||||
}
|
||||
|
||||
static CallInst *createCallHelper(Value *Callee, ArrayRef<Value *> Ops,
|
||||
static CallInst *createCallHelper(Function *Callee, ArrayRef<Value *> Ops,
|
||||
IRBuilderBase *Builder,
|
||||
const Twine &Name = "",
|
||||
Instruction *FMFSource = nullptr) {
|
||||
@ -104,7 +104,7 @@ CreateMemSet(Value *Ptr, Value *Val, Value *Size, unsigned Align,
|
||||
Value *Ops[] = {Ptr, Val, Size, getInt1(isVolatile)};
|
||||
Type *Tys[] = { Ptr->getType(), Size->getType() };
|
||||
Module *M = BB->getParent()->getParent();
|
||||
Value *TheFn = Intrinsic::getDeclaration(M, Intrinsic::memset, Tys);
|
||||
Function *TheFn = Intrinsic::getDeclaration(M, Intrinsic::memset, Tys);
|
||||
|
||||
CallInst *CI = createCallHelper(TheFn, Ops, this);
|
||||
|
||||
@ -134,7 +134,7 @@ CallInst *IRBuilderBase::CreateElementUnorderedAtomicMemSet(
|
||||
Value *Ops[] = {Ptr, Val, Size, getInt32(ElementSize)};
|
||||
Type *Tys[] = {Ptr->getType(), Size->getType()};
|
||||
Module *M = BB->getParent()->getParent();
|
||||
Value *TheFn = Intrinsic::getDeclaration(
|
||||
Function *TheFn = Intrinsic::getDeclaration(
|
||||
M, Intrinsic::memset_element_unordered_atomic, Tys);
|
||||
|
||||
CallInst *CI = createCallHelper(TheFn, Ops, this);
|
||||
@ -166,7 +166,7 @@ CreateMemCpy(Value *Dst, unsigned DstAlign, Value *Src, unsigned SrcAlign,
|
||||
Value *Ops[] = {Dst, Src, Size, getInt1(isVolatile)};
|
||||
Type *Tys[] = { Dst->getType(), Src->getType(), Size->getType() };
|
||||
Module *M = BB->getParent()->getParent();
|
||||
Value *TheFn = Intrinsic::getDeclaration(M, Intrinsic::memcpy, Tys);
|
||||
Function *TheFn = Intrinsic::getDeclaration(M, Intrinsic::memcpy, Tys);
|
||||
|
||||
CallInst *CI = createCallHelper(TheFn, Ops, this);
|
||||
|
||||
@ -207,7 +207,7 @@ CallInst *IRBuilderBase::CreateElementUnorderedAtomicMemCpy(
|
||||
Value *Ops[] = {Dst, Src, Size, getInt32(ElementSize)};
|
||||
Type *Tys[] = {Dst->getType(), Src->getType(), Size->getType()};
|
||||
Module *M = BB->getParent()->getParent();
|
||||
Value *TheFn = Intrinsic::getDeclaration(
|
||||
Function *TheFn = Intrinsic::getDeclaration(
|
||||
M, Intrinsic::memcpy_element_unordered_atomic, Tys);
|
||||
|
||||
CallInst *CI = createCallHelper(TheFn, Ops, this);
|
||||
@ -246,7 +246,7 @@ CreateMemMove(Value *Dst, unsigned DstAlign, Value *Src, unsigned SrcAlign,
|
||||
Value *Ops[] = {Dst, Src, Size, getInt1(isVolatile)};
|
||||
Type *Tys[] = { Dst->getType(), Src->getType(), Size->getType() };
|
||||
Module *M = BB->getParent()->getParent();
|
||||
Value *TheFn = Intrinsic::getDeclaration(M, Intrinsic::memmove, Tys);
|
||||
Function *TheFn = Intrinsic::getDeclaration(M, Intrinsic::memmove, Tys);
|
||||
|
||||
CallInst *CI = createCallHelper(TheFn, Ops, this);
|
||||
|
||||
@ -283,7 +283,7 @@ CallInst *IRBuilderBase::CreateElementUnorderedAtomicMemMove(
|
||||
Value *Ops[] = {Dst, Src, Size, getInt32(ElementSize)};
|
||||
Type *Tys[] = {Dst->getType(), Src->getType(), Size->getType()};
|
||||
Module *M = BB->getParent()->getParent();
|
||||
Value *TheFn = Intrinsic::getDeclaration(
|
||||
Function *TheFn = Intrinsic::getDeclaration(
|
||||
M, Intrinsic::memmove_element_unordered_atomic, Tys);
|
||||
|
||||
CallInst *CI = createCallHelper(TheFn, Ops, this);
|
||||
@ -408,8 +408,8 @@ CallInst *IRBuilderBase::CreateLifetimeStart(Value *Ptr, ConstantInt *Size) {
|
||||
"lifetime.start requires the size to be an i64");
|
||||
Value *Ops[] = { Size, Ptr };
|
||||
Module *M = BB->getParent()->getParent();
|
||||
Value *TheFn = Intrinsic::getDeclaration(M, Intrinsic::lifetime_start,
|
||||
{ Ptr->getType() });
|
||||
Function *TheFn =
|
||||
Intrinsic::getDeclaration(M, Intrinsic::lifetime_start, {Ptr->getType()});
|
||||
return createCallHelper(TheFn, Ops, this);
|
||||
}
|
||||
|
||||
@ -424,8 +424,8 @@ CallInst *IRBuilderBase::CreateLifetimeEnd(Value *Ptr, ConstantInt *Size) {
|
||||
"lifetime.end requires the size to be an i64");
|
||||
Value *Ops[] = { Size, Ptr };
|
||||
Module *M = BB->getParent()->getParent();
|
||||
Value *TheFn = Intrinsic::getDeclaration(M, Intrinsic::lifetime_end,
|
||||
{ Ptr->getType() });
|
||||
Function *TheFn =
|
||||
Intrinsic::getDeclaration(M, Intrinsic::lifetime_end, {Ptr->getType()});
|
||||
return createCallHelper(TheFn, Ops, this);
|
||||
}
|
||||
|
||||
@ -444,7 +444,7 @@ CallInst *IRBuilderBase::CreateInvariantStart(Value *Ptr, ConstantInt *Size) {
|
||||
// Fill in the single overloaded type: memory object type.
|
||||
Type *ObjectPtr[1] = {Ptr->getType()};
|
||||
Module *M = BB->getParent()->getParent();
|
||||
Value *TheFn =
|
||||
Function *TheFn =
|
||||
Intrinsic::getDeclaration(M, Intrinsic::invariant_start, ObjectPtr);
|
||||
return createCallHelper(TheFn, Ops, this);
|
||||
}
|
||||
@ -455,7 +455,7 @@ CallInst *IRBuilderBase::CreateAssumption(Value *Cond) {
|
||||
|
||||
Value *Ops[] = { Cond };
|
||||
Module *M = BB->getParent()->getParent();
|
||||
Value *FnAssume = Intrinsic::getDeclaration(M, Intrinsic::assume);
|
||||
Function *FnAssume = Intrinsic::getDeclaration(M, Intrinsic::assume);
|
||||
return createCallHelper(FnAssume, Ops, this);
|
||||
}
|
||||
|
||||
@ -507,7 +507,7 @@ CallInst *IRBuilderBase::CreateMaskedIntrinsic(Intrinsic::ID Id,
|
||||
ArrayRef<Type *> OverloadedTypes,
|
||||
const Twine &Name) {
|
||||
Module *M = BB->getParent()->getParent();
|
||||
Value *TheFn = Intrinsic::getDeclaration(M, Id, OverloadedTypes);
|
||||
Function *TheFn = Intrinsic::getDeclaration(M, Id, OverloadedTypes);
|
||||
return createCallHelper(TheFn, Ops, this, Name);
|
||||
}
|
||||
|
||||
@ -708,7 +708,7 @@ CallInst *IRBuilderBase::CreateGCResult(Instruction *Statepoint,
|
||||
Intrinsic::ID ID = Intrinsic::experimental_gc_result;
|
||||
Module *M = BB->getParent()->getParent();
|
||||
Type *Types[] = {ResultType};
|
||||
Value *FnGCResult = Intrinsic::getDeclaration(M, ID, Types);
|
||||
Function *FnGCResult = Intrinsic::getDeclaration(M, ID, Types);
|
||||
|
||||
Value *Args[] = {Statepoint};
|
||||
return createCallHelper(FnGCResult, Args, this, Name);
|
||||
@ -721,8 +721,8 @@ CallInst *IRBuilderBase::CreateGCRelocate(Instruction *Statepoint,
|
||||
const Twine &Name) {
|
||||
Module *M = BB->getParent()->getParent();
|
||||
Type *Types[] = {ResultType};
|
||||
Value *FnGCRelocate =
|
||||
Intrinsic::getDeclaration(M, Intrinsic::experimental_gc_relocate, Types);
|
||||
Function *FnGCRelocate =
|
||||
Intrinsic::getDeclaration(M, Intrinsic::experimental_gc_relocate, Types);
|
||||
|
||||
Value *Args[] = {Statepoint,
|
||||
getInt32(BaseOffset),
|
||||
|
@ -443,8 +443,8 @@ CallInst *CallInst::Create(CallInst *CI, ArrayRef<OperandBundleDef> OpB,
|
||||
Instruction *InsertPt) {
|
||||
std::vector<Value *> Args(CI->arg_begin(), CI->arg_end());
|
||||
|
||||
auto *NewCI = CallInst::Create(CI->getCalledValue(), Args, OpB, CI->getName(),
|
||||
InsertPt);
|
||||
auto *NewCI = CallInst::Create(CI->getFunctionType(), CI->getCalledValue(),
|
||||
Args, OpB, CI->getName(), InsertPt);
|
||||
NewCI->setTailCallKind(CI->getTailCallKind());
|
||||
NewCI->setCallingConv(CI->getCallingConv());
|
||||
NewCI->SubclassOptionalData = CI->SubclassOptionalData;
|
||||
|
@ -11763,7 +11763,7 @@ Value *AArch64TargetLowering::getSDagStackGuard(const Module &M) const {
|
||||
return TargetLowering::getSDagStackGuard(M);
|
||||
}
|
||||
|
||||
Value *AArch64TargetLowering::getSSPStackGuardCheck(const Module &M) const {
|
||||
Function *AArch64TargetLowering::getSSPStackGuardCheck(const Module &M) const {
|
||||
// MSVC CRT has a function to validate security cookie.
|
||||
if (Subtarget->getTargetTriple().isWindowsMSVCEnvironment())
|
||||
return M.getFunction("__security_check_cookie");
|
||||
|
@ -408,7 +408,7 @@ public:
|
||||
|
||||
void insertSSPDeclarations(Module &M) const override;
|
||||
Value *getSDagStackGuard(const Module &M) const override;
|
||||
Value *getSSPStackGuardCheck(const Module &M) const override;
|
||||
Function *getSSPStackGuardCheck(const Module &M) const override;
|
||||
|
||||
/// If the target has a standard location for the unsafe stack pointer,
|
||||
/// returns the address of that location. Otherwise, returns nullptr.
|
||||
|
@ -210,7 +210,7 @@ bool HexagonGenExtract::convert(Instruction *In) {
|
||||
Intrinsic::ID IntId = (BW == 32) ? Intrinsic::hexagon_S2_extractu
|
||||
: Intrinsic::hexagon_S2_extractup;
|
||||
Module *Mod = BB->getParent()->getParent();
|
||||
Value *ExtF = Intrinsic::getDeclaration(Mod, IntId);
|
||||
Function *ExtF = Intrinsic::getDeclaration(Mod, IntId);
|
||||
Value *NewIn = IRB.CreateCall(ExtF, {BF, IRB.getInt32(W), IRB.getInt32(SR)});
|
||||
if (SL != 0)
|
||||
NewIn = IRB.CreateShl(NewIn, SL, CSL->getName());
|
||||
|
@ -3116,12 +3116,12 @@ Value *HexagonTargetLowering::emitLoadLinked(IRBuilder<> &Builder, Value *Addr,
|
||||
assert((SZ == 32 || SZ == 64) && "Only 32/64-bit atomic loads supported");
|
||||
Intrinsic::ID IntID = (SZ == 32) ? Intrinsic::hexagon_L2_loadw_locked
|
||||
: Intrinsic::hexagon_L4_loadd_locked;
|
||||
Function *Fn = Intrinsic::getDeclaration(M, IntID);
|
||||
|
||||
PointerType *NewPtrTy
|
||||
= Builder.getIntNTy(SZ)->getPointerTo(PT->getAddressSpace());
|
||||
Addr = Builder.CreateBitCast(Addr, NewPtrTy);
|
||||
|
||||
Value *Fn = Intrinsic::getDeclaration(M, IntID);
|
||||
Value *Call = Builder.CreateCall(Fn, Addr, "larx");
|
||||
|
||||
return Builder.CreateBitCast(Call, Ty);
|
||||
@ -3140,7 +3140,7 @@ Value *HexagonTargetLowering::emitStoreConditional(IRBuilder<> &Builder,
|
||||
assert((SZ == 32 || SZ == 64) && "Only 32/64-bit atomic stores supported");
|
||||
Intrinsic::ID IntID = (SZ == 32) ? Intrinsic::hexagon_S2_storew_locked
|
||||
: Intrinsic::hexagon_S4_stored_locked;
|
||||
Value *Fn = Intrinsic::getDeclaration(M, IntID);
|
||||
Function *Fn = Intrinsic::getDeclaration(M, IntID);
|
||||
|
||||
unsigned AS = Addr->getType()->getPointerAddressSpace();
|
||||
Addr = Builder.CreateBitCast(Addr, CastTy->getPointerTo(AS));
|
||||
|
@ -1523,7 +1523,7 @@ Value *PolynomialMultiplyRecognize::generate(BasicBlock::iterator At,
|
||||
ParsedValues &PV) {
|
||||
IRBuilder<> B(&*At);
|
||||
Module *M = At->getParent()->getParent()->getParent();
|
||||
Value *PMF = Intrinsic::getDeclaration(M, Intrinsic::hexagon_M4_pmpyw);
|
||||
Function *PMF = Intrinsic::getDeclaration(M, Intrinsic::hexagon_M4_pmpyw);
|
||||
|
||||
Value *P = PV.P, *Q = PV.Q, *P0 = P;
|
||||
unsigned IC = PV.IterCount;
|
||||
|
@ -660,13 +660,13 @@ bool PPCCTRLoops::convertToCTRLoop(Loop *L) {
|
||||
|
||||
IRBuilder<> CountBuilder(Preheader->getTerminator());
|
||||
Module *M = Preheader->getParent()->getParent();
|
||||
Value *MTCTRFunc = Intrinsic::getDeclaration(M, Intrinsic::ppc_mtctr,
|
||||
CountType);
|
||||
Function *MTCTRFunc =
|
||||
Intrinsic::getDeclaration(M, Intrinsic::ppc_mtctr, CountType);
|
||||
CountBuilder.CreateCall(MTCTRFunc, ECValue);
|
||||
|
||||
IRBuilder<> CondBuilder(CountedExitBranch);
|
||||
Value *DecFunc =
|
||||
Intrinsic::getDeclaration(M, Intrinsic::ppc_is_decremented_ctr_nonzero);
|
||||
Function *DecFunc =
|
||||
Intrinsic::getDeclaration(M, Intrinsic::ppc_is_decremented_ctr_nonzero);
|
||||
Value *NewCond = CondBuilder.CreateCall(DecFunc, {});
|
||||
Value *OldCond = CountedExitBranch->getCondition();
|
||||
CountedExitBranch->setCondition(NewCond);
|
||||
|
@ -355,8 +355,8 @@ bool SystemZTDCPass::runOnFunction(Function &F) {
|
||||
if (!Worthy)
|
||||
continue;
|
||||
// Call the intrinsic, compare result with 0.
|
||||
Value *TDCFunc = Intrinsic::getDeclaration(&M, Intrinsic::s390_tdc,
|
||||
V->getType());
|
||||
Function *TDCFunc =
|
||||
Intrinsic::getDeclaration(&M, Intrinsic::s390_tdc, V->getType());
|
||||
IRBuilder<> IRB(I);
|
||||
Value *MaskVal = ConstantInt::get(Type::getInt64Ty(Ctx), Mask);
|
||||
Instruction *TDC = IRB.CreateCall(TDCFunc, {V, MaskVal});
|
||||
|
@ -262,7 +262,7 @@ bool FixFunctionBitcasts::runOnModule(Module &M) {
|
||||
UndefValue::get(MainArgTys[1])};
|
||||
Value *Casted =
|
||||
ConstantExpr::getBitCast(Main, PointerType::get(MainTy, 0));
|
||||
CallMain = CallInst::Create(Casted, Args, "call_main");
|
||||
CallMain = CallInst::Create(MainTy, Casted, Args, "call_main");
|
||||
Use *UseMain = &CallMain->getOperandUse(2);
|
||||
Uses.push_back(std::make_pair(UseMain, &F));
|
||||
}
|
||||
|
@ -768,7 +768,8 @@ bool WebAssemblyLowerEmscriptenEHSjLj::runEHOnFunction(Function &F) {
|
||||
// This can't throw, and we don't need this invoke, just replace it with a
|
||||
// call+branch
|
||||
SmallVector<Value *, 16> Args(II->arg_begin(), II->arg_end());
|
||||
CallInst *NewCall = IRB.CreateCall(II->getCalledValue(), Args);
|
||||
CallInst *NewCall =
|
||||
IRB.CreateCall(II->getFunctionType(), II->getCalledValue(), Args);
|
||||
NewCall->takeName(II);
|
||||
NewCall->setCallingConv(II->getCallingConv());
|
||||
NewCall->setDebugLoc(II->getDebugLoc());
|
||||
|
@ -143,13 +143,13 @@ bool LowerGlobalDtors::runOnModule(Module &M) {
|
||||
: Twine()),
|
||||
&M);
|
||||
BasicBlock *BB = BasicBlock::Create(C, "body", CallDtors);
|
||||
|
||||
for (auto Dtor : AssociatedAndMore.second)
|
||||
CallInst::Create(Dtor, "", BB);
|
||||
ReturnInst::Create(C, BB);
|
||||
|
||||
FunctionType *VoidVoid = FunctionType::get(Type::getVoidTy(C),
|
||||
/*isVarArg=*/false);
|
||||
|
||||
for (auto Dtor : AssociatedAndMore.second)
|
||||
CallInst::Create(VoidVoid, Dtor, "", BB);
|
||||
ReturnInst::Create(C, BB);
|
||||
|
||||
Function *RegisterCallDtors = Function::Create(
|
||||
VoidVoid, Function::PrivateLinkage,
|
||||
"register_call_dtors" +
|
||||
|
@ -2303,7 +2303,7 @@ Value *X86TargetLowering::getSDagStackGuard(const Module &M) const {
|
||||
return TargetLowering::getSDagStackGuard(M);
|
||||
}
|
||||
|
||||
Value *X86TargetLowering::getSSPStackGuardCheck(const Module &M) const {
|
||||
Function *X86TargetLowering::getSSPStackGuardCheck(const Module &M) const {
|
||||
// MSVC CRT has a function to validate security cookie.
|
||||
if (Subtarget.getTargetTriple().isWindowsMSVCEnvironment() ||
|
||||
Subtarget.getTargetTriple().isWindowsItaniumEnvironment()) {
|
||||
|
@ -1110,7 +1110,7 @@ namespace llvm {
|
||||
bool useStackGuardXorFP() const override;
|
||||
void insertSSPDeclarations(Module &M) const override;
|
||||
Value *getSDagStackGuard(const Module &M) const override;
|
||||
Value *getSSPStackGuardCheck(const Module &M) const override;
|
||||
Function *getSSPStackGuardCheck(const Module &M) const override;
|
||||
SDValue emitStackGuardXorFP(SelectionDAG &DAG, SDValue Val,
|
||||
const SDLoc &DL) const override;
|
||||
|
||||
|
@ -411,7 +411,7 @@ Function *WinEHStatePass::generateLSDAInEAXThunk(Function *ParentFunc) {
|
||||
Builder.CreateBitCast(PersonalityFn, TargetFuncTy->getPointerTo());
|
||||
auto AI = Trampoline->arg_begin();
|
||||
Value *Args[5] = {LSDA, &*AI++, &*AI++, &*AI++, &*AI++};
|
||||
CallInst *Call = Builder.CreateCall(CastPersonality, Args);
|
||||
CallInst *Call = Builder.CreateCall(TargetFuncTy, CastPersonality, Args);
|
||||
// Can't use musttail due to prototype mismatch, but we can use tail.
|
||||
Call->setTailCall(true);
|
||||
// Set inreg so we pass it in EAX.
|
||||
|
@ -827,6 +827,7 @@ static void splitCoroutine(Function &F, CallGraph &CG, CallGraphSCC &SCC) {
|
||||
// split.
|
||||
static void prepareForSplit(Function &F, CallGraph &CG) {
|
||||
Module &M = *F.getParent();
|
||||
LLVMContext &Context = F.getContext();
|
||||
#ifndef NDEBUG
|
||||
Function *DevirtFn = M.getFunction(CORO_DEVIRT_TRIGGER_FN);
|
||||
assert(DevirtFn && "coro.devirt.trigger function not found");
|
||||
@ -841,10 +842,12 @@ static void prepareForSplit(Function &F, CallGraph &CG) {
|
||||
// call void %1(i8* null)
|
||||
coro::LowererBase Lowerer(M);
|
||||
Instruction *InsertPt = F.getEntryBlock().getTerminator();
|
||||
auto *Null = ConstantPointerNull::get(Type::getInt8PtrTy(F.getContext()));
|
||||
auto *Null = ConstantPointerNull::get(Type::getInt8PtrTy(Context));
|
||||
auto *DevirtFnAddr =
|
||||
Lowerer.makeSubFnCall(Null, CoroSubFnInst::RestartTrigger, InsertPt);
|
||||
auto *IndirectCall = CallInst::Create(DevirtFnAddr, Null, "", InsertPt);
|
||||
FunctionType *FnTy = FunctionType::get(Type::getVoidTy(Context),
|
||||
{Type::getInt8PtrTy(Context)}, false);
|
||||
auto *IndirectCall = CallInst::Create(FnTy, DevirtFnAddr, Null, "", InsertPt);
|
||||
|
||||
// Update CG graph with an indirect call we just added.
|
||||
CG[&F]->addCalledFunction(IndirectCall, CG.getCallsExternalNode());
|
||||
|
@ -938,7 +938,7 @@ bool DeadArgumentEliminationPass::RemoveDeadStuffFromFunction(Function *F) {
|
||||
NewCS = InvokeInst::Create(NF, II->getNormalDest(), II->getUnwindDest(),
|
||||
Args, OpBundles, "", Call->getParent());
|
||||
} else {
|
||||
NewCS = CallInst::Create(NF, Args, OpBundles, "", Call);
|
||||
NewCS = CallInst::Create(NFTy, NF, Args, OpBundles, "", Call);
|
||||
cast<CallInst>(NewCS.getInstruction())
|
||||
->setTailCallKind(cast<CallInst>(Call)->getTailCallKind());
|
||||
}
|
||||
|
@ -881,7 +881,7 @@ void DevirtModule::tryICallBranchFunnel(
|
||||
}
|
||||
|
||||
BasicBlock *BB = BasicBlock::Create(M.getContext(), "", JT, nullptr);
|
||||
Constant *Intr =
|
||||
Function *Intr =
|
||||
Intrinsic::getDeclaration(&M, llvm::Intrinsic::icall_branch_funnel, {});
|
||||
|
||||
auto *CI = CallInst::Create(Intr, JTArgs, "", BB);
|
||||
@ -920,9 +920,10 @@ void DevirtModule::applyICallBranchFunnel(VTableSlotInfo &SlotInfo,
|
||||
NewArgs.push_back(Int8PtrTy);
|
||||
for (Type *T : CS.getFunctionType()->params())
|
||||
NewArgs.push_back(T);
|
||||
PointerType *NewFT = PointerType::getUnqual(
|
||||
FunctionType *NewFT =
|
||||
FunctionType::get(CS.getFunctionType()->getReturnType(), NewArgs,
|
||||
CS.getFunctionType()->isVarArg()));
|
||||
CS.getFunctionType()->isVarArg());
|
||||
PointerType *NewFTPtr = PointerType::getUnqual(NewFT);
|
||||
|
||||
IRBuilder<> IRB(CS.getInstruction());
|
||||
std::vector<Value *> Args;
|
||||
@ -932,10 +933,10 @@ void DevirtModule::applyICallBranchFunnel(VTableSlotInfo &SlotInfo,
|
||||
|
||||
CallSite NewCS;
|
||||
if (CS.isCall())
|
||||
NewCS = IRB.CreateCall(IRB.CreateBitCast(JT, NewFT), Args);
|
||||
NewCS = IRB.CreateCall(NewFT, IRB.CreateBitCast(JT, NewFTPtr), Args);
|
||||
else
|
||||
NewCS = IRB.CreateInvoke(
|
||||
IRB.CreateBitCast(JT, NewFT),
|
||||
IRB.CreateBitCast(JT, NewFTPtr),
|
||||
cast<InvokeInst>(CS.getInstruction())->getNormalDest(),
|
||||
cast<InvokeInst>(CS.getInstruction())->getUnwindDest(), Args);
|
||||
NewCS.setCallingConv(CS.getCallingConv());
|
||||
|
@ -917,7 +917,7 @@ static Value *simplifyX86extrq(IntrinsicInst &II, Value *Op0,
|
||||
if (II.getIntrinsicID() == Intrinsic::x86_sse4a_extrq) {
|
||||
Value *Args[] = {Op0, CILength, CIIndex};
|
||||
Module *M = II.getModule();
|
||||
Value *F = Intrinsic::getDeclaration(M, Intrinsic::x86_sse4a_extrqi);
|
||||
Function *F = Intrinsic::getDeclaration(M, Intrinsic::x86_sse4a_extrqi);
|
||||
return Builder.CreateCall(F, Args);
|
||||
}
|
||||
}
|
||||
@ -1018,7 +1018,7 @@ static Value *simplifyX86insertq(IntrinsicInst &II, Value *Op0, Value *Op1,
|
||||
|
||||
Value *Args[] = {Op0, Op1, CILength, CIIndex};
|
||||
Module *M = II.getModule();
|
||||
Value *F = Intrinsic::getDeclaration(M, Intrinsic::x86_sse4a_insertqi);
|
||||
Function *F = Intrinsic::getDeclaration(M, Intrinsic::x86_sse4a_insertqi);
|
||||
return Builder.CreateCall(F, Args);
|
||||
}
|
||||
|
||||
@ -3667,7 +3667,7 @@ Instruction *InstCombiner::visitCallInst(CallInst &CI) {
|
||||
// register (which contains the bitmask of live threads). So a
|
||||
// comparison that always returns true is the same as a read of the
|
||||
// EXEC register.
|
||||
Value *NewF = Intrinsic::getDeclaration(
|
||||
Function *NewF = Intrinsic::getDeclaration(
|
||||
II->getModule(), Intrinsic::read_register, II->getType());
|
||||
Metadata *MDArgs[] = {MDString::get(II->getContext(), "exec")};
|
||||
MDNode *MD = MDNode::get(II->getContext(), MDArgs);
|
||||
@ -3762,8 +3762,8 @@ Instruction *InstCombiner::visitCallInst(CallInst &CI) {
|
||||
} else if (!Ty->isFloatTy() && !Ty->isDoubleTy() && !Ty->isHalfTy())
|
||||
break;
|
||||
|
||||
Value *NewF = Intrinsic::getDeclaration(II->getModule(), NewIID,
|
||||
SrcLHS->getType());
|
||||
Function *NewF =
|
||||
Intrinsic::getDeclaration(II->getModule(), NewIID, SrcLHS->getType());
|
||||
Value *Args[] = { SrcLHS, SrcRHS,
|
||||
ConstantInt::get(CC->getType(), SrcPred) };
|
||||
CallInst *NewCall = Builder.CreateCall(NewF, Args);
|
||||
@ -3878,16 +3878,20 @@ Instruction *InstCombiner::visitCallInst(CallInst &CI) {
|
||||
// Canonicalize assume(a && b) -> assume(a); assume(b);
|
||||
// Note: New assumption intrinsics created here are registered by
|
||||
// the InstCombineIRInserter object.
|
||||
Value *AssumeIntrinsic = II->getCalledValue(), *A, *B;
|
||||
FunctionType *AssumeIntrinsicTy = II->getFunctionType();
|
||||
Value *AssumeIntrinsic = II->getCalledValue();
|
||||
Value *A, *B;
|
||||
if (match(IIOperand, m_And(m_Value(A), m_Value(B)))) {
|
||||
Builder.CreateCall(AssumeIntrinsic, A, II->getName());
|
||||
Builder.CreateCall(AssumeIntrinsic, B, II->getName());
|
||||
Builder.CreateCall(AssumeIntrinsicTy, AssumeIntrinsic, A, II->getName());
|
||||
Builder.CreateCall(AssumeIntrinsicTy, AssumeIntrinsic, B, II->getName());
|
||||
return eraseInstFromFunction(*II);
|
||||
}
|
||||
// assume(!(a || b)) -> assume(!a); assume(!b);
|
||||
if (match(IIOperand, m_Not(m_Or(m_Value(A), m_Value(B))))) {
|
||||
Builder.CreateCall(AssumeIntrinsic, Builder.CreateNot(A), II->getName());
|
||||
Builder.CreateCall(AssumeIntrinsic, Builder.CreateNot(B), II->getName());
|
||||
Builder.CreateCall(AssumeIntrinsicTy, AssumeIntrinsic,
|
||||
Builder.CreateNot(A), II->getName());
|
||||
Builder.CreateCall(AssumeIntrinsicTy, AssumeIntrinsic,
|
||||
Builder.CreateNot(B), II->getName());
|
||||
return eraseInstFromFunction(*II);
|
||||
}
|
||||
|
||||
@ -4662,13 +4666,13 @@ InstCombiner::transformCallThroughTrampoline(CallBase &Call,
|
||||
|
||||
Instruction *NewCaller;
|
||||
if (InvokeInst *II = dyn_cast<InvokeInst>(&Call)) {
|
||||
NewCaller = InvokeInst::Create(NewCallee,
|
||||
NewCaller = InvokeInst::Create(NewFTy, NewCallee,
|
||||
II->getNormalDest(), II->getUnwindDest(),
|
||||
NewArgs, OpBundles);
|
||||
cast<InvokeInst>(NewCaller)->setCallingConv(II->getCallingConv());
|
||||
cast<InvokeInst>(NewCaller)->setAttributes(NewPAL);
|
||||
} else {
|
||||
NewCaller = CallInst::Create(NewCallee, NewArgs, OpBundles);
|
||||
NewCaller = CallInst::Create(NewFTy, NewCallee, NewArgs, OpBundles);
|
||||
cast<CallInst>(NewCaller)->setTailCallKind(
|
||||
cast<CallInst>(Call).getTailCallKind());
|
||||
cast<CallInst>(NewCaller)->setCallingConv(
|
||||
|
@ -1656,8 +1656,8 @@ Instruction *InstCombiner::visitFPTrunc(FPTruncInst &FPT) {
|
||||
II->getIntrinsicID(), Ty);
|
||||
SmallVector<OperandBundleDef, 1> OpBundles;
|
||||
II->getOperandBundlesAsDefs(OpBundles);
|
||||
CallInst *NewCI = CallInst::Create(Overload, { InnerTrunc }, OpBundles,
|
||||
II->getName());
|
||||
CallInst *NewCI =
|
||||
CallInst::Create(Overload, {InnerTrunc}, OpBundles, II->getName());
|
||||
NewCI->copyFastMathFlags(II);
|
||||
return NewCI;
|
||||
}
|
||||
|
@ -1291,8 +1291,8 @@ static Instruction *processUGT_ADDCST_ADD(ICmpInst &I, Value *A, Value *B,
|
||||
// use the sadd_with_overflow intrinsic to efficiently compute both the
|
||||
// result and the overflow bit.
|
||||
Type *NewType = IntegerType::get(OrigAdd->getContext(), NewWidth);
|
||||
Value *F = Intrinsic::getDeclaration(I.getModule(),
|
||||
Intrinsic::sadd_with_overflow, NewType);
|
||||
Function *F = Intrinsic::getDeclaration(
|
||||
I.getModule(), Intrinsic::sadd_with_overflow, NewType);
|
||||
|
||||
InstCombiner::BuilderTy &Builder = IC.Builder;
|
||||
|
||||
@ -4139,8 +4139,8 @@ static Instruction *processUMulZExtIdiom(ICmpInst &I, Value *MulVal,
|
||||
MulA = Builder.CreateZExt(A, MulType);
|
||||
if (WidthB < MulWidth)
|
||||
MulB = Builder.CreateZExt(B, MulType);
|
||||
Value *F = Intrinsic::getDeclaration(I.getModule(),
|
||||
Intrinsic::umul_with_overflow, MulType);
|
||||
Function *F = Intrinsic::getDeclaration(
|
||||
I.getModule(), Intrinsic::umul_with_overflow, MulType);
|
||||
CallInst *Call = Builder.CreateCall(F, {MulA, MulB}, "umul");
|
||||
IC.Worklist.Add(MulInstr);
|
||||
|
||||
|
@ -332,6 +332,8 @@ class DataFlowSanitizer : public ModulePass {
|
||||
Constant *RetvalTLS;
|
||||
void *(*GetArgTLSPtr)();
|
||||
void *(*GetRetvalTLSPtr)();
|
||||
FunctionType *GetArgTLSTy;
|
||||
FunctionType *GetRetvalTLSTy;
|
||||
Constant *GetArgTLS;
|
||||
Constant *GetRetvalTLS;
|
||||
Constant *ExternalShadowMask;
|
||||
@ -580,17 +582,17 @@ bool DataFlowSanitizer::doInitialization(Module &M) {
|
||||
if (GetArgTLSPtr) {
|
||||
Type *ArgTLSTy = ArrayType::get(ShadowTy, 64);
|
||||
ArgTLS = nullptr;
|
||||
GetArgTLSTy = FunctionType::get(PointerType::getUnqual(ArgTLSTy), false);
|
||||
GetArgTLS = ConstantExpr::getIntToPtr(
|
||||
ConstantInt::get(IntptrTy, uintptr_t(GetArgTLSPtr)),
|
||||
PointerType::getUnqual(
|
||||
FunctionType::get(PointerType::getUnqual(ArgTLSTy), false)));
|
||||
PointerType::getUnqual(GetArgTLSTy));
|
||||
}
|
||||
if (GetRetvalTLSPtr) {
|
||||
RetvalTLS = nullptr;
|
||||
GetRetvalTLSTy = FunctionType::get(PointerType::getUnqual(ShadowTy), false);
|
||||
GetRetvalTLS = ConstantExpr::getIntToPtr(
|
||||
ConstantInt::get(IntptrTy, uintptr_t(GetRetvalTLSPtr)),
|
||||
PointerType::getUnqual(
|
||||
FunctionType::get(PointerType::getUnqual(ShadowTy), false)));
|
||||
PointerType::getUnqual(GetRetvalTLSTy));
|
||||
}
|
||||
|
||||
ColdCallWeights = MDBuilder(*Ctx).createBranchWeights(1, 1000);
|
||||
@ -686,7 +688,7 @@ Constant *DataFlowSanitizer::getOrBuildTrampolineFunction(FunctionType *FT,
|
||||
Function::arg_iterator AI = F->arg_begin(); ++AI;
|
||||
for (unsigned N = FT->getNumParams(); N != 0; ++AI, --N)
|
||||
Args.push_back(&*AI);
|
||||
CallInst *CI = CallInst::Create(&*F->arg_begin(), Args, "", BB);
|
||||
CallInst *CI = CallInst::Create(FT, &*F->arg_begin(), Args, "", BB);
|
||||
ReturnInst *RI;
|
||||
if (FT->getReturnType()->isVoidTy())
|
||||
RI = ReturnInst::Create(*Ctx, BB);
|
||||
@ -997,7 +999,7 @@ Value *DFSanFunction::getArgTLSPtr() {
|
||||
return ArgTLSPtr = DFS.ArgTLS;
|
||||
|
||||
IRBuilder<> IRB(&F->getEntryBlock().front());
|
||||
return ArgTLSPtr = IRB.CreateCall(DFS.GetArgTLS, {});
|
||||
return ArgTLSPtr = IRB.CreateCall(DFS.GetArgTLSTy, DFS.GetArgTLS, {});
|
||||
}
|
||||
|
||||
Value *DFSanFunction::getRetvalTLS() {
|
||||
@ -1007,7 +1009,8 @@ Value *DFSanFunction::getRetvalTLS() {
|
||||
return RetvalTLSPtr = DFS.RetvalTLS;
|
||||
|
||||
IRBuilder<> IRB(&F->getEntryBlock().front());
|
||||
return RetvalTLSPtr = IRB.CreateCall(DFS.GetRetvalTLS, {});
|
||||
return RetvalTLSPtr =
|
||||
IRB.CreateCall(DFS.GetRetvalTLSTy, DFS.GetRetvalTLS, {});
|
||||
}
|
||||
|
||||
Value *DFSanFunction::getArgTLS(unsigned Idx, Instruction *Pos) {
|
||||
@ -1485,7 +1488,7 @@ void DFSanVisitor::visitMemTransferInst(MemTransferInst &I) {
|
||||
DestShadow = IRB.CreateBitCast(DestShadow, Int8Ptr);
|
||||
SrcShadow = IRB.CreateBitCast(SrcShadow, Int8Ptr);
|
||||
auto *MTI = cast<MemTransferInst>(
|
||||
IRB.CreateCall(I.getCalledValue(),
|
||||
IRB.CreateCall(I.getFunctionType(), I.getCalledValue(),
|
||||
{DestShadow, SrcShadow, LenShadow, I.getVolatileCst()}));
|
||||
if (ClPreserveAlignment) {
|
||||
MTI->setDestAlignment(I.getDestAlignment() * (DFSF.DFS.ShadowWidth / 8));
|
||||
@ -1724,7 +1727,7 @@ void DFSanVisitor::visitCallSite(CallSite CS) {
|
||||
NewCS = IRB.CreateInvoke(Func, II->getNormalDest(), II->getUnwindDest(),
|
||||
Args);
|
||||
} else {
|
||||
NewCS = IRB.CreateCall(Func, Args);
|
||||
NewCS = IRB.CreateCall(NewFT, Func, Args);
|
||||
}
|
||||
NewCS.setCallingConv(CS.getCallingConv());
|
||||
NewCS.setAttributes(CS.getAttributes().removeAttributes(
|
||||
|
@ -1168,7 +1168,7 @@ insertFlush(ArrayRef<std::pair<GlobalVariable*, MDNode*> > CountersBySP) {
|
||||
BasicBlock *Entry = BasicBlock::Create(*Ctx, "entry", FlushF);
|
||||
|
||||
// Write out the current counters.
|
||||
Constant *WriteoutF = M->getFunction("__llvm_gcov_writeout");
|
||||
Function *WriteoutF = M->getFunction("__llvm_gcov_writeout");
|
||||
assert(WriteoutF && "Need to create the writeout function first!");
|
||||
|
||||
IRBuilder<> Builder(Entry);
|
||||
|
@ -980,7 +980,7 @@ void InstrProfiling::emitInitialization() {
|
||||
}
|
||||
}
|
||||
|
||||
Constant *RegisterF = M->getFunction(getInstrProfRegFuncsName());
|
||||
Function *RegisterF = M->getFunction(getInstrProfRegFuncsName());
|
||||
if (!RegisterF)
|
||||
return;
|
||||
|
||||
@ -996,8 +996,7 @@ void InstrProfiling::emitInitialization() {
|
||||
|
||||
// Add the basic block and the necessary calls.
|
||||
IRBuilder<> IRB(BasicBlock::Create(M->getContext(), "", F));
|
||||
if (RegisterF)
|
||||
IRB.CreateCall(RegisterF, {});
|
||||
IRB.CreateCall(RegisterF, {});
|
||||
IRB.CreateRetVoid();
|
||||
|
||||
appendToGlobalCtors(*M, F, 0);
|
||||
|
@ -2670,7 +2670,7 @@ struct MemorySanitizerVisitor : public InstVisitor<MemorySanitizerVisitor> {
|
||||
: Lower64ShadowExtend(IRB, S2, getShadowTy(&I));
|
||||
Value *V1 = I.getOperand(0);
|
||||
Value *V2 = I.getOperand(1);
|
||||
Value *Shift = IRB.CreateCall(I.getCalledValue(),
|
||||
Value *Shift = IRB.CreateCall(I.getFunctionType(), I.getCalledValue(),
|
||||
{IRB.CreateBitCast(S1, V1->getType()), V2});
|
||||
Shift = IRB.CreateBitCast(Shift, getShadowTy(&I));
|
||||
setShadow(&I, IRB.CreateOr(Shift, S2Conv));
|
||||
|
@ -33,7 +33,7 @@
|
||||
|
||||
namespace llvm {
|
||||
|
||||
class Constant;
|
||||
class Function;
|
||||
class LLVMContext;
|
||||
|
||||
namespace objcarc {
|
||||
@ -69,7 +69,7 @@ public:
|
||||
RetainAutoreleaseRV = nullptr;
|
||||
}
|
||||
|
||||
Constant *get(ARCRuntimeEntryPointKind kind) {
|
||||
Function *get(ARCRuntimeEntryPointKind kind) {
|
||||
assert(TheModule != nullptr && "Not initialized.");
|
||||
|
||||
switch (kind) {
|
||||
@ -105,33 +105,33 @@ private:
|
||||
Module *TheModule = nullptr;
|
||||
|
||||
/// Declaration for ObjC runtime function objc_autoreleaseReturnValue.
|
||||
Constant *AutoreleaseRV = nullptr;
|
||||
Function *AutoreleaseRV = nullptr;
|
||||
|
||||
/// Declaration for ObjC runtime function objc_release.
|
||||
Constant *Release = nullptr;
|
||||
Function *Release = nullptr;
|
||||
|
||||
/// Declaration for ObjC runtime function objc_retain.
|
||||
Constant *Retain = nullptr;
|
||||
Function *Retain = nullptr;
|
||||
|
||||
/// Declaration for ObjC runtime function objc_retainBlock.
|
||||
Constant *RetainBlock = nullptr;
|
||||
Function *RetainBlock = nullptr;
|
||||
|
||||
/// Declaration for ObjC runtime function objc_autorelease.
|
||||
Constant *Autorelease = nullptr;
|
||||
Function *Autorelease = nullptr;
|
||||
|
||||
/// Declaration for objc_storeStrong().
|
||||
Constant *StoreStrong = nullptr;
|
||||
Function *StoreStrong = nullptr;
|
||||
|
||||
/// Declaration for objc_retainAutoreleasedReturnValue().
|
||||
Constant *RetainRV = nullptr;
|
||||
Function *RetainRV = nullptr;
|
||||
|
||||
/// Declaration for objc_retainAutorelease().
|
||||
Constant *RetainAutorelease = nullptr;
|
||||
Function *RetainAutorelease = nullptr;
|
||||
|
||||
/// Declaration for objc_retainAutoreleaseReturnValue().
|
||||
Constant *RetainAutoreleaseRV = nullptr;
|
||||
Function *RetainAutoreleaseRV = nullptr;
|
||||
|
||||
Constant *getIntrinsicEntryPoint(Constant *&Decl, Intrinsic::ID IntID) {
|
||||
Function *getIntrinsicEntryPoint(Function *&Decl, Intrinsic::ID IntID) {
|
||||
if (Decl)
|
||||
return Decl;
|
||||
|
||||
|
@ -313,8 +313,8 @@ findRetainForStoreStrongContraction(Value *New, StoreInst *Store,
|
||||
/// Create a call instruction with the correct funclet token. Should be used
|
||||
/// instead of calling CallInst::Create directly.
|
||||
static CallInst *
|
||||
createCallInst(Value *Func, ArrayRef<Value *> Args, const Twine &NameStr,
|
||||
Instruction *InsertBefore,
|
||||
createCallInst(FunctionType *FTy, Value *Func, ArrayRef<Value *> Args,
|
||||
const Twine &NameStr, Instruction *InsertBefore,
|
||||
const DenseMap<BasicBlock *, ColorVector> &BlockColors) {
|
||||
SmallVector<OperandBundleDef, 1> OpBundles;
|
||||
if (!BlockColors.empty()) {
|
||||
@ -325,7 +325,15 @@ createCallInst(Value *Func, ArrayRef<Value *> Args, const Twine &NameStr,
|
||||
OpBundles.emplace_back("funclet", EHPad);
|
||||
}
|
||||
|
||||
return CallInst::Create(Func, Args, OpBundles, NameStr, InsertBefore);
|
||||
return CallInst::Create(FTy, Func, Args, OpBundles, NameStr, InsertBefore);
|
||||
}
|
||||
|
||||
static CallInst *
|
||||
createCallInst(FunctionCallee Func, ArrayRef<Value *> Args, const Twine &NameStr,
|
||||
Instruction *InsertBefore,
|
||||
const DenseMap<BasicBlock *, ColorVector> &BlockColors) {
|
||||
return createCallInst(Func.getFunctionType(), Func.getCallee(), Args, NameStr,
|
||||
InsertBefore, BlockColors);
|
||||
}
|
||||
|
||||
/// Attempt to merge an objc_release with a store, load, and objc_retain to form
|
||||
@ -408,7 +416,7 @@ void ObjCARCContract::tryToContractReleaseIntoStoreStrong(
|
||||
Args[0] = new BitCastInst(Args[0], I8XX, "", Store);
|
||||
if (Args[1]->getType() != I8X)
|
||||
Args[1] = new BitCastInst(Args[1], I8X, "", Store);
|
||||
Constant *Decl = EP.get(ARCRuntimeEntryPointKind::StoreStrong);
|
||||
Function *Decl = EP.get(ARCRuntimeEntryPointKind::StoreStrong);
|
||||
CallInst *StoreStrong = createCallInst(Decl, Args, "", Store, BlockColors);
|
||||
StoreStrong->setDoesNotThrow();
|
||||
StoreStrong->setDebugLoc(Store->getDebugLoc());
|
||||
|
@ -829,7 +829,7 @@ void ObjCARCOpt::OptimizeIndividualCalls(Function &F) {
|
||||
// Create the declaration lazily.
|
||||
LLVMContext &C = Inst->getContext();
|
||||
|
||||
Constant *Decl = EP.get(ARCRuntimeEntryPointKind::Release);
|
||||
Function *Decl = EP.get(ARCRuntimeEntryPointKind::Release);
|
||||
CallInst *NewCall = CallInst::Create(Decl, Call->getArgOperand(0), "",
|
||||
Call);
|
||||
NewCall->setMetadata(MDKindCache.get(ARCMDKindID::ImpreciseRelease),
|
||||
@ -1527,7 +1527,7 @@ void ObjCARCOpt::MoveCalls(Value *Arg, RRInfo &RetainsToMove,
|
||||
for (Instruction *InsertPt : ReleasesToMove.ReverseInsertPts) {
|
||||
Value *MyArg = ArgTy == ParamTy ? Arg :
|
||||
new BitCastInst(Arg, ParamTy, "", InsertPt);
|
||||
Constant *Decl = EP.get(ARCRuntimeEntryPointKind::Retain);
|
||||
Function *Decl = EP.get(ARCRuntimeEntryPointKind::Retain);
|
||||
CallInst *Call = CallInst::Create(Decl, MyArg, "", InsertPt);
|
||||
Call->setDoesNotThrow();
|
||||
Call->setTailCall();
|
||||
@ -1540,7 +1540,7 @@ void ObjCARCOpt::MoveCalls(Value *Arg, RRInfo &RetainsToMove,
|
||||
for (Instruction *InsertPt : RetainsToMove.ReverseInsertPts) {
|
||||
Value *MyArg = ArgTy == ParamTy ? Arg :
|
||||
new BitCastInst(Arg, ParamTy, "", InsertPt);
|
||||
Constant *Decl = EP.get(ARCRuntimeEntryPointKind::Release);
|
||||
Function *Decl = EP.get(ARCRuntimeEntryPointKind::Release);
|
||||
CallInst *Call = CallInst::Create(Decl, MyArg, "", InsertPt);
|
||||
// Attach a clang.imprecise_release metadata tag, if appropriate.
|
||||
if (MDNode *M = ReleasesToMove.ReleaseMetadata)
|
||||
@ -1876,7 +1876,7 @@ void ObjCARCOpt::OptimizeWeakCalls(Function &F) {
|
||||
Changed = true;
|
||||
// If the load has a builtin retain, insert a plain retain for it.
|
||||
if (Class == ARCInstKind::LoadWeakRetained) {
|
||||
Constant *Decl = EP.get(ARCRuntimeEntryPointKind::Retain);
|
||||
Function *Decl = EP.get(ARCRuntimeEntryPointKind::Retain);
|
||||
CallInst *CI = CallInst::Create(Decl, EarlierCall, "", Call);
|
||||
CI->setTailCall();
|
||||
}
|
||||
@ -1905,7 +1905,7 @@ void ObjCARCOpt::OptimizeWeakCalls(Function &F) {
|
||||
Changed = true;
|
||||
// If the load has a builtin retain, insert a plain retain for it.
|
||||
if (Class == ARCInstKind::LoadWeakRetained) {
|
||||
Constant *Decl = EP.get(ARCRuntimeEntryPointKind::Retain);
|
||||
Function *Decl = EP.get(ARCRuntimeEntryPointKind::Retain);
|
||||
CallInst *CI = CallInst::Create(Decl, EarlierCall, "", Call);
|
||||
CI->setTailCall();
|
||||
}
|
||||
|
@ -312,7 +312,8 @@ bool LoopDataPrefetch::runOnLoop(Loop *L) {
|
||||
IRBuilder<> Builder(MemI);
|
||||
Module *M = BB->getParent()->getParent();
|
||||
Type *I32 = Type::getInt32Ty(BB->getContext());
|
||||
Value *PrefetchFunc = Intrinsic::getDeclaration(M, Intrinsic::prefetch);
|
||||
Function *PrefetchFunc =
|
||||
Intrinsic::getDeclaration(M, Intrinsic::prefetch);
|
||||
Builder.CreateCall(
|
||||
PrefetchFunc,
|
||||
{PrefPtrValue,
|
||||
@ -332,4 +333,3 @@ bool LoopDataPrefetch::runOnLoop(Loop *L) {
|
||||
|
||||
return MadeChange;
|
||||
}
|
||||
|
||||
|
@ -1527,7 +1527,7 @@ static CallInst *createPopcntIntrinsic(IRBuilder<> &IRBuilder, Value *Val,
|
||||
Type *Tys[] = {Val->getType()};
|
||||
|
||||
Module *M = IRBuilder.GetInsertBlock()->getParent()->getParent();
|
||||
Value *Func = Intrinsic::getDeclaration(M, Intrinsic::ctpop, Tys);
|
||||
Function *Func = Intrinsic::getDeclaration(M, Intrinsic::ctpop, Tys);
|
||||
CallInst *CI = IRBuilder.CreateCall(Func, Ops);
|
||||
CI->setDebugLoc(DL);
|
||||
|
||||
@ -1541,7 +1541,7 @@ static CallInst *createFFSIntrinsic(IRBuilder<> &IRBuilder, Value *Val,
|
||||
Type *Tys[] = {Val->getType()};
|
||||
|
||||
Module *M = IRBuilder.GetInsertBlock()->getParent()->getParent();
|
||||
Value *Func = Intrinsic::getDeclaration(M, IID, Tys);
|
||||
Function *Func = Intrinsic::getDeclaration(M, IID, Tys);
|
||||
CallInst *CI = IRBuilder.CreateCall(Func, Ops);
|
||||
CI->setDebugLoc(DL);
|
||||
|
||||
|
@ -1306,7 +1306,7 @@ static void CreateGCRelocates(ArrayRef<Value *> LiveVariables,
|
||||
// Lazily populated map from input types to the canonicalized form mentioned
|
||||
// in the comment above. This should probably be cached somewhere more
|
||||
// broadly.
|
||||
DenseMap<Type*, Value*> TypeToDeclMap;
|
||||
DenseMap<Type *, Function *> TypeToDeclMap;
|
||||
|
||||
for (unsigned i = 0; i < LiveVariables.size(); i++) {
|
||||
// Generate the gc.relocate call and save the result
|
||||
@ -1317,7 +1317,7 @@ static void CreateGCRelocates(ArrayRef<Value *> LiveVariables,
|
||||
Type *Ty = LiveVariables[i]->getType();
|
||||
if (!TypeToDeclMap.count(Ty))
|
||||
TypeToDeclMap[Ty] = getGCRelocateDecl(Ty);
|
||||
Value *GCRelocateDecl = TypeToDeclMap[Ty];
|
||||
Function *GCRelocateDecl = TypeToDeclMap[Ty];
|
||||
|
||||
// only specify a debug name if we can give a useful one
|
||||
CallInst *Reloc = Builder.CreateCall(
|
||||
|
@ -1864,10 +1864,8 @@ llvm::InlineResult llvm::InlineFunction(CallSite CS, InlineFunctionInfo &IFI,
|
||||
// Add VarArgs to existing parameters.
|
||||
SmallVector<Value *, 6> Params(CI->arg_operands());
|
||||
Params.append(VarArgsToForward.begin(), VarArgsToForward.end());
|
||||
CallInst *NewCI =
|
||||
CallInst::Create(CI->getCalledFunction() ? CI->getCalledFunction()
|
||||
: CI->getCalledValue(),
|
||||
Params, "", CI);
|
||||
CallInst *NewCI = CallInst::Create(
|
||||
CI->getFunctionType(), CI->getCalledOperand(), Params, "", CI);
|
||||
NewCI->setDebugLoc(CI->getDebugLoc());
|
||||
NewCI->setAttributes(Attrs);
|
||||
NewCI->setCallingConv(CI->getCallingConv());
|
||||
|
@ -1936,8 +1936,8 @@ static void changeToCall(InvokeInst *II, DomTreeUpdater *DTU = nullptr) {
|
||||
SmallVector<Value*, 8> Args(II->arg_begin(), II->arg_end());
|
||||
SmallVector<OperandBundleDef, 1> OpBundles;
|
||||
II->getOperandBundlesAsDefs(OpBundles);
|
||||
CallInst *NewCall = CallInst::Create(II->getCalledValue(), Args, OpBundles,
|
||||
"", II);
|
||||
CallInst *NewCall = CallInst::Create(
|
||||
II->getFunctionType(), II->getCalledValue(), Args, OpBundles, "", II);
|
||||
NewCall->takeName(II);
|
||||
NewCall->setCallingConv(II->getCallingConv());
|
||||
NewCall->setAttributes(II->getAttributes());
|
||||
|
@ -52,7 +52,8 @@ static bool runImpl(Function &F) {
|
||||
II->getOperandBundlesAsDefs(OpBundles);
|
||||
// Insert a normal call instruction...
|
||||
CallInst *NewCall =
|
||||
CallInst::Create(II->getCalledValue(), CallArgs, OpBundles, "", II);
|
||||
CallInst::Create(II->getFunctionType(), II->getCalledValue(),
|
||||
CallArgs, OpBundles, "", II);
|
||||
NewCall->takeName(II);
|
||||
NewCall->setCallingConv(II->getCallingConv());
|
||||
NewCall->setAttributes(II->getAttributes());
|
||||
|
@ -1652,13 +1652,13 @@ Value *LibCallSimplifier::optimizeSqrt(CallInst *CI, IRBuilder<> &B) {
|
||||
// replace it with the fabs of that factor.
|
||||
Module *M = Callee->getParent();
|
||||
Type *ArgType = I->getType();
|
||||
Value *Fabs = Intrinsic::getDeclaration(M, Intrinsic::fabs, ArgType);
|
||||
Function *Fabs = Intrinsic::getDeclaration(M, Intrinsic::fabs, ArgType);
|
||||
Value *FabsCall = B.CreateCall(Fabs, RepeatOp, "fabs");
|
||||
if (OtherOp) {
|
||||
// If we found a non-repeated factor, we still need to get its square
|
||||
// root. We then multiply that by the value that was simplified out
|
||||
// of the square root calculation.
|
||||
Value *Sqrt = Intrinsic::getDeclaration(M, Intrinsic::sqrt, ArgType);
|
||||
Function *Sqrt = Intrinsic::getDeclaration(M, Intrinsic::sqrt, ArgType);
|
||||
Value *SqrtCall = B.CreateCall(Sqrt, OtherOp, "sqrt");
|
||||
return B.CreateFMul(FabsCall, SqrtCall);
|
||||
}
|
||||
@ -1838,8 +1838,8 @@ Value *LibCallSimplifier::optimizeFFS(CallInst *CI, IRBuilder<> &B) {
|
||||
// ffs(x) -> x != 0 ? (i32)llvm.cttz(x)+1 : 0
|
||||
Value *Op = CI->getArgOperand(0);
|
||||
Type *ArgType = Op->getType();
|
||||
Value *F = Intrinsic::getDeclaration(CI->getCalledFunction()->getParent(),
|
||||
Intrinsic::cttz, ArgType);
|
||||
Function *F = Intrinsic::getDeclaration(CI->getCalledFunction()->getParent(),
|
||||
Intrinsic::cttz, ArgType);
|
||||
Value *V = B.CreateCall(F, {Op, B.getTrue()}, "cttz");
|
||||
V = B.CreateAdd(V, ConstantInt::get(V->getType(), 1));
|
||||
V = B.CreateIntCast(V, B.getInt32Ty(), false);
|
||||
@ -1852,8 +1852,8 @@ Value *LibCallSimplifier::optimizeFls(CallInst *CI, IRBuilder<> &B) {
|
||||
// fls(x) -> (i32)(sizeInBits(x) - llvm.ctlz(x, false))
|
||||
Value *Op = CI->getArgOperand(0);
|
||||
Type *ArgType = Op->getType();
|
||||
Value *F = Intrinsic::getDeclaration(CI->getCalledFunction()->getParent(),
|
||||
Intrinsic::ctlz, ArgType);
|
||||
Function *F = Intrinsic::getDeclaration(CI->getCalledFunction()->getParent(),
|
||||
Intrinsic::ctlz, ArgType);
|
||||
Value *V = B.CreateCall(F, {Op, B.getFalse()}, "ctlz");
|
||||
V = B.CreateSub(ConstantInt::get(V->getType(), ArgType->getIntegerBitWidth()),
|
||||
V);
|
||||
|
@ -911,11 +911,11 @@ CleanupAndPrepareModules(BugDriver &BD, std::unique_ptr<Module> Test,
|
||||
|
||||
// Pass on the arguments to the real function, return its result
|
||||
if (F->getReturnType()->isVoidTy()) {
|
||||
CallInst::Create(FuncPtr, Args, "", DoCallBB);
|
||||
CallInst::Create(FuncTy, FuncPtr, Args, "", DoCallBB);
|
||||
ReturnInst::Create(F->getContext(), DoCallBB);
|
||||
} else {
|
||||
CallInst *Call =
|
||||
CallInst::Create(FuncPtr, Args, "retval", DoCallBB);
|
||||
CallInst::Create(FuncTy, FuncPtr, Args, "retval", DoCallBB);
|
||||
ReturnInst::Create(F->getContext(), Call, DoCallBB);
|
||||
}
|
||||
|
||||
|
@ -100,10 +100,9 @@ TEST(BasicBlockTest, TestInstructionsWithoutDebug) {
|
||||
Argument *V = new Argument(Type::getInt32Ty(Ctx));
|
||||
Function *F = Function::Create(FT, Function::ExternalLinkage, "", M);
|
||||
|
||||
Value *DbgAddr = Intrinsic::getDeclaration(M, Intrinsic::dbg_addr);
|
||||
Value *DbgDeclare =
|
||||
Intrinsic::getDeclaration(M, Intrinsic::dbg_declare);
|
||||
Value *DbgValue = Intrinsic::getDeclaration(M, Intrinsic::dbg_value);
|
||||
Function *DbgAddr = Intrinsic::getDeclaration(M, Intrinsic::dbg_addr);
|
||||
Function *DbgDeclare = Intrinsic::getDeclaration(M, Intrinsic::dbg_declare);
|
||||
Function *DbgValue = Intrinsic::getDeclaration(M, Intrinsic::dbg_value);
|
||||
Value *DIV = MetadataAsValue::get(Ctx, (Metadata *)nullptr);
|
||||
SmallVector<Value *, 3> Args = {DIV, DIV, DIV};
|
||||
|
||||
|
@ -353,7 +353,7 @@ TEST_F(IRBuilderTest, FastMathFlags) {
|
||||
FCall = Builder.CreateCall(Callee, None);
|
||||
EXPECT_FALSE(FCall->hasNoNaNs());
|
||||
|
||||
Value *V =
|
||||
Function *V =
|
||||
Function::Create(CalleeTy, Function::ExternalLinkage, "", M.get());
|
||||
FCall = Builder.CreateCall(V, None);
|
||||
EXPECT_FALSE(FCall->hasNoNaNs());
|
||||
|
@ -504,14 +504,15 @@ TEST(InstructionsTest, CloneCall) {
|
||||
LLVMContext C;
|
||||
Type *Int32Ty = Type::getInt32Ty(C);
|
||||
Type *ArgTys[] = {Int32Ty, Int32Ty, Int32Ty};
|
||||
Type *FnTy = FunctionType::get(Int32Ty, ArgTys, /*isVarArg=*/false);
|
||||
FunctionType *FnTy = FunctionType::get(Int32Ty, ArgTys, /*isVarArg=*/false);
|
||||
Value *Callee = Constant::getNullValue(FnTy->getPointerTo());
|
||||
Value *Args[] = {
|
||||
ConstantInt::get(Int32Ty, 1),
|
||||
ConstantInt::get(Int32Ty, 2),
|
||||
ConstantInt::get(Int32Ty, 3)
|
||||
};
|
||||
std::unique_ptr<CallInst> Call(CallInst::Create(Callee, Args, "result"));
|
||||
std::unique_ptr<CallInst> Call(
|
||||
CallInst::Create(FnTy, Callee, Args, "result"));
|
||||
|
||||
// Test cloning the tail call kind.
|
||||
CallInst::TailCallKind Kinds[] = {CallInst::TCK_None, CallInst::TCK_Tail,
|
||||
@ -537,12 +538,12 @@ TEST(InstructionsTest, CloneCall) {
|
||||
TEST(InstructionsTest, AlterCallBundles) {
|
||||
LLVMContext C;
|
||||
Type *Int32Ty = Type::getInt32Ty(C);
|
||||
Type *FnTy = FunctionType::get(Int32Ty, Int32Ty, /*isVarArg=*/false);
|
||||
FunctionType *FnTy = FunctionType::get(Int32Ty, Int32Ty, /*isVarArg=*/false);
|
||||
Value *Callee = Constant::getNullValue(FnTy->getPointerTo());
|
||||
Value *Args[] = {ConstantInt::get(Int32Ty, 42)};
|
||||
OperandBundleDef OldBundle("before", UndefValue::get(Int32Ty));
|
||||
std::unique_ptr<CallInst> Call(
|
||||
CallInst::Create(Callee, Args, OldBundle, "result"));
|
||||
CallInst::Create(FnTy, Callee, Args, OldBundle, "result"));
|
||||
Call->setTailCallKind(CallInst::TailCallKind::TCK_NoTail);
|
||||
AttrBuilder AB;
|
||||
AB.addAttribute(Attribute::Cold);
|
||||
|
Loading…
Reference in New Issue
Block a user