sunrpc: Tag rpc_xprt with net
authorPavel Emelyanov <xemul@parallels.com>
Wed, 29 Sep 2010 12:05:43 +0000 (16:05 +0400)
committerJ. Bruce Fields <bfields@redhat.com>
Fri, 1 Oct 2010 21:18:58 +0000 (17:18 -0400)
The net is known from the xprt_create and this tagging will also
give un the context in the conntection workers where real sockets
are created.

Signed-off-by: Pavel Emelyanov <xemul@openvz.org>
Signed-off-by: J. Bruce Fields <bfields@redhat.com>
include/linux/sunrpc/xprt.h
net/sunrpc/xprt.c
net/sunrpc/xprtrdma/transport.c
net/sunrpc/xprtsock.c

index c4f931597d0efab028af29506a93f182df51a62c..89d10d279a203d611bbc3f40760ab490c8eea098 100644 (file)
@@ -224,6 +224,7 @@ struct rpc_xprt {
                                        bklog_u;        /* backlog queue utilization */
        } stat;
 
+       struct net              *xprt_net;
        const char              *address_strings[RPC_DISPLAY_MAX];
 };
 
@@ -281,7 +282,7 @@ void                        xprt_release_xprt_cong(struct rpc_xprt *xprt, struct rpc_task *task);
 void                   xprt_release(struct rpc_task *task);
 struct rpc_xprt *      xprt_get(struct rpc_xprt *xprt);
 void                   xprt_put(struct rpc_xprt *xprt);
-struct rpc_xprt *      xprt_alloc(int size, int max_req);
+struct rpc_xprt *      xprt_alloc(struct net *net, int size, int max_req);
 void                   xprt_free(struct rpc_xprt *);
 
 static inline __be32 *xprt_skip_transport_header(struct rpc_xprt *xprt, __be32 *p)
index 0637340e53426c59b4fb019b259fd237741e7457..953206d8c6c2b436a95645a8d36faecddd63f2da 100644 (file)
@@ -962,7 +962,7 @@ static void xprt_free_slot(struct rpc_xprt *xprt, struct rpc_rqst *req)
        spin_unlock(&xprt->reserve_lock);
 }
 
-struct rpc_xprt *xprt_alloc(int size, int max_req)
+struct rpc_xprt *xprt_alloc(struct net *net, int size, int max_req)
 {
        struct rpc_xprt *xprt;
 
@@ -975,6 +975,7 @@ struct rpc_xprt *xprt_alloc(int size, int max_req)
        if (xprt->slot == NULL)
                goto out_free;
 
+       xprt->xprt_net = get_net(net);
        return xprt;
 
 out_free:
@@ -986,6 +987,7 @@ EXPORT_SYMBOL_GPL(xprt_alloc);
 
 void xprt_free(struct rpc_xprt *xprt)
 {
+       put_net(xprt->xprt_net);
        kfree(xprt->slot);
        kfree(xprt);
 }
index 0f7a1b9d05ada4b85e620abf7a3956b045b894f8..2da32b40bfcfc43bcabc9f98cf21ccec6100823f 100644 (file)
@@ -283,7 +283,7 @@ xprt_setup_rdma(struct xprt_create *args)
                return ERR_PTR(-EBADF);
        }
 
-       xprt = xprt_alloc(sizeof(struct rpcrdma_xprt),
+       xprt = xprt_alloc(args->net, sizeof(struct rpcrdma_xprt),
                        xprt_rdma_slot_table_entries);
        if (xprt == NULL) {
                dprintk("RPC:       %s: couldn't allocate rpcrdma_xprt\n",
index b1e36ec6fd80bba57daaebe08267e1510f5148b7..4ef3a6a9445c64ac91fde44e2b06d67b2b373968 100644 (file)
@@ -2272,7 +2272,7 @@ static struct rpc_xprt *xs_setup_xprt(struct xprt_create *args,
                return ERR_PTR(-EBADF);
        }
 
-       xprt = xprt_alloc(sizeof(*new), slot_table_size);
+       xprt = xprt_alloc(args->net, sizeof(*new), slot_table_size);
        if (xprt == NULL) {
                dprintk("RPC:       xs_setup_xprt: couldn't allocate "
                                "rpc_xprt\n");