From patchwork Sun Feb 20 06:01:10 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Meng Tang X-Patchwork-Id: 12752565 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) by smtp.lore.kernel.org (Postfix) with ESMTP id B83B9C433F5 for ; Sun, 20 Feb 2022 06:01:35 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id BD24D6B0072; Sun, 20 Feb 2022 01:01:34 -0500 (EST) Received: by kanga.kvack.org (Postfix, from userid 40) id B82BF6B0073; Sun, 20 Feb 2022 01:01:34 -0500 (EST) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id A4AFF6B0074; Sun, 20 Feb 2022 01:01:34 -0500 (EST) X-Delivered-To: linux-mm@kvack.org Received: from forelay.hostedemail.com (smtprelay0027.hostedemail.com [216.40.44.27]) by kanga.kvack.org (Postfix) with ESMTP id 95EFC6B0072 for ; Sun, 20 Feb 2022 01:01:34 -0500 (EST) Received: from smtpin20.hostedemail.com (10.5.19.251.rfc1918.com [10.5.19.251]) by forelay02.hostedemail.com (Postfix) with ESMTP id 26D0C9AC96 for ; Sun, 20 Feb 2022 06:01:34 +0000 (UTC) X-FDA: 79162111308.20.12322E2 Received: from smtpproxy21.qq.com (smtpbg704.qq.com [203.205.195.105]) by imf31.hostedemail.com (Postfix) with ESMTP id 0BCA420004 for ; Sun, 20 Feb 2022 06:01:32 +0000 (UTC) X-QQ-mid: bizesmtp82t1645336882t5dgk557 Received: from localhost.localdomain (unknown [180.102.102.45]) by bizesmtp.qq.com (ESMTP) with id ; Sun, 20 Feb 2022 14:01:16 +0800 (CST) X-QQ-SSF: 01400000002000B0F000B00A0000000 X-QQ-FEAT: zD6y7hNAcUDOz2spGL/eUKdvHQFW318WJmvVp1I5o3JA883k/G16UFiqIcHw4 PBZ45w9nlRbhLwZwLDc91e8FdhgMGUn61raT5T9pXHP1bIUcBLW/oW3bXuXhP3ZhHBBbw4l sdn+5SZ7+S6rIzzBNhT4bOxGaUOTTxQn3REmqbN6PWYflwJz2iSsrIZZ5XNQlNYtQcdLZFO nhDonfnvqbgU1bSTmKhWJ6kaJtkFZmLR/YAC7aoB21xhpZbyStZK7UL4WM3y8VYc+u23GH8 X578cnMVz9F37uklWZb+CU0sgSVjRtn/OnhTJwN3HFkVWOGFIUONEBk2H/5we+6FkMvqlHs f+FSmlATG7vdRv5ELgUXlO5onmn9p+WlGxBF21p X-QQ-GoodBg: 2 From: tangmeng To: mcgrof@kernel.org, keescook@chromium.org, yzaikin@google.com Cc: linux-kernel@vger.kernel.org, linux-mm@kvack.org, linux-fsdevel@vger.kernel.org, nizhen@uniontech.com, zhanglianjie@uniontech.com, nixiaoming@huawei.com, tangmeng Subject: [PATCH 06/11] mm/vmstat: move vmstat sysctls to its own file Date: Sun, 20 Feb 2022 14:01:10 +0800 Message-Id: <20220220060110.13770-1-tangmeng@uniontech.com> X-Mailer: git-send-email 2.20.1 MIME-Version: 1.0 X-QQ-SENDSIZE: 520 Feedback-ID: bizesmtp:uniontech.com:qybgforeign:qybgforeign6 X-QQ-Bgrelay: 1 X-Rspam-User: X-Rspamd-Server: rspam12 X-Rspamd-Queue-Id: 0BCA420004 X-Stat-Signature: ejobefipqw3735m7gc5g1nnkb5ihttak Authentication-Results: imf31.hostedemail.com; dkim=none; dmarc=none; spf=pass (imf31.hostedemail.com: domain of tangmeng@uniontech.com designates 203.205.195.105 as permitted sender) smtp.mailfrom=tangmeng@uniontech.com X-HE-Tag: 1645336892-815377 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: kernel/sysctl.c is a kitchen sink where everyone leaves their dirty dishes, this makes it very difficult to maintain. To help with this maintenance let's start by moving sysctls to places where they actually belong. The proc sysctl maintainers do not want to know what sysctl knobs you wish to add for your own piece of code, we just care about the core logic. All filesystem syctls now get reviewed by fs folks. This commit follows the commit of fs, move the vmstat sysctls to its own file, mm/vmstat.c. vmstat_refresh is defined when CONFIG_PROC_FS is defined, so macro control is added to stat_refresh. Signed-off-by: tangmeng --- include/linux/vmstat.h | 9 -------- kernel/sysctl.c | 25 --------------------- mm/vmstat.c | 50 ++++++++++++++++++++++++++++++++++++++---- 3 files changed, 46 insertions(+), 38 deletions(-) diff --git a/include/linux/vmstat.h b/include/linux/vmstat.h index bfe38869498d..b615d8d7c1d2 100644 --- a/include/linux/vmstat.h +++ b/include/linux/vmstat.h @@ -10,15 +10,10 @@ #include #include -extern int sysctl_stat_interval; - #ifdef CONFIG_NUMA #define ENABLE_NUMA_STAT 1 #define DISABLE_NUMA_STAT 0 -extern int sysctl_vm_numa_stat; DECLARE_STATIC_KEY_TRUE(vm_numa_stat_key); -int sysctl_vm_numa_stat_handler(struct ctl_table *table, int write, - void *buffer, size_t *length, loff_t *ppos); #endif struct reclaim_stat { @@ -300,10 +295,6 @@ void quiet_vmstat(void); void cpu_vm_stats_fold(int cpu); void refresh_zone_stat_thresholds(void); -struct ctl_table; -int vmstat_refresh(struct ctl_table *, int write, void *buffer, size_t *lenp, - loff_t *ppos); - void drain_zonestat(struct zone *zone, struct per_cpu_zonestat *); int calculate_pressure_threshold(struct zone *zone); diff --git a/kernel/sysctl.c b/kernel/sysctl.c index 62499e3207aa..31f2c6e21392 100644 --- a/kernel/sysctl.c +++ b/kernel/sysctl.c @@ -2192,15 +2192,6 @@ static struct ctl_table vm_table[] = { .mode = 0644, .proc_handler = &hugetlb_mempolicy_sysctl_handler, }, - { - .procname = "numa_stat", - .data = &sysctl_vm_numa_stat, - .maxlen = sizeof(int), - .mode = 0644, - .proc_handler = sysctl_vm_numa_stat_handler, - .extra1 = SYSCTL_ZERO, - .extra2 = SYSCTL_ONE, - }, #endif { .procname = "hugetlb_shm_group", @@ -2377,22 +2368,6 @@ static struct ctl_table vm_table[] = { .extra2 = SYSCTL_ONE_HUNDRED, }, #endif -#ifdef CONFIG_SMP - { - .procname = "stat_interval", - .data = &sysctl_stat_interval, - .maxlen = sizeof(sysctl_stat_interval), - .mode = 0644, - .proc_handler = proc_dointvec_jiffies, - }, - { - .procname = "stat_refresh", - .data = NULL, - .maxlen = 0, - .mode = 0600, - .proc_handler = vmstat_refresh, - }, -#endif #ifdef CONFIG_MMU { .procname = "mmap_min_addr", diff --git a/mm/vmstat.c b/mm/vmstat.c index 4057372745d0..e7eeba4db2eb 100644 --- a/mm/vmstat.c +++ b/mm/vmstat.c @@ -32,7 +32,7 @@ #include "internal.h" #ifdef CONFIG_NUMA -int sysctl_vm_numa_stat = ENABLE_NUMA_STAT; +static int sysctl_vm_numa_stat = ENABLE_NUMA_STAT; /* zero numa counters within a zone */ static void zero_zone_numa_counters(struct zone *zone) @@ -74,7 +74,7 @@ static void invalid_numa_statistics(void) static DEFINE_MUTEX(vm_numa_stat_lock); -int sysctl_vm_numa_stat_handler(struct ctl_table *table, int write, +static int sysctl_vm_numa_stat_handler(struct ctl_table *table, int write, void *buffer, size_t *length, loff_t *ppos) { int ret, oldval; @@ -1853,7 +1853,7 @@ static const struct seq_operations vmstat_op = { #ifdef CONFIG_SMP static DEFINE_PER_CPU(struct delayed_work, vmstat_work); -int sysctl_stat_interval __read_mostly = HZ; +static int sysctl_stat_interval __read_mostly = HZ; #ifdef CONFIG_PROC_FS static void refresh_vm_stats(struct work_struct *work) @@ -1861,7 +1861,7 @@ static void refresh_vm_stats(struct work_struct *work) refresh_cpu_vm_stats(true); } -int vmstat_refresh(struct ctl_table *table, int write, +static int vmstat_refresh(struct ctl_table *table, int write, void *buffer, size_t *lenp, loff_t *ppos) { long val; @@ -2238,3 +2238,45 @@ static int __init extfrag_debug_init(void) module_init(extfrag_debug_init); #endif + +#ifdef CONFIG_SYSCTL +static struct ctl_table vm_stat_table[] = { +#ifdef CONFIG_NUMA + { + .procname = "numa_stat", + .data = &sysctl_vm_numa_stat, + .maxlen = sizeof(int), + .mode = 0644, + .proc_handler = sysctl_vm_numa_stat_handler, + .extra1 = SYSCTL_ZERO, + .extra2 = SYSCTL_ONE, + }, +#endif /* CONFIG_NUMA */ +#ifdef CONFIG_SMP + { + .procname = "stat_interval", + .data = &sysctl_stat_interval, + .maxlen = sizeof(sysctl_stat_interval), + .mode = 0644, + .proc_handler = proc_dointvec_jiffies, + }, +#ifdef CONFIG_PROC_FS + { + .procname = "stat_refresh", + .data = NULL, + .maxlen = 0, + .mode = 0600, + .proc_handler = vmstat_refresh, + }, +#endif /* CONFIG_PROC_FS */ +#endif /* CONFIG_SMP */ + { } +}; + +static __init int vm_stat_sysctls_init(void) +{ + register_sysctl_init("vm", vm_stat_table); + return 0; +} +late_initcall(vm_stat_sysctls_init); +#endif /* CONFIG_SYSCTL */