From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-8.5 required=3.0 tests=INCLUDES_PATCH, MAILING_LIST_MULTI,SIGNED_OFF_BY,SPF_HELO_NONE,SPF_PASS,USER_AGENT_SANE_1 autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 9E069C4CED1 for ; Fri, 4 Oct 2019 08:14:17 +0000 (UTC) Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by mail.kernel.org (Postfix) with ESMTP id 6CDBA2084D for ; Fri, 4 Oct 2019 08:14:16 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 6CDBA2084D Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=kernel.org Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=owner-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix) id 2812E6B0003; Fri, 4 Oct 2019 04:14:16 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 231806B0005; Fri, 4 Oct 2019 04:14:16 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 147B18E0003; Fri, 4 Oct 2019 04:14:16 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0223.hostedemail.com [216.40.44.223]) by kanga.kvack.org (Postfix) with ESMTP id E07496B0003 for ; Fri, 4 Oct 2019 04:14:15 -0400 (EDT) Received: from smtpin14.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay05.hostedemail.com (Postfix) with SMTP id 3AD56181AC9AE for ; Fri, 4 Oct 2019 08:14:15 +0000 (UTC) X-FDA: 76005389670.14.noise35_7c6872b46b332 X-HE-Tag: noise35_7c6872b46b332 X-Filterd-Recvd-Size: 3412 Received: from mx1.suse.de (mx2.suse.de [195.135.220.15]) by imf40.hostedemail.com (Postfix) with ESMTP for ; Fri, 4 Oct 2019 08:14:14 +0000 (UTC) X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.220.254]) by mx1.suse.de (Postfix) with ESMTP id 6495EB16B; Fri, 4 Oct 2019 08:14:12 +0000 (UTC) Date: Fri, 4 Oct 2019 10:13:58 +0200 From: Michal Hocko To: Qian Cai Cc: akpm@linux-foundation.org, cl@linux.com, penberg@kernel.org, rientjes@google.com, tj@kernel.org, vdavydov.dev@gmail.com, hannes@cmpxchg.org, guro@fb.com, linux-mm@kvack.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH] mm/slub: fix a deadlock in show_slab_objects() Message-ID: <20191004081358.GA9578@dhcp22.suse.cz> References: <1570131869-2545-1-git-send-email-cai@lca.pw> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1570131869-2545-1-git-send-email-cai@lca.pw> User-Agent: Mutt/1.10.1 (2018-07-13) X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: On Thu 03-10-19 15:44:29, Qian Cai wrote: > Long time ago, there fixed a similar deadlock in show_slab_objects() > [1]. However, it is apparently due to the commits like 01fb58bcba63 > ("slab: remove synchronous synchronize_sched() from memcg cache > deactivation path") and 03afc0e25f7f ("slab: get_online_mems for > kmem_cache_{create,destroy,shrink}"), this kind of deadlock is back by > just reading files in /sys/kernel/slab will generate a lockdep splat > below. > > Since the "mem_hotplug_lock" here is only to obtain a stable online node > mask while racing with NUMA node hotplug, it is probably fine to do > without it. "It is probably fine" is not a proper justification. Please have a look at my older email where I've exaplained why I believe it is safe. > WARNING: possible circular locking dependency detected > ------------------------------------------------------ I pressume the deadlock is real. If that is the case then Cc: stable and Fixes tag would be really appreciated. > Signed-off-by: Qian Cai Anyway, I do agree that this is the right thing to do. With the improved changelog, fixed up the comment alignment feel free to add Acked-by: Michal Hocko > --- > mm/slub.c | 11 +++++++++-- > 1 file changed, 9 insertions(+), 2 deletions(-) > > diff --git a/mm/slub.c b/mm/slub.c > index 42c1b3af3c98..922cdcf5758a 100644 > --- a/mm/slub.c > +++ b/mm/slub.c > @@ -4838,7 +4838,15 @@ static ssize_t show_slab_objects(struct kmem_cache *s, > } > } > > - get_online_mems(); > +/* > + * It is not possible to take "mem_hotplug_lock" here, as it has already held > + * "kernfs_mutex" which could race with the lock order: > + * > + * mem_hotplug_lock->slab_mutex->kernfs_mutex > + * > + * In the worest case, it might be mis-calculated while doing NUMA node > + * hotplug, but it shall be corrected by later reads of the same files. > + */ > #ifdef CONFIG_SLUB_DEBUG > if (flags & SO_ALL) { > struct kmem_cache_node *n; > @@ -4879,7 +4887,6 @@ static ssize_t show_slab_objects(struct kmem_cache *s, > x += sprintf(buf + x, " N%d=%lu", > node, nodes[node]); > #endif > - put_online_mems(); > kfree(nodes); > return x + sprintf(buf + x, "\n"); > } > -- > 1.8.3.1 > -- Michal Hocko SUSE Labs