27 template <
class ArgIt>
29 ArgIt ArgBegin, ArgIt ArgEnd,
32 std::vector<Type *> ParamTys;
33 for (ArgIt
I = ArgBegin;
I != ArgEnd; ++
I)
34 ParamTys.push_back(
I->getType());
40 const char *DName,
const char *LDName) {
42 switch((
int)Fn->
arg_begin()->getType()->getTypeID()) {
64 template <
class ArgIt>
66 ArgIt ArgBegin, ArgIt ArgEnd,
72 std::vector<Type *> ParamTys;
73 for (ArgIt
I = ArgBegin;
I != ArgEnd; ++
I)
74 ParamTys.push_back((*I)->getType());
80 CallInst *NewCI = Builder.CreateCall(FCache, Args);
88 #if defined(_MSC_VER) && defined(setjmp) && \
89 !defined(setjmp_undefined_for_msvc)
90 # pragma push_macro("setjmp")
92 # define setjmp_undefined_for_msvc
98 if (
I->isDeclaration() && !
I->use_empty())
99 switch (
I->getIntrinsicID()) {
180 V = Builder.CreateOr(Tmp1, Tmp2,
"bswap.i16");
192 Tmp3 = Builder.CreateAnd(Tmp3,
195 Tmp2 = Builder.CreateAnd(Tmp2,
198 Tmp4 = Builder.CreateOr(Tmp4, Tmp3,
"bswap.or1");
199 Tmp2 = Builder.CreateOr(Tmp2, Tmp1,
"bswap.or2");
200 V = Builder.CreateOr(Tmp4, Tmp2,
"bswap.i32");
214 Value* Tmp3 = Builder.CreateLShr(V,
217 Value* Tmp2 = Builder.CreateLShr(V,
220 Value* Tmp1 = Builder.CreateLShr(V,
223 Tmp7 = Builder.CreateAnd(Tmp7,
225 0xFF000000000000ULL),
227 Tmp6 = Builder.CreateAnd(Tmp6,
231 Tmp5 = Builder.CreateAnd(Tmp5,
235 Tmp4 = Builder.CreateAnd(Tmp4,
239 Tmp3 = Builder.CreateAnd(Tmp3,
243 Tmp2 = Builder.CreateAnd(Tmp2,
247 Tmp8 = Builder.CreateOr(Tmp8, Tmp7,
"bswap.or1");
248 Tmp6 = Builder.CreateOr(Tmp6, Tmp5,
"bswap.or2");
249 Tmp4 = Builder.CreateOr(Tmp4, Tmp3,
"bswap.or3");
250 Tmp2 = Builder.CreateOr(Tmp2, Tmp1,
"bswap.or4");
251 Tmp8 = Builder.CreateOr(Tmp8, Tmp6,
"bswap.or5");
252 Tmp4 = Builder.CreateOr(Tmp4, Tmp2,
"bswap.or6");
253 V = Builder.CreateOr(Tmp8, Tmp4,
"bswap.i64");
265 static const uint64_t MaskValues[6] = {
266 0x5555555555555555ULL, 0x3333333333333333ULL,
267 0x0F0F0F0F0F0F0F0FULL, 0x00FF00FF00FF00FFULL,
268 0x0000FFFF0000FFFFULL, 0x00000000FFFFFFFFULL
274 unsigned WordSize = (BitSize + 63) / 64;
277 for (
unsigned n = 0; n < WordSize; ++n) {
278 Value *PartValue = V;
279 for (
unsigned i = 1, ct = 0; i < (BitSize>64 ? 64 : BitSize);
282 Value *LHS = Builder.CreateAnd(PartValue, MaskCst,
"cppop.and1");
283 Value *VShift = Builder.CreateLShr(PartValue,
286 Value *RHS = Builder.CreateAnd(VShift, MaskCst,
"cppop.and2");
287 PartValue = Builder.CreateAdd(LHS, RHS,
"ctpop.step");
289 Count = Builder.CreateAdd(PartValue, Count,
"ctpop.part");
307 for (
unsigned i = 1; i < BitSize; i <<= 1) {
309 ShVal = Builder.CreateLShr(V, ShVal,
"ctlz.sh");
310 V = Builder.CreateOr(V, ShVal,
"ctlz.step");
313 V = Builder.CreateNot(V);
319 const char *LDname) {
345 assert(Callee &&
"Cannot lower an indirect call!");
406 Value *NotSrc = Builder.CreateNot(Src);
409 SrcM1 = Builder.CreateSub(Src, SrcM1);
418 errs() <<
"WARNING: this target does not support the llvm.stack"
420 "save" :
"restore") <<
" intrinsic.\n";
429 errs() <<
"WARNING: this target does not support the llvm."
431 "return" :
"frame") <<
"address intrinsic.\n";
433 cast<PointerType>(CI->
getType())));
442 errs() <<
"WARNING: this target does not support the llvm.readcyclecoun"
443 <<
"ter intrinsic. It is being lowered to a constant 0\n";
547 "Lowering should have eliminated any uses of the intrinsic call!");
static Type * getDoubleTy(LLVMContext &C)
The main container class for the LLVM Intermediate Representation.
static CallInst * ReplaceCallWith(const char *NewFn, CallInst *CI, ArgIt ArgBegin, ArgIt ArgEnd, Type *RetTy)
2: 32-bit floating point type
enable_if_c<!is_simple_type< Y >::value, typename cast_retty< X, const Y >::ret_type >::type dyn_cast(const Y &Val)
const Function * getParent() const
Return the enclosing method, or null if none.
4: 80-bit floating point type (X87)
static IntegerType * getInt64Ty(LLVMContext &C)
static void EnsureFPIntrinsicsExist(Module &M, Function *Fn, const char *FName, const char *DName, const char *LDName)
LLVM_ATTRIBUTE_NORETURN void report_fatal_error(const char *reason, bool gen_crash_diag=true)
static Constant * getNullValue(Type *Ty)
StringRef getName() const
static Type * getFloatTy(LLVMContext &C)
#define llvm_unreachable(msg)
unsigned getNumArgOperands() const
This provides a uniform API for creating instructions and inserting them into a basic block: either a...
static void EnsureFunctionExists(Module &M, const char *Name, ArgIt ArgBegin, ArgIt ArgEnd, Type *RetTy)
static void ReplaceFPIntrinsicWithCall(CallInst *CI, const char *Fname, const char *Dname, const char *LDname)
void setName(const Twine &Name)
Value * CreateAnd(Value *LHS, Value *RHS, const Twine &Name="")
static FunctionType * get(Type *Result, ArrayRef< Type * > Params, bool isVarArg)
Function * getDeclaration(Module *M, ID id, ArrayRef< Type * > Tys=None)
void replaceAllUsesWith(Value *V)
static ConstantPointerNull * get(PointerType *T)
get() - Static factory methods - Return objects of the specified value
Constant * getOrInsertFunction(StringRef Name, FunctionType *T, AttributeSet AttributeList)
static Value * LowerBSWAP(LLVMContext &Context, Value *V, Instruction *IP)
unsigned getIntrinsicID() const LLVM_READONLY
LLVM Constant Representation.
static Type * getVoidTy(LLVMContext &C)
6: 128-bit floating point type (two 64-bits, PowerPC)
Value * getOperand(unsigned i) const
Integer representation type.
static UndefValue * get(Type *T)
LLVMContext & getContext() const
All values hold a context through their type.
static PointerType * getInt8PtrTy(LLVMContext &C, unsigned AS=0)
static Value * LowerCTPOP(LLVMContext &Context, Value *V, Instruction *IP)
static CallInst * Create(Value *Func, ArrayRef< Value * > Args, const Twine &NameStr="", Instruction *InsertBefore=0)
IntegerType * getIntPtrType(LLVMContext &C, unsigned AddressSpace=0) const
void AddPrototypes(Module &M)
static Value * LowerCTLZ(LLVMContext &Context, Value *V, Instruction *IP)
static Constant * get(Type *Ty, uint64_t V, bool isSigned=false)
Function * getCalledFunction() const
Value * getArgOperand(unsigned i) const
static bool LowerToByteSwap(CallInst *CI)
static IntegerType * getInt32Ty(LLVMContext &C)
void LowerIntrinsicCall(CallInst *CI)
unsigned getPrimitiveSizeInBits() const
3: 64-bit floating point type
LLVM Value Representation.
const BasicBlock * getParent() const
LLVMContext & getContext() const
bool isVoidTy() const
isVoidTy - Return true if this is 'void'.
5: 128-bit floating point type (112-bit mantissa)