Fix invalid calling convention used for libcalls on ARM.
ARM ABI specifies that all the libcalls use soft FP ABI (even hard FP binaries). These days clang emits _mulsc3 / _muldc3 calls with default (C) calling convention which would be translated into AAPCS_VFP LLVM calling and thus the result of complex multiplication will be bogus. Introduce a way for a target to specify explicitly calling convention for libcalls. Right now this is temporary correctness fix. Ultimately, we'll end with intrinsic for complex multiplication and all calling convention decisions for libcalls will be put into backend. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@223123 91177308-0d34-0410-b5e6-96231b3b80d8
Showing
- lib/CodeGen/ABIInfo.h 9 additions, 1 deletionlib/CodeGen/ABIInfo.h
- lib/CodeGen/CGExprComplex.cpp 14 additions, 5 deletionslib/CodeGen/CGExprComplex.cpp
- lib/CodeGen/CodeGenModule.cpp 16 additions, 0 deletionslib/CodeGen/CodeGenModule.cpp
- lib/CodeGen/CodeGenModule.h 7 additions, 0 deletionslib/CodeGen/CodeGenModule.h
- lib/CodeGen/TargetInfo.cpp 6 additions, 3 deletionslib/CodeGen/TargetInfo.cpp
- test/CodeGen/complex-math.c 8 additions, 0 deletionstest/CodeGen/complex-math.c
Loading
Please register or sign in to comment