mirror of
https://github.com/RPCSX/llvm.git
synced 2024-11-26 05:00:26 +00:00
Add some additional functions to the list of helper functions for
pic calls. These need to be there so we don't try and use helper functions when we call those. As part of this, make sure that we properly exclude helper functions in pic mode when indirect calls are involved. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@182343 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
6f43379e23
commit
bf00bf9ad2
@ -46,9 +46,13 @@ Mips16TargetLowering::Mips16TargetLowering(MipsTargetMachine &TM)
|
||||
// Set up the register classes
|
||||
addRegisterClass(MVT::i32, &Mips::CPU16RegsRegClass);
|
||||
|
||||
if (Subtarget->inMips16HardFloat())
|
||||
if (Subtarget->inMips16HardFloat()) {
|
||||
setMips16HardFloatLibCalls();
|
||||
|
||||
NoHelperNeeded.insert("__mips16_ret_sf");
|
||||
NoHelperNeeded.insert("__mips16_ret_df");
|
||||
NoHelperNeeded.insert("__mips16_ret_sc");
|
||||
NoHelperNeeded.insert("__mips16_ret_dc");
|
||||
}
|
||||
setOperationAction(ISD::ATOMIC_FENCE, MVT::Other, Expand);
|
||||
setOperationAction(ISD::ATOMIC_CMP_SWAP, MVT::i32, Expand);
|
||||
setOperationAction(ISD::ATOMIC_SWAP, MVT::i32, Expand);
|
||||
@ -383,6 +387,13 @@ getOpndList(SmallVectorImpl<SDValue> &Ops,
|
||||
LookupHelper = false;
|
||||
}
|
||||
}
|
||||
else if (GlobalAddressSDNode *G =
|
||||
dyn_cast<GlobalAddressSDNode>(CLI.Callee)) {
|
||||
if (NoHelperNeeded.find(G->getGlobal()->getName().data()) !=
|
||||
NoHelperNeeded.end()) {
|
||||
LookupHelper = false;
|
||||
}
|
||||
}
|
||||
if (LookupHelper) Mips16HelperFunction =
|
||||
getMips16HelperFunction(CLI.RetTy, CLI.Args, NeedMips16Helper);
|
||||
|
||||
|
67
test/CodeGen/Mips/hfptrcall.ll
Normal file
67
test/CodeGen/Mips/hfptrcall.ll
Normal file
@ -0,0 +1,67 @@
|
||||
; RUN: llc -mtriple=mipsel-linux-gnu -march=mipsel -mcpu=mips16 -soft-float -mips16-hard-float -relocation-model=pic < %s | FileCheck %s -check-prefix=picel
|
||||
|
||||
@ptrsv = global float ()* @sv, align 4
|
||||
@ptrdv = global double ()* @dv, align 4
|
||||
@ptrscv = global { float, float } ()* @scv, align 4
|
||||
@ptrdcv = global { double, double } ()* @dcv, align 4
|
||||
@x = common global float 0.000000e+00, align 4
|
||||
@.str = private unnamed_addr constant [4 x i8] c"%f\0A\00", align 1
|
||||
@xd = common global double 0.000000e+00, align 8
|
||||
@xy = common global { float, float } zeroinitializer, align 4
|
||||
@.str1 = private unnamed_addr constant [10 x i8] c"%f + %fi\0A\00", align 1
|
||||
@xyd = common global { double, double } zeroinitializer, align 8
|
||||
|
||||
; Function Attrs: nounwind
|
||||
define float @sv() #0 {
|
||||
entry:
|
||||
ret float 1.000000e+01
|
||||
}
|
||||
; picel: .ent sv
|
||||
; picel: lw ${{[0-9]+}}, %call16(__mips16_ret_sf)(${{[0-9]+}})
|
||||
; picel: .end sv
|
||||
|
||||
; Function Attrs: nounwind
|
||||
define double @dv() #0 {
|
||||
entry:
|
||||
ret double 1.500000e+01
|
||||
}
|
||||
|
||||
; picel: .ent dv
|
||||
; picel: lw ${{[0-9]+}}, %call16(__mips16_ret_df)(${{[0-9]+}})
|
||||
; picel: .end dv
|
||||
|
||||
; Function Attrs: nounwind
|
||||
define { float, float } @scv() #0 {
|
||||
entry:
|
||||
%retval = alloca { float, float }, align 4
|
||||
%real = getelementptr inbounds { float, float }* %retval, i32 0, i32 0
|
||||
%imag = getelementptr inbounds { float, float }* %retval, i32 0, i32 1
|
||||
store float 5.000000e+00, float* %real
|
||||
store float 9.900000e+01, float* %imag
|
||||
%0 = load { float, float }* %retval
|
||||
ret { float, float } %0
|
||||
}
|
||||
|
||||
; picel: .ent scv
|
||||
; picel: lw ${{[0-9]+}}, %call16(__mips16_ret_sc)(${{[0-9]+}})
|
||||
; picel: .end scv
|
||||
|
||||
; Function Attrs: nounwind
|
||||
define { double, double } @dcv() #0 {
|
||||
entry:
|
||||
%retval = alloca { double, double }, align 8
|
||||
%real = getelementptr inbounds { double, double }* %retval, i32 0, i32 0
|
||||
%imag = getelementptr inbounds { double, double }* %retval, i32 0, i32 1
|
||||
store double 0x416BC8B0A0000000, double* %real
|
||||
store double 0x41CDCCB763800000, double* %imag
|
||||
%0 = load { double, double }* %retval
|
||||
ret { double, double } %0
|
||||
}
|
||||
|
||||
; picel: .ent dcv
|
||||
; picel: lw ${{[0-9]+}}, %call16(__mips16_ret_dc)(${{[0-9]+}})
|
||||
; picel: .end dcv
|
||||
|
||||
|
||||
attributes #0 = { nounwind "less-precise-fpmad"="false" "no-frame-pointer-elim"="true" "no-frame-pointer-elim-non-leaf"="true" "no-infs-fp-math"="false" "no-nans-fp-math"="false" "unsafe-fp-math"="false" "use-soft-float"="true" }
|
||||
|
Loading…
Reference in New Issue
Block a user