Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp957386ybt; Sun, 14 Jun 2020 05:45:33 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzFlywqEg3Zgy9ELGqmsDWd54PH+ZxNAmxklMHUIjwKWL4iuna1dCdAwqyXXNC90UqgQ1bW X-Received: by 2002:a17:906:768e:: with SMTP id o14mr22250988ejm.497.1592138733190; Sun, 14 Jun 2020 05:45:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592138733; cv=none; d=google.com; s=arc-20160816; b=AzaE8l8ppuVmYsV6zZNYuf3x5LooSy7O5EHwl0hBcQ2tvYRv7nTGbdihQBwfIIJ8Dk nWvOK4gvkisWlb6l5z4I6rStdcajlJvI4XGncJOC0L6KieLjBO2Hc8A17sxCIETn0zIg Qw+PI3AL1ucBhyP1j+wWGjT+1pfqD159dUZGdpAVLdkpfl4omNHRgoiqMqLBAIJPS3zS RRk0TK8x1CrPR+ybRopqXkRws+iRPeuBLyax8LO6sh6d5tpkHr+Yt5PxvioAVtNHqtXG vuB/LfmAUs8RXW1BKAv2a7oXAoyufMtG6/VbsXaCJcmsQaKZ/rA5thG8nOVegZLvvwVd P41A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=+068bSrQRTzwliNa3JuLLexz/LOjrev0rMh10PzRkI8=; b=XHsOBs2ePf25ejCFPjdzQKtLEZwyPcO6xaa6jNeKkSW+/MPSNPjmNQuwo0MXW5rTPD t8vAf7d7CSN6JqsMV1VcAt3Vb8vrblqf+9AcC3DU9+/rP/JKjSp6ngyDtptj8M5Arw+A XI+i4QG4CNpEaw2EFSg8Rg3h5KPah8wqVkjj2aSB/RiqypkgTi109lJWdsuNoOlIXUaU 2SHpgy6VNn6h7GAAbQYFcZPfhzxdFE78izxa3ocPKr0nt5FHCFTrUXokOrmgYl4/J4Bb wWbUbplGp0IC7iPZbbby1O6OFAemcwGIssS35tHc9eNB1bAvWeHcZEFtqc7CbO4EWsg/ fBWQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@bytedance-com.20150623.gappssmtp.com header.s=20150623 header.b=JPjtjnfY; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=bytedance.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id w17si7001038edt.490.2020.06.14.05.45.11; Sun, 14 Jun 2020 05:45:33 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@bytedance-com.20150623.gappssmtp.com header.s=20150623 header.b=JPjtjnfY; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=bytedance.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727770AbgFNMjy (ORCPT + 99 others); Sun, 14 Jun 2020 08:39:54 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54730 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725815AbgFNMjv (ORCPT ); Sun, 14 Jun 2020 08:39:51 -0400 Received: from mail-pf1-x444.google.com (mail-pf1-x444.google.com [IPv6:2607:f8b0:4864:20::444]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B1D32C05BD43 for ; Sun, 14 Jun 2020 05:39:51 -0700 (PDT) Received: by mail-pf1-x444.google.com with SMTP id 64so6574492pfv.11 for ; Sun, 14 Jun 2020 05:39:51 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bytedance-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=+068bSrQRTzwliNa3JuLLexz/LOjrev0rMh10PzRkI8=; b=JPjtjnfY+gebb1zk2du4tey5HVKYeX+m/+ub8pbP6YeBTMpjROS969iZf3azxemzet Z0FjJx1ePbqhmmFbiwcA8Si1ec1mjJfeLHORUEEiuROweMIpQsldZgRTejmdf7uRWdUc BRkWHU/806uFqRxmmx1RVd3GVqQOR0GU/qJBvK6pqxdL9CdqnBffj2AsB3T+tRQcmv+7 f17bqV0jXeYfyhb7uLfFX/sVAXbJ+dDa+KnalDDqFwVgU1G+TrLdZ66XMJrtiDz4XmE0 PQADGnDM4ODrbtXAmRfPDATcAdcEMtqWJnRK5dqDqLIYWEDj1hgRy9zTLDzMkEPOEJQI ZipQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=+068bSrQRTzwliNa3JuLLexz/LOjrev0rMh10PzRkI8=; b=ll0GyKMEm300z8L8PrYcZ7FlF7xjsYaIcvr3n0/BjHzvRtKgkJ0KPwP3KUl3Gfik+f KT7H7rVYCE57yAgDfgVz9+2MdD0rQyCrv9dvDBnCKXBIEWqCdiPxQSwS/qA3ir67iVY6 L9uu0eVtdE8f4Yld/OJaPXBBNotZZb1+9YETqtQqdjNc3asvIzuLQlYc/7FM0TdFR/km k6gElGNlf1ljBF/3zLCxUF5yhQheT0H/UIO0pALXqysli5KxJL+bZarhsh3Mag9MBMAT YmJpKjrBrIzZR/XOtZvAfd0b1V2/tntIPF9kxsa4jMzIPDeUpvs+F0ubdFvTey8AuT4U lSyQ== X-Gm-Message-State: AOAM531StlAwLLb69G55K0FOi5QT02fC+PfEpbPPZjldrolg27ipGt9i MJB9xnHTIZXKLysi3t+uUJvFqA== X-Received: by 2002:a05:6a00:1510:: with SMTP id q16mr18443425pfu.164.1592138391321; Sun, 14 Jun 2020 05:39:51 -0700 (PDT) Received: from Smcdef-MBP.lan ([103.136.221.68]) by smtp.gmail.com with ESMTPSA id hi19sm9776606pjb.49.2020.06.14.05.39.48 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Sun, 14 Jun 2020 05:39:50 -0700 (PDT) From: Muchun Song To: cl@linux.com, penberg@kernel.org, rientjes@google.com, iamjoonsoo.kim@lge.com, akpm@linux-foundation.org Cc: linux-mm@kvack.org, linux-kernel@vger.kernel.org, Muchun Song Subject: [PATCH 3/3] mm/slub: Fix release all resources used by a slab cache Date: Sun, 14 Jun 2020 20:39:23 +0800 Message-Id: <20200614123923.99189-4-songmuchun@bytedance.com> X-Mailer: git-send-email 2.21.0 (Apple Git-122) In-Reply-To: <20200614123923.99189-1-songmuchun@bytedance.com> References: <20200614123923.99189-1-songmuchun@bytedance.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The function of __kmem_cache_shutdown() is that release all resources used by the slab cache, while currently it stop release resources when the preceding node is not empty. Signed-off-by: Muchun Song --- mm/slub.c | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/mm/slub.c b/mm/slub.c index b73505df3de2..4e477ef0f2b9 100644 --- a/mm/slub.c +++ b/mm/slub.c @@ -3839,6 +3839,7 @@ bool __kmem_cache_empty(struct kmem_cache *s) */ int __kmem_cache_shutdown(struct kmem_cache *s) { + int ret = 0; int node; struct kmem_cache_node *n; @@ -3846,11 +3847,11 @@ int __kmem_cache_shutdown(struct kmem_cache *s) /* Attempt to free all objects */ for_each_kmem_cache_node(s, node, n) { free_partial(s, n); - if (node_nr_slabs(n)) - return 1; + if (!ret && node_nr_slabs(n)) + ret = 1; } sysfs_slab_remove(s); - return 0; + return ret; } /******************************************************************** -- 2.11.0