Skip to content

Commit

Permalink
fs/proc: use __ro_after_init
Browse files Browse the repository at this point in the history
/proc/self inode numbers, value of proc_inode_cache and st_nlink of
/proc/$TGID are fixed constants.

Link: http://lkml.kernel.org/r/20180103184707.GA31849@avx2
Signed-off-by: Alexey Dobriyan <[email protected]>
Signed-off-by: Andrew Morton <[email protected]>
Signed-off-by: Linus Torvalds <[email protected]>
  • Loading branch information
Alexey Dobriyan authored and torvalds committed Feb 7, 2018
1 parent 53f6334 commit efb1a57
Show file tree
Hide file tree
Showing 4 changed files with 9 additions and 5 deletions.
5 changes: 3 additions & 2 deletions fs/proc/base.c
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,7 @@
#include <linux/ptrace.h>
#include <linux/tracehook.h>
#include <linux/printk.h>
#include <linux/cache.h>
#include <linux/cgroup.h>
#include <linux/cpuset.h>
#include <linux/audit.h>
Expand Down Expand Up @@ -112,8 +113,8 @@
* in /proc for a task before it execs a suid executable.
*/

static u8 nlink_tid;
static u8 nlink_tgid;
static u8 nlink_tid __ro_after_init;
static u8 nlink_tgid __ro_after_init;

struct pid_entry {
const char *name;
Expand Down
3 changes: 2 additions & 1 deletion fs/proc/inode.c
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
* Copyright (C) 1991, 1992 Linus Torvalds
*/

#include <linux/cache.h>
#include <linux/time.h>
#include <linux/proc_fs.h>
#include <linux/kernel.h>
Expand Down Expand Up @@ -52,7 +53,7 @@ static void proc_evict_inode(struct inode *inode)
}
}

static struct kmem_cache * proc_inode_cachep;
static struct kmem_cache *proc_inode_cachep __ro_after_init;

static struct inode *proc_alloc_inode(struct super_block *sb)
{
Expand Down
3 changes: 2 additions & 1 deletion fs/proc/self.c
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
// SPDX-License-Identifier: GPL-2.0
#include <linux/cache.h>
#include <linux/sched.h>
#include <linux/slab.h>
#include <linux/pid_namespace.h>
Expand Down Expand Up @@ -30,7 +31,7 @@ static const struct inode_operations proc_self_inode_operations = {
.get_link = proc_self_get_link,
};

static unsigned self_inum;
static unsigned self_inum __ro_after_init;

int proc_setup_self(struct super_block *s)
{
Expand Down
3 changes: 2 additions & 1 deletion fs/proc/thread_self.c
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
// SPDX-License-Identifier: GPL-2.0
#include <linux/cache.h>
#include <linux/sched.h>
#include <linux/slab.h>
#include <linux/pid_namespace.h>
Expand Down Expand Up @@ -30,7 +31,7 @@ static const struct inode_operations proc_thread_self_inode_operations = {
.get_link = proc_thread_self_get_link,
};

static unsigned thread_self_inum;
static unsigned thread_self_inum __ro_after_init;

int proc_setup_thread_self(struct super_block *s)
{
Expand Down

0 comments on commit efb1a57

Please sign in to comment.