Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 69231
b: refs/heads/master
c: 4fa016e
h: refs/heads/master
i:
  69229: d0746c8
  69227: 73d97c8
  69223: 5539fc8
  69215: 2af0e66
v: v3
  • Loading branch information
\"Talpey, Thomas\ authored and Trond Myklebust committed Oct 9, 2007
1 parent 24205d2 commit ba41a7f
Show file tree
Hide file tree
Showing 6 changed files with 20 additions and 14 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 49c36fcc441baf6a4d698e3645d1adf28edaf57b
refs/heads/master: 4fa016eb248cac875541fa199af550a8aefa0e90
5 changes: 2 additions & 3 deletions trunk/include/linux/sunrpc/xprt.h
Original file line number Diff line number Diff line change
Expand Up @@ -187,7 +187,7 @@ struct rpc_xprt {
};

struct xprt_create {
int proto; /* IPPROTO_UDP or IPPROTO_TCP */
int ident; /* XPRT_TRANSPORT identifier */
struct sockaddr * srcaddr; /* optional local address */
struct sockaddr * dstaddr; /* remote peer address */
size_t addrlen;
Expand All @@ -196,8 +196,7 @@ struct xprt_create {

struct xprt_class {
struct list_head list;
unsigned short family;
int protocol;
int ident; /* XPRT_TRANSPORT identifier */
struct rpc_xprt * (*setup)(struct xprt_create *);
struct module *owner;
char name[32];
Expand Down
11 changes: 11 additions & 0 deletions trunk/include/linux/sunrpc/xprtsock.h
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,17 @@ struct rpc_xprt *xs_setup_tcp(struct xprt_create *args);
int init_socket_xprt(void);
void cleanup_socket_xprt(void);

/*
* RPC transport identifiers for UDP, TCP
*
* To preserve compatibility with the historical use of raw IP protocol
* id's for transport selection, these are specified with the previous
* values. No such restriction exists for new transports, except that
* they may not collide with these values (17 and 6, respectively).
*/
#define XPRT_TRANSPORT_UDP IPPROTO_UDP
#define XPRT_TRANSPORT_TCP IPPROTO_TCP

/*
* RPC slot table sizes for UDP, TCP transports
*/
Expand Down
2 changes: 1 addition & 1 deletion trunk/net/sunrpc/clnt.c
Original file line number Diff line number Diff line change
Expand Up @@ -241,7 +241,7 @@ struct rpc_clnt *rpc_create(struct rpc_create_args *args)
struct rpc_xprt *xprt;
struct rpc_clnt *clnt;
struct xprt_create xprtargs = {
.proto = args->protocol,
.ident = args->protocol,
.srcaddr = args->saddress,
.dstaddr = args->address,
.addrlen = args->addrsize,
Expand Down
8 changes: 3 additions & 5 deletions trunk/net/sunrpc/xprt.c
Original file line number Diff line number Diff line change
Expand Up @@ -104,7 +104,7 @@ int xprt_register_transport(struct xprt_class *transport)
spin_lock(&xprt_list_lock);
list_for_each_entry(t, &xprt_list, list) {
/* don't register the same transport class twice */
if (t == transport)
if (t->ident == transport->ident)
goto out;
}

Expand Down Expand Up @@ -987,15 +987,13 @@ struct rpc_xprt *xprt_create_transport(struct xprt_create *args)

spin_lock(&xprt_list_lock);
list_for_each_entry(t, &xprt_list, list) {
if ((t->family == args->dstaddr->sa_family) &&
(t->protocol == args->proto)) {
if (t->ident == args->ident) {
spin_unlock(&xprt_list_lock);
goto found;
}
}
spin_unlock(&xprt_list_lock);
printk(KERN_ERR "RPC: transport (%u/%d) not supported\n",
args->dstaddr->sa_family, args->proto);
printk(KERN_ERR "RPC: transport (%d) not supported\n", args->ident);
return ERR_PTR(-EIO);

found:
Expand Down
6 changes: 2 additions & 4 deletions trunk/net/sunrpc/xprtsock.c
Original file line number Diff line number Diff line change
Expand Up @@ -1955,17 +1955,15 @@ static struct xprt_class xs_udp_transport = {
.list = LIST_HEAD_INIT(xs_udp_transport.list),
.name = "udp",
.owner = THIS_MODULE,
.family = AF_INET,
.protocol = IPPROTO_UDP,
.ident = IPPROTO_UDP,
.setup = xs_setup_udp,
};

static struct xprt_class xs_tcp_transport = {
.list = LIST_HEAD_INIT(xs_tcp_transport.list),
.name = "tcp",
.owner = THIS_MODULE,
.family = AF_INET,
.protocol = IPPROTO_TCP,
.ident = IPPROTO_TCP,
.setup = xs_setup_tcp,
};

Expand Down

0 comments on commit ba41a7f

Please sign in to comment.