aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
author\"Talpey, Thomas\ <Thomas.Talpey@netapp.com>2007-09-10 13:47:57 -0400
committerTrond Myklebust <Trond.Myklebust@netapp.com>2007-10-09 17:17:50 -0400
commit4fa016eb248cac875541fa199af550a8aefa0e90 (patch)
tree2a8aad2ebc1a05174d0eacaceb671bca6b24850c
parent49c36fcc441baf6a4d698e3645d1adf28edaf57b (diff)
NFS/SUNRPC: support transport protocol naming
To prepare for including non-sockets-based RPC transports, select RPC transports by an identifier (to be used in following patches). Signed-off-by: Tom Talpey <tmt@netapp.com> Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
-rw-r--r--include/linux/sunrpc/xprt.h5
-rw-r--r--include/linux/sunrpc/xprtsock.h11
-rw-r--r--net/sunrpc/clnt.c2
-rw-r--r--net/sunrpc/xprt.c8
-rw-r--r--net/sunrpc/xprtsock.c6
5 files changed, 19 insertions, 13 deletions
diff --git a/include/linux/sunrpc/xprt.h b/include/linux/sunrpc/xprt.h
index d7b8fcd312cc..30b17b3bc1a9 100644
--- a/include/linux/sunrpc/xprt.h
+++ b/include/linux/sunrpc/xprt.h
@@ -187,7 +187,7 @@ struct rpc_xprt {
187}; 187};
188 188
189struct xprt_create { 189struct xprt_create {
190 int proto; /* IPPROTO_UDP or IPPROTO_TCP */ 190 int ident; /* XPRT_TRANSPORT identifier */
191 struct sockaddr * srcaddr; /* optional local address */ 191 struct sockaddr * srcaddr; /* optional local address */
192 struct sockaddr * dstaddr; /* remote peer address */ 192 struct sockaddr * dstaddr; /* remote peer address */
193 size_t addrlen; 193 size_t addrlen;
@@ -196,8 +196,7 @@ struct xprt_create {
196 196
197struct xprt_class { 197struct xprt_class {
198 struct list_head list; 198 struct list_head list;
199 unsigned short family; 199 int ident; /* XPRT_TRANSPORT identifier */
200 int protocol;
201 struct rpc_xprt * (*setup)(struct xprt_create *); 200 struct rpc_xprt * (*setup)(struct xprt_create *);
202 struct module *owner; 201 struct module *owner;
203 char name[32]; 202 char name[32];
diff --git a/include/linux/sunrpc/xprtsock.h b/include/linux/sunrpc/xprtsock.h
index 9bde77061e4f..2c6c2c2783d8 100644
--- a/include/linux/sunrpc/xprtsock.h
+++ b/include/linux/sunrpc/xprtsock.h
@@ -19,6 +19,17 @@ int init_socket_xprt(void);
19void cleanup_socket_xprt(void); 19void cleanup_socket_xprt(void);
20 20
21/* 21/*
22 * RPC transport identifiers for UDP, TCP
23 *
24 * To preserve compatibility with the historical use of raw IP protocol
25 * id's for transport selection, these are specified with the previous
26 * values. No such restriction exists for new transports, except that
27 * they may not collide with these values (17 and 6, respectively).
28 */
29#define XPRT_TRANSPORT_UDP IPPROTO_UDP
30#define XPRT_TRANSPORT_TCP IPPROTO_TCP
31
32/*
22 * RPC slot table sizes for UDP, TCP transports 33 * RPC slot table sizes for UDP, TCP transports
23 */ 34 */
24extern unsigned int xprt_udp_slot_table_entries; 35extern unsigned int xprt_udp_slot_table_entries;
diff --git a/net/sunrpc/clnt.c b/net/sunrpc/clnt.c
index e86958c61a20..6cdf53c489b7 100644
--- a/net/sunrpc/clnt.c
+++ b/net/sunrpc/clnt.c
@@ -241,7 +241,7 @@ struct rpc_clnt *rpc_create(struct rpc_create_args *args)
241 struct rpc_xprt *xprt; 241 struct rpc_xprt *xprt;
242 struct rpc_clnt *clnt; 242 struct rpc_clnt *clnt;
243 struct xprt_create xprtargs = { 243 struct xprt_create xprtargs = {
244 .proto = args->protocol, 244 .ident = args->protocol,
245 .srcaddr = args->saddress, 245 .srcaddr = args->saddress,
246 .dstaddr = args->address, 246 .dstaddr = args->address,
247 .addrlen = args->addrsize, 247 .addrlen = args->addrsize,
diff --git a/net/sunrpc/xprt.c b/net/sunrpc/xprt.c
index 473b48ff4523..282a9a2ec90c 100644
--- a/net/sunrpc/xprt.c
+++ b/net/sunrpc/xprt.c
@@ -104,7 +104,7 @@ int xprt_register_transport(struct xprt_class *transport)
104 spin_lock(&xprt_list_lock); 104 spin_lock(&xprt_list_lock);
105 list_for_each_entry(t, &xprt_list, list) { 105 list_for_each_entry(t, &xprt_list, list) {
106 /* don't register the same transport class twice */ 106 /* don't register the same transport class twice */
107 if (t == transport) 107 if (t->ident == transport->ident)
108 goto out; 108 goto out;
109 } 109 }
110 110
@@ -987,15 +987,13 @@ struct rpc_xprt *xprt_create_transport(struct xprt_create *args)
987 987
988 spin_lock(&xprt_list_lock); 988 spin_lock(&xprt_list_lock);
989 list_for_each_entry(t, &xprt_list, list) { 989 list_for_each_entry(t, &xprt_list, list) {
990 if ((t->family == args->dstaddr->sa_family) && 990 if (t->ident == args->ident) {
991 (t->protocol == args->proto)) {
992 spin_unlock(&xprt_list_lock); 991 spin_unlock(&xprt_list_lock);
993 goto found; 992 goto found;
994 } 993 }
995 } 994 }
996 spin_unlock(&xprt_list_lock); 995 spin_unlock(&xprt_list_lock);
997 printk(KERN_ERR "RPC: transport (%u/%d) not supported\n", 996 printk(KERN_ERR "RPC: transport (%d) not supported\n", args->ident);
998 args->dstaddr->sa_family, args->proto);
999 return ERR_PTR(-EIO); 997 return ERR_PTR(-EIO);
1000 998
1001found: 999found:
diff --git a/net/sunrpc/xprtsock.c b/net/sunrpc/xprtsock.c
index 192a06e3b8c5..b81494a97a5e 100644
--- a/net/sunrpc/xprtsock.c
+++ b/net/sunrpc/xprtsock.c
@@ -1955,8 +1955,7 @@ static struct xprt_class xs_udp_transport = {
1955 .list = LIST_HEAD_INIT(xs_udp_transport.list), 1955 .list = LIST_HEAD_INIT(xs_udp_transport.list),
1956 .name = "udp", 1956 .name = "udp",
1957 .owner = THIS_MODULE, 1957 .owner = THIS_MODULE,
1958 .family = AF_INET, 1958 .ident = IPPROTO_UDP,
1959 .protocol = IPPROTO_UDP,
1960 .setup = xs_setup_udp, 1959 .setup = xs_setup_udp,
1961}; 1960};
1962 1961
@@ -1964,8 +1963,7 @@ static struct xprt_class xs_tcp_transport = {
1964 .list = LIST_HEAD_INIT(xs_tcp_transport.list), 1963 .list = LIST_HEAD_INIT(xs_tcp_transport.list),
1965 .name = "tcp", 1964 .name = "tcp",
1966 .owner = THIS_MODULE, 1965 .owner = THIS_MODULE,
1967 .family = AF_INET, 1966 .ident = IPPROTO_TCP,
1968 .protocol = IPPROTO_TCP,
1969 .setup = xs_setup_tcp, 1967 .setup = xs_setup_tcp,
1970}; 1968};
1971 1969