On Tue, 2017-08-01 at 11:31 +0100, Will Deacon wrote: > Looks like that's what's currently relied upon: > > /* Clearing is done after a TLB flush, which also provides a barrier. */ > > It also provides barrier semantics on arm/arm64. In reality, I suspect > all archs have to provide some order between set_pte_at and flush_tlb_range > which is sufficient to hold up clearing the flag. :/
Hrm... not explicitely. Most archs (powerpc among them) have set_pte_at be just a dumb store, so the only barrier it has is the surrounding PTL. Now flush_tlb_range() I assume has some internal strong barriers but none of that is well defined or documented at all, so I suspect all bets are off. Ben.