diff options
author | Misha Brukman <brukman+llvm@gmail.com> | 2004-07-08 19:41:16 +0000 |
---|---|---|
committer | Misha Brukman <brukman+llvm@gmail.com> | 2004-07-08 19:41:16 +0000 |
commit | f3f63824238b383946e921328e45246f2dd8bfdb (patch) | |
tree | 77e870e48c3a4cbe1e0bbbdc41723f331158ad50 /lib/Target/PowerPC/PowerPCISelSimple.cpp | |
parent | 4bb2867bc1faa2eedafc39b37bbf481ff4dcb725 (diff) |
Add support for __fixdfdi(), __floatdisf(), and __floatdidf() external functions
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@14703 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/PowerPC/PowerPCISelSimple.cpp')
-rw-r--r-- | lib/Target/PowerPC/PowerPCISelSimple.cpp | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/lib/Target/PowerPC/PowerPCISelSimple.cpp b/lib/Target/PowerPC/PowerPCISelSimple.cpp index 2099c25eee..c6d2c6e085 100644 --- a/lib/Target/PowerPC/PowerPCISelSimple.cpp +++ b/lib/Target/PowerPC/PowerPCISelSimple.cpp @@ -79,7 +79,8 @@ namespace { std::map<Value*, unsigned> RegMap; // Mapping between Val's and SSA Regs // External functions used in the Module - Function *fmodFn, *__moddi3Fn, *__divdi3Fn, *__umoddi3Fn, *__udivdi3Fn; + Function *fmodFn, *__moddi3Fn, *__divdi3Fn, *__umoddi3Fn, *__udivdi3Fn, + *__fixdfdiFn, *__floatdisfFn, *__floatdidfFn; // MBBMap - Mapping between LLVM BB -> Machine BB std::map<const BasicBlock*, MachineBasicBlock*> MBBMap; @@ -93,6 +94,7 @@ namespace { bool doInitialization(Module &M) { // Add external functions that we may call Type *d = Type::DoubleTy; + Type *f = Type::FloatTy; Type *l = Type::LongTy; Type *ul = Type::ULongTy; // double fmod(double, double); @@ -105,6 +107,12 @@ namespace { __umoddi3Fn = M.getOrInsertFunction("__umoddi3", ul, ul, ul, 0); // unsigned long __udivdi3(unsigned long, unsigned long); __udivdi3Fn = M.getOrInsertFunction("__udivdi3", ul, ul, ul, 0); + // long __fixdfdi(double) + __fixdfdiFn = M.getOrInsertFunction("__fixdfdi", l, d, 0); + // float __floatdisf(long) + __floatdisfFn = M.getOrInsertFunction("__floatdisf", f, l, 0); + // double __floatdidf(long) + __floatdidfFn = M.getOrInsertFunction("__floatdidf", d, l, 0); return false; } @@ -2487,7 +2495,7 @@ void ISel::emitCastOperation(MachineBasicBlock *BB, std::vector<ValueRecord> Args; Args.push_back(ValueRecord(SrcReg, SrcTy)); MachineInstr *TheCall = - BuildMI(PPC32::CALLpcrel, 1).addExternalSymbol("__floatdidf", true); + BuildMI(PPC32::CALLpcrel, 1).addGlobalAddress(__floatdidfFn, true); doCall(ValueRecord(DestReg, DestTy), TheCall, Args, false); return; } @@ -2580,7 +2588,7 @@ void ISel::emitCastOperation(MachineBasicBlock *BB, std::vector<ValueRecord> Args; Args.push_back(ValueRecord(SrcReg, SrcTy)); MachineInstr *TheCall = - BuildMI(PPC32::CALLpcrel, 1).addExternalSymbol("__fixdfdi", true); + BuildMI(PPC32::CALLpcrel, 1).addGlobalAddress(__fixdfdiFn, true); doCall(ValueRecord(DestReg, DestTy), TheCall, Args, false); return; } |