xen-devel.lists.xenproject.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] xen: always set the sched clock as unstable
@ 2012-04-13 18:20 David Vrabel
  2012-04-13 18:31 ` Sheng Yang
                   ` (3 more replies)
  0 siblings, 4 replies; 24+ messages in thread
From: David Vrabel @ 2012-04-13 18:20 UTC (permalink / raw)
  To: xen-devel
  Cc: David Vrabel, Konrad Rzeszutek Wilk, linux-kernel,
	Thomas Gleixner, Tim Deegan, Jan Beulich, Sheng Yang

From: David Vrabel <david.vrabel@citrix.com>

The sched clock was considered stable based on the capabilities of the
underlying hardware.  This does not make sense for Xen PV guests as:
a) the hardware TSC is not used directly as the clock source; and b)
guests may migrate to hosts with different hardware capabilities.

It is not clear to me whether the Xen clock source is supposed to be
stable and whether it should be stable across migration.  For a clock
source to be stable it must be: a) monotonic; c) synchronized across
CPUs; and c) constant rate.

There have also been reports of systems with apparently unstable
clocks where clearing sched_clock_stable has fixed problems with
migrated VMs hanging.

So, always set the sched clock as unstable when using the Xen clock
source.

Signed-off-by: David Vrabel <david.vrabel@citrix.com>
---
 arch/x86/xen/time.c |    1 +
 1 files changed, 1 insertions(+), 0 deletions(-)

diff --git a/arch/x86/xen/time.c b/arch/x86/xen/time.c
index 0296a95..8469b5a 100644
--- a/arch/x86/xen/time.c
+++ b/arch/x86/xen/time.c
@@ -473,6 +473,7 @@ static void __init xen_time_init(void)
 	do_settimeofday(&tp);
 
 	setup_force_cpu_cap(X86_FEATURE_TSC);
+	sched_clock_stable = 0;
 
 	xen_setup_runstate_info(cpu);
 	xen_setup_timer(cpu);
-- 
1.7.2.5

^ permalink raw reply related	[flat|nested] 24+ messages in thread

end of thread, other threads:[~2012-04-17 15:42 UTC | newest]

Thread overview: 24+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-04-13 18:20 [PATCH] xen: always set the sched clock as unstable David Vrabel
2012-04-13 18:31 ` Sheng Yang
2012-04-13 18:39   ` David Vrabel
2012-04-13 18:33 ` Sheng Yang
2012-04-16 11:32 ` Jan Beulich
     [not found] ` <4F8C1F6D020000780007E11A@nat28.tlf.novell.com>
2012-04-16 14:59   ` David Vrabel
     [not found]   ` <4F8C33E0.2080007@citrix.com>
2012-04-16 15:16     ` Tim Deegan
2012-04-16 15:17     ` Konrad Rzeszutek Wilk
2012-04-16 16:20       ` Dan Magenheimer
2012-04-16 16:05     ` Dan Magenheimer
     [not found]     ` <049b7b93-fb37-4962-b272-d786e1dcfacb@default>
2012-04-16 16:14       ` Jan Beulich
2012-04-16 16:26       ` David Vrabel
2012-04-16 17:08       ` Tim Deegan
     [not found]       ` <4F8C619C020000780007E34E@nat28.tlf.novell.com>
2012-04-16 17:22         ` Dan Magenheimer
     [not found]         ` <84023b26-a682-44b5-990e-1635da6949ff@default>
2012-04-17  7:27           ` Jan Beulich
     [not found]           ` <4F8D3778020000780007E63A@nat28.tlf.novell.com>
2012-04-17 15:36             ` Dan Magenheimer
     [not found]       ` <4F8C4818.8070603@citrix.com>
2012-04-16 17:30         ` Dan Magenheimer
     [not found]         ` <8a78da52-26b2-42a2-80c7-c1ab8aee86eb@default>
2012-04-17  7:47           ` Jan Beulich
     [not found]           ` <4F8D3C4E020000780007E658@nat28.tlf.novell.com>
2012-04-17 15:42             ` Dan Magenheimer
     [not found]       ` <20120416170827.GE13111@ocelot.phlegethon.org>
2012-04-16 17:52         ` Dan Magenheimer
     [not found]         ` <3e05ae0e-afe4-4ed7-b839-39a343cc0d06@default>
2012-04-16 18:17           ` Tim Deegan
     [not found]           ` <20120416181744.GF13111@ocelot.phlegethon.org>
2012-04-16 23:01             ` Sheng Yang
     [not found]             ` <CA+2rt41pCFV1haMAHo63rY9kx88VgiV419pf8Y=u2cXrdmGOBA@mail.gmail.com>
2012-04-17  0:29               ` Dan Magenheimer
2012-04-17  8:19               ` Tim Deegan

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).