blob: 630dfed4467c840bd52824e68ba73d9ed3fc2a8e [file] [log] [blame]
Christian Pirker39db7ec2014-05-13 16:44:30 +00001; RUN: llc < %s -mtriple armeb-eabi -mattr v7 -filetype obj -o - | llvm-objdump -s - | FileCheck %s
2
3; ARM EHABI for big endian
4; This test case checks whether frame unwinding instructions are laid out in big endian format.
5;
6; This is the LLVM assembly generated from following C++ code:
7;
8; extern void foo(int);
9; void test(int a, int b) {
10; try {
11; foo(a);
12; } catch (...) {
13; foo(b);
14; }
15;}
16
17define void @_Z4testii(i32 %a, i32 %b) #0 {
18entry:
19 invoke void @_Z3fooi(i32 %a)
20 to label %try.cont unwind label %lpad
21
22lpad: ; preds = %entry
23 %0 = landingpad { i8*, i32 } personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*)
24 catch i8* null
25 %1 = extractvalue { i8*, i32 } %0, 0
26 %2 = tail call i8* @__cxa_begin_catch(i8* %1) #2
27 invoke void @_Z3fooi(i32 %b)
28 to label %invoke.cont2 unwind label %lpad1
29
30invoke.cont2: ; preds = %lpad
31 tail call void @__cxa_end_catch()
32 br label %try.cont
33
34try.cont: ; preds = %entry, %invoke.cont2
35 ret void
36
37lpad1: ; preds = %lpad
38 %3 = landingpad { i8*, i32 } personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*)
39 cleanup
40 invoke void @__cxa_end_catch()
41 to label %eh.resume unwind label %terminate.lpad
42
43eh.resume: ; preds = %lpad1
44 resume { i8*, i32 } %3
45
46terminate.lpad: ; preds = %lpad1
47 %4 = landingpad { i8*, i32 } personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*)
48 catch i8* null
49 %5 = extractvalue { i8*, i32 } %4, 0
50 tail call void @__clang_call_terminate(i8* %5) #3
51 unreachable
52}
53
54declare void @_Z3fooi(i32) #0
55
56declare i32 @__gxx_personality_v0(...)
57
58declare i8* @__cxa_begin_catch(i8*)
59
60declare void @__cxa_end_catch()
61
62; Function Attrs: noinline noreturn nounwind
63define linkonce_odr hidden void @__clang_call_terminate(i8*) #1 {
64 %2 = tail call i8* @__cxa_begin_catch(i8* %0) #2
65 tail call void @_ZSt9terminatev() #3
66 unreachable
67}
68
69declare void @_ZSt9terminatev()
70
71; CHECK-LABEL: Contents of section .ARM.extab:
72; CHECK-NEXT: 0000 00000000 00a8b0b0
73