From mboxrd@z Thu Jan 1 00:00:00 1970 From: Avi Kivity Subject: Re: [PATCH 01/18] Make TSC offset writes non-preemptible Date: Sun, 18 Jul 2010 17:30:38 +0300 Message-ID: <4C43100E.20707@redhat.com> References: <1278987938-23873-1-git-send-email-zamsden@redhat.com> <1278987938-23873-2-git-send-email-zamsden@redhat.com> Mime-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Cc: KVM , Marcelo Tosatti , Glauber Costa , Linux-kernel To: Zachary Amsden Return-path: Received: from mx1.redhat.com ([209.132.183.28]:19884 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755516Ab0GROak (ORCPT ); Sun, 18 Jul 2010 10:30:40 -0400 In-Reply-To: <1278987938-23873-2-git-send-email-zamsden@redhat.com> Sender: kvm-owner@vger.kernel.org List-ID: On 07/13/2010 05:25 AM, Zachary Amsden wrote: > > +void guest_write_tsc(struct kvm_vcpu *vcpu, u64 data) > +{ > + struct kvm *kvm = vcpu->kvm; > + u64 offset; > + > + spin_lock(&kvm->arch.tsc_write_lock); > Perhaps spin_lock_irq() for even more accuracy? spin_lock_irq_nmi_smi_hypervisor(), if you can find it. > + offset = data - native_read_tsc(); > + kvm_x86_ops->write_tsc_offset(vcpu, offset); > + spin_unlock(&kvm->arch.tsc_write_lock); > + > + /* Reset of TSC must disable overshoot protection below */ > + vcpu->arch.hv_clock.tsc_timestamp = 0; > +} > +EXPORT_SYMBOL_GPL(guest_write_tsc); > + > -- error compiling committee.c: too many arguments to function