Merge branches 'x86-alternatives-for-linus', 'x86-fpu-for-linus', 'x86-hwmon-for...
[GitHub/mt8127/android_kernel_alcatel_ttab.git] / arch / x86 / include / asm / dwarf2.h
1 #ifndef _ASM_X86_DWARF2_H
2 #define _ASM_X86_DWARF2_H
3
4 #ifndef __ASSEMBLY__
5 #warning "asm/dwarf2.h should be only included in pure assembly files"
6 #endif
7
8 /*
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.
13 */
14
15 #ifdef CONFIG_AS_CFI
16
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
30
31 #ifdef CONFIG_AS_CFI_SIGNAL_FRAME
32 #define CFI_SIGNAL_FRAME .cfi_signal_frame
33 #else
34 #define CFI_SIGNAL_FRAME
35 #endif
36
37 #if defined(CONFIG_AS_CFI_SECTIONS) && defined(__ASSEMBLY__)
38 /*
39 * Emit CFI data in .debug_frame sections, not .eh_frame sections.
40 * The latter we currently just discard since we don't do DWARF
41 * unwinding at runtime. So only the offline DWARF information is
42 * useful to anyone. Note we should not use this directive if this
43 * file is used in the vDSO assembly, or if vmlinux.lds.S gets
44 * changed so it doesn't discard .eh_frame.
45 */
46 .cfi_sections .debug_frame
47 #endif
48
49 #else
50
51 /*
52 * Due to the structure of pre-exisiting code, don't use assembler line
53 * comment character # to ignore the arguments. Instead, use a dummy macro.
54 */
55 .macro cfi_ignore a=0, b=0, c=0, d=0
56 .endm
57
58 #define CFI_STARTPROC cfi_ignore
59 #define CFI_ENDPROC cfi_ignore
60 #define CFI_DEF_CFA cfi_ignore
61 #define CFI_DEF_CFA_REGISTER cfi_ignore
62 #define CFI_DEF_CFA_OFFSET cfi_ignore
63 #define CFI_ADJUST_CFA_OFFSET cfi_ignore
64 #define CFI_OFFSET cfi_ignore
65 #define CFI_REL_OFFSET cfi_ignore
66 #define CFI_REGISTER cfi_ignore
67 #define CFI_RESTORE cfi_ignore
68 #define CFI_REMEMBER_STATE cfi_ignore
69 #define CFI_RESTORE_STATE cfi_ignore
70 #define CFI_UNDEFINED cfi_ignore
71 #define CFI_SIGNAL_FRAME cfi_ignore
72
73 #endif
74
75 /*
76 * An attempt to make CFI annotations more or less
77 * correct and shorter. It is implied that you know
78 * what you're doing if you use them.
79 */
80 #ifdef __ASSEMBLY__
81 #ifdef CONFIG_X86_64
82 .macro pushq_cfi reg
83 pushq \reg
84 CFI_ADJUST_CFA_OFFSET 8
85 .endm
86
87 .macro popq_cfi reg
88 popq \reg
89 CFI_ADJUST_CFA_OFFSET -8
90 .endm
91
92 .macro pushfq_cfi
93 pushfq
94 CFI_ADJUST_CFA_OFFSET 8
95 .endm
96
97 .macro popfq_cfi
98 popfq
99 CFI_ADJUST_CFA_OFFSET -8
100 .endm
101
102 .macro movq_cfi reg offset=0
103 movq %\reg, \offset(%rsp)
104 CFI_REL_OFFSET \reg, \offset
105 .endm
106
107 .macro movq_cfi_restore offset reg
108 movq \offset(%rsp), %\reg
109 CFI_RESTORE \reg
110 .endm
111 #else /*!CONFIG_X86_64*/
112 .macro pushl_cfi reg
113 pushl \reg
114 CFI_ADJUST_CFA_OFFSET 4
115 .endm
116
117 .macro popl_cfi reg
118 popl \reg
119 CFI_ADJUST_CFA_OFFSET -4
120 .endm
121
122 .macro pushfl_cfi
123 pushfl
124 CFI_ADJUST_CFA_OFFSET 4
125 .endm
126
127 .macro popfl_cfi
128 popfl
129 CFI_ADJUST_CFA_OFFSET -4
130 .endm
131
132 .macro movl_cfi reg offset=0
133 movl %\reg, \offset(%esp)
134 CFI_REL_OFFSET \reg, \offset
135 .endm
136
137 .macro movl_cfi_restore offset reg
138 movl \offset(%esp), %\reg
139 CFI_RESTORE \reg
140 .endm
141 #endif /*!CONFIG_X86_64*/
142 #endif /*__ASSEMBLY__*/
143
144 #endif /* _ASM_X86_DWARF2_H */