123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147 |
- #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 popq_cfi reg
- popq \reg
- CFI_ADJUST_CFA_OFFSET -8
- .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 popl_cfi reg
- popl \reg
- CFI_ADJUST_CFA_OFFSET -4
- .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 */
|