aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJosh Poimboeuf <jpoimboe@redhat.com>2018-02-20 21:42:14 -0500
committerIngo Molnar <mingo@kernel.org>2018-02-21 10:54:07 -0500
commit0ca7d5baa1787e5f2a7abd6bfca3303b1bbb48ac (patch)
tree866043b4ad57ddfb6fe60eef21ea1b0381e9f36e
parent9fbcc57aa16424ef84cb54e0d9db3221763de88a (diff)
x86/entry/64: Simplify ENCODE_FRAME_POINTER
On 64-bit, the stack pointer is always aligned on interrupt, so instead of setting the LSB of the pt_regs address, we can just add 1 to it. Suggested-by: Linus Torvalds <torvalds@linux-foundation.org> Signed-off-by: Josh Poimboeuf <jpoimboe@redhat.com> Cc: Andrew Lutomirski <luto@kernel.org> Cc: Brian Gerst <brgerst@gmail.com> Cc: Dan Williams <dan.j.williams@intel.com> Cc: Dominik Brodowski <linux@dominikbrodowski.net> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Thomas Gleixner <tglx@linutronix.de> Link: http://lkml.kernel.org/r/20180221024214.lhl5jfgw33c4vz3m@treble Signed-off-by: Ingo Molnar <mingo@kernel.org>
-rw-r--r--arch/x86/entry/calling.h7
1 files changed, 1 insertions, 6 deletions
diff --git a/arch/x86/entry/calling.h b/arch/x86/entry/calling.h
index 5d10b7a85cad..be63330c5511 100644
--- a/arch/x86/entry/calling.h
+++ b/arch/x86/entry/calling.h
@@ -181,12 +181,7 @@ For 32-bit we have the following conventions - kernel is built with
181 */ 181 */
182.macro ENCODE_FRAME_POINTER ptregs_offset=0 182.macro ENCODE_FRAME_POINTER ptregs_offset=0
183#ifdef CONFIG_FRAME_POINTER 183#ifdef CONFIG_FRAME_POINTER
184 .if \ptregs_offset 184 leaq 1+\ptregs_offset(%rsp), %rbp
185 leaq \ptregs_offset(%rsp), %rbp
186 .else
187 mov %rsp, %rbp
188 .endif
189 orq $0x1, %rbp
190#endif 185#endif
191.endm 186.endm
192 187