LLVM 22.0.0git
DeclareRuntimeLibcalls.cpp
Go to the documentation of this file.
1//===- DeclareRuntimeLibcalls.cpp -----------------------------------------===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// Insert declarations for all runtime library calls known for the target.
10//
11//===----------------------------------------------------------------------===//
12
15#include "llvm/IR/Module.h"
17
18using namespace llvm;
19
20static void mergeAttributes(LLVMContext &Ctx, const Module &M,
21 const DataLayout &DL, const Triple &TT,
22 Function *Func, FunctionType *FuncTy,
23 AttributeList FuncAttrs) {
24 AttributeList OldAttrs = Func->getAttributes();
25 AttributeList NewAttrs = OldAttrs;
26
27 {
28 AttrBuilder OldBuilder(Ctx, OldAttrs.getFnAttrs());
29 AttrBuilder NewBuilder(Ctx, FuncAttrs.getFnAttrs());
30 OldBuilder.merge(NewBuilder);
31 NewAttrs = NewAttrs.addFnAttributes(Ctx, OldBuilder);
32 }
33
34 {
35 AttrBuilder OldBuilder(Ctx, OldAttrs.getRetAttrs());
36 AttrBuilder NewBuilder(Ctx, FuncAttrs.getRetAttrs());
37 OldBuilder.merge(NewBuilder);
38 NewAttrs = NewAttrs.addRetAttributes(Ctx, OldBuilder);
39 }
40
41 for (unsigned I = 0, E = FuncTy->getNumParams(); I != E; ++I) {
42 AttrBuilder OldBuilder(Ctx, OldAttrs.getParamAttrs(I));
43 AttrBuilder NewBuilder(Ctx, FuncAttrs.getParamAttrs(I));
44 OldBuilder.merge(NewBuilder);
45 NewAttrs = NewAttrs.addParamAttributes(Ctx, I, OldBuilder);
46 }
47
48 Func->setAttributes(NewAttrs);
49}
50
53 const RTLIB::RuntimeLibcallsInfo &RTLCI =
54 MAM.getResult<RuntimeLibraryAnalysis>(M);
55
56 LLVMContext &Ctx = M.getContext();
57 const DataLayout &DL = M.getDataLayout();
58 const Triple &TT = M.getTargetTriple();
59
60 for (RTLIB::LibcallImpl Impl : RTLIB::libcall_impls()) {
61 if (!RTLCI.isAvailable(Impl))
62 continue;
63
64 auto [FuncTy, FuncAttrs] = RTLCI.getFunctionTy(Ctx, TT, DL, Impl);
65
66 // TODO: Declare with correct type, calling convention, and attributes.
67 if (!FuncTy)
68 FuncTy = FunctionType::get(Type::getVoidTy(Ctx), {}, /*IsVarArgs=*/true);
69
70 StringRef FuncName = RTLCI.getLibcallImplName(Impl);
71
72 Function *Func =
73 cast<Function>(M.getOrInsertFunction(FuncName, FuncTy).getCallee());
74 if (Func->getFunctionType() == FuncTy) {
75 mergeAttributes(Ctx, M, DL, TT, Func, FuncTy, FuncAttrs);
76 Func->setCallingConv(RTLCI.getLibcallImplCallingConv(Impl));
77 }
78 }
79
81}
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
static void mergeAttributes(LLVMContext &Ctx, const Module &M, const DataLayout &DL, const Triple &TT, Function *Func, FunctionType *FuncTy, AttributeList FuncAttrs)
Module.h This file contains the declarations for the Module class.
#define I(x, y, z)
Definition MD5.cpp:57
ModuleAnalysisManager MAM
A parsed version of the target data layout string in and methods for querying it.
Definition DataLayout.h:63
PreservedAnalyses run(Module &M, ModuleAnalysisManager &MAM)
static LLVM_ABI FunctionType * get(Type *Result, ArrayRef< Type * > Params, bool isVarArg)
This static method is the primary way of constructing a FunctionType.
This is an important class for using LLVM in a threaded context.
Definition LLVMContext.h:68
A Module instance is used to store all the information related to an LLVM module.
Definition Module.h:67
A set of analyses that are preserved following a run of a transformation pass.
Definition Analysis.h:112
static PreservedAnalyses none()
Convenience factory function for the empty preserved set.
Definition Analysis.h:115
StringRef - Represent a constant reference to a string, i.e.
Definition StringRef.h:55
Triple - Helper class for working with autoconf configuration names.
Definition Triple.h:47
static LLVM_ABI Type * getVoidTy(LLVMContext &C)
Definition Type.cpp:280
static auto libcall_impls()
This is an optimization pass for GlobalISel generic memory operations.
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
Definition Casting.h:559
AnalysisManager< Module > ModuleAnalysisManager
Convenience typedef for the Module analysis manager.
Definition MIRParser.h:39
A simple container for information about the supported runtime calls.
CallingConv::ID getLibcallImplCallingConv(RTLIB::LibcallImpl Call) const
Get the CallingConv that should be used for the specified libcall.
bool isAvailable(RTLIB::LibcallImpl Impl) const
std::pair< FunctionType *, AttributeList > getFunctionTy(LLVMContext &Ctx, const Triple &TT, const DataLayout &DL, RTLIB::LibcallImpl LibcallImpl) const
static StringRef getLibcallImplName(RTLIB::LibcallImpl CallImpl)
Get the libcall routine name for the specified libcall implementation.