mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
take rlimit check to callers of expand_files()
... except for one in android, where the check is different and already done in caller. No need to recalculate rlimit many times in alloc_fd() either. Change-Id: Ia6eb7e1af1047f4d4f188d89deb70d708fa9110a Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
parent
85efe69668
commit
d219028583
2 changed files with 11 additions and 7 deletions
|
@ -64,6 +64,9 @@ SYSCALL_DEFINE3(dup3, unsigned int, oldfd, unsigned int, newfd, int, flags)
|
||||||
if (unlikely(oldfd == newfd))
|
if (unlikely(oldfd == newfd))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
|
if (newfd >= rlimit(RLIMIT_NOFILE))
|
||||||
|
return -EMFILE;
|
||||||
|
|
||||||
spin_lock(&files->file_lock);
|
spin_lock(&files->file_lock);
|
||||||
err = expand_files(files, newfd);
|
err = expand_files(files, newfd);
|
||||||
file = fcheck(oldfd);
|
file = fcheck(oldfd);
|
||||||
|
|
15
fs/file.c
15
fs/file.c
|
@ -251,13 +251,6 @@ int expand_files(struct files_struct *files, int nr)
|
||||||
|
|
||||||
fdt = files_fdtable(files);
|
fdt = files_fdtable(files);
|
||||||
|
|
||||||
/*
|
|
||||||
* N.B. For clone tasks sharing a files structure, this test
|
|
||||||
* will limit the total number of files that can be opened.
|
|
||||||
*/
|
|
||||||
if (nr >= rlimit(RLIMIT_NOFILE))
|
|
||||||
return -EMFILE;
|
|
||||||
|
|
||||||
/* Do we need to expand? */
|
/* Do we need to expand? */
|
||||||
if (nr < fdt->max_fds)
|
if (nr < fdt->max_fds)
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -444,6 +437,14 @@ repeat:
|
||||||
if (fd < fdt->max_fds)
|
if (fd < fdt->max_fds)
|
||||||
fd = find_next_zero_bit(fdt->open_fds, fdt->max_fds, fd);
|
fd = find_next_zero_bit(fdt->open_fds, fdt->max_fds, fd);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* N.B. For clone tasks sharing a files structure, this test
|
||||||
|
* will limit the total number of files that can be opened.
|
||||||
|
*/
|
||||||
|
error = -EMFILE;
|
||||||
|
if (fd >= end)
|
||||||
|
goto out;
|
||||||
|
|
||||||
error = expand_files(files, fd);
|
error = expand_files(files, fd);
|
||||||
if (error < 0)
|
if (error < 0)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
Loading…
Reference in a new issue