diff options
author | \"Talpey, Thomas\ <Thomas.Talpey@netapp.com> | 2007-09-10 13:47:57 -0400 |
---|---|---|
committer | Trond Myklebust <Trond.Myklebust@netapp.com> | 2007-10-09 17:17:50 -0400 |
commit | 4fa016eb248cac875541fa199af550a8aefa0e90 (patch) | |
tree | 2a8aad2ebc1a05174d0eacaceb671bca6b24850c | |
parent | 49c36fcc441baf6a4d698e3645d1adf28edaf57b (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.h | 5 | ||||
-rw-r--r-- | include/linux/sunrpc/xprtsock.h | 11 | ||||
-rw-r--r-- | net/sunrpc/clnt.c | 2 | ||||
-rw-r--r-- | net/sunrpc/xprt.c | 8 | ||||
-rw-r--r-- | net/sunrpc/xprtsock.c | 6 |
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 | ||
189 | struct xprt_create { | 189 | struct 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 | ||
197 | struct xprt_class { | 197 | struct 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); | |||
19 | void cleanup_socket_xprt(void); | 19 | void 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 | */ |
24 | extern unsigned int xprt_udp_slot_table_entries; | 35 | extern 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 | ||
1001 | found: | 999 | found: |
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 | ||