sunrpc: replace svc_serv->sv_bc_xprt by boolean flag
authorVasily Averin <vvs@virtuozzo.com>
Mon, 24 Dec 2018 11:45:04 +0000 (14:45 +0300)
committerJ. Bruce Fields <bfields@redhat.com>
Fri, 28 Dec 2018 02:01:41 +0000 (21:01 -0500)
svc_serv-> sv_bc_xprt is netns-unsafe and cannot be used as pointer.
To prevent its misuse in future it is replaced by new boolean flag.

Signed-off-by: Vasily Averin <vvs@virtuozzo.com>
Signed-off-by: J. Bruce Fields <bfields@redhat.com>
fs/nfs/callback.c
include/linux/sunrpc/bc_xprt.h
include/linux/sunrpc/svc.h
net/sunrpc/svcsock.c
net/sunrpc/xprtrdma/svc_rdma_transport.c

index 509dc5adeb8f79e9f5508274e32039547873ed45..6dd04774aedcf1b8127731e20385d4e257b53f67 100644 (file)
@@ -206,11 +206,13 @@ static int nfs_callback_up_net(int minorversion, struct svc_serv *serv,
                goto err_bind;
        }
 
-       ret = -EPROTONOSUPPORT;
+       ret = 0;
        if (!IS_ENABLED(CONFIG_NFS_V4_1) || minorversion == 0)
                ret = nfs4_callback_up_net(serv, net);
-       else if (xprt->ops->bc_up)
-               ret = xprt->ops->bc_up(serv, net);
+       else if (xprt->ops->bc_setup)
+               serv->sv_bc_enabled = true;
+       else
+               ret = -EPROTONOSUPPORT;
 
        if (ret < 0) {
                printk(KERN_ERR "NFS: callback service start failed\n");
index 28721cf73ec3cfe247c54e8f802eac18a551aa6f..4e8c773d02bef3628c9bdc6c7a1b7e9072d4c357 100644 (file)
@@ -47,11 +47,9 @@ void xprt_free_bc_rqst(struct rpc_rqst *req);
 /*
  * Determine if a shared backchannel is in use
  */
-static inline int svc_is_backchannel(const struct svc_rqst *rqstp)
+static inline bool svc_is_backchannel(const struct svc_rqst *rqstp)
 {
-       if (rqstp->rq_server->sv_bc_xprt)
-               return 1;
-       return 0;
+       return rqstp->rq_server->sv_bc_enabled;
 }
 #else /* CONFIG_SUNRPC_BACKCHANNEL */
 static inline int xprt_setup_backchannel(struct rpc_xprt *xprt,
@@ -60,9 +58,9 @@ static inline int xprt_setup_backchannel(struct rpc_xprt *xprt,
        return 0;
 }
 
-static inline int svc_is_backchannel(const struct svc_rqst *rqstp)
+static inline bool svc_is_backchannel(const struct svc_rqst *rqstp)
 {
-       return 0;
+       return false;
 }
 
 static inline void xprt_free_bc_request(struct rpc_rqst *req)
index fdb6b317d974739afcdf5519d8872790493bc244..e52385340b3b874c3d047b01873791b2bfbd5397 100644 (file)
@@ -109,7 +109,7 @@ struct svc_serv {
        spinlock_t              sv_cb_lock;     /* protects the svc_cb_list */
        wait_queue_head_t       sv_cb_waitq;    /* sleep here if there are no
                                                 * entries in the svc_cb_list */
-       struct svc_xprt         *sv_bc_xprt;    /* callback on fore channel */
+       bool                    sv_bc_enabled;  /* service uses backchannel */
 #endif /* CONFIG_SUNRPC_BACKCHANNEL */
 };
 
index 793149ba1bdaff141993075b9c8ae46e0cda3565..8ce181ecb62765131f7bb88fab2df8bb13cf622d 100644 (file)
@@ -1623,8 +1623,6 @@ static struct svc_xprt *svc_bc_create_socket(struct svc_serv *serv,
        svc_xprt_init(net, &svc_tcp_bc_class, xprt, serv);
        set_bit(XPT_CONG_CTRL, &svsk->sk_xprt.xpt_flags);
 
-       serv->sv_bc_xprt = xprt;
-
        return xprt;
 }
 
index 2f7ec8912f49417f2fc65afc7e6d067e74559de9..d410e6f34f443c62693b86d72eb203ed678a3c74 100644 (file)
@@ -136,7 +136,6 @@ static struct svc_xprt *svc_rdma_bc_create(struct svc_serv *serv,
 
        svc_xprt_init(net, &svc_rdma_bc_class, xprt, serv);
        set_bit(XPT_CONG_CTRL, &xprt->xpt_flags);
-       serv->sv_bc_xprt = xprt;
 
        dprintk("svcrdma: %s(%p)\n", __func__, xprt);
        return xprt;