提交 49a69787 编写于 作者: G Glauber de Oliveira Costa 提交者: Ingo Molnar

x86: turn priviled operation into a macro in head_64.S

under paravirt, read cr2 cannot be issued directly anymore.
So wrap it in a macro, defined to the operation itself in case
paravirt is off, but to something else if we have paravirt
in the game
Signed-off-by: NGlauber de Oliveira Costa <gcosta@redhat.com>
Signed-off-by: NSteven Rostedt <rostedt@goodmis.org>
Acked-by: NJeremy Fitzhardinge <jeremy@xensource.com>
Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
Signed-off-by: NIngo Molnar <mingo@elte.hu>
Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
上级 70fd93c9
...@@ -19,6 +19,13 @@ ...@@ -19,6 +19,13 @@
#include <asm/msr.h> #include <asm/msr.h>
#include <asm/cache.h> #include <asm/cache.h>
#ifdef CONFIG_PARAVIRT
#include <asm/asm-offsets.h>
#include <asm/paravirt.h>
#else
#define GET_CR2_INTO_RCX movq %cr2, %rcx
#endif
/* we are not able to switch in one step to the final KERNEL ADRESS SPACE /* we are not able to switch in one step to the final KERNEL ADRESS SPACE
* because we need identity-mapped pages. * because we need identity-mapped pages.
* *
...@@ -267,7 +274,7 @@ ENTRY(early_idt_handler) ...@@ -267,7 +274,7 @@ ENTRY(early_idt_handler)
xorl %eax,%eax xorl %eax,%eax
movq 8(%rsp),%rsi # get rip movq 8(%rsp),%rsi # get rip
movq (%rsp),%rdx movq (%rsp),%rdx
movq %cr2,%rcx GET_CR2_INTO_RCX
leaq early_idt_msg(%rip),%rdi leaq early_idt_msg(%rip),%rdi
call early_printk call early_printk
cmpl $2,early_recursion_flag(%rip) cmpl $2,early_recursion_flag(%rip)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册