From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail-wg0-f42.google.com (mail-wg0-f42.google.com [74.125.82.42]) by kanga.kvack.org (Postfix) with ESMTP id E34916B0032 for ; Thu, 15 Jan 2015 04:26:50 -0500 (EST) Received: by mail-wg0-f42.google.com with SMTP id k14so13703545wgh.1 for ; Thu, 15 Jan 2015 01:26:50 -0800 (PST) Received: from mx2.suse.de (cantor2.suse.de. [195.135.220.15]) by mx.google.com with ESMTPS id p10si1705679wjx.72.2015.01.15.01.26.50 for (version=TLSv1 cipher=ECDHE-RSA-RC4-SHA bits=128/128); Thu, 15 Jan 2015 01:26:50 -0800 (PST) Message-ID: <54B787D7.7040202@suse.com> Date: Thu, 15 Jan 2015 10:26:47 +0100 From: =?windows-1252?Q?J=FCrgen_Gro=DF?= MIME-Version: 1.0 Subject: Re: [PATCH 3/8] x86/xen/p2m: Replace ACCESS_ONCE with READ_ONCE References: <1421312314-72330-1-git-send-email-borntraeger@de.ibm.com> <1421312314-72330-4-git-send-email-borntraeger@de.ibm.com> In-Reply-To: <1421312314-72330-4-git-send-email-borntraeger@de.ibm.com> Content-Type: text/plain; charset=windows-1252; format=flowed Content-Transfer-Encoding: 7bit Sender: owner-linux-mm@kvack.org List-ID: To: Christian Borntraeger , linux-kernel@vger.kernel.org Cc: linux-arch@vger.kernel.org, kvm@vger.kernel.org, kvm-ppc@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, x86@kernel.org, xen-devel@lists.xenproject.org, linux-mm@kvack.org On 01/15/2015 09:58 AM, Christian Borntraeger wrote: > ACCESS_ONCE does not work reliably on non-scalar types. For > example gcc 4.6 and 4.7 might remove the volatile tag for such > accesses during the SRA (scalar replacement of aggregates) step > (https://gcc.gnu.org/bugzilla/show_bug.cgi?id=58145) > > Change the p2m code to replace ACCESS_ONCE with READ_ONCE. > > Signed-off-by: Christian Borntraeger Reviewed-by: Juergen Gross > --- > arch/x86/xen/p2m.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/arch/x86/xen/p2m.c b/arch/x86/xen/p2m.c > index edbc7a6..cb71016 100644 > --- a/arch/x86/xen/p2m.c > +++ b/arch/x86/xen/p2m.c > @@ -554,7 +554,7 @@ static bool alloc_p2m(unsigned long pfn) > mid_mfn = NULL; > } > > - p2m_pfn = pte_pfn(ACCESS_ONCE(*ptep)); > + p2m_pfn = pte_pfn(READ_ONCE(*ptep)); > if (p2m_pfn == PFN_DOWN(__pa(p2m_identity)) || > p2m_pfn == PFN_DOWN(__pa(p2m_missing))) { > /* p2m leaf page is missing */ > -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: email@kvack.org