[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: Eric W. Biederman <ebiederm@xmission.com> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:
committed by
Linus Torvalds
parent
87bfbf679f
commit
aed7a6c476
@ -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 files_struct *files;
|
||||
struct file *file;
|
||||
int fd = proc_type(inode) - PROC_TID_FD_DIR;
|
||||
int fd = proc_fd(inode);
|
||||
|
||||
files = get_files_struct(task);
|
||||
if (files) {
|
||||
@ -1368,7 +1368,6 @@ static struct inode *proc_pid_make_inode(struct super_block * sb, struct task_st
|
||||
*/
|
||||
get_task_struct(task);
|
||||
ei->task = task;
|
||||
ei->type = ino;
|
||||
inode->i_uid = 0;
|
||||
inode->i_gid = 0;
|
||||
if (task_dumpable(task)) {
|
||||
@ -1418,7 +1417,7 @@ static int tid_fd_revalidate(struct dentry *dentry, struct nameidata *nd)
|
||||
{
|
||||
struct inode *inode = dentry->d_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;
|
||||
|
||||
files = get_files_struct(task);
|
||||
@ -1525,6 +1524,7 @@ static struct dentry *proc_lookupfd(struct inode * dir, struct dentry * dentry,
|
||||
if (!inode)
|
||||
goto out;
|
||||
ei = PROC_I(inode);
|
||||
ei->fd = fd;
|
||||
files = get_files_struct(task);
|
||||
if (!files)
|
||||
goto out_unlock;
|
||||
|
Reference in New Issue
Block a user