diff options
Diffstat (limited to 'test/CodeGen/AArch64/GlobalISel/legalize-exceptions.ll')
-rw-r--r-- | test/CodeGen/AArch64/GlobalISel/legalize-exceptions.ll | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/test/CodeGen/AArch64/GlobalISel/legalize-exceptions.ll b/test/CodeGen/AArch64/GlobalISel/legalize-exceptions.ll new file mode 100644 index 000000000000..23e7d5163e5a --- /dev/null +++ b/test/CodeGen/AArch64/GlobalISel/legalize-exceptions.ll @@ -0,0 +1,53 @@ +; RUN: llc -O0 -mtriple=aarch64-apple-ios -verify-machineinstrs -global-isel -stop-after=legalizer %s -o - | FileCheck %s + +@_ZTIi = external global i8* + +declare i32 @foo(i32) +declare i32 @__gxx_personality_v0(...) +declare i32 @llvm.eh.typeid.for(i8*) +declare void @_Unwind_Resume(i8*) + +; CHECK: name: bar +; CHECK: body: +; CHECK-NEXT: bb.1 (%ir-block.0): +; CHECK: successors: %{{bb.[0-9]+.continue.*}}%[[LP:bb.[0-9]+.cleanup]] + +; CHECK: [[LP]] (landing-pad): +; CHECK: EH_LABEL + +; CHECK: [[PTR:%[0-9]+]](p0) = COPY %x0 +; CHECK: [[STRUCT_PTR:%[0-9]+]](s64) = G_PTRTOINT [[PTR]](p0) + +; CHECK: [[SEL_PTR:%[0-9]+]](p0) = COPY %x1 +; CHECK: [[SEL:%[0-9]+]](s32) = G_PTRTOINT [[SEL_PTR]] +; CHECK: [[STRUCT_SEL:%[0-9]+]](s64) = G_INSERT {{%[0-9]+}}, [[SEL]](s32), 0 + +; CHECK: [[STRUCT:%[0-9]+]](s128) = G_MERGE_VALUES [[STRUCT_PTR]](s64), [[STRUCT_SEL]] + +; CHECK: [[PTR:%[0-9]+]](p0) = G_EXTRACT [[STRUCT]](s128), 0 +; CHECK: G_STORE [[PTR]](p0), {{%[0-9]+}}(p0) + +; CHECK: [[SEL:%[0-9]+]](s32) = G_EXTRACT [[STRUCT]](s128), 64 +; CHECK: G_STORE [[SEL]](s32), {{%[0-9]+}}(p0) + +define void @bar() personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*) { + %exn.slot = alloca i8* + %ehselector.slot = alloca i32 + %1 = invoke i32 @foo(i32 42) to label %continue unwind label %cleanup + +cleanup: + %2 = landingpad { i8*, i32 } cleanup + %3 = extractvalue { i8*, i32 } %2, 0 + store i8* %3, i8** %exn.slot, align 8 + %4 = extractvalue { i8*, i32 } %2, 1 + store i32 %4, i32* %ehselector.slot, align 4 + br label %eh.resume + +continue: + ret void + +eh.resume: + %exn = load i8*, i8** %exn.slot, align 8 + call void @_Unwind_Resume(i8* %exn) + unreachable +} |