* [PATCH 0/3] kvmclock: shutdown clock before reboot
@ 2008-03-17 19:08 Glauber Costa
2008-03-17 19:08 ` [PATCH 1/3] allow machine_crash_shutdown to be replaced Glauber Costa
2008-03-18 6:47 ` [PATCH 0/3] kvmclock: shutdown clock before reboot Avi Kivity
0 siblings, 2 replies; 6+ messages in thread
From: Glauber Costa @ 2008-03-17 19:08 UTC (permalink / raw)
To: kvm-devel; +Cc: avi
Avi,
This series now apply ontop of kvm.git.
Only the needed function from machine_ops is made non-static.
-------------------------------------------------------------------------
This SF.net email is sponsored by: Microsoft
Defy all challenges. Microsoft(R) Visual Studio 2008.
http://clk.atdmt.com/MRT/go/vse0120000070mrt/direct/01/
^ permalink raw reply [flat|nested] 6+ messages in thread
* [PATCH 1/3] allow machine_crash_shutdown to be replaced
2008-03-17 19:08 [PATCH 0/3] kvmclock: shutdown clock before reboot Glauber Costa
@ 2008-03-17 19:08 ` Glauber Costa
2008-03-17 19:08 ` [PATCH 2/3] make native_machine_shutdown non-static Glauber Costa
2008-03-18 6:47 ` [PATCH 0/3] kvmclock: shutdown clock before reboot Avi Kivity
1 sibling, 1 reply; 6+ messages in thread
From: Glauber Costa @ 2008-03-17 19:08 UTC (permalink / raw)
To: kvm-devel; +Cc: avi, Glauber Costa
This patch a llows machine_crash_shutdown to
be replaced, just like any of the other functions
in machine_ops
Signed-off-by: Glauber Costa <gcosta@redhat.com>
---
arch/x86/kernel/crash.c | 3 ++-
arch/x86/kernel/reboot.c | 7 ++++++-
include/asm-x86/reboot.h | 1 +
3 files changed, 9 insertions(+), 2 deletions(-)
diff --git a/arch/x86/kernel/crash.c b/arch/x86/kernel/crash.c
index 9a5fa0a..d262306 100644
--- a/arch/x86/kernel/crash.c
+++ b/arch/x86/kernel/crash.c
@@ -25,6 +25,7 @@ #include <asm/apic.h>
#include <asm/hpet.h>
#include <linux/kdebug.h>
#include <asm/smp.h>
+#include <asm/reboot.h>
#ifdef CONFIG_X86_32
#include <mach_ipi.h>
@@ -121,7 +122,7 @@ static void nmi_shootdown_cpus(void)
}
#endif
-void machine_crash_shutdown(struct pt_regs *regs)
+void native_machine_crash_shutdown(struct pt_regs *regs)
{
/* This function is only called after the system
* has panicked or is otherwise in a critical state.
diff --git a/arch/x86/kernel/reboot.c b/arch/x86/kernel/reboot.c
index 55ceb8c..bb21078 100644
--- a/arch/x86/kernel/reboot.c
+++ b/arch/x86/kernel/reboot.c
@@ -453,7 +453,8 @@ struct machine_ops machine_ops = {
.shutdown = native_machine_shutdown,
.emergency_restart = native_machine_emergency_restart,
.restart = native_machine_restart,
- .halt = native_machine_halt
+ .halt = native_machine_halt,
+ .crash_shutdown = native_machine_crash_shutdown,
};
void machine_power_off(void)
@@ -481,3 +482,7 @@ void machine_halt(void)
machine_ops.halt();
}
+void machine_crash_shutdown(struct pt_regs *regs)
+{
+ machine_ops.crash_shutdown(regs);
+}
diff --git a/include/asm-x86/reboot.h b/include/asm-x86/reboot.h
index e9e3ffc..ff9b546 100644
--- a/include/asm-x86/reboot.h
+++ b/include/asm-x86/reboot.h
@@ -16,5 +16,6 @@ struct machine_ops
extern struct machine_ops machine_ops;
void machine_real_restart(unsigned char *code, int length);
+void native_machine_crash_shutdown(struct pt_regs *regs);
#endif /* _ASM_REBOOT_H */
--
1.4.2
-------------------------------------------------------------------------
This SF.net email is sponsored by: Microsoft
Defy all challenges. Microsoft(R) Visual Studio 2008.
http://clk.atdmt.com/MRT/go/vse0120000070mrt/direct/01/
^ permalink raw reply related [flat|nested] 6+ messages in thread
* [PATCH 2/3] make native_machine_shutdown non-static
2008-03-17 19:08 ` [PATCH 1/3] allow machine_crash_shutdown to be replaced Glauber Costa
@ 2008-03-17 19:08 ` Glauber Costa
2008-03-17 19:08 ` [PATCH 3/3] disable clock before rebooting Glauber Costa
0 siblings, 1 reply; 6+ messages in thread
From: Glauber Costa @ 2008-03-17 19:08 UTC (permalink / raw)
To: kvm-devel; +Cc: avi, Glauber Costa
it will allow external users to call it. It is mainly
useful for routines that will override its machine_ops
field for its own special purposes, but want to call the
normal shutdown routine after they're done
Signed-off-by: Glauber Costa <gcosta@redhat.com>
---
arch/x86/kernel/reboot.c | 2 +-
include/asm-x86/reboot.h | 1 +
2 files changed, 2 insertions(+), 1 deletions(-)
diff --git a/arch/x86/kernel/reboot.c b/arch/x86/kernel/reboot.c
index bb21078..bb3ee86 100644
--- a/arch/x86/kernel/reboot.c
+++ b/arch/x86/kernel/reboot.c
@@ -382,7 +382,7 @@ #endif
}
}
-static void native_machine_shutdown(void)
+void native_machine_shutdown(void)
{
/* Stop the cpus and apics */
#ifdef CONFIG_SMP
diff --git a/include/asm-x86/reboot.h b/include/asm-x86/reboot.h
index ff9b546..c5e8722 100644
--- a/include/asm-x86/reboot.h
+++ b/include/asm-x86/reboot.h
@@ -17,5 +17,6 @@ extern struct machine_ops machine_ops;
void machine_real_restart(unsigned char *code, int length);
void native_machine_crash_shutdown(struct pt_regs *regs);
+void native_machine_shutdown(void);
#endif /* _ASM_REBOOT_H */
--
1.4.2
-------------------------------------------------------------------------
This SF.net email is sponsored by: Microsoft
Defy all challenges. Microsoft(R) Visual Studio 2008.
http://clk.atdmt.com/MRT/go/vse0120000070mrt/direct/01/
^ permalink raw reply related [flat|nested] 6+ messages in thread
* [PATCH 3/3] disable clock before rebooting.
2008-03-17 19:08 ` [PATCH 2/3] make native_machine_shutdown non-static Glauber Costa
@ 2008-03-17 19:08 ` Glauber Costa
0 siblings, 0 replies; 6+ messages in thread
From: Glauber Costa @ 2008-03-17 19:08 UTC (permalink / raw)
To: kvm-devel; +Cc: avi, Glauber Costa
This patch writes 0 (actually, what really matters is that the
LSB is cleared) to the system time msr before shutting down
the machine for kexec.
Without it, we can have a random memory location being written
when the guest comes back
It overrides the functions shutdown, used in the path of kernel_kexec() (sys.c)
and crash_shutdown, used in the path of crash_kexec() (kexec.c)
Signed-off-by: Glauber Costa <gcosta@redhat.com>
---
arch/x86/kernel/kvmclock.c | 23 +++++++++++++++++++++++
1 files changed, 23 insertions(+), 0 deletions(-)
diff --git a/arch/x86/kernel/kvmclock.c b/arch/x86/kernel/kvmclock.c
index b999f5e..d47734a 100644
--- a/arch/x86/kernel/kvmclock.c
+++ b/arch/x86/kernel/kvmclock.c
@@ -22,6 +22,7 @@ #include <asm/arch_hooks.h>
#include <asm/msr.h>
#include <asm/apic.h>
#include <linux/percpu.h>
+#include <asm/reboot.h>
#define KVM_SCALE 22
@@ -143,6 +144,26 @@ static void kvm_setup_secondary_clock(vo
setup_secondary_APIC_clock();
}
+/*
+ * After the clock is registered, the host will keep writing to the
+ * registered memory location. If the guest happens to shutdown, this memory
+ * won't be valid. In cases like kexec, in which you install a new kernel, this
+ * means a random memory location will be kept being written. So before any
+ * kind of shutdown from our side, we unregister the clock by writting anything
+ * that does not have the 'enable' bit set in the msr
+ */
+static void kvm_crash_shutdown(struct pt_regs *regs)
+{
+ native_write_msr_safe(MSR_KVM_SYSTEM_TIME, 0, 0);
+ native_machine_crash_shutdown(regs);
+}
+
+static void kvm_shutdown(void)
+{
+ native_write_msr_safe(MSR_KVM_SYSTEM_TIME, 0, 0);
+ native_machine_shutdown();
+}
+
void __init kvmclock_init(void)
{
if (!kvm_para_available())
@@ -155,6 +176,8 @@ void __init kvmclock_init(void)
pv_time_ops.set_wallclock = kvm_set_wallclock;
pv_time_ops.sched_clock = kvm_clock_read;
pv_apic_ops.setup_secondary_clock = kvm_setup_secondary_clock;
+ machine_ops.shutdown = kvm_shutdown;
+ machine_ops.crash_shutdown = kvm_crash_shutdown;
clocksource_register(&kvm_clock);
}
}
--
1.4.2
-------------------------------------------------------------------------
This SF.net email is sponsored by: Microsoft
Defy all challenges. Microsoft(R) Visual Studio 2008.
http://clk.atdmt.com/MRT/go/vse0120000070mrt/direct/01/
^ permalink raw reply related [flat|nested] 6+ messages in thread
* Re: [PATCH 0/3] kvmclock: shutdown clock before reboot
2008-03-17 19:08 [PATCH 0/3] kvmclock: shutdown clock before reboot Glauber Costa
2008-03-17 19:08 ` [PATCH 1/3] allow machine_crash_shutdown to be replaced Glauber Costa
@ 2008-03-18 6:47 ` Avi Kivity
2008-03-18 7:20 ` Avi Kivity
1 sibling, 1 reply; 6+ messages in thread
From: Avi Kivity @ 2008-03-18 6:47 UTC (permalink / raw)
To: Glauber Costa; +Cc: kvm-devel
Glauber Costa wrote:
> Avi,
>
> This series now apply ontop of kvm.git.
> Only the needed function from machine_ops is made non-static.
>
>
Applied, thanks.
Ingo, can you carry the first two patches as well? They are
602ac559a208ba44d5879a8e6381a379b376a8b7 and
0c7f95e535a02caba52f944f067fbc05a0608cc1 in kvm.git
(git://git.kernel.org/pub/scm/linux/kernel/git/avi/kvm.git).
--
Do not meddle in the internals of kernels, for they are subtle and quick to panic.
-------------------------------------------------------------------------
This SF.net email is sponsored by: Microsoft
Defy all challenges. Microsoft(R) Visual Studio 2008.
http://clk.atdmt.com/MRT/go/vse0120000070mrt/direct/01/
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH 0/3] kvmclock: shutdown clock before reboot
2008-03-18 6:47 ` [PATCH 0/3] kvmclock: shutdown clock before reboot Avi Kivity
@ 2008-03-18 7:20 ` Avi Kivity
0 siblings, 0 replies; 6+ messages in thread
From: Avi Kivity @ 2008-03-18 7:20 UTC (permalink / raw)
To: Glauber Costa; +Cc: kvm-devel
Avi Kivity wrote:
> Glauber Costa wrote:
>> Avi,
>>
>> This series now apply ontop of kvm.git.
>> Only the needed function from machine_ops is made non-static.
>>
>>
>
> Applied, thanks.
Er, compilation breaks if CONFIG_KEXEC is not set (i386).
--
Do not meddle in the internals of kernels, for they are subtle and quick to panic.
-------------------------------------------------------------------------
This SF.net email is sponsored by: Microsoft
Defy all challenges. Microsoft(R) Visual Studio 2008.
http://clk.atdmt.com/MRT/go/vse0120000070mrt/direct/01/
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2008-03-18 7:20 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-03-17 19:08 [PATCH 0/3] kvmclock: shutdown clock before reboot Glauber Costa
2008-03-17 19:08 ` [PATCH 1/3] allow machine_crash_shutdown to be replaced Glauber Costa
2008-03-17 19:08 ` [PATCH 2/3] make native_machine_shutdown non-static Glauber Costa
2008-03-17 19:08 ` [PATCH 3/3] disable clock before rebooting Glauber Costa
2008-03-18 6:47 ` [PATCH 0/3] kvmclock: shutdown clock before reboot Avi Kivity
2008-03-18 7:20 ` Avi Kivity
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox