Fix ARM unwind opcode assembler in several cases.
[oota-llvm.git] / test / CodeGen / ARM / ehabi-mc.ll
1 ; RUN: llc -mtriple armv7-unknown-linux-gnueabi \
2 ; RUN:     -arm-enable-ehabi -arm-enable-ehabi-descriptors \
3 ; RUN:     -disable-fp-elim -filetype=obj -o - %s \
4 ; RUN:   | llvm-objdump -s - \
5 ; RUN:   | FileCheck %s --check-prefix=CHECK
6
7 ; RUN: llc -mtriple armv7-unknown-linux-gnueabi \
8 ; RUN:     -arm-enable-ehabi -arm-enable-ehabi-descriptors \
9 ; RUN:     -filetype=obj -o - %s \
10 ; RUN:   | llvm-objdump -s - \
11 ; RUN:   | FileCheck %s --check-prefix=CHECK-FP-ELIM
12
13 define void @_Z4testiiiiiddddd(i32 %u1, i32 %u2, i32 %u3, i32 %u4, i32 %u5, double %v1, double %v2, double %v3, double %v4, double %v5) {
14 entry:
15   invoke void @_Z5printiiiii(i32 %u1, i32 %u2, i32 %u3, i32 %u4, i32 %u5)
16           to label %try.cont unwind label %lpad
17
18 lpad:                                             ; preds = %entry
19   %0 = landingpad { i8*, i32 } personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*)
20           catch i8* null
21   %1 = extractvalue { i8*, i32 } %0, 0
22   %2 = tail call i8* @__cxa_begin_catch(i8* %1) nounwind
23   invoke void @_Z5printddddd(double %v1, double %v2, double %v3, double %v4, double %v5)
24           to label %invoke.cont2 unwind label %lpad1
25
26 invoke.cont2:                                     ; preds = %lpad
27   tail call void @__cxa_end_catch()
28   br label %try.cont
29
30 try.cont:                                         ; preds = %entry, %invoke.cont2
31   ret void
32
33 lpad1:                                            ; preds = %lpad
34   %3 = landingpad { i8*, i32 } personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*)
35           cleanup
36   invoke void @__cxa_end_catch()
37           to label %eh.resume unwind label %terminate.lpad
38
39 eh.resume:                                        ; preds = %lpad1
40   resume { i8*, i32 } %3
41
42 terminate.lpad:                                   ; preds = %lpad1
43   %4 = landingpad { i8*, i32 } personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*)
44           catch i8* null
45   tail call void @_ZSt9terminatev() noreturn nounwind
46   unreachable
47 }
48
49 declare void @_Z5printiiiii(i32, i32, i32, i32, i32)
50
51 declare i32 @__gxx_personality_v0(...)
52
53 declare i8* @__cxa_begin_catch(i8*)
54
55 declare void @_Z5printddddd(double, double, double, double, double)
56
57 declare void @__cxa_end_catch()
58
59 declare void @_ZSt9terminatev()
60
61 ; CHECK: section .text
62 ; CHECK: section .ARM.extab
63 ; CHECK-NEXT: 0000 00000000 c94a9b01 b0818484
64 ; CHECK: section .ARM.exidx
65 ; CHECK-NEXT: 0000 00000000 00000000
66
67 ; CHECK-FP-ELIM: section .text
68 ; CHECK-FP-ELIM: section .ARM.extab
69 ; CHECK-FP-ELIM-NEXT: 0000 00000000 84c90501 b0b0b0a8
70 ; CHECK-FP-ELIM: section .ARM.exidx
71 ; CHECK-FP-ELIM-NEXT: 0000 00000000 00000000