]>
Commit | Line | Data |
---|---|---|
1965aae3 PA |
1 | #ifndef _ASM_X86_DWARF2_H |
2 | #define _ASM_X86_DWARF2_H | |
392a0fc9 GC |
3 | |
4 | #ifndef __ASSEMBLY__ | |
5 | #warning "asm/dwarf2.h should be only included in pure assembly files" | |
6 | #endif | |
7 | ||
8 | /* | |
8a2503fa CG |
9 | * Macros for dwarf2 CFI unwind table entries. |
10 | * See "as.info" for details on these pseudo ops. Unfortunately | |
11 | * they are only supported in very new binutils, so define them | |
12 | * away for older version. | |
392a0fc9 GC |
13 | */ |
14 | ||
15 | #ifdef CONFIG_AS_CFI | |
16 | ||
8a2503fa CG |
17 | #define CFI_STARTPROC .cfi_startproc |
18 | #define CFI_ENDPROC .cfi_endproc | |
19 | #define CFI_DEF_CFA .cfi_def_cfa | |
20 | #define CFI_DEF_CFA_REGISTER .cfi_def_cfa_register | |
21 | #define CFI_DEF_CFA_OFFSET .cfi_def_cfa_offset | |
22 | #define CFI_ADJUST_CFA_OFFSET .cfi_adjust_cfa_offset | |
23 | #define CFI_OFFSET .cfi_offset | |
24 | #define CFI_REL_OFFSET .cfi_rel_offset | |
25 | #define CFI_REGISTER .cfi_register | |
26 | #define CFI_RESTORE .cfi_restore | |
27 | #define CFI_REMEMBER_STATE .cfi_remember_state | |
28 | #define CFI_RESTORE_STATE .cfi_restore_state | |
29 | #define CFI_UNDEFINED .cfi_undefined | |
eab9e613 | 30 | #define CFI_ESCAPE .cfi_escape |
392a0fc9 GC |
31 | |
32 | #ifdef CONFIG_AS_CFI_SIGNAL_FRAME | |
8a2503fa | 33 | #define CFI_SIGNAL_FRAME .cfi_signal_frame |
392a0fc9 GC |
34 | #else |
35 | #define CFI_SIGNAL_FRAME | |
36 | #endif | |
37 | ||
9e565292 RM |
38 | #if defined(CONFIG_AS_CFI_SECTIONS) && defined(__ASSEMBLY__) |
39 | /* | |
40 | * Emit CFI data in .debug_frame sections, not .eh_frame sections. | |
41 | * The latter we currently just discard since we don't do DWARF | |
42 | * unwinding at runtime. So only the offline DWARF information is | |
43 | * useful to anyone. Note we should not use this directive if this | |
44 | * file is used in the vDSO assembly, or if vmlinux.lds.S gets | |
45 | * changed so it doesn't discard .eh_frame. | |
46 | */ | |
47 | .cfi_sections .debug_frame | |
48 | #endif | |
49 | ||
96a388de | 50 | #else |
392a0fc9 | 51 | |
8a2503fa CG |
52 | /* |
53 | * Due to the structure of pre-exisiting code, don't use assembler line | |
54 | * comment character # to ignore the arguments. Instead, use a dummy macro. | |
55 | */ | |
3f1c3872 | 56 | .macro cfi_ignore a=0, b=0, c=0, d=0 |
392a0fc9 GC |
57 | .endm |
58 | ||
8a2503fa CG |
59 | #define CFI_STARTPROC cfi_ignore |
60 | #define CFI_ENDPROC cfi_ignore | |
61 | #define CFI_DEF_CFA cfi_ignore | |
3f1c3872 KW |
62 | #define CFI_DEF_CFA_REGISTER cfi_ignore |
63 | #define CFI_DEF_CFA_OFFSET cfi_ignore | |
64 | #define CFI_ADJUST_CFA_OFFSET cfi_ignore | |
8a2503fa CG |
65 | #define CFI_OFFSET cfi_ignore |
66 | #define CFI_REL_OFFSET cfi_ignore | |
67 | #define CFI_REGISTER cfi_ignore | |
68 | #define CFI_RESTORE cfi_ignore | |
69 | #define CFI_REMEMBER_STATE cfi_ignore | |
70 | #define CFI_RESTORE_STATE cfi_ignore | |
71 | #define CFI_UNDEFINED cfi_ignore | |
eab9e613 | 72 | #define CFI_ESCAPE cfi_ignore |
8a2503fa | 73 | #define CFI_SIGNAL_FRAME cfi_ignore |
392a0fc9 GC |
74 | |
75 | #endif | |
76 | ||
8a2503fa CG |
77 | /* |
78 | * An attempt to make CFI annotations more or less | |
79 | * correct and shorter. It is implied that you know | |
80 | * what you're doing if you use them. | |
81 | */ | |
82 | #ifdef __ASSEMBLY__ | |
83 | #ifdef CONFIG_X86_64 | |
84 | .macro pushq_cfi reg | |
85 | pushq \reg | |
86 | CFI_ADJUST_CFA_OFFSET 8 | |
87 | .endm | |
88 | ||
49db46a6 DV |
89 | .macro pushq_cfi_reg reg |
90 | pushq %\reg | |
91 | CFI_ADJUST_CFA_OFFSET 8 | |
92 | CFI_REL_OFFSET \reg, 0 | |
93 | .endm | |
94 | ||
8a2503fa CG |
95 | .macro popq_cfi reg |
96 | popq \reg | |
97 | CFI_ADJUST_CFA_OFFSET -8 | |
98 | .endm | |
99 | ||
49db46a6 DV |
100 | .macro popq_cfi_reg reg |
101 | popq %\reg | |
102 | CFI_ADJUST_CFA_OFFSET -8 | |
103 | CFI_RESTORE \reg | |
104 | .endm | |
105 | ||
df5d1874 JB |
106 | .macro pushfq_cfi |
107 | pushfq | |
108 | CFI_ADJUST_CFA_OFFSET 8 | |
109 | .endm | |
110 | ||
111 | .macro popfq_cfi | |
112 | popfq | |
113 | CFI_ADJUST_CFA_OFFSET -8 | |
114 | .endm | |
115 | ||
8a2503fa CG |
116 | .macro movq_cfi reg offset=0 |
117 | movq %\reg, \offset(%rsp) | |
118 | CFI_REL_OFFSET \reg, \offset | |
119 | .endm | |
120 | ||
121 | .macro movq_cfi_restore offset reg | |
122 | movq \offset(%rsp), %\reg | |
123 | CFI_RESTORE \reg | |
124 | .endm | |
125 | #else /*!CONFIG_X86_64*/ | |
fe9b4e4e PA |
126 | .macro pushl_cfi reg |
127 | pushl \reg | |
128 | CFI_ADJUST_CFA_OFFSET 4 | |
129 | .endm | |
8a2503fa | 130 | |
49db46a6 DV |
131 | .macro pushl_cfi_reg reg |
132 | pushl %\reg | |
133 | CFI_ADJUST_CFA_OFFSET 4 | |
134 | CFI_REL_OFFSET \reg, 0 | |
135 | .endm | |
136 | ||
fe9b4e4e PA |
137 | .macro popl_cfi reg |
138 | popl \reg | |
139 | CFI_ADJUST_CFA_OFFSET -4 | |
140 | .endm | |
8a2503fa | 141 | |
49db46a6 DV |
142 | .macro popl_cfi_reg reg |
143 | popl %\reg | |
144 | CFI_ADJUST_CFA_OFFSET -4 | |
145 | CFI_RESTORE \reg | |
146 | .endm | |
147 | ||
df5d1874 JB |
148 | .macro pushfl_cfi |
149 | pushfl | |
150 | CFI_ADJUST_CFA_OFFSET 4 | |
151 | .endm | |
152 | ||
153 | .macro popfl_cfi | |
154 | popfl | |
155 | CFI_ADJUST_CFA_OFFSET -4 | |
156 | .endm | |
157 | ||
fe9b4e4e PA |
158 | .macro movl_cfi reg offset=0 |
159 | movl %\reg, \offset(%esp) | |
160 | CFI_REL_OFFSET \reg, \offset | |
161 | .endm | |
162 | ||
163 | .macro movl_cfi_restore offset reg | |
164 | movl \offset(%esp), %\reg | |
165 | CFI_RESTORE \reg | |
166 | .endm | |
8a2503fa CG |
167 | #endif /*!CONFIG_X86_64*/ |
168 | #endif /*__ASSEMBLY__*/ | |
169 | ||
1965aae3 | 170 | #endif /* _ASM_X86_DWARF2_H */ |