diff options
Diffstat (limited to 'arch/alpha/kernel/osf_sys.c')
| -rw-r--r-- | arch/alpha/kernel/osf_sys.c | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/arch/alpha/kernel/osf_sys.c b/arch/alpha/kernel/osf_sys.c index 0636116210d2..01fe990d3e54 100644 --- a/arch/alpha/kernel/osf_sys.c +++ b/arch/alpha/kernel/osf_sys.c | |||
| @@ -37,6 +37,7 @@ | |||
| 37 | #include <linux/namei.h> | 37 | #include <linux/namei.h> |
| 38 | #include <linux/uio.h> | 38 | #include <linux/uio.h> |
| 39 | #include <linux/vfs.h> | 39 | #include <linux/vfs.h> |
| 40 | #include <linux/rcupdate.h> | ||
| 40 | 41 | ||
| 41 | #include <asm/fpu.h> | 42 | #include <asm/fpu.h> |
| 42 | #include <asm/io.h> | 43 | #include <asm/io.h> |
| @@ -975,6 +976,7 @@ osf_select(int n, fd_set __user *inp, fd_set __user *outp, fd_set __user *exp, | |||
| 975 | long timeout; | 976 | long timeout; |
| 976 | int ret = -EINVAL; | 977 | int ret = -EINVAL; |
| 977 | struct fdtable *fdt; | 978 | struct fdtable *fdt; |
| 979 | int max_fdset; | ||
| 978 | 980 | ||
| 979 | timeout = MAX_SCHEDULE_TIMEOUT; | 981 | timeout = MAX_SCHEDULE_TIMEOUT; |
| 980 | if (tvp) { | 982 | if (tvp) { |
| @@ -996,8 +998,11 @@ osf_select(int n, fd_set __user *inp, fd_set __user *outp, fd_set __user *exp, | |||
| 996 | } | 998 | } |
| 997 | } | 999 | } |
| 998 | 1000 | ||
| 1001 | rcu_read_lock(); | ||
| 999 | fdt = files_fdtable(current->files); | 1002 | fdt = files_fdtable(current->files); |
| 1000 | if (n < 0 || n > fdt->max_fdset) | 1003 | max_fdset = fdt->max_fdset; |
| 1004 | rcu_read_unlock(); | ||
| 1005 | if (n < 0 || n > max_fdset) | ||
| 1001 | goto out_nofds; | 1006 | goto out_nofds; |
| 1002 | 1007 | ||
| 1003 | /* | 1008 | /* |
