mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-18 02:46:06 +00:00
procfs: reorder struct pid_dentry to save space on 64bit archs, and constify them
Change the order of fields of struct pid_entry (file fs/proc/base.c) in order to avoid a hole on 64bit archs. (8 bytes saved per object) Also change all pid_entry arrays to be const qualified, to make clear they must not be modified. Before (on x86_64) : # size fs/proc/base.o text data bss dec hex filename 15549 2192 0 17741 454d fs/proc/base.o After : # size fs/proc/base.o text data bss dec hex filename 17229 176 0 17405 43fd fs/proc/base.o Thats 336 bytes saved on kernel size on x86_64 Signed-off-by: Eric Dumazet <dada1@cosmosbay.com> Acked-by: "Eric W. Biederman" <ebiederm@xmission.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
d9a2f4a494
commit
c5141e6d64
@ -91,8 +91,8 @@
|
|||||||
#define PROC_NUMBUF 13
|
#define PROC_NUMBUF 13
|
||||||
|
|
||||||
struct pid_entry {
|
struct pid_entry {
|
||||||
int len;
|
|
||||||
char *name;
|
char *name;
|
||||||
|
int len;
|
||||||
mode_t mode;
|
mode_t mode;
|
||||||
const struct inode_operations *iop;
|
const struct inode_operations *iop;
|
||||||
const struct file_operations *fop;
|
const struct file_operations *fop;
|
||||||
@ -100,8 +100,8 @@ struct pid_entry {
|
|||||||
};
|
};
|
||||||
|
|
||||||
#define NOD(NAME, MODE, IOP, FOP, OP) { \
|
#define NOD(NAME, MODE, IOP, FOP, OP) { \
|
||||||
.len = sizeof(NAME) - 1, \
|
|
||||||
.name = (NAME), \
|
.name = (NAME), \
|
||||||
|
.len = sizeof(NAME) - 1, \
|
||||||
.mode = MODE, \
|
.mode = MODE, \
|
||||||
.iop = IOP, \
|
.iop = IOP, \
|
||||||
.fop = FOP, \
|
.fop = FOP, \
|
||||||
@ -1159,7 +1159,8 @@ static struct dentry_operations pid_dentry_operations =
|
|||||||
|
|
||||||
/* Lookups */
|
/* Lookups */
|
||||||
|
|
||||||
typedef struct dentry *instantiate_t(struct inode *, struct dentry *, struct task_struct *, void *);
|
typedef struct dentry *instantiate_t(struct inode *, struct dentry *,
|
||||||
|
struct task_struct *, const void *);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Fill a directory entry.
|
* Fill a directory entry.
|
||||||
@ -1175,7 +1176,7 @@ typedef struct dentry *instantiate_t(struct inode *, struct dentry *, struct tas
|
|||||||
*/
|
*/
|
||||||
static int proc_fill_cache(struct file *filp, void *dirent, filldir_t filldir,
|
static int proc_fill_cache(struct file *filp, void *dirent, filldir_t filldir,
|
||||||
char *name, int len,
|
char *name, int len,
|
||||||
instantiate_t instantiate, struct task_struct *task, void *ptr)
|
instantiate_t instantiate, struct task_struct *task, const void *ptr)
|
||||||
{
|
{
|
||||||
struct dentry *child, *dir = filp->f_path.dentry;
|
struct dentry *child, *dir = filp->f_path.dentry;
|
||||||
struct inode *inode;
|
struct inode *inode;
|
||||||
@ -1310,9 +1311,9 @@ static struct dentry_operations tid_fd_dentry_operations =
|
|||||||
};
|
};
|
||||||
|
|
||||||
static struct dentry *proc_fd_instantiate(struct inode *dir,
|
static struct dentry *proc_fd_instantiate(struct inode *dir,
|
||||||
struct dentry *dentry, struct task_struct *task, void *ptr)
|
struct dentry *dentry, struct task_struct *task, const void *ptr)
|
||||||
{
|
{
|
||||||
unsigned fd = *(unsigned *)ptr;
|
unsigned fd = *(const unsigned *)ptr;
|
||||||
struct file *file;
|
struct file *file;
|
||||||
struct files_struct *files;
|
struct files_struct *files;
|
||||||
struct inode *inode;
|
struct inode *inode;
|
||||||
@ -1478,9 +1479,9 @@ static const struct inode_operations proc_fd_inode_operations = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static struct dentry *proc_pident_instantiate(struct inode *dir,
|
static struct dentry *proc_pident_instantiate(struct inode *dir,
|
||||||
struct dentry *dentry, struct task_struct *task, void *ptr)
|
struct dentry *dentry, struct task_struct *task, const void *ptr)
|
||||||
{
|
{
|
||||||
struct pid_entry *p = ptr;
|
const struct pid_entry *p = ptr;
|
||||||
struct inode *inode;
|
struct inode *inode;
|
||||||
struct proc_inode *ei;
|
struct proc_inode *ei;
|
||||||
struct dentry *error = ERR_PTR(-EINVAL);
|
struct dentry *error = ERR_PTR(-EINVAL);
|
||||||
@ -1509,13 +1510,13 @@ out:
|
|||||||
|
|
||||||
static struct dentry *proc_pident_lookup(struct inode *dir,
|
static struct dentry *proc_pident_lookup(struct inode *dir,
|
||||||
struct dentry *dentry,
|
struct dentry *dentry,
|
||||||
struct pid_entry *ents,
|
const struct pid_entry *ents,
|
||||||
unsigned int nents)
|
unsigned int nents)
|
||||||
{
|
{
|
||||||
struct inode *inode;
|
struct inode *inode;
|
||||||
struct dentry *error;
|
struct dentry *error;
|
||||||
struct task_struct *task = get_proc_task(dir);
|
struct task_struct *task = get_proc_task(dir);
|
||||||
struct pid_entry *p, *last;
|
const struct pid_entry *p, *last;
|
||||||
|
|
||||||
error = ERR_PTR(-ENOENT);
|
error = ERR_PTR(-ENOENT);
|
||||||
inode = NULL;
|
inode = NULL;
|
||||||
@ -1544,8 +1545,8 @@ out_no_task:
|
|||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int proc_pident_fill_cache(struct file *filp, void *dirent, filldir_t filldir,
|
static int proc_pident_fill_cache(struct file *filp, void *dirent,
|
||||||
struct task_struct *task, struct pid_entry *p)
|
filldir_t filldir, struct task_struct *task, const struct pid_entry *p)
|
||||||
{
|
{
|
||||||
return proc_fill_cache(filp, dirent, filldir, p->name, p->len,
|
return proc_fill_cache(filp, dirent, filldir, p->name, p->len,
|
||||||
proc_pident_instantiate, task, p);
|
proc_pident_instantiate, task, p);
|
||||||
@ -1553,14 +1554,14 @@ static int proc_pident_fill_cache(struct file *filp, void *dirent, filldir_t fil
|
|||||||
|
|
||||||
static int proc_pident_readdir(struct file *filp,
|
static int proc_pident_readdir(struct file *filp,
|
||||||
void *dirent, filldir_t filldir,
|
void *dirent, filldir_t filldir,
|
||||||
struct pid_entry *ents, unsigned int nents)
|
const struct pid_entry *ents, unsigned int nents)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
int pid;
|
int pid;
|
||||||
struct dentry *dentry = filp->f_path.dentry;
|
struct dentry *dentry = filp->f_path.dentry;
|
||||||
struct inode *inode = dentry->d_inode;
|
struct inode *inode = dentry->d_inode;
|
||||||
struct task_struct *task = get_proc_task(inode);
|
struct task_struct *task = get_proc_task(inode);
|
||||||
struct pid_entry *p, *last;
|
const struct pid_entry *p, *last;
|
||||||
ino_t ino;
|
ino_t ino;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
@ -1675,7 +1676,7 @@ static const struct file_operations proc_pid_attr_operations = {
|
|||||||
.write = proc_pid_attr_write,
|
.write = proc_pid_attr_write,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct pid_entry attr_dir_stuff[] = {
|
static const struct pid_entry attr_dir_stuff[] = {
|
||||||
REG("current", S_IRUGO|S_IWUGO, pid_attr),
|
REG("current", S_IRUGO|S_IWUGO, pid_attr),
|
||||||
REG("prev", S_IRUGO, pid_attr),
|
REG("prev", S_IRUGO, pid_attr),
|
||||||
REG("exec", S_IRUGO|S_IWUGO, pid_attr),
|
REG("exec", S_IRUGO|S_IWUGO, pid_attr),
|
||||||
@ -1741,7 +1742,7 @@ static const struct inode_operations proc_self_inode_operations = {
|
|||||||
* that properly belong to the /proc filesystem, as they describe
|
* that properly belong to the /proc filesystem, as they describe
|
||||||
* describe something that is process related.
|
* describe something that is process related.
|
||||||
*/
|
*/
|
||||||
static struct pid_entry proc_base_stuff[] = {
|
static const struct pid_entry proc_base_stuff[] = {
|
||||||
NOD("self", S_IFLNK|S_IRWXUGO,
|
NOD("self", S_IFLNK|S_IRWXUGO,
|
||||||
&proc_self_inode_operations, NULL, {}),
|
&proc_self_inode_operations, NULL, {}),
|
||||||
};
|
};
|
||||||
@ -1770,9 +1771,9 @@ static struct dentry_operations proc_base_dentry_operations =
|
|||||||
};
|
};
|
||||||
|
|
||||||
static struct dentry *proc_base_instantiate(struct inode *dir,
|
static struct dentry *proc_base_instantiate(struct inode *dir,
|
||||||
struct dentry *dentry, struct task_struct *task, void *ptr)
|
struct dentry *dentry, struct task_struct *task, const void *ptr)
|
||||||
{
|
{
|
||||||
struct pid_entry *p = ptr;
|
const struct pid_entry *p = ptr;
|
||||||
struct inode *inode;
|
struct inode *inode;
|
||||||
struct proc_inode *ei;
|
struct proc_inode *ei;
|
||||||
struct dentry *error = ERR_PTR(-EINVAL);
|
struct dentry *error = ERR_PTR(-EINVAL);
|
||||||
@ -1820,7 +1821,7 @@ static struct dentry *proc_base_lookup(struct inode *dir, struct dentry *dentry)
|
|||||||
{
|
{
|
||||||
struct dentry *error;
|
struct dentry *error;
|
||||||
struct task_struct *task = get_proc_task(dir);
|
struct task_struct *task = get_proc_task(dir);
|
||||||
struct pid_entry *p, *last;
|
const struct pid_entry *p, *last;
|
||||||
|
|
||||||
error = ERR_PTR(-ENOENT);
|
error = ERR_PTR(-ENOENT);
|
||||||
|
|
||||||
@ -1846,8 +1847,8 @@ out_no_task:
|
|||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int proc_base_fill_cache(struct file *filp, void *dirent, filldir_t filldir,
|
static int proc_base_fill_cache(struct file *filp, void *dirent,
|
||||||
struct task_struct *task, struct pid_entry *p)
|
filldir_t filldir, struct task_struct *task, const struct pid_entry *p)
|
||||||
{
|
{
|
||||||
return proc_fill_cache(filp, dirent, filldir, p->name, p->len,
|
return proc_fill_cache(filp, dirent, filldir, p->name, p->len,
|
||||||
proc_base_instantiate, task, p);
|
proc_base_instantiate, task, p);
|
||||||
@ -1884,7 +1885,7 @@ static int proc_pid_io_accounting(struct task_struct *task, char *buffer)
|
|||||||
static const struct file_operations proc_task_operations;
|
static const struct file_operations proc_task_operations;
|
||||||
static const struct inode_operations proc_task_inode_operations;
|
static const struct inode_operations proc_task_inode_operations;
|
||||||
|
|
||||||
static struct pid_entry tgid_base_stuff[] = {
|
static const struct pid_entry tgid_base_stuff[] = {
|
||||||
DIR("task", S_IRUGO|S_IXUGO, task),
|
DIR("task", S_IRUGO|S_IXUGO, task),
|
||||||
DIR("fd", S_IRUSR|S_IXUSR, fd),
|
DIR("fd", S_IRUSR|S_IXUSR, fd),
|
||||||
INF("environ", S_IRUSR, pid_environ),
|
INF("environ", S_IRUSR, pid_environ),
|
||||||
@ -2027,7 +2028,7 @@ out:
|
|||||||
|
|
||||||
static struct dentry *proc_pid_instantiate(struct inode *dir,
|
static struct dentry *proc_pid_instantiate(struct inode *dir,
|
||||||
struct dentry * dentry,
|
struct dentry * dentry,
|
||||||
struct task_struct *task, void *ptr)
|
struct task_struct *task, const void *ptr)
|
||||||
{
|
{
|
||||||
struct dentry *error = ERR_PTR(-ENOENT);
|
struct dentry *error = ERR_PTR(-ENOENT);
|
||||||
struct inode *inode;
|
struct inode *inode;
|
||||||
@ -2142,7 +2143,7 @@ int proc_pid_readdir(struct file * filp, void * dirent, filldir_t filldir)
|
|||||||
goto out_no_task;
|
goto out_no_task;
|
||||||
|
|
||||||
for (; nr < ARRAY_SIZE(proc_base_stuff); filp->f_pos++, nr++) {
|
for (; nr < ARRAY_SIZE(proc_base_stuff); filp->f_pos++, nr++) {
|
||||||
struct pid_entry *p = &proc_base_stuff[nr];
|
const struct pid_entry *p = &proc_base_stuff[nr];
|
||||||
if (proc_base_fill_cache(filp, dirent, filldir, reaper, p) < 0)
|
if (proc_base_fill_cache(filp, dirent, filldir, reaper, p) < 0)
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
@ -2168,7 +2169,7 @@ out_no_task:
|
|||||||
/*
|
/*
|
||||||
* Tasks
|
* Tasks
|
||||||
*/
|
*/
|
||||||
static struct pid_entry tid_base_stuff[] = {
|
static const struct pid_entry tid_base_stuff[] = {
|
||||||
DIR("fd", S_IRUSR|S_IXUSR, fd),
|
DIR("fd", S_IRUSR|S_IXUSR, fd),
|
||||||
INF("environ", S_IRUSR, pid_environ),
|
INF("environ", S_IRUSR, pid_environ),
|
||||||
INF("auxv", S_IRUSR, pid_auxv),
|
INF("auxv", S_IRUSR, pid_auxv),
|
||||||
@ -2238,7 +2239,7 @@ static const struct inode_operations proc_tid_base_inode_operations = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
static struct dentry *proc_task_instantiate(struct inode *dir,
|
static struct dentry *proc_task_instantiate(struct inode *dir,
|
||||||
struct dentry *dentry, struct task_struct *task, void *ptr)
|
struct dentry *dentry, struct task_struct *task, const void *ptr)
|
||||||
{
|
{
|
||||||
struct dentry *error = ERR_PTR(-ENOENT);
|
struct dentry *error = ERR_PTR(-ENOENT);
|
||||||
struct inode *inode;
|
struct inode *inode;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user