From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1764266AbXHHIdj (ORCPT ); Wed, 8 Aug 2007 04:33:39 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1757438AbXHHId3 (ORCPT ); Wed, 8 Aug 2007 04:33:29 -0400 Received: from 207.47.19.6.static.nextweb.net ([207.47.19.6]:19451 "EHLO ex1.resilience.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1757406AbXHHId2 (ORCPT ); Wed, 8 Aug 2007 04:33:28 -0400 Date: Wed, 8 Aug 2007 16:27:55 +0800 From: Jerry Jiang To: Chris Snook Cc: Chris Friesen , Zan Lynx , "Robert P. J. Day" , Linux Kernel Mailing List Subject: Re: why are some atomic_t's not volatile, while most are? Message-Id: <20070808162755.61f50fbf.wjiang@resilience.com> In-Reply-To: <46B96719.3050006@redhat.com> References: <20070806123551.a6c3c154.wjiang@resilience.com> <46B72C58.5030502@redhat.com> <46B894E4.4010501@nortel.com> <46B8D6D7.2020206@redhat.com> <46B8DDF3.7050008@nortel.com> <46B8E1D3.8050501@redhat.com> <46B8E64E.7010708@nortel.com> <1186525977.232321.43.camel@localhost> <46B91D0C.5050704@redhat.com> <46B94B94.6000600@nortel.com> <46B96719.3050006@redhat.com> Organization: Resilience X-Mailer: Sylpheed version 2.3.0beta5 (GTK+ 2.8.20; i486-pc-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit X-OriginalArrivalTime: 08 Aug 2007 08:33:15.0796 (UTC) FILETIME=[C3E0CD40:01C7D996] Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org On Wed, 08 Aug 2007 02:47:53 -0400 Chris Snook wrote: > Chris Friesen wrote: > > Chris Snook wrote: > > > >> This is not a problem, since indirect references will cause the CPU to > >> fetch the data from memory/cache anyway. > > > > Isn't Zan's sample code (that shows the problem) already using indirect > > references? > > Yeah, I misinterpreted his conclusion. I thought about this for a > while, and realized that it's perfectly legal for the compiler to re-use > a value obtained from atomic_read. All that matters is that the read > itself was atomic. The use (or non-use) of the volatile keyword is > really more relevant to the other atomic operations. If you want to > guarantee a re-read from memory, use barrier(). This, incidentally, > uses volatile under the hood. > So for example, without volatile int a = read_atomic(v); int b = read_atomic(v); the compiler will optimize it as b = a, But with volatile, it will be forced to fetch v's value from memory again. So, come back our initial question, include/asm-v850/atomic.h:typedef struct { int counter; } atomic_t; Why is it right without volatile? -- Jerry > -- Chris