[ARM] Cortex-M4 schedule additions
[llvm-complete.git] / test / CodeGen / ARM / big-endian-eh-unwind.ll
blob7df5f30570ef682c196d976db4a9f29506dbdb14
1 ; RUN: llc < %s -mtriple armeb-eabi -mattr v7 -filetype obj -o - | llvm-objdump -s - | FileCheck %s
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:
8 ; extern void foo(int);
9 ; void test(int a, int b) {
10 ;   try {
11 ;   foo(a);
12 ; } catch (...) {
13 ;   foo(b);
14 ; }
17 define void @_Z4testii(i32 %a, i32 %b) #0 personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*) {
18 entry:
19   invoke void @_Z3fooi(i32 %a)
20           to label %try.cont unwind label %lpad
22 lpad:                                             ; preds = %entry
23   %0 = landingpad { i8*, i32 }
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
30 invoke.cont2:                                     ; preds = %lpad
31   tail call void @__cxa_end_catch()
32   br label %try.cont
34 try.cont:                                         ; preds = %entry, %invoke.cont2
35   ret void
37 lpad1:                                            ; preds = %lpad
38   %3 = landingpad { i8*, i32 }
39           cleanup
40   invoke void @__cxa_end_catch()
41           to label %eh.resume unwind label %terminate.lpad
43 eh.resume:                                        ; preds = %lpad1
44   resume { i8*, i32 } %3
46 terminate.lpad:                                   ; preds = %lpad1
47   %4 = landingpad { i8*, i32 }
48           catch i8* null
49   %5 = extractvalue { i8*, i32 } %4, 0
50   tail call void @__clang_call_terminate(i8* %5) #3
51   unreachable
54 declare void @_Z3fooi(i32) #0
56 declare i32 @__gxx_personality_v0(...)
58 declare i8* @__cxa_begin_catch(i8*)
60 declare void @__cxa_end_catch()
62 ; Function Attrs: noinline noreturn nounwind
63 define 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
69 declare void @_ZSt9terminatev()
71 ; CHECK-LABEL: Contents of section .ARM.extab:
72 ; CHECK-NEXT: 0000 00000000 00a8b0b0