aboutsummaryrefslogtreecommitdiffstats
path: root/net/sunrpc
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 /net/sunrpc
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>
Diffstat (limited to 'net/sunrpc')
-rw-r--r--net/sunrpc/clnt.c2
-rw-r--r--net/sunrpc/xprt.c8
-rw-r--r--net/sunrpc/xprtsock.c6
3 files changed, 6 insertions, 10 deletions
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