net: Fix wrong interpretation of some copy_to_user() results.
I found some places, that erroneously return the value obtained from the copy_to_user() call: if some amount of bytes were not able to get to the user (this is what this one returns) the proper behavior is to return the -EFAULT error, not that number itself. Signed-off-by: Pavel Emelyanov <xemul@openvz.org> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
committed by
David S. Miller
parent
cc93d7d77d
commit
653252c230
@@ -573,7 +573,8 @@ static int raw_getsockopt(struct socket *sock, int level, int optname,
|
||||
int fsize = ro->count * sizeof(struct can_filter);
|
||||
if (len > fsize)
|
||||
len = fsize;
|
||||
err = copy_to_user(optval, ro->filter, len);
|
||||
if (copy_to_user(optval, ro->filter, len))
|
||||
err = -EFAULT;
|
||||
} else
|
||||
len = 0;
|
||||
release_sock(sk);
|
||||
|
Reference in New Issue
Block a user