From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932154AbdJJJzt (ORCPT ); Tue, 10 Oct 2017 05:55:49 -0400 Received: from usa-sjc-mx-foss1.foss.arm.com ([217.140.101.70]:41352 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932102AbdJJJzr (ORCPT ); Tue, 10 Oct 2017 05:55:47 -0400 Date: Tue, 10 Oct 2017 10:54:14 +0100 From: Mark Rutland To: "Paul E. McKenney" Cc: linux-kernel@vger.kernel.org Subject: Re: [PATCH 13/13] rcutorture: formal: prepare for ACCESS_ONCE() removal Message-ID: <20171010095413.GE27659@leverpostej> References: <1507573730-8083-1-git-send-email-mark.rutland@arm.com> <1507573730-8083-14-git-send-email-mark.rutland@arm.com> <20171009195112.GL3521@linux.vnet.ibm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20171009195112.GL3521@linux.vnet.ibm.com> User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Oct 09, 2017 at 12:51:12PM -0700, Paul E. McKenney wrote: > On Mon, Oct 09, 2017 at 07:28:50PM +0100, Mark Rutland wrote: > > diff --git a/tools/testing/selftests/rcutorture/formal/srcu-cbmc/src/barriers.h b/tools/testing/selftests/rcutorture/formal/srcu-cbmc/src/barriers.h > > index 6687acc..ee4e4f8 100644 > > --- a/tools/testing/selftests/rcutorture/formal/srcu-cbmc/src/barriers.h > > +++ b/tools/testing/selftests/rcutorture/formal/srcu-cbmc/src/barriers.h > > @@ -34,8 +34,9 @@ > > #define rs_smp_mb() do {} while (0) > > #endif > > > > -#define ACCESS_ONCE(x) (*(volatile typeof(x) *) &(x)) > > -#define READ_ONCE(x) ACCESS_ONCE(x) > > -#define WRITE_ONCE(x, val) (ACCESS_ONCE(x) = (val)) > > +#define __ACCESS_ONCE(x) (*(volatile typeof(x) *) &(x)) > > +#define ACCESS_ONCE(x) __ACCESS_ONCE(x) > > +#define READ_ONCE(x) __ACCESS_ONCE(x) > > +#define WRITE_ONCE(x, val) (__ACCESS_ONCE(x) = (val)) > > How about something like the following? > > #define READ_ONCE(x) (*(volatile typeof(x) *) &(x)) > #define WRITE_ONCE(x) ((*(volatile typeof(x) *) &(x)) = (val)) Sure; folded in and pushed out. :) I've assumed that the ACCESS_ONCE() definition needs to be kept until that's ripped out treewide. Please shout if that's not the case! Thanks, Mark.