On Sat, Jan 30, 2021 at 04:11:20PM -0800, Nadav Amit wrote: > +static inline void tlb_update_generation(atomic64_t *gen, u64 new_gen) > +{ > + u64 cur_gen = atomic64_read(gen); > + > + while (cur_gen < new_gen) { > + u64 old_gen = atomic64_cmpxchg(gen, cur_gen, new_gen); > + > + /* Check if we succeeded in the cmpxchg */ > + if (likely(cur_gen == old_gen)) > + break; > + > + cur_gen = old_gen; > + }; > +} u64 cur_gen = atomic64_read(gen); while (cur_gen < new_gen && !atomic64_try_cmpxchg(gen, &cur_gen, new_gen)) ;