bolt/deps/llvm-18.1.8/llvm/test/CodeGen/SystemZ/zos-landingpad.ll
2025-02-14 19:21:04 +01:00

41 lines
1.4 KiB
LLVM

; RUN: llc < %s -mtriple=s390x-none-zos -mcpu=z10 | FileCheck %s
;
; Ensures that landingpad instructions use the right Exception Pointer
; and Exception Selector registers, and that the exception table is emitted.
declare void @callee()
declare void @passeh(i8*, i32) noreturn
declare i32 @__zos_cxx_personality_v2(...)
define void @test1() uwtable personality i32 (...)* @__zos_cxx_personality_v2 {
entry:
%ehptr = alloca i8*, align 8
%ehsel = alloca i32, align 8
invoke void @callee() to label %done unwind label %lpad
done:
ret void
; Match the return instruction.
; CHECK: b 2(7)
lpad:
%0 = landingpad { i8*, i32 } cleanup
; The Exception Pointer is %r1; the Exception Selector, %r2.
; CHECK: @BB{{[^%]*}} %lpad
; CHECK-DAG: stg 1, {{.*}}
; CHECK-DAG: st 2, {{.*}}
%1 = extractvalue { i8*, i32 } %0, 0
%2 = extractvalue { i8*, i32 } %0, 1
store i8* %1, i8** %ehptr, align 8
store i32 %2, i32* %ehsel, align 8
call void @passeh(i8* %1, i32 %2)
unreachable
}
; Check that offsets to the FD of the personality routine and LSDA are emitted in PPA1
; CHECK: .byte 145 {{.*PPA1 Flags}}
; CHECK: Bit 3: 1 = C++ EH block
; TODO: Emit the value instead of a dummy value.
; CHECK: Personality routine
; CHECK: LSDA location
; Check that the exception table is emitted into .lsda section.
; CHECK: .section ".gcc_exception_table.test1"
; CHECK: GCC_except_table0: