From mboxrd@z Thu Jan 1 00:00:00 1970 From: Peter Zijlstra Subject: Re: [PATCH 1/5] Add a global synchronization point for pvclock Date: Mon, 19 Apr 2010 12:43:56 +0200 Message-ID: <1271673836.1674.757.camel@laptop> References: <1271356648-5108-1-git-send-email-glommer@redhat.com> <1271356648-5108-2-git-send-email-glommer@redhat.com> <4BCA026D.3070309@redhat.com> <4BCA02D1.2020608@redhat.com> Mime-Version: 1.0 Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit Cc: Glauber Costa , kvm@vger.kernel.org, linux-kernel@vger.kernel.org, Jeremy Fitzhardinge , Marcelo Tosatti , Zachary Amsden To: Avi Kivity Return-path: Received: from casper.infradead.org ([85.118.1.10]:58604 "EHLO casper.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753549Ab0DSKn7 (ORCPT ); Mon, 19 Apr 2010 06:43:59 -0400 Received: from f199130.upc-f.chello.nl ([80.56.199.130] helo=dyad.programming.kicks-ass.net) by casper.infradead.org with esmtpsa (Exim 4.69 #1 (Red Hat Linux)) id 1O3oSM-0006jN-Jy for kvm@vger.kernel.org; Mon, 19 Apr 2010 10:43:58 +0000 In-Reply-To: <4BCA02D1.2020608@redhat.com> Sender: kvm-owner@vger.kernel.org List-ID: On Sat, 2010-04-17 at 21:49 +0300, Avi Kivity wrote: > On 04/17/2010 09:48 PM, Avi Kivity wrote: > > > >> > >> +static u64 last_value = 0; > > > > Needs to be atomic64_t. > > > >> + > >> cycle_t pvclock_clocksource_read(struct pvclock_vcpu_time_info *src) > >> { > >> struct pvclock_shadow_time shadow; > >> unsigned version; > >> cycle_t ret, offset; > >> + u64 last; > >> > >> > >> + do { > >> + last = last_value; > > > > Otherwise, this assignment can see a partial update. > > On a 32-bit guest, that is. Right, do bear in mind that the x86 implementation of atomic64_read() is terrifyingly expensive, it is better to not do that read and simply use the result of the cmpxchg.