mirror of
https://github.com/RPCS3/llvm.git
synced 2024-12-26 14:15:53 +00:00
ARM: correct assertion for long-calls on WoA
COFF/PE, so the relocation model is never static. Loosen the assertion accordingly. The relocation can still be emitted properly, as it will be converted to an IMAGE_REL_ARM_ADDR32 which will be resolved by the loader taking the base relocation into account. This is necessary to permit the emission of long calls which can be controlled via the -mlong-calls option in the driver. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@210399 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
3ddcc49650
commit
104e73dd34
@ -1598,8 +1598,9 @@ ARMTargetLowering::LowerCall(TargetLowering::CallLoweringInfo &CLI,
|
||||
ARMFunctionInfo *AFI = MF.getInfo<ARMFunctionInfo>();
|
||||
|
||||
if (EnableARMLongCalls) {
|
||||
assert (getTargetMachine().getRelocationModel() == Reloc::Static
|
||||
&& "long-calls with non-static relocation model!");
|
||||
assert((Subtarget->isTargetWindows() ||
|
||||
getTargetMachine().getRelocationModel() == Reloc::Static) &&
|
||||
"long-calls with non-static relocation model!");
|
||||
// Handle a global address or an external symbol. If it's not one of
|
||||
// those, the target's already in a register, so we don't need to do
|
||||
// anything extra.
|
||||
|
18
test/CodeGen/ARM/Windows/long-calls.ll
Normal file
18
test/CodeGen/ARM/Windows/long-calls.ll
Normal file
@ -0,0 +1,18 @@
|
||||
; RUN: llc -mtriple=thumbv7-windows -mcpu=cortex-a9 -arm-long-calls -o - %s \
|
||||
; RUN: | FileCheck %s
|
||||
|
||||
declare arm_aapcs_vfpcc void @callee()
|
||||
|
||||
define arm_aapcs_vfpcc void @caller() nounwind {
|
||||
entry:
|
||||
tail call void @callee()
|
||||
ret void
|
||||
}
|
||||
|
||||
; CHECK-LABEL: caller
|
||||
; CHECK: ldr [[REG:r[0-9]+]], [[CPI:.LCPI[_0-9]+]]
|
||||
; CHECK: bx [[REG]]
|
||||
; CHECK: .align 2
|
||||
; CHECK: [[CPI]]:
|
||||
; CHECK: .long callee
|
||||
|
Loading…
Reference in New Issue
Block a user