[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <47266B90.8000008@vmware.com>
Date: Mon, 29 Oct 2007 16:24:00 -0700
From: Dan Hecht <dhecht@...are.com>
To: Ingo Molnar <mingo@...e.hu>
CC: Zachary Amsden <zach@...are.com>,
Glauber de Oliveira Costa <gcosta@...hat.com>,
linux-kernel@...r.kernel.org, tglx@...utronix.de,
rusty@...tcorp.com.au, jeremy@...p.org, --cc@...hat.com,
avi@...amnet.com, kvm-devel@...ts.sourceforge.net,
Glauber de Oliveira Costa <glauber@....localdomain>,
Garrett Smith <garrett@...are.com>
Subject: Re: [PATCH] raise tsc clocksource rating
On 10/29/2007 04:02 PM, Ingo Molnar wrote:
> * Zachary Amsden <zach@...are.com> wrote:
>
>> On Mon, 2007-10-29 at 23:48 +0100, Ingo Molnar wrote:
>>> * Zachary Amsden <zach@...are.com> wrote:
>>> if it's inaccurate why are you exposing it to the guest then? Native
>>> only uses the TSC if it's safe and accurate to do so.
>> Not every guest support paravirt, but for correctness, all guests
>> require TSC, which must be exposed all the way up to userspace, no
>> matter what the efficiency or accuracy may be.
>
> but if there's a perfect TSC available (there is such hardware) then the
> TSC _is_ the best clocksource. Paravirt now turns it off unconditionally
> in essence.
>
Not really. In the case hardware TSC is perfect, the paravirt time
counter can be implemented directly in terms of hardware TSC; there is
no loss in optimization. This is done transparently. And virtual TSC
can be implemented this way too.
The real improvement that a paravirt clocksource offers over the TSC
clocksource is that the guest does not need to measure the TSC frequency
itself against some other constant frequency source (which is
problematic on a virtual machine). Instead, the paravirt clocksource
queries the hypervisor for the frequency of the counter. As you know,
with clocksource style kernels, it's important to get this frequency
correct, or else the guest will have long-term time drift.
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists