mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 04:02:41 +01:00
674ab91499
Currently, the Int_eh_sjlj_dispatchsetup intrinsic is marked as clobbering all registers, including floating-point registers that may not be present on the target. This is technically true, as we could get linked against code that does use the FP registers, but that will not actually work, as the soft-float code cannot save and restore the FP registers. SjLj exception handling can only work correctly if either all or none of the code is built for a target with FP registers. Therefore, we can assume that, when Int_eh_sjlj_dispatchsetup is compiled for a soft-float target, it is only going to be linked against other soft-float code, and so only clobbers the general-purpose registers. This allows us to check that no non-savable registers are clobbered when generating the prologue/epilogue. Differential Revision: https://reviews.llvm.org/D25180 llvm-svn: 283866
108 lines
3.7 KiB
LLVM
108 lines
3.7 KiB
LLVM
; RUN: llc -mtriple armv7-apple-ios -relocation-model=pic -o - %s | FileCheck %s -check-prefix=ARM-PIC -check-prefix=ARM
|
|
; RUN: llc -mtriple armv7-apple-ios -relocation-model=static -o - %s | FileCheck %s -check-prefix=ARM-NOPIC -check-prefix=ARM
|
|
; RUN: llc -mtriple armv7-apple-ios -relocation-model=dynamic-no-pic -o - %s | FileCheck %s -check-prefix=ARM-NOPIC -check-prefix=ARM
|
|
; RUN: llc -mtriple thumbv6-apple-ios -relocation-model=pic -o - %s | FileCheck %s -check-prefix=THUMB1-PIC -check-prefix=THUMB1
|
|
; RUN: llc -mtriple thumbv6-apple-ios -relocation-model=static -o - %s | FileCheck %s -check-prefix=THUMB1-NOPIC -check-prefix=THUMB1
|
|
; RUN: llc -mtriple thumbv6-apple-ios -relocation-model=dynamic-no-pic -o - %s | FileCheck %s -check-prefix=THUMB1-NOPIC -check-prefix=THUMB1
|
|
|
|
@_ZTIi = external constant i8*
|
|
|
|
define i32 @main() #0 personality i8* bitcast (i32 (...)* @__gxx_personality_sj0 to i8*) {
|
|
entry:
|
|
%exception = tail call i8* @__cxa_allocate_exception(i32 4) #1
|
|
%0 = bitcast i8* %exception to i32*
|
|
store i32 1, i32* %0, align 4
|
|
invoke void @__cxa_throw(i8* %exception, i8* bitcast (i8** @_ZTIi to i8*), i8* null) #2
|
|
to label %unreachable unwind label %lpad
|
|
|
|
lpad: ; preds = %entry
|
|
%1 = landingpad { i8*, i32 }
|
|
catch i8* null
|
|
%2 = extractvalue { i8*, i32 } %1, 0
|
|
%3 = tail call i8* @__cxa_begin_catch(i8* %2) #1
|
|
tail call void @__cxa_end_catch()
|
|
ret i32 0
|
|
|
|
unreachable: ; preds = %entry
|
|
unreachable
|
|
}
|
|
|
|
declare i8* @__cxa_allocate_exception(i32)
|
|
|
|
declare void @__cxa_throw(i8*, i8*, i8*)
|
|
|
|
declare i8* @__cxa_begin_catch(i8*)
|
|
|
|
declare void @__cxa_end_catch()
|
|
|
|
declare i32 @__gxx_personality_sj0(...)
|
|
|
|
attributes #0 = { ssp }
|
|
attributes #1 = { nounwind }
|
|
attributes #2 = { noreturn }
|
|
|
|
; ARM: vst1.64
|
|
; ARM: vst1.64
|
|
|
|
; ARM-PIC: cxa_throw
|
|
; ARM-PIC: trap
|
|
; ARM-PIC: adr [[REG1:r[0-9]+]], [[LJTI:.*]]
|
|
; ARM-PIC: ldr [[REG0:r[0-9]+]], [r{{[0-9]+}}, [[REG1]]]
|
|
; ARM-PIC: add pc, [[REG0]], [[REG1]]
|
|
; ARM-PIC: [[LJTI]]
|
|
; ARM-PIC: .data_region jt32
|
|
; ARM-PIC: .long [[LABEL:LBB0_[0-9]]]-[[LJTI]]
|
|
; ARM-PIC: .end_data_region
|
|
; ARM-PIC: [[LABEL]]
|
|
|
|
; ARM-NOPIC: cxa_throw
|
|
; ARM-NOPIC: trap
|
|
; ARM-NOPIC: adr [[REG1:r[0-9]+]], [[LJTI:.*]]
|
|
; ARM-NOPIC: ldr [[REG0:r[0-9]+]], [r{{[0-9]+}}, [[REG1]]]
|
|
; ARM-NOPIC: mov pc, [[REG0]]
|
|
; ARM-NOPIC: [[LJTI]]
|
|
; ARM-NOPIC: .data_region jt32
|
|
; ARM-NOPIC: .long [[LABEL:LBB0_[0-9]]]
|
|
; ARM-NOPIC: .end_data_region
|
|
; ARM-NOPIC: [[LABEL]]
|
|
|
|
; ARM: vld1.64
|
|
; ARM: vld1.64
|
|
|
|
; On Thumb1 targets, we have no way to preserve the floating-point registers.
|
|
; If all other code is built for Thumb1 or is built soft-float, this is not a
|
|
; problem as the FP regs don't need saving. However, if this code is linked
|
|
; against ARM code that uses the FP regs, they won't be restored correctly. We
|
|
; don't support this use-case, but have no way to prevent it in the compiler.
|
|
|
|
; THUMB1: push {{[^d]*$}}
|
|
; THUMB1-NOT: vst
|
|
|
|
; THUMB1-PIC: cxa_throw
|
|
; THUMB1-PIC: trap
|
|
; THUMB1-PIC: adr [[REG1:r[0-9]+]], [[LJTI:.*]]
|
|
; THUMB1-PIC: adds [[REG0:r[0-9]+]], [[REG0]], [[REG1]]
|
|
; THUMB1-PIC: ldr [[REG0]]
|
|
; THUMB1-PIC: adds [[REG0]], [[REG0]], [[REG1]]
|
|
; THUMB1-PIC: mov pc, [[REG0]]
|
|
; THUMB1-PIC: [[LJTI]]
|
|
; THUMB1-PIC: .data_region jt32
|
|
; THUMB1-PIC: .long [[LABEL:LBB0_[0-9]]]-[[LJTI]]
|
|
; THUMB1-PIC: .end_data_region
|
|
; THUMB1-PIC: [[LABEL]]
|
|
|
|
; THUMB1-NOPIC: cxa_throw
|
|
; THUMB1-NOPIC: trap
|
|
; THUMB1-NOPIC: adr [[REG1:r[0-9]+]], [[LJTI:.*]]
|
|
; THUMB1-NOPIC: adds [[REG0:r[0-9]+]], [[REG0]], [[REG1]]
|
|
; THUMB1-NOPIC: ldr [[REG0]]
|
|
; THUMB1-NOPIC: mov pc, [[REG0]]
|
|
; THUMB1-NOPIC: [[LJTI]]
|
|
; THUMB1-NOPIC: .data_region jt32
|
|
; THUMB1-NOPIC: .long [[LABEL:LBB0_[0-9]]]+1
|
|
; THUMB1-NOPIC: .end_data_region
|
|
; THUMB1-NOPIC: [[LABEL]]
|
|
|
|
; THUMB1-NOT: vld
|
|
; THUMB1: pop {{[^d]*$}}
|