提交 aed7a6c4 编写于 作者: E Eric W. Biederman 提交者: Linus Torvalds

[PATCH] proc: Replace proc_inode.type with proc_inode.fd

The sole renaming use of proc_inode.type is to discover the file descriptor
number, so just store the file descriptor number and don't wory about
processing this field.  This removes any /proc limits on the maximum number of
file descriptors, and clears the path to make the hard coded /proc inode
numbers go away.
Signed-off-by: NEric W. Biederman <ebiederm@xmission.com>
Signed-off-by: NAndrew Morton <akpm@osdl.org>
Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
上级 87bfbf67
...@@ -297,7 +297,7 @@ static int proc_fd_link(struct inode *inode, struct dentry **dentry, struct vfsm ...@@ -297,7 +297,7 @@ static int proc_fd_link(struct inode *inode, struct dentry **dentry, struct vfsm
struct task_struct *task = proc_task(inode); struct task_struct *task = proc_task(inode);
struct files_struct *files; struct files_struct *files;
struct file *file; struct file *file;
int fd = proc_type(inode) - PROC_TID_FD_DIR; int fd = proc_fd(inode);
files = get_files_struct(task); files = get_files_struct(task);
if (files) { if (files) {
...@@ -1368,7 +1368,6 @@ static struct inode *proc_pid_make_inode(struct super_block * sb, struct task_st ...@@ -1368,7 +1368,6 @@ static struct inode *proc_pid_make_inode(struct super_block * sb, struct task_st
*/ */
get_task_struct(task); get_task_struct(task);
ei->task = task; ei->task = task;
ei->type = ino;
inode->i_uid = 0; inode->i_uid = 0;
inode->i_gid = 0; inode->i_gid = 0;
if (task_dumpable(task)) { if (task_dumpable(task)) {
...@@ -1418,7 +1417,7 @@ static int tid_fd_revalidate(struct dentry *dentry, struct nameidata *nd) ...@@ -1418,7 +1417,7 @@ static int tid_fd_revalidate(struct dentry *dentry, struct nameidata *nd)
{ {
struct inode *inode = dentry->d_inode; struct inode *inode = dentry->d_inode;
struct task_struct *task = proc_task(inode); struct task_struct *task = proc_task(inode);
int fd = proc_type(inode) - PROC_TID_FD_DIR; int fd = proc_fd(inode);
struct files_struct *files; struct files_struct *files;
files = get_files_struct(task); files = get_files_struct(task);
...@@ -1525,6 +1524,7 @@ static struct dentry *proc_lookupfd(struct inode * dir, struct dentry * dentry, ...@@ -1525,6 +1524,7 @@ static struct dentry *proc_lookupfd(struct inode * dir, struct dentry * dentry,
if (!inode) if (!inode)
goto out; goto out;
ei = PROC_I(inode); ei = PROC_I(inode);
ei->fd = fd;
files = get_files_struct(task); files = get_files_struct(task);
if (!files) if (!files)
goto out_unlock; goto out_unlock;
......
...@@ -95,7 +95,7 @@ static struct inode *proc_alloc_inode(struct super_block *sb) ...@@ -95,7 +95,7 @@ static struct inode *proc_alloc_inode(struct super_block *sb)
if (!ei) if (!ei)
return NULL; return NULL;
ei->task = NULL; ei->task = NULL;
ei->type = 0; ei->fd = 0;
ei->op.proc_get_link = NULL; ei->op.proc_get_link = NULL;
ei->pde = NULL; ei->pde = NULL;
inode = &ei->vfs_inode; inode = &ei->vfs_inode;
......
...@@ -46,7 +46,7 @@ static inline struct task_struct *proc_task(struct inode *inode) ...@@ -46,7 +46,7 @@ static inline struct task_struct *proc_task(struct inode *inode)
return PROC_I(inode)->task; return PROC_I(inode)->task;
} }
static inline int proc_type(struct inode *inode) static inline int proc_fd(struct inode *inode)
{ {
return PROC_I(inode)->type; return PROC_I(inode)->fd;
} }
...@@ -249,7 +249,7 @@ extern void kclist_add(struct kcore_list *, void *, size_t); ...@@ -249,7 +249,7 @@ extern void kclist_add(struct kcore_list *, void *, size_t);
struct proc_inode { struct proc_inode {
struct task_struct *task; struct task_struct *task;
int type; int fd;
union { union {
int (*proc_get_link)(struct inode *, struct dentry **, struct vfsmount **); int (*proc_get_link)(struct inode *, struct dentry **, struct vfsmount **);
int (*proc_read)(struct task_struct *task, char *page); int (*proc_read)(struct task_struct *task, char *page);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册