diff options
Diffstat (limited to 'net/sunrpc/svcsock.c')
-rw-r--r-- | net/sunrpc/svcsock.c | 10 |
1 files changed, 4 insertions, 6 deletions
diff --git a/net/sunrpc/svcsock.c b/net/sunrpc/svcsock.c index d00bc3307745..ac6cd65220c7 100644 --- a/net/sunrpc/svcsock.c +++ b/net/sunrpc/svcsock.c | |||
@@ -1144,13 +1144,11 @@ static struct svc_sock *svc_setup_socket(struct svc_serv *serv, | |||
1144 | svc_tcp_init(svsk, serv); | 1144 | svc_tcp_init(svsk, serv); |
1145 | 1145 | ||
1146 | /* | 1146 | /* |
1147 | * We start one listener per sv_serv. We want AF_INET | 1147 | * If this is a PF_INET6 listener, we want to avoid |
1148 | * requests to be automatically shunted to our PF_INET6 | 1148 | * getting requests from IPv4 remotes. Those should |
1149 | * listener using a mapped IPv4 address. Make sure | 1149 | * be shunted to a PF_INET listener via rpcbind. |
1150 | * no-one starts an equivalent IPv4 listener, which | ||
1151 | * would steal our incoming connections. | ||
1152 | */ | 1150 | */ |
1153 | val = 0; | 1151 | val = 1; |
1154 | if (inet->sk_family == PF_INET6) | 1152 | if (inet->sk_family == PF_INET6) |
1155 | kernel_setsockopt(sock, SOL_IPV6, IPV6_V6ONLY, | 1153 | kernel_setsockopt(sock, SOL_IPV6, IPV6_V6ONLY, |
1156 | (char *)&val, sizeof(val)); | 1154 | (char *)&val, sizeof(val)); |