|
@@ -1,23 +1,34 @@
|
|
|
+#ifndef _ASM_X86_FRAME_H
|
|
|
+#define _ASM_X86_FRAME_H
|
|
|
+
|
|
|
#ifdef __ASSEMBLY__
|
|
|
|
|
|
#include <asm/asm.h>
|
|
|
|
|
|
-/* The annotation hides the frame from the unwinder and makes it look
|
|
|
- like a ordinary ebp save/restore. This avoids some special cases for
|
|
|
- frame pointer later */
|
|
|
+/*
|
|
|
+ * These are stack frame creation macros. They should be used by every
|
|
|
+ * callable non-leaf asm function to make kernel stack traces more reliable.
|
|
|
+ */
|
|
|
#ifdef CONFIG_FRAME_POINTER
|
|
|
- .macro FRAME
|
|
|
- __ASM_SIZE(push,) %__ASM_REG(bp)
|
|
|
- __ASM_SIZE(mov) %__ASM_REG(sp), %__ASM_REG(bp)
|
|
|
- .endm
|
|
|
- .macro ENDFRAME
|
|
|
- __ASM_SIZE(pop,) %__ASM_REG(bp)
|
|
|
- .endm
|
|
|
-#else
|
|
|
- .macro FRAME
|
|
|
- .endm
|
|
|
- .macro ENDFRAME
|
|
|
- .endm
|
|
|
-#endif
|
|
|
+
|
|
|
+.macro FRAME_BEGIN
|
|
|
+ push %_ASM_BP
|
|
|
+ _ASM_MOV %_ASM_SP, %_ASM_BP
|
|
|
+.endm
|
|
|
+
|
|
|
+.macro FRAME_END
|
|
|
+ pop %_ASM_BP
|
|
|
+.endm
|
|
|
+
|
|
|
+#define FRAME_OFFSET __ASM_SEL(4, 8)
|
|
|
+
|
|
|
+#else /* !CONFIG_FRAME_POINTER */
|
|
|
+
|
|
|
+#define FRAME_BEGIN
|
|
|
+#define FRAME_END
|
|
|
+#define FRAME_OFFSET 0
|
|
|
+
|
|
|
+#endif /* CONFIG_FRAME_POINTER */
|
|
|
|
|
|
#endif /* __ASSEMBLY__ */
|
|
|
+#endif /* _ASM_X86_FRAME_H */
|