From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Date: Thu, 7 Jun 2012 23:02:49 +0200 From: Andrea Arcangeli To: Linus Torvalds Cc: Josh Boyer , Greg KH , linux-kernel@vger.kernel.org, stable@vger.kernel.org, akpm@linux-foundation.org, alan@lxorguk.ukuu.org.uk, Ulrich Obergfell , Mel Gorman , Hugh Dickins , Larry Woodman , Petr Matousek , Rik van Riel Subject: Re: [ 08/82] mm: pmd_read_atomic: fix 32bit PAE pmd walk vs pmd_populate SMP race condition Message-ID: <20120607210249.GI21339@redhat.com> References: <20120607041406.GA13233@kroah.com> <20120607040337.622672845@linuxfoundation.org> <20120607144204.GD21339@redhat.com> <20120607190414.GF21339@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20120607190414.GF21339@redhat.com> Sender: linux-kernel-owner@vger.kernel.org List-ID: On Thu, Jun 07, 2012 at 09:04:14PM +0200, Andrea Arcangeli wrote: > #ifndef CONFIG_TRANSPARENT_HUGEPAGE > +#define pmd_read_atomic pmd_read_atomic > static inline pmd_t pmd_read_atomic(pmd_t *pmdp) > { > pmdval_t ret; > @@ -74,11 +81,6 @@ static inline pmd_t pmd_read_atomic(pmd_t *pmdp) > > return (pmd_t) { ret }; > } > -#else /* CONFIG_TRANSPARENT_HUGEPAGE */ > -static inline pmd_t pmd_read_atomic(pmd_t *pmdp) > -{ > - return (pmd_t) { atomic64_read((atomic64_t *)pmdp) }; > -} > #endif /* CONFIG_TRANSPARENT_HUGEPAGE */ > > static inline void native_set_pte_atomic(pte_t *ptep, pte_t pte) This actually wasn't safe because if the high part wasn't none and the low part was none, the pmd_none check would fail. I sent an updated version that will fix this hopefully for good and it turns out the same pmd_read_atomic will work for THP=n/y without need of cmpxchg8b even if it's slightly less obviously safe than if we used atomic64_read for THP=y. Still safe that is...