aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChuck Lever <chuck.lever@oracle.com>2006-08-22 20:06:19 -0400
committerTrond Myklebust <Trond.Myklebust@netapp.com>2006-09-22 23:24:48 -0400
commitc4efcb1d3e0bc76aeb9ca6301d19a5079893c6c9 (patch)
tree23f113b897f1ab2e00e4fcf774d93711d7f703b8
parente7f7865743fff3d3938ec7540e5a784d662426da (diff)
SUNRPC: Use "sockaddr_storage" for storing RPC client's remote peer address
IPv6 addresses are big (128 bytes). Now that no RPC client consumers treat the addr field in rpc_xprt structs as an opaque, and access it only via the API calls, we can safely widen the field in the rpc_xprt struct to accomodate larger addresses. Test plan: Compile kernel with CONFIG_NFS enabled. Signed-off-by: Chuck Lever <chuck.lever@oracle.com> Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
-rw-r--r--include/linux/sunrpc/xprt.h3
-rw-r--r--net/sunrpc/clnt.c2
-rw-r--r--net/sunrpc/xprt.c3
-rw-r--r--net/sunrpc/xprtsock.c15
4 files changed, 15 insertions, 8 deletions
diff --git a/include/linux/sunrpc/xprt.h b/include/linux/sunrpc/xprt.h
index 8372ab8fc9b5..fc05cfbd5805 100644
--- a/include/linux/sunrpc/xprt.h
+++ b/include/linux/sunrpc/xprt.h
@@ -134,7 +134,8 @@ struct rpc_xprt {
134 struct sock * inet; /* INET layer */ 134 struct sock * inet; /* INET layer */
135 135
136 struct rpc_timeout timeout; /* timeout parms */ 136 struct rpc_timeout timeout; /* timeout parms */
137 struct sockaddr_in addr; /* server address */ 137 struct sockaddr_storage addr; /* server address */
138 size_t addrlen; /* size of server address */
138 int prot; /* IP protocol */ 139 int prot; /* IP protocol */
139 140
140 unsigned long cong; /* current congestion */ 141 unsigned long cong; /* current congestion */
diff --git a/net/sunrpc/clnt.c b/net/sunrpc/clnt.c
index e5b19e348d88..ff1e90fd81ab 100644
--- a/net/sunrpc/clnt.c
+++ b/net/sunrpc/clnt.c
@@ -550,7 +550,7 @@ size_t rpc_peeraddr(struct rpc_clnt *clnt, struct sockaddr *buf, size_t bufsize)
550 if (bytes > bufsize) 550 if (bytes > bufsize)
551 bytes = bufsize; 551 bytes = bufsize;
552 memcpy(buf, &clnt->cl_xprt->addr, bytes); 552 memcpy(buf, &clnt->cl_xprt->addr, bytes);
553 return sizeof(xprt->addr); 553 return xprt->addrlen;
554} 554}
555EXPORT_SYMBOL(rpc_peeraddr); 555EXPORT_SYMBOL(rpc_peeraddr);
556 556
diff --git a/net/sunrpc/xprt.c b/net/sunrpc/xprt.c
index b45abd0743cb..4987517cc74b 100644
--- a/net/sunrpc/xprt.c
+++ b/net/sunrpc/xprt.c
@@ -896,7 +896,8 @@ static struct rpc_xprt *xprt_setup(int proto, struct sockaddr_in *ap, struct rpc
896 if ((xprt = kzalloc(sizeof(struct rpc_xprt), GFP_KERNEL)) == NULL) 896 if ((xprt = kzalloc(sizeof(struct rpc_xprt), GFP_KERNEL)) == NULL)
897 return ERR_PTR(-ENOMEM); 897 return ERR_PTR(-ENOMEM);
898 898
899 xprt->addr = *ap; 899 memcpy(&xprt->addr, ap, sizeof(*ap));
900 xprt->addrlen = sizeof(*ap);
900 901
901 switch (proto) { 902 switch (proto) {
902 case IPPROTO_UDP: 903 case IPPROTO_UDP:
diff --git a/net/sunrpc/xprtsock.c b/net/sunrpc/xprtsock.c
index cb8e6c34e12f..17179aa4c207 100644
--- a/net/sunrpc/xprtsock.c
+++ b/net/sunrpc/xprtsock.c
@@ -341,7 +341,7 @@ static int xs_udp_send_request(struct rpc_task *task)
341 341
342 req->rq_xtime = jiffies; 342 req->rq_xtime = jiffies;
343 status = xs_sendpages(xprt->sock, (struct sockaddr *) &xprt->addr, 343 status = xs_sendpages(xprt->sock, (struct sockaddr *) &xprt->addr,
344 sizeof(xprt->addr), xdr, req->rq_bytes_sent); 344 xprt->addrlen, xdr, req->rq_bytes_sent);
345 345
346 dprintk("RPC: xs_udp_send_request(%u) = %d\n", 346 dprintk("RPC: xs_udp_send_request(%u) = %d\n",
347 xdr->len - req->rq_bytes_sent, status); 347 xdr->len - req->rq_bytes_sent, status);
@@ -1027,8 +1027,11 @@ static char *xs_print_peer_address(struct rpc_xprt *xprt, enum rpc_display_forma
1027 */ 1027 */
1028static void xs_set_port(struct rpc_xprt *xprt, unsigned short port) 1028static void xs_set_port(struct rpc_xprt *xprt, unsigned short port)
1029{ 1029{
1030 struct sockaddr_in *sap = (struct sockaddr_in *) &xprt->addr;
1031
1030 dprintk("RPC: setting port for xprt %p to %u\n", xprt, port); 1032 dprintk("RPC: setting port for xprt %p to %u\n", xprt, port);
1031 xprt->addr.sin_port = htons(port); 1033
1034 sap->sin_port = htons(port);
1032} 1035}
1033 1036
1034static int xs_bindresvport(struct rpc_xprt *xprt, struct socket *sock) 1037static int xs_bindresvport(struct rpc_xprt *xprt, struct socket *sock)
@@ -1209,7 +1212,7 @@ static void xs_tcp_connect_worker(void *args)
1209 xprt->stat.connect_count++; 1212 xprt->stat.connect_count++;
1210 xprt->stat.connect_start = jiffies; 1213 xprt->stat.connect_start = jiffies;
1211 status = sock->ops->connect(sock, (struct sockaddr *) &xprt->addr, 1214 status = sock->ops->connect(sock, (struct sockaddr *) &xprt->addr,
1212 sizeof(xprt->addr), O_NONBLOCK); 1215 xprt->addrlen, O_NONBLOCK);
1213 dprintk("RPC: %p connect status %d connected %d sock state %d\n", 1216 dprintk("RPC: %p connect status %d connected %d sock state %d\n",
1214 xprt, -status, xprt_connected(xprt), sock->sk->sk_state); 1217 xprt, -status, xprt_connected(xprt), sock->sk->sk_state);
1215 if (status < 0) { 1218 if (status < 0) {
@@ -1359,6 +1362,7 @@ static struct rpc_xprt_ops xs_tcp_ops = {
1359int xs_setup_udp(struct rpc_xprt *xprt, struct rpc_timeout *to) 1362int xs_setup_udp(struct rpc_xprt *xprt, struct rpc_timeout *to)
1360{ 1363{
1361 size_t slot_table_size; 1364 size_t slot_table_size;
1365 struct sockaddr_in *addr = (struct sockaddr_in *) &xprt->addr;
1362 1366
1363 xprt->max_reqs = xprt_udp_slot_table_entries; 1367 xprt->max_reqs = xprt_udp_slot_table_entries;
1364 slot_table_size = xprt->max_reqs * sizeof(xprt->slot[0]); 1368 slot_table_size = xprt->max_reqs * sizeof(xprt->slot[0]);
@@ -1366,7 +1370,7 @@ int xs_setup_udp(struct rpc_xprt *xprt, struct rpc_timeout *to)
1366 if (xprt->slot == NULL) 1370 if (xprt->slot == NULL)
1367 return -ENOMEM; 1371 return -ENOMEM;
1368 1372
1369 if (ntohs(xprt->addr.sin_port) != 0) 1373 if (ntohs(addr->sin_port != 0))
1370 xprt_set_bound(xprt); 1374 xprt_set_bound(xprt);
1371 xprt->port = xs_get_random_port(); 1375 xprt->port = xs_get_random_port();
1372 1376
@@ -1405,6 +1409,7 @@ int xs_setup_udp(struct rpc_xprt *xprt, struct rpc_timeout *to)
1405int xs_setup_tcp(struct rpc_xprt *xprt, struct rpc_timeout *to) 1409int xs_setup_tcp(struct rpc_xprt *xprt, struct rpc_timeout *to)
1406{ 1410{
1407 size_t slot_table_size; 1411 size_t slot_table_size;
1412 struct sockaddr_in *addr = (struct sockaddr_in *) &xprt->addr;
1408 1413
1409 xprt->max_reqs = xprt_tcp_slot_table_entries; 1414 xprt->max_reqs = xprt_tcp_slot_table_entries;
1410 slot_table_size = xprt->max_reqs * sizeof(xprt->slot[0]); 1415 slot_table_size = xprt->max_reqs * sizeof(xprt->slot[0]);
@@ -1412,7 +1417,7 @@ int xs_setup_tcp(struct rpc_xprt *xprt, struct rpc_timeout *to)
1412 if (xprt->slot == NULL) 1417 if (xprt->slot == NULL)
1413 return -ENOMEM; 1418 return -ENOMEM;
1414 1419
1415 if (ntohs(xprt->addr.sin_port) != 0) 1420 if (ntohs(addr->sin_port) != 0)
1416 xprt_set_bound(xprt); 1421 xprt_set_bound(xprt);
1417 xprt->port = xs_get_random_port(); 1422 xprt->port = xs_get_random_port();
1418 1423