Implement AsmParser for ARM unwind directives.
[oota-llvm.git] / test / MC / ARM / eh-directive-handlerdata.s
1 @ RUN: llvm-mc %s -triple=armv7-unknown-linux-gnueabi -filetype=obj -o - \
2 @ RUN:   | llvm-readobj -s -sd -sr | FileCheck %s
3
4 @ Check the .handlerdata directive (without .personality directive)
5
6         .syntax unified
7
8 @-------------------------------------------------------------------------------
9 @ TEST1
10 @-------------------------------------------------------------------------------
11         .section        .TEST1
12         .globl  func1
13         .align  2
14         .type   func1,%function
15         .fnstart
16 func1:
17         bx      lr
18         .handlerdata
19         .fnend
20
21
22 @ CHECK:Section {
23 @ CHECK:  Name: .TEST1
24 @ CHECK:  SectionData (
25 @ CHECK:    0000: 1EFF2FE1                             |../.|
26 @ CHECK:  )
27 @ CHECK:}
28
29 @ CHECK:Section {
30 @ CHECK:  Name: .ARM.extab.TEST1
31 @ CHECK:  SectionData (
32 @ CHECK:    0000: B0B0B080                             |....|
33 @ CHECK:  )
34 @ CHECK:}
35
36 @ CHECK:Section {
37 @ CHECK:  Name: .ARM.exidx.TEST1
38 @-------------------------------------------------------------------------------
39 @ We should see a relocation entry to __aeabi_unwind_cpp_pr0, so that the
40 @ linker can keep __aeabi_unwind_cpp_pr0.
41 @-------------------------------------------------------------------------------
42 @ CHECK:  Relocations [
43 @ CHECK:    0x0 R_ARM_PREL31 .TEST1 0x0
44 @ CHECK:    0x0 R_ARM_NONE __aeabi_unwind_cpp_pr0 0x0
45 @ CHECK:    0x4 R_ARM_PREL31 .ARM.extab.TEST1 0x0
46 @ CHECK:  ]
47 @ CHECK:  SectionData (
48 @ CHECK:    0000: 00000000 00000000                    |........|
49 @ CHECK:  )
50 @ CHECK:}
51
52
53
54
55 @-------------------------------------------------------------------------------
56 @ TEST2
57 @-------------------------------------------------------------------------------
58         .section        .TEST2
59         .globl  func2
60         .align  2
61         .type   func2,%function
62         .fnstart
63 func2:
64 @-------------------------------------------------------------------------------
65 @ Use a lot of unwind opcdes to get __aeabi_unwind_cpp_pr1.
66 @-------------------------------------------------------------------------------
67         .save   {r4, r5, r6, r7, r8, r9, r10, r11, r12}
68         push    {r4, r5, r6, r7, r8, r9, r10, r11, r12}
69         pop     {r4, r5, r6, r7, r8, r9, r10, r11, r12}
70         .pad    #0x240
71         sub     sp, sp, #0x240
72         add     sp, sp, #0x240
73         bx      lr
74         .handlerdata
75         .fnend
76
77
78
79 @ CHECK:Section {
80 @ CHECK:  Name: .TEST2
81 @ CHECK:  SectionData (
82 @ CHECK:    0000: F01F2DE9 F01FBDE8 09DD4DE2 09DD8DE2  |..-.......M.....|
83 @ CHECK:    0010: 1EFF2FE1                             |../.|
84 @ CHECK:  )
85 @ CHECK:}
86
87 @ CHECK:Section {
88 @ CHECK:  Name: .ARM.extab.TEST2
89 @ CHECK:  SectionData (
90 @ CHECK:    0000: 0FB20181 B0B0FF81                    |........|
91 @ CHECK:  )
92 @ CHECK:}
93
94 @ CHECK:Section {
95 @ CHECK:  Name: .ARM.exidx.TEST2
96 @-------------------------------------------------------------------------------
97 @ We should see a relocation entry to __aeabi_unwind_cpp_pr0, so that the
98 @ linker can keep __aeabi_unwind_cpp_pr0.
99 @-------------------------------------------------------------------------------
100 @ CHECK:  Relocations [
101 @ CHECK:    0x0 R_ARM_PREL31 .TEST2 0x0
102 @ CHECK:    0x0 R_ARM_NONE __aeabi_unwind_cpp_pr1 0x0
103 @ CHECK:    0x4 R_ARM_PREL31 .ARM.extab.TEST2 0x0
104 @ CHECK:  ]
105 @ CHECK:  SectionData (
106 @ CHECK:    0000: 00000000 00000000                    |........|
107 @ CHECK:  )
108 @ CHECK:}