On Tue, 2017-08-01 at 18:48 +0200, Peter Zijlstra wrote: > On Tue, Aug 01, 2017 at 05:44:14PM +0100, Will Deacon wrote: > > On Tue, Aug 01, 2017 at 06:39:03PM +0200, Peter Zijlstra wrote: > > > Still this is all rather unsatisfactory. Either we should define > > > flush_tlb*() to imply a barrier when its not a no-op (sparc64/ppc-hash) > > > or simply make clear_tlb_flush_pending() an smp_store_release(). > > > > > > I prefer the latter option. > > > > > > Opinions? > > > > I prefer the latter option too, since I'd like to relax the arm64 TLB > > flushing to have weaker barriers for the local case. Granted, that doesn't > > break the NUMA migration code, but it would make the barrier semantics of > > the TLB invalidation routines even more subtle if we were to define them > > generally. > > Another 'fun' question, is smp_mb() strong enough to order against the > TLB invalidate? Because we really want to clear this flag _after_. > > PowerPC for example uses PTESYNC before the TBLIE, so does a SYNC after > work? Ben?
I have no idea. But then our tlbie has a ptesync after too no ? And afaik a ptesync is a superset of sync. Cheers, Ben.

