From: Michal Hocko <mhocko@suse.com>
To: Oleg Nesterov <oleg@redhat.com>
Cc: Andrew Morton <akpm@linux-foundation.org>,
Christian Brauner <brauner@kernel.org>,
"Eric W. Biederman" <ebiederm@xmission.com>,
Jens Axboe <axboe@kernel.dk>,
Jinliang Zheng <alexjlzheng@tencent.com>,
Mateusz Guzik <mjguzik@gmail.com>,
Matthew Wilcox <willy@infradead.org>,
Tycho Andersen <tandersen@netflix.com>,
linux-kernel@vger.kernel.org
Subject: Re: [PATCH 2/2] memcg: mm_update_next_owner: move for_each_thread() into try_to_set_owner()
Date: Thu, 27 Jun 2024 11:02:47 +0200 [thread overview]
Message-ID: <Zn0qt4KY8S4E65IM@tiehlicka> (raw)
In-Reply-To: <20240626152930.GA17936@redhat.com>
On Wed 26-06-24 17:29:30, Oleg Nesterov wrote:
> mm_update_next_owner() checks the children / real_parent->children to
> avoid the "everything else" loop in the likely case, but this won't work
> if a child/sibling has a zombie leader with ->mm == NULL.
>
> Move the for_each_thread() logic into try_to_set_owner(), if nothing else
> this makes the children/siblings/everything searches more consistent.
>
> Signed-off-by: Oleg Nesterov <oleg@redhat.com>
Acked-by: Michal Hocko <mhocko@suse.com>
> ---
> kernel/exit.c | 40 ++++++++++++++++++++++++----------------
> 1 file changed, 24 insertions(+), 16 deletions(-)
>
> diff --git a/kernel/exit.c b/kernel/exit.c
> index a1ef5f23d5be..cc56edc1103e 100644
> --- a/kernel/exit.c
> +++ b/kernel/exit.c
> @@ -440,7 +440,7 @@ static void coredump_task_exit(struct task_struct *tsk)
>
> #ifdef CONFIG_MEMCG
> /* drops tasklist_lock if succeeds */
> -static bool try_to_set_owner(struct task_struct *tsk, struct mm_struct *mm)
> +static bool __try_to_set_owner(struct task_struct *tsk, struct mm_struct *mm)
> {
> bool ret = false;
>
> @@ -456,12 +456,28 @@ static bool try_to_set_owner(struct task_struct *tsk, struct mm_struct *mm)
> return ret;
> }
>
> +static bool try_to_set_owner(struct task_struct *g, struct mm_struct *mm)
> +{
> + struct task_struct *t;
> +
> + for_each_thread(g, t) {
> + struct mm_struct *t_mm = READ_ONCE(t->mm);
> + if (t_mm == mm) {
> + if (__try_to_set_owner(t, mm))
> + return true;
> + } else if (t_mm)
> + break;
> + }
> +
> + return false;
> +}
> +
> /*
> * A task is exiting. If it owned this mm, find a new owner for the mm.
> */
> void mm_update_next_owner(struct mm_struct *mm)
> {
> - struct task_struct *c, *g, *p = current;
> + struct task_struct *g, *p = current;
>
> /*
> * If the exiting or execing task is not the owner, it's
> @@ -483,19 +499,17 @@ void mm_update_next_owner(struct mm_struct *mm)
> /*
> * Search in the children
> */
> - list_for_each_entry(c, &p->children, sibling) {
> - if (c->mm == mm && try_to_set_owner(c, mm))
> + list_for_each_entry(g, &p->children, sibling) {
> + if (try_to_set_owner(g, mm))
> goto ret;
> }
> -
> /*
> * Search in the siblings
> */
> - list_for_each_entry(c, &p->real_parent->children, sibling) {
> - if (c->mm == mm && try_to_set_owner(c, mm))
> + list_for_each_entry(g, &p->real_parent->children, sibling) {
> + if (try_to_set_owner(g, mm))
> goto ret;
> }
> -
> /*
> * Search through everything else, we should not get here often.
> */
> @@ -504,14 +518,8 @@ void mm_update_next_owner(struct mm_struct *mm)
> break;
> if (g->flags & PF_KTHREAD)
> continue;
> - for_each_thread(g, c) {
> - struct mm_struct *c_mm = READ_ONCE(c->mm);
> - if (c_mm == mm) {
> - if (try_to_set_owner(c, mm))
> - goto ret;
> - } else if (c_mm)
> - break;
> - }
> + if (try_to_set_owner(g, mm))
> + goto ret;
> }
> read_unlock(&tasklist_lock);
> /*
> --
> 2.25.1.362.g51ebf55
--
Michal Hocko
SUSE Labs
next prev parent reply other threads:[~2024-06-27 9:02 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-06-26 15:28 [PATCH -mm 0/2] memcg: deuglify mm_update_next_owner() Oleg Nesterov
2024-06-26 15:29 ` [PATCH 1/2] memcg: mm_update_next_owner: kill the "retry" logic Oleg Nesterov
2024-06-27 7:56 ` Michal Hocko
2024-06-27 8:29 ` Oleg Nesterov
2024-06-27 9:02 ` Michal Hocko
2024-06-26 15:29 ` [PATCH 2/2] memcg: mm_update_next_owner: move for_each_thread() into try_to_set_owner() Oleg Nesterov
2024-06-27 9:02 ` Michal Hocko [this message]
2024-06-26 19:24 ` [PATCH -mm 0/2] memcg: deuglify mm_update_next_owner() Andrew Morton
2024-06-26 20:27 ` Oleg Nesterov
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=Zn0qt4KY8S4E65IM@tiehlicka \
--to=mhocko@suse.com \
--cc=akpm@linux-foundation.org \
--cc=alexjlzheng@tencent.com \
--cc=axboe@kernel.dk \
--cc=brauner@kernel.org \
--cc=ebiederm@xmission.com \
--cc=linux-kernel@vger.kernel.org \
--cc=mjguzik@gmail.com \
--cc=oleg@redhat.com \
--cc=tandersen@netflix.com \
--cc=willy@infradead.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.