On Tue, Dec 14, 2021 at 9:50 PM Johannes Weiner <hannes@xxxxxxxxxxx> wrote: > > On Tue, Dec 14, 2021 at 12:53:27AM +0800, Muchun Song wrote: > > +/* > > + * The allocated list lru pointers array is not accounted directly. > > + * Moreover, it should not come from DMA buffer and is not readily > > + * reclaimable. So those GFP bits should be masked off. > > + */ > > +#define LRUS_CLEAR_MASK (__GFP_DMA | __GFP_RECLAIMABLE | __GFP_ACCOUNT | __GFP_ZERO) > > There is already GFP_RECLAIM_MASK for this purpose, you can use that. Cool. Thanks. > > > +int memcg_list_lru_alloc(struct mem_cgroup *memcg, struct list_lru *lru, > > + gfp_t gfp) > > +{ > > + int i; > > + unsigned long flags; > > + struct list_lru_memcg *mlrus; > > + struct list_lru_memcg_table { > > + struct list_lru_per_memcg *mlru; > > + struct mem_cgroup *memcg; > > + } *table; > > + > > + if (!list_lru_memcg_aware(lru) || memcg_list_lru_allocated(memcg, lru)) > > + return 0; > > + > > + gfp &= ~LRUS_CLEAR_MASK; > > gfp &= GFP_RECLAIM_MASK;