Commit 28190752 authored by Sowmini Varadhan's avatar Sowmini Varadhan Committed by David S. Miller

sock: permit SO_ZEROCOPY on PF_RDS socket

allow the application to set SO_ZEROCOPY on the underlying sk
of a PF_RDS socket
Signed-off-by: default avatarSowmini Varadhan <sowmini.varadhan@oracle.com>
Acked-by: default avatarWillem de Bruijn <willemb@google.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent ea8994cb
...@@ -1049,18 +1049,21 @@ int sock_setsockopt(struct socket *sock, int level, int optname, ...@@ -1049,18 +1049,21 @@ int sock_setsockopt(struct socket *sock, int level, int optname,
break; break;
case SO_ZEROCOPY: case SO_ZEROCOPY:
if (sk->sk_family != PF_INET && sk->sk_family != PF_INET6) if (sk->sk_family == PF_INET || sk->sk_family == PF_INET6) {
if (sk->sk_protocol != IPPROTO_TCP)
ret = -ENOTSUPP;
else if (sk->sk_state != TCP_CLOSE)
ret = -EBUSY;
} else if (sk->sk_family != PF_RDS) {
ret = -ENOTSUPP; ret = -ENOTSUPP;
else if (sk->sk_protocol != IPPROTO_TCP) }
ret = -ENOTSUPP; if (!ret) {
else if (sk->sk_state != TCP_CLOSE) if (val < 0 || val > 1)
ret = -EBUSY; ret = -EINVAL;
else if (val < 0 || val > 1) else
ret = -EINVAL; sock_valbool_flag(sk, SOCK_ZEROCOPY, valbool);
else break;
sock_valbool_flag(sk, SOCK_ZEROCOPY, valbool); }
break;
default: default:
ret = -ENOPROTOOPT; ret = -ENOPROTOOPT;
break; break;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment