llvm-project/llvm/test/CodeGen/AArch64/exception-handling-windows-elf.ll
Matt Arsenault 617af3cc50
AArch64: Base MCAsmInfo type on binary format before OS (#147875)
Fixes asserting with windows-elf triples. Should fix regression
reported in https://github.com/llvm/llvm-project/pull/147225#issuecomment-3054190938

I'm not sure this is a valid triple, but I'm guessing the MCJIT usage
is an accident. This does change the behavior from trying to use WinEH
to DwarfCFI; however the backend crashes with WinEH so I'm assuming following
ELF is the more correct option.
2025-07-10 13:06:14 +09:00

45 lines
1.4 KiB
LLVM

; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
; RUN: llc -mtriple=aarch64-pc-windows-elf < %s | FileCheck %s
; Make sure windows elf does not assert with exceptions. This is a
; hack for MCJIT that could be treated as an error when it is removed.
@_ZTIi = external global ptr
declare i32 @foo(i32)
declare i32 @__gxx_personality_v0(...)
define void @bar() personality ptr @__gxx_personality_v0 {
; CHECK-LABEL: bar:
; CHECK: // %bb.0: // %continue
; CHECK-NEXT: sub sp, sp, #32
; CHECK-NEXT: str x30, [sp, #16] // 8-byte Folded Spill
; CHECK-NEXT: .cfi_def_cfa_offset 32
; CHECK-NEXT: .cfi_offset w30, -16
; CHECK-NEXT: adrp x8, :got:foo
; CHECK-NEXT: mov w0, #42 // =0x2a
; CHECK-NEXT: ldr x8, [x8, :got_lo12:foo]
; CHECK-NEXT: blr x8
; CHECK-NEXT: ldr x30, [sp, #16] // 8-byte Folded Reload
; CHECK-NEXT: add sp, sp, #32
; CHECK-NEXT: ret
%exn.slot = alloca ptr
%ehselector.slot = alloca i32
%1 = invoke i32 @foo(i32 42) to label %continue unwind label %cleanup
cleanup:
%lp = landingpad { ptr, i32 } cleanup
%lp.0 = extractvalue { ptr, i32 } %lp, 0
store ptr %lp.0, ptr %exn.slot, align 8
%lp.1 = extractvalue { ptr, i32 } %lp, 1
store i32 %lp.1, ptr %ehselector.slot, align 4
br label %eh.resume
continue:
ret void
eh.resume:
%exn = load ptr, ptr %exn.slot, align 8
unreachable
}