123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264 |
- #pragma once
- #ifdef __GNUC__
- #pragma GCC diagnostic push
- #pragma GCC diagnostic ignored "-Wunused-parameter"
- #endif
- //===- BuildLibCalls.h - Utility builder for libcalls -----------*- C++ -*-===//
- //
- // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
- // See https://llvm.org/LICENSE.txt for license information.
- // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
- //
- //===----------------------------------------------------------------------===//
- //
- // This file exposes an interface to build some C language libcalls for
- // optimization passes that need to call the various functions.
- //
- //===----------------------------------------------------------------------===//
- #ifndef LLVM_TRANSFORMS_UTILS_BUILDLIBCALLS_H
- #define LLVM_TRANSFORMS_UTILS_BUILDLIBCALLS_H
- #include "llvm/Analysis/TargetLibraryInfo.h"
- namespace llvm {
- class Value;
- class DataLayout;
- class IRBuilderBase;
- /// Analyze the name and prototype of the given function and set any
- /// applicable attributes. Note that this merely helps optimizations on an
- /// already existing function but does not consider mandatory attributes.
- ///
- /// If the library function is unavailable, this doesn't modify it.
- ///
- /// Returns true if any attributes were set and false otherwise.
- bool inferNonMandatoryLibFuncAttrs(Module *M, StringRef Name,
- const TargetLibraryInfo &TLI);
- bool inferNonMandatoryLibFuncAttrs(Function &F, const TargetLibraryInfo &TLI);
- /// Calls getOrInsertFunction() and then makes sure to add mandatory
- /// argument attributes.
- FunctionCallee getOrInsertLibFunc(Module *M, const TargetLibraryInfo &TLI,
- LibFunc TheLibFunc, FunctionType *T,
- AttributeList AttributeList);
- FunctionCallee getOrInsertLibFunc(Module *M, const TargetLibraryInfo &TLI,
- LibFunc TheLibFunc, FunctionType *T);
- template <typename... ArgsTy>
- FunctionCallee getOrInsertLibFunc(Module *M, const TargetLibraryInfo &TLI,
- LibFunc TheLibFunc, AttributeList AttributeList,
- Type *RetTy, ArgsTy... Args) {
- SmallVector<Type*, sizeof...(ArgsTy)> ArgTys{Args...};
- return getOrInsertLibFunc(M, TLI, TheLibFunc,
- FunctionType::get(RetTy, ArgTys, false),
- AttributeList);
- }
- /// Same as above, but without the attributes.
- template <typename... ArgsTy>
- FunctionCallee getOrInsertLibFunc(Module *M, const TargetLibraryInfo &TLI,
- LibFunc TheLibFunc, Type *RetTy, ArgsTy... Args) {
- return getOrInsertLibFunc(M, TLI, TheLibFunc, AttributeList{}, RetTy,
- Args...);
- }
- // Avoid an incorrect ordering that'd otherwise compile incorrectly.
- template <typename... ArgsTy>
- FunctionCallee
- getOrInsertLibFunc(Module *M, const TargetLibraryInfo &TLI,
- LibFunc TheLibFunc, AttributeList AttributeList,
- FunctionType *Invalid, ArgsTy... Args) = delete;
- /// Check whether the library function is available on target and also that
- /// it in the current Module is a Function with the right type.
- bool isLibFuncEmittable(const Module *M, const TargetLibraryInfo *TLI,
- LibFunc TheLibFunc);
- bool isLibFuncEmittable(const Module *M, const TargetLibraryInfo *TLI,
- StringRef Name);
- /// Check whether the overloaded floating point function
- /// corresponding to \a Ty is available.
- bool hasFloatFn(const Module *M, const TargetLibraryInfo *TLI, Type *Ty,
- LibFunc DoubleFn, LibFunc FloatFn, LibFunc LongDoubleFn);
- /// Get the name of the overloaded floating point function
- /// corresponding to \a Ty. Return the LibFunc in \a TheLibFunc.
- StringRef getFloatFn(const Module *M, const TargetLibraryInfo *TLI, Type *Ty,
- LibFunc DoubleFn, LibFunc FloatFn, LibFunc LongDoubleFn,
- LibFunc &TheLibFunc);
- /// Return V if it is an i8*, otherwise cast it to i8*.
- Value *castToCStr(Value *V, IRBuilderBase &B);
- /// Emit a call to the strlen function to the builder, for the specified
- /// pointer. Ptr is required to be some pointer type, and the return value has
- /// 'size_t' type.
- Value *emitStrLen(Value *Ptr, IRBuilderBase &B, const DataLayout &DL,
- const TargetLibraryInfo *TLI);
- /// Emit a call to the strdup function to the builder, for the specified
- /// pointer. Ptr is required to be some pointer type, and the return value has
- /// 'i8*' type.
- Value *emitStrDup(Value *Ptr, IRBuilderBase &B, const TargetLibraryInfo *TLI);
- /// Emit a call to the strchr function to the builder, for the specified
- /// pointer and character. Ptr is required to be some pointer type, and the
- /// return value has 'i8*' type.
- Value *emitStrChr(Value *Ptr, char C, IRBuilderBase &B,
- const TargetLibraryInfo *TLI);
- /// Emit a call to the strncmp function to the builder.
- Value *emitStrNCmp(Value *Ptr1, Value *Ptr2, Value *Len, IRBuilderBase &B,
- const DataLayout &DL, const TargetLibraryInfo *TLI);
- /// Emit a call to the strcpy function to the builder, for the specified
- /// pointer arguments.
- Value *emitStrCpy(Value *Dst, Value *Src, IRBuilderBase &B,
- const TargetLibraryInfo *TLI);
- /// Emit a call to the stpcpy function to the builder, for the specified
- /// pointer arguments.
- Value *emitStpCpy(Value *Dst, Value *Src, IRBuilderBase &B,
- const TargetLibraryInfo *TLI);
- /// Emit a call to the strncpy function to the builder, for the specified
- /// pointer arguments and length.
- Value *emitStrNCpy(Value *Dst, Value *Src, Value *Len, IRBuilderBase &B,
- const TargetLibraryInfo *TLI);
- /// Emit a call to the stpncpy function to the builder, for the specified
- /// pointer arguments and length.
- Value *emitStpNCpy(Value *Dst, Value *Src, Value *Len, IRBuilderBase &B,
- const TargetLibraryInfo *TLI);
- /// Emit a call to the __memcpy_chk function to the builder. This expects that
- /// the Len and ObjSize have type 'size_t' and Dst/Src are pointers.
- Value *emitMemCpyChk(Value *Dst, Value *Src, Value *Len, Value *ObjSize,
- IRBuilderBase &B, const DataLayout &DL,
- const TargetLibraryInfo *TLI);
- /// Emit a call to the mempcpy function.
- Value *emitMemPCpy(Value *Dst, Value *Src, Value *Len, IRBuilderBase &B,
- const DataLayout &DL, const TargetLibraryInfo *TLI);
- /// Emit a call to the memchr function. This assumes that Ptr is a pointer,
- /// Val is an 'int' value, and Len is an 'size_t' value.
- Value *emitMemChr(Value *Ptr, Value *Val, Value *Len, IRBuilderBase &B,
- const DataLayout &DL, const TargetLibraryInfo *TLI);
- /// Emit a call to the memrchr function, analogously to emitMemChr.
- Value *emitMemRChr(Value *Ptr, Value *Val, Value *Len, IRBuilderBase &B,
- const DataLayout &DL, const TargetLibraryInfo *TLI);
- /// Emit a call to the memcmp function.
- Value *emitMemCmp(Value *Ptr1, Value *Ptr2, Value *Len, IRBuilderBase &B,
- const DataLayout &DL, const TargetLibraryInfo *TLI);
- /// Emit a call to the bcmp function.
- Value *emitBCmp(Value *Ptr1, Value *Ptr2, Value *Len, IRBuilderBase &B,
- const DataLayout &DL, const TargetLibraryInfo *TLI);
- /// Emit a call to the memccpy function.
- Value *emitMemCCpy(Value *Ptr1, Value *Ptr2, Value *Val, Value *Len,
- IRBuilderBase &B, const TargetLibraryInfo *TLI);
- /// Emit a call to the snprintf function.
- Value *emitSNPrintf(Value *Dest, Value *Size, Value *Fmt,
- ArrayRef<Value *> Args, IRBuilderBase &B,
- const TargetLibraryInfo *TLI);
- /// Emit a call to the sprintf function.
- Value *emitSPrintf(Value *Dest, Value *Fmt, ArrayRef<Value *> VariadicArgs,
- IRBuilderBase &B, const TargetLibraryInfo *TLI);
- /// Emit a call to the strcat function.
- Value *emitStrCat(Value *Dest, Value *Src, IRBuilderBase &B,
- const TargetLibraryInfo *TLI);
- /// Emit a call to the strlcpy function.
- Value *emitStrLCpy(Value *Dest, Value *Src, Value *Size, IRBuilderBase &B,
- const TargetLibraryInfo *TLI);
- /// Emit a call to the strlcat function.
- Value *emitStrLCat(Value *Dest, Value *Src, Value *Size, IRBuilderBase &B,
- const TargetLibraryInfo *TLI);
- /// Emit a call to the strncat function.
- Value *emitStrNCat(Value *Dest, Value *Src, Value *Size, IRBuilderBase &B,
- const TargetLibraryInfo *TLI);
- /// Emit a call to the vsnprintf function.
- Value *emitVSNPrintf(Value *Dest, Value *Size, Value *Fmt, Value *VAList,
- IRBuilderBase &B, const TargetLibraryInfo *TLI);
- /// Emit a call to the vsprintf function.
- Value *emitVSPrintf(Value *Dest, Value *Fmt, Value *VAList, IRBuilderBase &B,
- const TargetLibraryInfo *TLI);
- /// Emit a call to the unary function named 'Name' (e.g. 'floor'). This
- /// function is known to take a single of type matching 'Op' and returns one
- /// value with the same type. If 'Op' is a long double, 'l' is added as the
- /// suffix of name, if 'Op' is a float, we add a 'f' suffix.
- Value *emitUnaryFloatFnCall(Value *Op, const TargetLibraryInfo *TLI,
- StringRef Name, IRBuilderBase &B,
- const AttributeList &Attrs);
- /// Emit a call to the unary function DoubleFn, FloatFn or LongDoubleFn,
- /// depending of the type of Op.
- Value *emitUnaryFloatFnCall(Value *Op, const TargetLibraryInfo *TLI,
- LibFunc DoubleFn, LibFunc FloatFn,
- LibFunc LongDoubleFn, IRBuilderBase &B,
- const AttributeList &Attrs);
- /// Emit a call to the binary function named 'Name' (e.g. 'fmin'). This
- /// function is known to take type matching 'Op1' and 'Op2' and return one
- /// value with the same type. If 'Op1/Op2' are long double, 'l' is added as
- /// the suffix of name, if 'Op1/Op2' are float, we add a 'f' suffix.
- Value *emitBinaryFloatFnCall(Value *Op1, Value *Op2,
- const TargetLibraryInfo *TLI,
- StringRef Name, IRBuilderBase &B,
- const AttributeList &Attrs);
- /// Emit a call to the binary function DoubleFn, FloatFn or LongDoubleFn,
- /// depending of the type of Op1.
- Value *emitBinaryFloatFnCall(Value *Op1, Value *Op2,
- const TargetLibraryInfo *TLI, LibFunc DoubleFn,
- LibFunc FloatFn, LibFunc LongDoubleFn,
- IRBuilderBase &B, const AttributeList &Attrs);
- /// Emit a call to the putchar function. This assumes that Char is an 'int'.
- Value *emitPutChar(Value *Char, IRBuilderBase &B,
- const TargetLibraryInfo *TLI);
- /// Emit a call to the puts function. This assumes that Str is some pointer.
- Value *emitPutS(Value *Str, IRBuilderBase &B, const TargetLibraryInfo *TLI);
- /// Emit a call to the fputc function. This assumes that Char is an 'int', and
- /// File is a pointer to FILE.
- Value *emitFPutC(Value *Char, Value *File, IRBuilderBase &B,
- const TargetLibraryInfo *TLI);
- /// Emit a call to the fputs function. Str is required to be a pointer and
- /// File is a pointer to FILE.
- Value *emitFPutS(Value *Str, Value *File, IRBuilderBase &B,
- const TargetLibraryInfo *TLI);
- /// Emit a call to the fwrite function. This assumes that Ptr is a pointer,
- /// Size is an 'size_t', and File is a pointer to FILE.
- Value *emitFWrite(Value *Ptr, Value *Size, Value *File, IRBuilderBase &B,
- const DataLayout &DL, const TargetLibraryInfo *TLI);
- /// Emit a call to the malloc function.
- Value *emitMalloc(Value *Num, IRBuilderBase &B, const DataLayout &DL,
- const TargetLibraryInfo *TLI);
- /// Emit a call to the calloc function.
- Value *emitCalloc(Value *Num, Value *Size, IRBuilderBase &B,
- const TargetLibraryInfo &TLI);
- }
- #endif
- #ifdef __GNUC__
- #pragma GCC diagnostic pop
- #endif
|