|
@@ -0,0 +1,170 @@
|
|
|
+#ifndef _ASM_X86_DWARF2_H
|
|
|
+#define _ASM_X86_DWARF2_H
|
|
|
+
|
|
|
+#ifndef __ASSEMBLY__
|
|
|
+#warning "asm/dwarf2.h should be only included in pure assembly files"
|
|
|
+#endif
|
|
|
+
|
|
|
+/*
|
|
|
+ * Macros for dwarf2 CFI unwind table entries.
|
|
|
+ * See "as.info" for details on these pseudo ops. Unfortunately
|
|
|
+ * they are only supported in very new binutils, so define them
|
|
|
+ * away for older version.
|
|
|
+ */
|
|
|
+
|
|
|
+#ifdef CONFIG_AS_CFI
|
|
|
+
|
|
|
+#define CFI_STARTPROC .cfi_startproc
|
|
|
+#define CFI_ENDPROC .cfi_endproc
|
|
|
+#define CFI_DEF_CFA .cfi_def_cfa
|
|
|
+#define CFI_DEF_CFA_REGISTER .cfi_def_cfa_register
|
|
|
+#define CFI_DEF_CFA_OFFSET .cfi_def_cfa_offset
|
|
|
+#define CFI_ADJUST_CFA_OFFSET .cfi_adjust_cfa_offset
|
|
|
+#define CFI_OFFSET .cfi_offset
|
|
|
+#define CFI_REL_OFFSET .cfi_rel_offset
|
|
|
+#define CFI_REGISTER .cfi_register
|
|
|
+#define CFI_RESTORE .cfi_restore
|
|
|
+#define CFI_REMEMBER_STATE .cfi_remember_state
|
|
|
+#define CFI_RESTORE_STATE .cfi_restore_state
|
|
|
+#define CFI_UNDEFINED .cfi_undefined
|
|
|
+#define CFI_ESCAPE .cfi_escape
|
|
|
+
|
|
|
+#ifdef CONFIG_AS_CFI_SIGNAL_FRAME
|
|
|
+#define CFI_SIGNAL_FRAME .cfi_signal_frame
|
|
|
+#else
|
|
|
+#define CFI_SIGNAL_FRAME
|
|
|
+#endif
|
|
|
+
|
|
|
+#if defined(CONFIG_AS_CFI_SECTIONS) && defined(__ASSEMBLY__)
|
|
|
+ /*
|
|
|
+ * Emit CFI data in .debug_frame sections, not .eh_frame sections.
|
|
|
+ * The latter we currently just discard since we don't do DWARF
|
|
|
+ * unwinding at runtime. So only the offline DWARF information is
|
|
|
+ * useful to anyone. Note we should not use this directive if this
|
|
|
+ * file is used in the vDSO assembly, or if vmlinux.lds.S gets
|
|
|
+ * changed so it doesn't discard .eh_frame.
|
|
|
+ */
|
|
|
+ .cfi_sections .debug_frame
|
|
|
+#endif
|
|
|
+
|
|
|
+#else
|
|
|
+
|
|
|
+/*
|
|
|
+ * Due to the structure of pre-exisiting code, don't use assembler line
|
|
|
+ * comment character # to ignore the arguments. Instead, use a dummy macro.
|
|
|
+ */
|
|
|
+.macro cfi_ignore a=0, b=0, c=0, d=0
|
|
|
+.endm
|
|
|
+
|
|
|
+#define CFI_STARTPROC cfi_ignore
|
|
|
+#define CFI_ENDPROC cfi_ignore
|
|
|
+#define CFI_DEF_CFA cfi_ignore
|
|
|
+#define CFI_DEF_CFA_REGISTER cfi_ignore
|
|
|
+#define CFI_DEF_CFA_OFFSET cfi_ignore
|
|
|
+#define CFI_ADJUST_CFA_OFFSET cfi_ignore
|
|
|
+#define CFI_OFFSET cfi_ignore
|
|
|
+#define CFI_REL_OFFSET cfi_ignore
|
|
|
+#define CFI_REGISTER cfi_ignore
|
|
|
+#define CFI_RESTORE cfi_ignore
|
|
|
+#define CFI_REMEMBER_STATE cfi_ignore
|
|
|
+#define CFI_RESTORE_STATE cfi_ignore
|
|
|
+#define CFI_UNDEFINED cfi_ignore
|
|
|
+#define CFI_ESCAPE cfi_ignore
|
|
|
+#define CFI_SIGNAL_FRAME cfi_ignore
|
|
|
+
|
|
|
+#endif
|
|
|
+
|
|
|
+/*
|
|
|
+ * An attempt to make CFI annotations more or less
|
|
|
+ * correct and shorter. It is implied that you know
|
|
|
+ * what you're doing if you use them.
|
|
|
+ */
|
|
|
+#ifdef __ASSEMBLY__
|
|
|
+#ifdef CONFIG_X86_64
|
|
|
+ .macro pushq_cfi reg
|
|
|
+ pushq \reg
|
|
|
+ CFI_ADJUST_CFA_OFFSET 8
|
|
|
+ .endm
|
|
|
+
|
|
|
+ .macro pushq_cfi_reg reg
|
|
|
+ pushq %\reg
|
|
|
+ CFI_ADJUST_CFA_OFFSET 8
|
|
|
+ CFI_REL_OFFSET \reg, 0
|
|
|
+ .endm
|
|
|
+
|
|
|
+ .macro popq_cfi reg
|
|
|
+ popq \reg
|
|
|
+ CFI_ADJUST_CFA_OFFSET -8
|
|
|
+ .endm
|
|
|
+
|
|
|
+ .macro popq_cfi_reg reg
|
|
|
+ popq %\reg
|
|
|
+ CFI_ADJUST_CFA_OFFSET -8
|
|
|
+ CFI_RESTORE \reg
|
|
|
+ .endm
|
|
|
+
|
|
|
+ .macro pushfq_cfi
|
|
|
+ pushfq
|
|
|
+ CFI_ADJUST_CFA_OFFSET 8
|
|
|
+ .endm
|
|
|
+
|
|
|
+ .macro popfq_cfi
|
|
|
+ popfq
|
|
|
+ CFI_ADJUST_CFA_OFFSET -8
|
|
|
+ .endm
|
|
|
+
|
|
|
+ .macro movq_cfi reg offset=0
|
|
|
+ movq %\reg, \offset(%rsp)
|
|
|
+ CFI_REL_OFFSET \reg, \offset
|
|
|
+ .endm
|
|
|
+
|
|
|
+ .macro movq_cfi_restore offset reg
|
|
|
+ movq \offset(%rsp), %\reg
|
|
|
+ CFI_RESTORE \reg
|
|
|
+ .endm
|
|
|
+#else /*!CONFIG_X86_64*/
|
|
|
+ .macro pushl_cfi reg
|
|
|
+ pushl \reg
|
|
|
+ CFI_ADJUST_CFA_OFFSET 4
|
|
|
+ .endm
|
|
|
+
|
|
|
+ .macro pushl_cfi_reg reg
|
|
|
+ pushl %\reg
|
|
|
+ CFI_ADJUST_CFA_OFFSET 4
|
|
|
+ CFI_REL_OFFSET \reg, 0
|
|
|
+ .endm
|
|
|
+
|
|
|
+ .macro popl_cfi reg
|
|
|
+ popl \reg
|
|
|
+ CFI_ADJUST_CFA_OFFSET -4
|
|
|
+ .endm
|
|
|
+
|
|
|
+ .macro popl_cfi_reg reg
|
|
|
+ popl %\reg
|
|
|
+ CFI_ADJUST_CFA_OFFSET -4
|
|
|
+ CFI_RESTORE \reg
|
|
|
+ .endm
|
|
|
+
|
|
|
+ .macro pushfl_cfi
|
|
|
+ pushfl
|
|
|
+ CFI_ADJUST_CFA_OFFSET 4
|
|
|
+ .endm
|
|
|
+
|
|
|
+ .macro popfl_cfi
|
|
|
+ popfl
|
|
|
+ CFI_ADJUST_CFA_OFFSET -4
|
|
|
+ .endm
|
|
|
+
|
|
|
+ .macro movl_cfi reg offset=0
|
|
|
+ movl %\reg, \offset(%esp)
|
|
|
+ CFI_REL_OFFSET \reg, \offset
|
|
|
+ .endm
|
|
|
+
|
|
|
+ .macro movl_cfi_restore offset reg
|
|
|
+ movl \offset(%esp), %\reg
|
|
|
+ CFI_RESTORE \reg
|
|
|
+ .endm
|
|
|
+#endif /*!CONFIG_X86_64*/
|
|
|
+#endif /*__ASSEMBLY__*/
|
|
|
+
|
|
|
+#endif /* _ASM_X86_DWARF2_H */
|