diff options
author | Lin Feng Shen <shenlinf@cn.ibm.com> | 2006-05-20 14:59:49 -0700 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-05-21 12:59:16 -0700 |
commit | d64b1c878fc1e384ae53d1d40034239bc33848f4 (patch) | |
tree | fe31b26f2db18d021cf04181bd39e08b2beb17f1 /include/asm-alpha/current.h | |
parent | 84b3932bf0fd8cdc8c75a5be77e1dded1e6479c6 (diff) | |
download | op-kernel-dev-d64b1c878fc1e384ae53d1d40034239bc33848f4.zip op-kernel-dev-d64b1c878fc1e384ae53d1d40034239bc33848f4.tar.gz |
[PATCH] NFS: fix error handling on access_ok in compat_sys_nfsservctl
Functions compat_nfs_svc_trans, compat_nfs_clnt_trans,
compat_nfs_exp_trans, compat_nfs_getfd_trans and compat_nfs_getfs_trans,
which are called by compat_sys_nfsservctl(fs/compat.c), don't handle the
return value of access_ok properly. access_ok return 1 when the addr is
valid, and 0 when it's not, but these functions have the reversed
understanding. When the address is valid, they always return -EFAULT to
compat_sys_nfsservctl.
An example is to run /usr/sbin/rpc.nfsd(32bit program on Power5). It
doesn't function as expected. strace showes that nfsservctl returns
-EFAULT.
The patch fixes this by correcting the error handling on the return value
of access_ok in the five functions.
Signed-off-by: Lin Feng Shen <shenlinf@cn.ibm.com>
Cc: Trond Myklebust <trond.myklebust@fys.uio.no>
Acked-by: Neil Brown <neilb@suse.de>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'include/asm-alpha/current.h')
0 files changed, 0 insertions, 0 deletions