aboutsummaryrefslogtreecommitdiffstats
path: root/net/sunrpc/xprtsock.c
diff options
context:
space:
mode:
Diffstat (limited to 'net/sunrpc/xprtsock.c')
-rw-r--r--net/sunrpc/xprtsock.c24
1 files changed, 12 insertions, 12 deletions
diff --git a/net/sunrpc/xprtsock.c b/net/sunrpc/xprtsock.c
index 302a40904923..7bc3c178ccb3 100644
--- a/net/sunrpc/xprtsock.c
+++ b/net/sunrpc/xprtsock.c
@@ -248,8 +248,8 @@ struct sock_xprt {
248 * Connection of transports 248 * Connection of transports
249 */ 249 */
250 struct delayed_work connect_worker; 250 struct delayed_work connect_worker;
251 struct sockaddr_storage addr; 251 struct sockaddr_storage srcaddr;
252 unsigned short port; 252 unsigned short srcport;
253 253
254 /* 254 /*
255 * UDP socket buffer size parameters 255 * UDP socket buffer size parameters
@@ -1546,7 +1546,7 @@ static void xs_set_port(struct rpc_xprt *xprt, unsigned short port)
1546 1546
1547static unsigned short xs_get_srcport(struct sock_xprt *transport, struct socket *sock) 1547static unsigned short xs_get_srcport(struct sock_xprt *transport, struct socket *sock)
1548{ 1548{
1549 unsigned short port = transport->port; 1549 unsigned short port = transport->srcport;
1550 1550
1551 if (port == 0 && transport->xprt.resvport) 1551 if (port == 0 && transport->xprt.resvport)
1552 port = xs_get_random_port(); 1552 port = xs_get_random_port();
@@ -1555,8 +1555,8 @@ static unsigned short xs_get_srcport(struct sock_xprt *transport, struct socket
1555 1555
1556static unsigned short xs_next_srcport(struct sock_xprt *transport, struct socket *sock, unsigned short port) 1556static unsigned short xs_next_srcport(struct sock_xprt *transport, struct socket *sock, unsigned short port)
1557{ 1557{
1558 if (transport->port != 0) 1558 if (transport->srcport != 0)
1559 transport->port = 0; 1559 transport->srcport = 0;
1560 if (!transport->xprt.resvport) 1560 if (!transport->xprt.resvport)
1561 return 0; 1561 return 0;
1562 if (port <= xprt_min_resvport || port > xprt_max_resvport) 1562 if (port <= xprt_min_resvport || port > xprt_max_resvport)
@@ -1574,7 +1574,7 @@ static int xs_bind4(struct sock_xprt *transport, struct socket *sock)
1574 unsigned short port = xs_get_srcport(transport, sock); 1574 unsigned short port = xs_get_srcport(transport, sock);
1575 unsigned short last; 1575 unsigned short last;
1576 1576
1577 sa = (struct sockaddr_in *)&transport->addr; 1577 sa = (struct sockaddr_in *)&transport->srcaddr;
1578 myaddr.sin_addr = sa->sin_addr; 1578 myaddr.sin_addr = sa->sin_addr;
1579 do { 1579 do {
1580 myaddr.sin_port = htons(port); 1580 myaddr.sin_port = htons(port);
@@ -1583,7 +1583,7 @@ static int xs_bind4(struct sock_xprt *transport, struct socket *sock)
1583 if (port == 0) 1583 if (port == 0)
1584 break; 1584 break;
1585 if (err == 0) { 1585 if (err == 0) {
1586 transport->port = port; 1586 transport->srcport = port;
1587 break; 1587 break;
1588 } 1588 }
1589 last = port; 1589 last = port;
@@ -1607,7 +1607,7 @@ static int xs_bind6(struct sock_xprt *transport, struct socket *sock)
1607 unsigned short port = xs_get_srcport(transport, sock); 1607 unsigned short port = xs_get_srcport(transport, sock);
1608 unsigned short last; 1608 unsigned short last;
1609 1609
1610 sa = (struct sockaddr_in6 *)&transport->addr; 1610 sa = (struct sockaddr_in6 *)&transport->srcaddr;
1611 myaddr.sin6_addr = sa->sin6_addr; 1611 myaddr.sin6_addr = sa->sin6_addr;
1612 do { 1612 do {
1613 myaddr.sin6_port = htons(port); 1613 myaddr.sin6_port = htons(port);
@@ -1616,7 +1616,7 @@ static int xs_bind6(struct sock_xprt *transport, struct socket *sock)
1616 if (port == 0) 1616 if (port == 0)
1617 break; 1617 break;
1618 if (err == 0) { 1618 if (err == 0) {
1619 transport->port = port; 1619 transport->srcport = port;
1620 break; 1620 break;
1621 } 1621 }
1622 last = port; 1622 last = port;
@@ -2061,7 +2061,7 @@ static void xs_udp_print_stats(struct rpc_xprt *xprt, struct seq_file *seq)
2061 struct sock_xprt *transport = container_of(xprt, struct sock_xprt, xprt); 2061 struct sock_xprt *transport = container_of(xprt, struct sock_xprt, xprt);
2062 2062
2063 seq_printf(seq, "\txprt:\tudp %u %lu %lu %lu %lu %Lu %Lu\n", 2063 seq_printf(seq, "\txprt:\tudp %u %lu %lu %lu %lu %Lu %Lu\n",
2064 transport->port, 2064 transport->srcport,
2065 xprt->stat.bind_count, 2065 xprt->stat.bind_count,
2066 xprt->stat.sends, 2066 xprt->stat.sends,
2067 xprt->stat.recvs, 2067 xprt->stat.recvs,
@@ -2085,7 +2085,7 @@ static void xs_tcp_print_stats(struct rpc_xprt *xprt, struct seq_file *seq)
2085 idle_time = (long)(jiffies - xprt->last_used) / HZ; 2085 idle_time = (long)(jiffies - xprt->last_used) / HZ;
2086 2086
2087 seq_printf(seq, "\txprt:\ttcp %u %lu %lu %lu %ld %lu %lu %lu %Lu %Lu\n", 2087 seq_printf(seq, "\txprt:\ttcp %u %lu %lu %lu %ld %lu %lu %lu %Lu %Lu\n",
2088 transport->port, 2088 transport->srcport,
2089 xprt->stat.bind_count, 2089 xprt->stat.bind_count,
2090 xprt->stat.connect_count, 2090 xprt->stat.connect_count,
2091 xprt->stat.connect_time, 2091 xprt->stat.connect_time,
@@ -2164,7 +2164,7 @@ static struct rpc_xprt *xs_setup_xprt(struct xprt_create *args,
2164 memcpy(&xprt->addr, args->dstaddr, args->addrlen); 2164 memcpy(&xprt->addr, args->dstaddr, args->addrlen);
2165 xprt->addrlen = args->addrlen; 2165 xprt->addrlen = args->addrlen;
2166 if (args->srcaddr) 2166 if (args->srcaddr)
2167 memcpy(&new->addr, args->srcaddr, args->addrlen); 2167 memcpy(&new->srcaddr, args->srcaddr, args->addrlen);
2168 2168
2169 return xprt; 2169 return xprt;
2170} 2170}