Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp129782ybl; Thu, 29 Aug 2019 20:04:15 -0700 (PDT) X-Google-Smtp-Source: APXvYqzefelEgyVTI35kHcwlsdsXMtfsYkNWZ9kDkiWzfFtRWOSUwSABVczWwAjF7D6fsSpOUGCX X-Received: by 2002:a17:902:a410:: with SMTP id p16mr13419124plq.150.1567134254922; Thu, 29 Aug 2019 20:04:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1567134254; cv=none; d=google.com; s=arc-20160816; b=rPlmDYUswOG2aYTpLP95LLX/s3/BReD4LtfXWQMnIviROR1e+d+hXXNw8Kemj1umT5 m1YqRwDE1deam+Ipod75Q3/efiuuQkiPJCwDn6VNnweevFJtWdMMkkqqU9U7gepeHzNs GSaA3JjNK8EIKXsWhRFGbJTM0dF8dzyH4ww71SvMru2fw6jBxrK9Y3TLDcgfplNWRBk2 H94OqIq9+sVQSTnCNRBwmp6fqKwN97uyxPE5fwdyG+zw8DgMKwtg+2ss3VjpQNsKtCqu dmY/dC9npSlyYhZG8f9t8HhGiYFQcGbwgbGu+yo8rTDNJT4jD2llzUtqbgu6srohigge 3V2w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from; bh=JhA3qN8NphLkZIBEEAFfOUREWU6rWoAiFZIs6ofBkQE=; b=U/RNE/TPrs4m5JaALa3JI7+GSrHAZlp3ESAS/eAukLsrK5zbhNHmvX9OkOI/Jry7f5 91tV1SDiXpUcaBAkHD0MAxY77/K8Ej8D2xzcf5dzEvswrUYtQIdMIseubnWP0MKP039P obB1EfLXXKkjvychAxQiZ4odVfrAKqQV/8vulnQya9mcPJTmWNEiJTWu5/0tTCZUChxK WmQs3zWyUXXgDlXZAlpoN/0UajSLtkxe/kLHzFjq8k8ZbZXB474n/X5ALbBaPidSqVO5 4nfBEgRdqdydd4k6PYc6G8APWINdNbKjgBUy3roe7tfMca40gZq6kSwg8IE7gc5VBZIl Ertw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 72si4933480pfx.268.2019.08.29.20.03.58; Thu, 29 Aug 2019 20:04:14 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727904AbfH3DB5 (ORCPT + 99 others); Thu, 29 Aug 2019 23:01:57 -0400 Received: from szxga04-in.huawei.com ([45.249.212.190]:5697 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1727859AbfH3DBz (ORCPT ); Thu, 29 Aug 2019 23:01:55 -0400 Received: from DGGEMS412-HUB.china.huawei.com (unknown [172.30.72.58]) by Forcepoint Email with ESMTP id E5339F18DB5F0AD4409E; Fri, 30 Aug 2019 11:01:50 +0800 (CST) Received: from architecture4.huawei.com (10.140.130.215) by smtp.huawei.com (10.3.19.212) with Microsoft SMTP Server (TLS) id 14.3.439.0; Fri, 30 Aug 2019 11:01:43 +0800 From: Gao Xiang To: Chao Yu , Dan Carpenter , Christoph Hellwig , Joe Perches , "Greg Kroah-Hartman" , CC: LKML , , "Chao Yu" , Miao Xie , , Fang Wei , Gao Xiang Subject: [PATCH v2 5/7] erofs: kill erofs_{init,exit}_inode_cache Date: Fri, 30 Aug 2019 11:00:38 +0800 Message-ID: <20190830030040.10599-5-gaoxiang25@huawei.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20190830030040.10599-1-gaoxiang25@huawei.com> References: <20190830030040.10599-1-gaoxiang25@huawei.com> MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.140.130.215] X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org As Christoph said [1] "having this function seems entirely pointless", I have to kill those. filesystem function name ext2,f2fs,ext4,isofs,squashfs,cifs,... init_inodecache In addition, add a "rcu_barrier()" when exit_fs(); [1] https://lore.kernel.org/r/20190829101545.GC20598@infradead.org/ Reported-by: Christoph Hellwig Signed-off-by: Gao Xiang --- new patch. fs/erofs/super.c | 31 ++++++++++++------------------- 1 file changed, 12 insertions(+), 19 deletions(-) diff --git a/fs/erofs/super.c b/fs/erofs/super.c index 6d3a9bcb8daa..556aae5426d6 100644 --- a/fs/erofs/super.c +++ b/fs/erofs/super.c @@ -23,21 +23,6 @@ static void init_once(void *ptr) inode_init_once(&vi->vfs_inode); } -static int __init erofs_init_inode_cache(void) -{ - erofs_inode_cachep = kmem_cache_create("erofs_inode", - sizeof(struct erofs_vnode), 0, - SLAB_RECLAIM_ACCOUNT, - init_once); - - return erofs_inode_cachep ? 0 : -ENOMEM; -} - -static void erofs_exit_inode_cache(void) -{ - kmem_cache_destroy(erofs_inode_cachep); -} - static struct inode *alloc_inode(struct super_block *sb) { struct erofs_vnode *vi = @@ -531,9 +516,14 @@ static int __init erofs_module_init(void) erofs_check_ondisk_layout_definitions(); infoln("initializing erofs " EROFS_VERSION); - err = erofs_init_inode_cache(); - if (err) + erofs_inode_cachep = kmem_cache_create("erofs_inode", + sizeof(struct erofs_vnode), 0, + SLAB_RECLAIM_ACCOUNT, + init_once); + if (!erofs_inode_cachep) { + err = -ENOMEM; goto icache_err; + } err = erofs_init_shrinker(); if (err) @@ -555,7 +545,7 @@ static int __init erofs_module_init(void) zip_err: erofs_exit_shrinker(); shrinker_err: - erofs_exit_inode_cache(); + kmem_cache_destroy(erofs_inode_cachep); icache_err: return err; } @@ -565,7 +555,10 @@ static void __exit erofs_module_exit(void) unregister_filesystem(&erofs_fs_type); z_erofs_exit_zip_subsystem(); erofs_exit_shrinker(); - erofs_exit_inode_cache(); + + /* Ensure all RCU free inodes are safe before cache is destroyed. */ + rcu_barrier(); + kmem_cache_destroy(erofs_inode_cachep); infoln("successfully finalize erofs"); } -- 2.17.1