On Wed, Oct 18, 2023 at 3:38 PM Roman Gushchin <roman.gushchin@xxxxxxxxx> wrote: > > On Wed, Oct 18, 2023 at 11:26:59AM -0700, Shakeel Butt wrote: > > On Wed, Oct 18, 2023 at 10:22 AM Roman Gushchin > > <roman.gushchin@xxxxxxxxx> wrote: > > > > > [...] > > > > > struct mem_cgroup *memcg; > > > > > @@ -3008,19 +3054,26 @@ __always_inline struct obj_cgroup *get_obj_cgroup_from_current(void) > > > > > > > > > > if (in_task()) { > > > > > memcg = current->active_memcg; > > > > > + if (unlikely(memcg)) > > > > > + goto from_memcg; > > > > > > > > > > - /* Memcg to charge can't be determined. */ > > > > > - if (likely(!memcg) && (!current->mm || (current->flags & PF_KTHREAD))) > > > > > > > > The checks for current->mm and PF_KTHREAD seem to be gone completely after > > > > the patch, was that intended and why? > > > > > > There is no need for those anymore because it's as cheap or cheaper > > > to check task->objcg for being NULL. Those were primarily used to rule out > > > kernel threads allocations early. > > > > > > > I have the same understanding but please correct my suspicions here. > > We can echo the kernel thread's pid to cgroup.procs which have > > PF_NO_SETAFFINITY and thus this will cause the lower bit of the kernel > > thread's task->objcg to be set. Please correct me if I am missing > > something. > > Yes, you seem to be right. It's a gray zone because moving kernel threads out of > the root cgroup doesn't sound like a good idea, but I agree it's better to keep > the old behavior in place. > > Does this fixlet look good to you? > This looks fine. Another option is not to set the bit for such task_structs in fork/attach. > Thanks! > > -- > > diff --git a/mm/memcontrol.c b/mm/memcontrol.c > index 1a2835448028..0b0d2dc7a7d4 100644 > --- a/mm/memcontrol.c > +++ b/mm/memcontrol.c > @@ -3021,6 +3021,10 @@ static struct obj_cgroup *current_objcg_update(void) > old = NULL; > } > > + /* If new objcg is NULL, no reason for the second atomic update. */ > + if (!current->mm || (current->flags & PF_KTHREAD)) > + return NULL; > + > /* > * Release the objcg pointer from the previous iteration, > * if try_cmpxcg() below fails.