1
+ ; NOTE: Assertions have been autogenerated by utils/update_mir_test_checks.py
1
2
; RUN: llc -O0 -global-isel -stop-after=irtranslator < %s | FileCheck %s
2
3
3
4
target datalayout = "e-m:e-i8:8:32-i16:16:32-i64:64-i128:128-n32:64-S128"
@@ -6,19 +7,45 @@ target triple = "aarch64-unknown-linux-gnu"
6
7
@.str.2 = private unnamed_addr constant [7 x i8 ] c "Boom!\0A\00 " , align 1
7
8
8
9
define dso_local void @trap () {
10
+ ; CHECK-LABEL: name: trap
11
+ ; CHECK: bb.1.entry:
9
12
entry:
10
13
unreachable
11
14
}
12
15
13
16
define dso_local void @test () personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8* ) {
17
+ ; CHECK-LABEL: name: test
18
+ ; CHECK: bb.1.entry:
19
+ ; CHECK-NEXT: successors: %bb.2(0x40000000), %bb.3(0x40000000)
20
+ ; CHECK-NEXT: {{ $}}
21
+ ; CHECK-NEXT: [[GV:%[0-9]+]]:_(p0) = G_GLOBAL_VALUE @.str.2
22
+ ; CHECK-NEXT: [[COPY:%[0-9]+]]:_(p0) = COPY [[GV]](p0)
23
+ ; CHECK-NEXT: EH_LABEL <mcsymbol >
24
+ ; CHECK-NEXT: INLINEASM &"bl trap", 1 /* sideeffect attdialect */
25
+ ; CHECK-NEXT: EH_LABEL <mcsymbol >
26
+ ; CHECK-NEXT: G_BR %bb.2
27
+ ; CHECK-NEXT: {{ $}}
28
+ ; CHECK-NEXT: bb.2.invoke.cont:
29
+ ; CHECK-NEXT: RET_ReallyLR
30
+ ; CHECK-NEXT: {{ $}}
31
+ ; CHECK-NEXT: bb.3.lpad (landing-pad):
32
+ ; CHECK-NEXT: liveins: $x0, $x1
33
+ ; CHECK-NEXT: {{ $}}
34
+ ; CHECK-NEXT: EH_LABEL <mcsymbol >
35
+ ; CHECK-NEXT: [[DEF:%[0-9]+]]:_(s128) = G_IMPLICIT_DEF
36
+ ; CHECK-NEXT: [[COPY1:%[0-9]+]]:_(p0) = COPY $x0
37
+ ; CHECK-NEXT: [[COPY2:%[0-9]+]]:_(p0) = COPY $x1
38
+ ; CHECK-NEXT: [[PTRTOINT:%[0-9]+]]:_(s32) = G_PTRTOINT [[COPY2]](p0)
39
+ ; CHECK-NEXT: ADJCALLSTACKDOWN 0, 0, implicit-def $sp, implicit $sp
40
+ ; CHECK-NEXT: $x0 = COPY [[COPY]](p0)
41
+ ; CHECK-NEXT: BL @printf, csr_aarch64_aapcs, implicit-def $lr, implicit $sp, implicit $x0
42
+ ; CHECK-NEXT: ADJCALLSTACKUP 0, 0, implicit-def $sp, implicit $sp
43
+ ; CHECK-NEXT: ADJCALLSTACKDOWN 0, 0, implicit-def $sp, implicit $sp
44
+ ; CHECK-NEXT: $x0 = COPY [[COPY1]](p0)
45
+ ; CHECK-NEXT: BL @_Unwind_Resume, csr_aarch64_aapcs, implicit-def $lr, implicit $sp, implicit $x0
46
+ ; CHECK-NEXT: ADJCALLSTACKUP 0, 0, implicit-def $sp, implicit $sp
14
47
entry:
15
48
16
- ; CHECK-LABEL: name: test
17
- ; CHECK: body:
18
- ; CHECK-NEXT: bb.1.entry
19
- ; CHECK: EH_LABEL
20
- ; CHECK-NEXT: INLINEASM
21
- ; CHECK-NEXT: EH_LABEL
22
49
23
50
invoke void asm sideeffect unwind "bl trap" , "" ()
24
51
to label %invoke.cont unwind label %lpad
@@ -27,8 +54,6 @@ invoke.cont:
27
54
ret void
28
55
29
56
lpad:
30
- ; CHECK: bb.3.lpad
31
- ; CHECK: EH_LABEL
32
57
33
58
%0 = landingpad { i8* , i32 }
34
59
cleanup
37
62
38
63
}
39
64
65
+ define void @test2 () #0 personality i32 (...)* @__gcc_personality_v0 {
66
+ ; CHECK-LABEL: name: test2
67
+ ; CHECK: bb.1 (%ir-block.0):
68
+ ; CHECK-NEXT: successors: %bb.2(0x40000000), %bb.3(0x40000000)
69
+ ; CHECK-NEXT: {{ $}}
70
+ ; CHECK-NEXT: [[DEF:%[0-9]+]]:_(p0) = G_IMPLICIT_DEF
71
+ ; CHECK-NEXT: [[COPY:%[0-9]+]]:gpr64common = COPY [[DEF]](p0)
72
+ ; CHECK-NEXT: INLINEASM &"", 1 /* sideeffect attdialect */, 1572873 /* reguse:GPR64common */, [[COPY]]
73
+ ; CHECK-NEXT: G_BR %bb.2
74
+ ; CHECK-NEXT: {{ $}}
75
+ ; CHECK-NEXT: bb.2.a:
76
+ ; CHECK-NEXT: RET_ReallyLR
77
+ ; CHECK-NEXT: {{ $}}
78
+ ; CHECK-NEXT: bb.3.b (landing-pad):
79
+ ; CHECK-NEXT: liveins: $x0, $x1
80
+ ; CHECK-NEXT: {{ $}}
81
+ ; CHECK-NEXT: EH_LABEL <mcsymbol >
82
+ ; CHECK-NEXT: [[DEF1:%[0-9]+]]:_(s128) = G_IMPLICIT_DEF
83
+ ; CHECK-NEXT: [[COPY1:%[0-9]+]]:_(p0) = COPY $x0
84
+ ; CHECK-NEXT: [[COPY2:%[0-9]+]]:_(p0) = COPY $x1
85
+ ; CHECK-NEXT: [[PTRTOINT:%[0-9]+]]:_(s32) = G_PTRTOINT [[COPY2]](p0)
86
+ ; CHECK-NEXT: ADJCALLSTACKDOWN 0, 0, implicit-def $sp, implicit $sp
87
+ ; CHECK-NEXT: $x0 = COPY [[COPY1]](p0)
88
+ ; CHECK-NEXT: BL @_Unwind_Resume, csr_aarch64_aapcs, implicit-def $lr, implicit $sp, implicit $x0
89
+ ; CHECK-NEXT: ADJCALLSTACKUP 0, 0, implicit-def $sp, implicit $sp
90
+ invoke void asm sideeffect "" , "r" (i64* undef ) to label %a unwind label %b
91
+ a:
92
+ ret void
93
+ b:
94
+ %landing_pad = landingpad { i8* , i32 } cleanup
95
+ resume { i8* , i32 } %landing_pad
96
+ }
97
+
98
+ declare i32 @__gcc_personality_v0 (...)
40
99
declare dso_local i32 @__gxx_personality_v0 (...)
41
100
42
101
declare dso_local void @printf (i8* , ...)
0 commit comments