public inbox for kvm@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH 0/3 - resend] kvmclock reboot
@ 2008-03-18 10:30 Glauber Costa
  2008-03-18 10:30 ` [PATCH 1/3] [PATCH] allow machine_crash_shutdown to be replaced Glauber Costa
  2008-03-18 10:52 ` [PATCH 0/3 - resend] kvmclock reboot Avi Kivity
  0 siblings, 2 replies; 8+ messages in thread
From: Glauber Costa @ 2008-03-18 10:30 UTC (permalink / raw)
  To: kvm-devel; +Cc: akpm, avi, virtualization

Avi,

Hope this series is okay now.

Thanks for the testing



-------------------------------------------------------------------------
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] 8+ messages in thread

* [PATCH 1/3] [PATCH] allow machine_crash_shutdown to be replaced
  2008-03-18 10:30 [PATCH 0/3 - resend] kvmclock reboot Glauber Costa
@ 2008-03-18 10:30 ` Glauber Costa
  2008-03-18 10:30   ` [PATCH 2/3] [PATCH] make native_machine_shutdown non-static Glauber Costa
  2008-03-18 10:52 ` [PATCH 0/3 - resend] kvmclock reboot Avi Kivity
  1 sibling, 1 reply; 8+ messages in thread
From: Glauber Costa @ 2008-03-18 10:30 UTC (permalink / raw)
  To: kvm-devel; +Cc: avi, Glauber Costa, akpm, virtualization

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 |   11 ++++++++++-
 include/asm-x86/reboot.h |    1 +
 3 files changed, 13 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/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..ea95f11 100644
--- a/arch/x86/kernel/reboot.c
+++ b/arch/x86/kernel/reboot.c
@@ -453,7 +453,10 @@ 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,
+#ifdef CONFIG_KEXEC
+	.crash_shutdown = native_machine_crash_shutdown,
+#endif
 };
 
 void machine_power_off(void)
@@ -481,3 +484,9 @@ void machine_halt(void)
 	machine_ops.halt();
 }
 
+#ifdef CONFIG_KEXEC
+void machine_crash_shutdown(struct pt_regs *regs)
+{
+	machine_ops.crash_shutdown(regs);
+}
+#endif
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.5.0.6


-------------------------------------------------------------------------
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] 8+ messages in thread

* [PATCH 2/3] [PATCH] make native_machine_shutdown non-static
  2008-03-18 10:30 ` [PATCH 1/3] [PATCH] allow machine_crash_shutdown to be replaced Glauber Costa
@ 2008-03-18 10:30   ` Glauber Costa
  2008-03-18 10:30     ` [PATCH 3/3] [PATCH] disable clock before rebooting Glauber Costa
  0 siblings, 1 reply; 8+ messages in thread
From: Glauber Costa @ 2008-03-18 10:30 UTC (permalink / raw)
  To: kvm-devel; +Cc: avi, Glauber Costa, akpm, virtualization

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 ea95f11..7215de6 100644
--- a/arch/x86/kernel/reboot.c
+++ b/arch/x86/kernel/reboot.c
@@ -382,7 +382,7 @@ static void native_machine_emergency_restart(void)
 	}
 }
 
-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.5.0.6


-------------------------------------------------------------------------
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] 8+ messages in thread

* [PATCH 3/3] [PATCH] disable clock before rebooting.
  2008-03-18 10:30   ` [PATCH 2/3] [PATCH] make native_machine_shutdown non-static Glauber Costa
@ 2008-03-18 10:30     ` Glauber Costa
  0 siblings, 0 replies; 8+ messages in thread
From: Glauber Costa @ 2008-03-18 10:30 UTC (permalink / raw)
  To: kvm-devel; +Cc: avi, Glauber Costa, akpm, virtualization

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 |   27 +++++++++++++++++++++++++++
 1 files changed, 27 insertions(+), 0 deletions(-)

diff --git a/arch/x86/kernel/kvmclock.c b/arch/x86/kernel/kvmclock.c
index b999f5e..ddee040 100644
--- a/arch/x86/kernel/kvmclock.c
+++ b/arch/x86/kernel/kvmclock.c
@@ -22,6 +22,7 @@
 #include <asm/msr.h>
 #include <asm/apic.h>
 #include <linux/percpu.h>
+#include <asm/reboot.h>
 
 #define KVM_SCALE 22
 
@@ -143,6 +144,28 @@ static void kvm_setup_secondary_clock(void)
 	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
+ */
+#ifdef CONFIG_KEXEC
+static void kvm_crash_shutdown(struct pt_regs *regs)
+{
+	native_write_msr_safe(MSR_KVM_SYSTEM_TIME, 0, 0);
+	native_machine_crash_shutdown(regs);
+}
+#endif
+
+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 +178,10 @@ 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;
+#ifdef CONFIG_KEXEC
+		machine_ops.crash_shutdown  = kvm_crash_shutdown;
+#endif
 		clocksource_register(&kvm_clock);
 	}
 }
-- 
1.5.0.6


-------------------------------------------------------------------------
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] 8+ messages in thread

* Re: [PATCH 0/3 - resend] kvmclock reboot
  2008-03-18 10:30 [PATCH 0/3 - resend] kvmclock reboot Glauber Costa
  2008-03-18 10:30 ` [PATCH 1/3] [PATCH] allow machine_crash_shutdown to be replaced Glauber Costa
@ 2008-03-18 10:52 ` Avi Kivity
  2008-03-18 10:55   ` Glauber Costa
  1 sibling, 1 reply; 8+ messages in thread
From: Avi Kivity @ 2008-03-18 10:52 UTC (permalink / raw)
  To: Glauber Costa; +Cc: kvm-devel, akpm, virtualization

Glauber Costa wrote:
> Avi,
>
> Hope this series is okay now.
>
> Thanks for the testing
>
>
>   

Applied, thanks.

[Once a patchset has been applied and pushed (as seen on kvm-commits), I 
prefer incremental patches]

-- 
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] 8+ messages in thread

* Re: [PATCH 0/3 - resend] kvmclock reboot
  2008-03-18 10:52 ` [PATCH 0/3 - resend] kvmclock reboot Avi Kivity
@ 2008-03-18 10:55   ` Glauber Costa
  2008-03-18 11:00     ` Avi Kivity
  0 siblings, 1 reply; 8+ messages in thread
From: Glauber Costa @ 2008-03-18 10:55 UTC (permalink / raw)
  To: Avi Kivity; +Cc: kvm-devel, akpm, virtualization

Avi Kivity wrote:
> Glauber Costa wrote:
>> Avi,
>>
>> Hope this series is okay now.
>>
>> Thanks for the testing
>>
>>
>>   
> 
> Applied, thanks.
> 
> [Once a patchset has been applied and pushed (as seen on kvm-commits), I 
> prefer incremental patches]
> 
But I think this is a very good case of an exception, since the applied 
patches would break bisect. I prefer to hear "damn glommer!" because of 
that than "damn glommer!!" because of a broken bisect.

-------------------------------------------------------------------------
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] 8+ messages in thread

* Re: [PATCH 0/3 - resend] kvmclock reboot
  2008-03-18 10:55   ` Glauber Costa
@ 2008-03-18 11:00     ` Avi Kivity
  2008-03-18 11:02       ` Glauber Costa
  0 siblings, 1 reply; 8+ messages in thread
From: Avi Kivity @ 2008-03-18 11:00 UTC (permalink / raw)
  To: Glauber Costa; +Cc: kvm-devel, akpm, virtualization

Glauber Costa wrote:
>>
>> [Once a patchset has been applied and pushed (as seen on 
>> kvm-commits), I prefer incremental patches]
>>
> But I think this is a very good case of an exception, since the 
> applied patches would break bisect. I prefer to hear "damn glommer!" 
> because of that than "damn glommer!!" because of a broken bisect.

I fold them up before sending to Linus anyway, so upstream bisect 
continues to work.  For kvm.git, it's a choice between rewinding it a 
bit (which may confuse anyone who pulls) and breaking bisect.


-- 
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] 8+ messages in thread

* Re: [PATCH 0/3 - resend] kvmclock reboot
  2008-03-18 11:00     ` Avi Kivity
@ 2008-03-18 11:02       ` Glauber Costa
  0 siblings, 0 replies; 8+ messages in thread
From: Glauber Costa @ 2008-03-18 11:02 UTC (permalink / raw)
  To: Avi Kivity; +Cc: kvm-devel, akpm, virtualization

Avi Kivity wrote:
> Glauber Costa wrote:
>>>
>>> [Once a patchset has been applied and pushed (as seen on 
>>> kvm-commits), I prefer incremental patches]
>>>
>> But I think this is a very good case of an exception, since the 
>> applied patches would break bisect. I prefer to hear "damn glommer!" 
>> because of that than "damn glommer!!" because of a broken bisect.
> 
> I fold them up before sending to Linus anyway, so upstream bisect 
> continues to work.  For kvm.git, it's a choice between rewinding it a 
> bit (which may confuse anyone who pulls) and breaking bisect.
> 
> 
ok, this wfm. I'll send incrementally next time.

-------------------------------------------------------------------------
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] 8+ messages in thread

end of thread, other threads:[~2008-03-18 11:02 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-03-18 10:30 [PATCH 0/3 - resend] kvmclock reboot Glauber Costa
2008-03-18 10:30 ` [PATCH 1/3] [PATCH] allow machine_crash_shutdown to be replaced Glauber Costa
2008-03-18 10:30   ` [PATCH 2/3] [PATCH] make native_machine_shutdown non-static Glauber Costa
2008-03-18 10:30     ` [PATCH 3/3] [PATCH] disable clock before rebooting Glauber Costa
2008-03-18 10:52 ` [PATCH 0/3 - resend] kvmclock reboot Avi Kivity
2008-03-18 10:55   ` Glauber Costa
2008-03-18 11:00     ` Avi Kivity
2008-03-18 11:02       ` Glauber Costa

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox