[LLVM][IR] Use splat syntax when printing ConstantExpr based splats. (#116856)
[llvm-project.git] / llvm / test / CodeGen / AArch64 / pr58516.ll
blob3361ded48d4e2a0db6d0ae8e8d9a422efdc76410
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -mtriple=aarch64-pc-windows-msvc %s -o - | FileCheck %s
5 $osfx = comdat any
7 declare dso_local i32 @__CxxFrameHandler3(...)
9 define void @osfx(ptr %this) comdat personality ptr @__CxxFrameHandler3 {
10 ; CHECK-LABEL: osfx:
11 ; CHECK:       .Lfunc_begin0:
12 ; CHECK-NEXT:  .seh_proc osfx
13 ; CHECK-NEXT:    .seh_handler __CxxFrameHandler3, @unwind, @except
14 ; CHECK-NEXT:  // %bb.0: // %invoke.cont
15 ; CHECK-NEXT:    stp x19, x20, [sp, #-64]! // 16-byte Folded Spill
16 ; CHECK-NEXT:    .seh_save_regp_x x19, 64
17 ; CHECK-NEXT:    str x21, [sp, #16] // 8-byte Folded Spill
18 ; CHECK-NEXT:    .seh_save_reg x21, 16
19 ; CHECK-NEXT:    stp x29, x30, [sp, #24] // 16-byte Folded Spill
20 ; CHECK-NEXT:    .seh_save_fplr 24
21 ; CHECK-NEXT:    add x29, sp, #24
22 ; CHECK-NEXT:    .seh_add_fp 24
23 ; CHECK-NEXT:    .seh_endprologue
24 ; CHECK-NEXT:    sub x9, sp, #32
25 ; CHECK-NEXT:    and sp, x9, #0xffffffffffffffe0
26 ; CHECK-NEXT:    mov x19, sp
27 ; CHECK-NEXT:    mov x1, #-2 // =0xfffffffffffffffe
28 ; CHECK-NEXT:    mov x20, x0
29 ; CHECK-NEXT:    add x8, x19, #0
30 ; CHECK-NEXT:    stur x1, [x29, #24]
31 ; CHECK-NEXT:    lsr x21, x8, #3
32 ; CHECK-NEXT:    adrp x8, osfx
33 ; CHECK-NEXT:    add x8, x8, :lo12:osfx
34 ; CHECK-NEXT:    str x8, [x0]
35 ; CHECK-NEXT:    str wzr, [x21]
36 ; CHECK-NEXT:    ldr x0, [x0]
37 ; CHECK-NEXT:  .Ltmp0:
38 ; CHECK-NEXT:    blr x0
39 ; CHECK-NEXT:  .Ltmp1:
40 ; CHECK-NEXT:  // %bb.1: // %invoke.cont12
41 ; CHECK-NEXT:    str wzr, [x20]
42 ; CHECK-NEXT:    str wzr, [x21]
43 ; CHECK-NEXT:  .LBB0_2: // Block address taken
44 ; CHECK-NEXT:    // %try.cont
45 ; CHECK-NEXT:  $ehgcr_0_2:
46 ; CHECK-NEXT:    .seh_startepilogue
47 ; CHECK-NEXT:    sub sp, x29, #24
48 ; CHECK-NEXT:    .seh_add_fp 24
49 ; CHECK-NEXT:    ldp x29, x30, [sp, #24] // 16-byte Folded Reload
50 ; CHECK-NEXT:    .seh_save_fplr 24
51 ; CHECK-NEXT:    ldr x21, [sp, #16] // 8-byte Folded Reload
52 ; CHECK-NEXT:    .seh_save_reg x21, 16
53 ; CHECK-NEXT:    ldp x19, x20, [sp], #64 // 16-byte Folded Reload
54 ; CHECK-NEXT:    .seh_save_regp_x x19, 64
55 ; CHECK-NEXT:    .seh_endepilogue
56 ; CHECK-NEXT:    ret
57 ; CHECK-NEXT:    .seh_endfunclet
58 ; CHECK-NEXT:    .seh_handlerdata
59 ; CHECK-NEXT:    .word ($cppxdata$osfx)@IMGREL
60 ; CHECK-NEXT:    .section .text,"xr",discard,osfx
61 ; CHECK-NEXT:    .seh_endproc
62 ; CHECK-NEXT:    .def "?catch$3@?0?osfx@4HA";
63 ; CHECK-NEXT:    .scl 3;
64 ; CHECK-NEXT:    .type 32;
65 ; CHECK-NEXT:    .endef
66 ; CHECK-NEXT:    .p2align 2
67 ; CHECK-NEXT:  "?catch$3@?0?osfx@4HA":
68 ; CHECK-NEXT:  .seh_proc "?catch$3@?0?osfx@4HA"
69 ; CHECK-NEXT:    .seh_handler __CxxFrameHandler3, @unwind, @except
70 ; CHECK-NEXT:  .LBB0_3: // %catch
71 ; CHECK-NEXT:    stp x19, x20, [sp, #-48]! // 16-byte Folded Spill
72 ; CHECK-NEXT:    .seh_save_regp_x x19, 48
73 ; CHECK-NEXT:    str x21, [sp, #16] // 8-byte Folded Spill
74 ; CHECK-NEXT:    .seh_save_reg x21, 16
75 ; CHECK-NEXT:    stp x29, x30, [sp, #24] // 16-byte Folded Spill
76 ; CHECK-NEXT:    .seh_save_fplr 24
77 ; CHECK-NEXT:    .seh_endprologue
78 ; CHECK-NEXT:    adrp x0, .LBB0_2
79 ; CHECK-NEXT:    add x0, x0, .LBB0_2
80 ; CHECK-NEXT:    .seh_startepilogue
81 ; CHECK-NEXT:    ldp x29, x30, [sp, #24] // 16-byte Folded Reload
82 ; CHECK-NEXT:    .seh_save_fplr 24
83 ; CHECK-NEXT:    ldr x21, [sp, #16] // 8-byte Folded Reload
84 ; CHECK-NEXT:    .seh_save_reg x21, 16
85 ; CHECK-NEXT:    ldp x19, x20, [sp], #48 // 16-byte Folded Reload
86 ; CHECK-NEXT:    .seh_save_regp_x x19, 48
87 ; CHECK-NEXT:    .seh_endepilogue
88 ; CHECK-NEXT:    ret
89 invoke.cont:
90   %MyAlloca2 = alloca [32 x i8], align 32
91   %0 = ptrtoint ptr %MyAlloca2 to i64
92   store i64 ptrtoint (ptr @osfx to i64), ptr %this
93   %1 = lshr exact i64 %0, 3
94   %2 = inttoptr i64 %1 to ptr
95   store i32 0, ptr %2
96   %vbtable = load ptr, ptr %this
97   %call.i21 = invoke noundef i32 %vbtable(ptr %vbtable)
98           to label %invoke.cont12 unwind label %catch.dispatch
100 invoke.cont12:                                    ; preds = %invoke.cont
101   store i32 0, ptr %this
102   store i32 0, ptr %2
103   br label %try.cont
105 catch.dispatch:                                   ; preds = %invoke.cont
106   %3 = catchswitch within none [label %catch] unwind to caller
108 catch:                                            ; preds = %catch.dispatch
109   %4 = catchpad within %3 [ptr null, i32 64, ptr null]
110   catchret from %4 to label %try.cont
112 try.cont:                                         ; preds = %catch, %invoke.cont12
113   ret void