]> git.ipfire.org Git - thirdparty/kernel/stable-queue.git/commitdiff
drop sunrpc patch that broke the build
authorGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 10 Jan 2019 18:19:45 +0000 (19:19 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 10 Jan 2019 18:19:45 +0000 (19:19 +0100)
queue-4.14/series
queue-4.14/sunrpc-use-after-free-in-svc_process_common.patch [deleted file]
queue-4.19/series
queue-4.19/sunrpc-use-after-free-in-svc_process_common.patch [deleted file]
queue-4.20/series
queue-4.20/sunrpc-use-after-free-in-svc_process_common.patch [deleted file]

index aa6d500937e34bc8bed8044b30a271d9d807e028..c20717d30b7fe3f3a498470b9f6e94c380f492f9 100644 (file)
@@ -66,4 +66,3 @@ mm-hmm-mark-hmm_devmem_-add-add_resource-export_symbol_gpl.patch
 mm-swap-fix-swapoff-with-ksm-pages.patch
 sunrpc-fix-cache_head-leak-due-to-queued-request.patch
 sunrpc-use-svc_net-in-svcauth_gss_-functions.patch
-sunrpc-use-after-free-in-svc_process_common.patch
diff --git a/queue-4.14/sunrpc-use-after-free-in-svc_process_common.patch b/queue-4.14/sunrpc-use-after-free-in-svc_process_common.patch
deleted file mode 100644 (file)
index bcccc91..0000000
+++ /dev/null
@@ -1,143 +0,0 @@
-From d4b09acf924b84bae77cad090a9d108e70b43643 Mon Sep 17 00:00:00 2001
-From: Vasily Averin <vvs@virtuozzo.com>
-Date: Mon, 24 Dec 2018 14:44:52 +0300
-Subject: sunrpc: use-after-free in svc_process_common()
-
-From: Vasily Averin <vvs@virtuozzo.com>
-
-commit d4b09acf924b84bae77cad090a9d108e70b43643 upstream.
-
-if node have NFSv41+ mounts inside several net namespaces
-it can lead to use-after-free in svc_process_common()
-
-svc_process_common()
-        /* Setup reply header */
-        rqstp->rq_xprt->xpt_ops->xpo_prep_reply_hdr(rqstp); <<< HERE
-
-svc_process_common() can use incorrect rqstp->rq_xprt,
-its caller function bc_svc_process() takes it from serv->sv_bc_xprt.
-The problem is that serv is global structure but sv_bc_xprt
-is assigned per-netnamespace.
-
-According to Trond, the whole "let's set up rqstp->rq_xprt
-for the back channel" is nothing but a giant hack in order
-to work around the fact that svc_process_common() uses it
-to find the xpt_ops, and perform a couple of (meaningless
-for the back channel) tests of xpt_flags.
-
-All we really need in svc_process_common() is to be able to run
-rqstp->rq_xprt->xpt_ops->xpo_prep_reply_hdr()
-
-Bruce J Fields points that this xpo_prep_reply_hdr() call
-is an awfully roundabout way just to do "svc_putnl(resv, 0);"
-in the tcp case.
-
-This patch does not initialiuze rqstp->rq_xprt in bc_svc_process(),
-now it calls svc_process_common() with rqstp->rq_xprt = NULL.
-
-To adjust reply header svc_process_common() just check
-rqstp->rq_prot and calls svc_tcp_prep_reply_hdr() for tcp case.
-
-To handle rqstp->rq_xprt = NULL case in functions called from
-svc_process_common() patch intruduces net namespace pointer
-svc_rqst->rq_bc_net and adjust SVC_NET() definition.
-Some other function was also adopted to properly handle described case.
-
-Signed-off-by: Vasily Averin <vvs@virtuozzo.com>
-Cc: stable@vger.kernel.org
-Fixes: 23c20ecd4475 ("NFS: callback up - users counting cleanup")
-Signed-off-by: J. Bruce Fields <bfields@redhat.com>
-Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-
----
- include/linux/sunrpc/svc.h |    5 ++++-
- net/sunrpc/svc.c           |    9 +++++----
- net/sunrpc/svc_xprt.c      |    5 +++--
- net/sunrpc/svcsock.c       |    2 +-
- 4 files changed, 13 insertions(+), 8 deletions(-)
-
---- a/include/linux/sunrpc/svc.h
-+++ b/include/linux/sunrpc/svc.h
-@@ -292,9 +292,12 @@ struct svc_rqst {
-       struct svc_cacherep *   rq_cacherep;    /* cache info */
-       struct task_struct      *rq_task;       /* service thread */
-       spinlock_t              rq_lock;        /* per-request lock */
-+      struct net              *rq_bc_net;     /* pointer to backchannel's
-+                                               * net namespace
-+                                               */
- };
--#define SVC_NET(svc_rqst)     (svc_rqst->rq_xprt->xpt_net)
-+#define SVC_NET(rqst) (rqst->rq_xprt ? rqst->rq_xprt->xpt_net : rqst->rq_bc_net)
- /*
-  * Rigorous type checking on sockaddr type conversions
---- a/net/sunrpc/svc.c
-+++ b/net/sunrpc/svc.c
-@@ -1172,7 +1172,8 @@ svc_process_common(struct svc_rqst *rqst
-       clear_bit(RQ_DROPME, &rqstp->rq_flags);
-       /* Setup reply header */
--      rqstp->rq_xprt->xpt_ops->xpo_prep_reply_hdr(rqstp);
-+      if (rqstp->rq_prot == IPPROTO_TCP)
-+              svc_tcp_prep_reply_hdr(rqstp);
-       svc_putu32(resv, rqstp->rq_xid);
-@@ -1244,7 +1245,7 @@ svc_process_common(struct svc_rqst *rqst
-        * for lower versions. RPC_PROG_MISMATCH seems to be the closest
-        * fit.
-        */
--      if (versp->vs_need_cong_ctrl &&
-+      if (versp->vs_need_cong_ctrl && rqstp->rq_xprt &&
-           !test_bit(XPT_CONG_CTRL, &rqstp->rq_xprt->xpt_flags))
-               goto err_bad_vers;
-@@ -1335,7 +1336,7 @@ svc_process_common(struct svc_rqst *rqst
-       return 0;
-  close:
--      if (test_bit(XPT_TEMP, &rqstp->rq_xprt->xpt_flags))
-+      if (rqstp->rq_xprt && test_bit(XPT_TEMP, &rqstp->rq_xprt->xpt_flags))
-               svc_close_xprt(rqstp->rq_xprt);
-       dprintk("svc: svc_process close\n");
-       return 0;
-@@ -1462,10 +1463,10 @@ bc_svc_process(struct svc_serv *serv, st
-       dprintk("svc: %s(%p)\n", __func__, req);
-       /* Build the svc_rqst used by the common processing routine */
--      rqstp->rq_xprt = serv->sv_bc_xprt;
-       rqstp->rq_xid = req->rq_xid;
-       rqstp->rq_prot = req->rq_xprt->prot;
-       rqstp->rq_server = serv;
-+      rqstp->rq_bc_net = req->rq_xprt->xprt_net;
-       rqstp->rq_addrlen = sizeof(req->rq_xprt->addr);
-       memcpy(&rqstp->rq_addr, &req->rq_xprt->addr, rqstp->rq_addrlen);
---- a/net/sunrpc/svc_xprt.c
-+++ b/net/sunrpc/svc_xprt.c
-@@ -510,10 +510,11 @@ out:
-  */
- void svc_reserve(struct svc_rqst *rqstp, int space)
- {
-+      struct svc_xprt *xprt = rqstp->rq_xprt;
-+
-       space += rqstp->rq_res.head[0].iov_len;
--      if (space < rqstp->rq_reserved) {
--              struct svc_xprt *xprt = rqstp->rq_xprt;
-+      if (xprt && space < rqstp->rq_reserved) {
-               atomic_sub((rqstp->rq_reserved - space), &xprt->xpt_reserved);
-               rqstp->rq_reserved = space;
---- a/net/sunrpc/svcsock.c
-+++ b/net/sunrpc/svcsock.c
-@@ -1207,7 +1207,7 @@ static int svc_tcp_sendto(struct svc_rqs
- /*
-  * Setup response header. TCP has a 4B record length field.
-  */
--static void svc_tcp_prep_reply_hdr(struct svc_rqst *rqstp)
-+void svc_tcp_prep_reply_hdr(struct svc_rqst *rqstp)
- {
-       struct kvec *resv = &rqstp->rq_res.head[0];
index a77f12101358e2c476d0a55dc21b16e2d14cae39..14bfe4965dde53c428c6c3f3669d2a8c217b6817 100644 (file)
@@ -89,4 +89,3 @@ mm-swap-fix-swapoff-with-ksm-pages.patch
 memcg-oom-notify-on-oom-killer-invocation-from-the-charge-path.patch
 sunrpc-fix-cache_head-leak-due-to-queued-request.patch
 sunrpc-use-svc_net-in-svcauth_gss_-functions.patch
-sunrpc-use-after-free-in-svc_process_common.patch
diff --git a/queue-4.19/sunrpc-use-after-free-in-svc_process_common.patch b/queue-4.19/sunrpc-use-after-free-in-svc_process_common.patch
deleted file mode 100644 (file)
index 6041048..0000000
+++ /dev/null
@@ -1,166 +0,0 @@
-From d4b09acf924b84bae77cad090a9d108e70b43643 Mon Sep 17 00:00:00 2001
-From: Vasily Averin <vvs@virtuozzo.com>
-Date: Mon, 24 Dec 2018 14:44:52 +0300
-Subject: sunrpc: use-after-free in svc_process_common()
-
-From: Vasily Averin <vvs@virtuozzo.com>
-
-commit d4b09acf924b84bae77cad090a9d108e70b43643 upstream.
-
-if node have NFSv41+ mounts inside several net namespaces
-it can lead to use-after-free in svc_process_common()
-
-svc_process_common()
-        /* Setup reply header */
-        rqstp->rq_xprt->xpt_ops->xpo_prep_reply_hdr(rqstp); <<< HERE
-
-svc_process_common() can use incorrect rqstp->rq_xprt,
-its caller function bc_svc_process() takes it from serv->sv_bc_xprt.
-The problem is that serv is global structure but sv_bc_xprt
-is assigned per-netnamespace.
-
-According to Trond, the whole "let's set up rqstp->rq_xprt
-for the back channel" is nothing but a giant hack in order
-to work around the fact that svc_process_common() uses it
-to find the xpt_ops, and perform a couple of (meaningless
-for the back channel) tests of xpt_flags.
-
-All we really need in svc_process_common() is to be able to run
-rqstp->rq_xprt->xpt_ops->xpo_prep_reply_hdr()
-
-Bruce J Fields points that this xpo_prep_reply_hdr() call
-is an awfully roundabout way just to do "svc_putnl(resv, 0);"
-in the tcp case.
-
-This patch does not initialiuze rqstp->rq_xprt in bc_svc_process(),
-now it calls svc_process_common() with rqstp->rq_xprt = NULL.
-
-To adjust reply header svc_process_common() just check
-rqstp->rq_prot and calls svc_tcp_prep_reply_hdr() for tcp case.
-
-To handle rqstp->rq_xprt = NULL case in functions called from
-svc_process_common() patch intruduces net namespace pointer
-svc_rqst->rq_bc_net and adjust SVC_NET() definition.
-Some other function was also adopted to properly handle described case.
-
-Signed-off-by: Vasily Averin <vvs@virtuozzo.com>
-Cc: stable@vger.kernel.org
-Fixes: 23c20ecd4475 ("NFS: callback up - users counting cleanup")
-Signed-off-by: J. Bruce Fields <bfields@redhat.com>
-Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-
----
- include/linux/sunrpc/svc.h    |    5 ++++-
- include/trace/events/sunrpc.h |    6 ++++--
- net/sunrpc/svc.c              |    9 +++++----
- net/sunrpc/svc_xprt.c         |    5 +++--
- net/sunrpc/svcsock.c          |    2 +-
- 5 files changed, 17 insertions(+), 10 deletions(-)
-
---- a/include/linux/sunrpc/svc.h
-+++ b/include/linux/sunrpc/svc.h
-@@ -295,9 +295,12 @@ struct svc_rqst {
-       struct svc_cacherep *   rq_cacherep;    /* cache info */
-       struct task_struct      *rq_task;       /* service thread */
-       spinlock_t              rq_lock;        /* per-request lock */
-+      struct net              *rq_bc_net;     /* pointer to backchannel's
-+                                               * net namespace
-+                                               */
- };
--#define SVC_NET(svc_rqst)     (svc_rqst->rq_xprt->xpt_net)
-+#define SVC_NET(rqst) (rqst->rq_xprt ? rqst->rq_xprt->xpt_net : rqst->rq_bc_net)
- /*
-  * Rigorous type checking on sockaddr type conversions
---- a/include/trace/events/sunrpc.h
-+++ b/include/trace/events/sunrpc.h
-@@ -582,7 +582,8 @@ TRACE_EVENT(svc_process,
-               __field(u32, vers)
-               __field(u32, proc)
-               __string(service, name)
--              __string(addr, rqst->rq_xprt->xpt_remotebuf)
-+              __string(addr, rqst->rq_xprt ?
-+                       rqst->rq_xprt->xpt_remotebuf : "(null)")
-       ),
-       TP_fast_assign(
-@@ -590,7 +591,8 @@ TRACE_EVENT(svc_process,
-               __entry->vers = rqst->rq_vers;
-               __entry->proc = rqst->rq_proc;
-               __assign_str(service, name);
--              __assign_str(addr, rqst->rq_xprt->xpt_remotebuf);
-+              __assign_str(addr, rqst->rq_xprt ?
-+                           rqst->rq_xprt->xpt_remotebuf : "(null)");
-       ),
-       TP_printk("addr=%s xid=0x%08x service=%s vers=%u proc=%u",
---- a/net/sunrpc/svc.c
-+++ b/net/sunrpc/svc.c
-@@ -1172,7 +1172,8 @@ svc_process_common(struct svc_rqst *rqst
-       clear_bit(RQ_DROPME, &rqstp->rq_flags);
-       /* Setup reply header */
--      rqstp->rq_xprt->xpt_ops->xpo_prep_reply_hdr(rqstp);
-+      if (rqstp->rq_prot == IPPROTO_TCP)
-+              svc_tcp_prep_reply_hdr(rqstp);
-       svc_putu32(resv, rqstp->rq_xid);
-@@ -1244,7 +1245,7 @@ svc_process_common(struct svc_rqst *rqst
-        * for lower versions. RPC_PROG_MISMATCH seems to be the closest
-        * fit.
-        */
--      if (versp->vs_need_cong_ctrl &&
-+      if (versp->vs_need_cong_ctrl && rqstp->rq_xprt &&
-           !test_bit(XPT_CONG_CTRL, &rqstp->rq_xprt->xpt_flags))
-               goto err_bad_vers;
-@@ -1336,7 +1337,7 @@ svc_process_common(struct svc_rqst *rqst
-       return 0;
-  close:
--      if (test_bit(XPT_TEMP, &rqstp->rq_xprt->xpt_flags))
-+      if (rqstp->rq_xprt && test_bit(XPT_TEMP, &rqstp->rq_xprt->xpt_flags))
-               svc_close_xprt(rqstp->rq_xprt);
-       dprintk("svc: svc_process close\n");
-       return 0;
-@@ -1459,10 +1460,10 @@ bc_svc_process(struct svc_serv *serv, st
-       dprintk("svc: %s(%p)\n", __func__, req);
-       /* Build the svc_rqst used by the common processing routine */
--      rqstp->rq_xprt = serv->sv_bc_xprt;
-       rqstp->rq_xid = req->rq_xid;
-       rqstp->rq_prot = req->rq_xprt->prot;
-       rqstp->rq_server = serv;
-+      rqstp->rq_bc_net = req->rq_xprt->xprt_net;
-       rqstp->rq_addrlen = sizeof(req->rq_xprt->addr);
-       memcpy(&rqstp->rq_addr, &req->rq_xprt->addr, rqstp->rq_addrlen);
---- a/net/sunrpc/svc_xprt.c
-+++ b/net/sunrpc/svc_xprt.c
-@@ -469,10 +469,11 @@ out:
-  */
- void svc_reserve(struct svc_rqst *rqstp, int space)
- {
-+      struct svc_xprt *xprt = rqstp->rq_xprt;
-+
-       space += rqstp->rq_res.head[0].iov_len;
--      if (space < rqstp->rq_reserved) {
--              struct svc_xprt *xprt = rqstp->rq_xprt;
-+      if (xprt && space < rqstp->rq_reserved) {
-               atomic_sub((rqstp->rq_reserved - space), &xprt->xpt_reserved);
-               rqstp->rq_reserved = space;
---- a/net/sunrpc/svcsock.c
-+++ b/net/sunrpc/svcsock.c
-@@ -1198,7 +1198,7 @@ static int svc_tcp_sendto(struct svc_rqs
- /*
-  * Setup response header. TCP has a 4B record length field.
-  */
--static void svc_tcp_prep_reply_hdr(struct svc_rqst *rqstp)
-+void svc_tcp_prep_reply_hdr(struct svc_rqst *rqstp)
- {
-       struct kvec *resv = &rqstp->rq_res.head[0];
index b97dd01b6790795e7961c1fcb5f1fcc195db39b3..462217d26379c98add6d672cc1a0406bbb0508b5 100644 (file)
@@ -9,7 +9,6 @@ mm-devm_memremap_pages-fix-shutdown-handling.patch
 memcg-oom-notify-on-oom-killer-invocation-from-the-charge-path.patch
 sunrpc-fix-cache_head-leak-due-to-queued-request.patch
 sunrpc-use-svc_net-in-svcauth_gss_-functions.patch
-sunrpc-use-after-free-in-svc_process_common.patch
 mm-devm_memremap_pages-add-memory_device_private-support.patch
 mm-hmm-use-devm-semantics-for-hmm_devmem_-add-remove.patch
 mm-hmm-replace-hmm_devmem_pages_create-with-devm_memremap_pages.patch
diff --git a/queue-4.20/sunrpc-use-after-free-in-svc_process_common.patch b/queue-4.20/sunrpc-use-after-free-in-svc_process_common.patch
deleted file mode 100644 (file)
index d997170..0000000
+++ /dev/null
@@ -1,166 +0,0 @@
-From d4b09acf924b84bae77cad090a9d108e70b43643 Mon Sep 17 00:00:00 2001
-From: Vasily Averin <vvs@virtuozzo.com>
-Date: Mon, 24 Dec 2018 14:44:52 +0300
-Subject: sunrpc: use-after-free in svc_process_common()
-
-From: Vasily Averin <vvs@virtuozzo.com>
-
-commit d4b09acf924b84bae77cad090a9d108e70b43643 upstream.
-
-if node have NFSv41+ mounts inside several net namespaces
-it can lead to use-after-free in svc_process_common()
-
-svc_process_common()
-        /* Setup reply header */
-        rqstp->rq_xprt->xpt_ops->xpo_prep_reply_hdr(rqstp); <<< HERE
-
-svc_process_common() can use incorrect rqstp->rq_xprt,
-its caller function bc_svc_process() takes it from serv->sv_bc_xprt.
-The problem is that serv is global structure but sv_bc_xprt
-is assigned per-netnamespace.
-
-According to Trond, the whole "let's set up rqstp->rq_xprt
-for the back channel" is nothing but a giant hack in order
-to work around the fact that svc_process_common() uses it
-to find the xpt_ops, and perform a couple of (meaningless
-for the back channel) tests of xpt_flags.
-
-All we really need in svc_process_common() is to be able to run
-rqstp->rq_xprt->xpt_ops->xpo_prep_reply_hdr()
-
-Bruce J Fields points that this xpo_prep_reply_hdr() call
-is an awfully roundabout way just to do "svc_putnl(resv, 0);"
-in the tcp case.
-
-This patch does not initialiuze rqstp->rq_xprt in bc_svc_process(),
-now it calls svc_process_common() with rqstp->rq_xprt = NULL.
-
-To adjust reply header svc_process_common() just check
-rqstp->rq_prot and calls svc_tcp_prep_reply_hdr() for tcp case.
-
-To handle rqstp->rq_xprt = NULL case in functions called from
-svc_process_common() patch intruduces net namespace pointer
-svc_rqst->rq_bc_net and adjust SVC_NET() definition.
-Some other function was also adopted to properly handle described case.
-
-Signed-off-by: Vasily Averin <vvs@virtuozzo.com>
-Cc: stable@vger.kernel.org
-Fixes: 23c20ecd4475 ("NFS: callback up - users counting cleanup")
-Signed-off-by: J. Bruce Fields <bfields@redhat.com>
-Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-
----
- include/linux/sunrpc/svc.h    |    5 ++++-
- include/trace/events/sunrpc.h |    6 ++++--
- net/sunrpc/svc.c              |    9 +++++----
- net/sunrpc/svc_xprt.c         |    5 +++--
- net/sunrpc/svcsock.c          |    2 +-
- 5 files changed, 17 insertions(+), 10 deletions(-)
-
---- a/include/linux/sunrpc/svc.h
-+++ b/include/linux/sunrpc/svc.h
-@@ -295,9 +295,12 @@ struct svc_rqst {
-       struct svc_cacherep *   rq_cacherep;    /* cache info */
-       struct task_struct      *rq_task;       /* service thread */
-       spinlock_t              rq_lock;        /* per-request lock */
-+      struct net              *rq_bc_net;     /* pointer to backchannel's
-+                                               * net namespace
-+                                               */
- };
--#define SVC_NET(svc_rqst)     (svc_rqst->rq_xprt->xpt_net)
-+#define SVC_NET(rqst) (rqst->rq_xprt ? rqst->rq_xprt->xpt_net : rqst->rq_bc_net)
- /*
-  * Rigorous type checking on sockaddr type conversions
---- a/include/trace/events/sunrpc.h
-+++ b/include/trace/events/sunrpc.h
-@@ -569,7 +569,8 @@ TRACE_EVENT(svc_process,
-               __field(u32, vers)
-               __field(u32, proc)
-               __string(service, name)
--              __string(addr, rqst->rq_xprt->xpt_remotebuf)
-+              __string(addr, rqst->rq_xprt ?
-+                       rqst->rq_xprt->xpt_remotebuf : "(null)")
-       ),
-       TP_fast_assign(
-@@ -577,7 +578,8 @@ TRACE_EVENT(svc_process,
-               __entry->vers = rqst->rq_vers;
-               __entry->proc = rqst->rq_proc;
-               __assign_str(service, name);
--              __assign_str(addr, rqst->rq_xprt->xpt_remotebuf);
-+              __assign_str(addr, rqst->rq_xprt ?
-+                           rqst->rq_xprt->xpt_remotebuf : "(null)");
-       ),
-       TP_printk("addr=%s xid=0x%08x service=%s vers=%u proc=%u",
---- a/net/sunrpc/svc.c
-+++ b/net/sunrpc/svc.c
-@@ -1172,7 +1172,8 @@ svc_process_common(struct svc_rqst *rqst
-       clear_bit(RQ_DROPME, &rqstp->rq_flags);
-       /* Setup reply header */
--      rqstp->rq_xprt->xpt_ops->xpo_prep_reply_hdr(rqstp);
-+      if (rqstp->rq_prot == IPPROTO_TCP)
-+              svc_tcp_prep_reply_hdr(rqstp);
-       svc_putu32(resv, rqstp->rq_xid);
-@@ -1244,7 +1245,7 @@ svc_process_common(struct svc_rqst *rqst
-        * for lower versions. RPC_PROG_MISMATCH seems to be the closest
-        * fit.
-        */
--      if (versp->vs_need_cong_ctrl &&
-+      if (versp->vs_need_cong_ctrl && rqstp->rq_xprt &&
-           !test_bit(XPT_CONG_CTRL, &rqstp->rq_xprt->xpt_flags))
-               goto err_bad_vers;
-@@ -1336,7 +1337,7 @@ svc_process_common(struct svc_rqst *rqst
-       return 0;
-  close:
--      if (test_bit(XPT_TEMP, &rqstp->rq_xprt->xpt_flags))
-+      if (rqstp->rq_xprt && test_bit(XPT_TEMP, &rqstp->rq_xprt->xpt_flags))
-               svc_close_xprt(rqstp->rq_xprt);
-       dprintk("svc: svc_process close\n");
-       return 0;
-@@ -1459,10 +1460,10 @@ bc_svc_process(struct svc_serv *serv, st
-       dprintk("svc: %s(%p)\n", __func__, req);
-       /* Build the svc_rqst used by the common processing routine */
--      rqstp->rq_xprt = serv->sv_bc_xprt;
-       rqstp->rq_xid = req->rq_xid;
-       rqstp->rq_prot = req->rq_xprt->prot;
-       rqstp->rq_server = serv;
-+      rqstp->rq_bc_net = req->rq_xprt->xprt_net;
-       rqstp->rq_addrlen = sizeof(req->rq_xprt->addr);
-       memcpy(&rqstp->rq_addr, &req->rq_xprt->addr, rqstp->rq_addrlen);
---- a/net/sunrpc/svc_xprt.c
-+++ b/net/sunrpc/svc_xprt.c
-@@ -468,10 +468,11 @@ out:
-  */
- void svc_reserve(struct svc_rqst *rqstp, int space)
- {
-+      struct svc_xprt *xprt = rqstp->rq_xprt;
-+
-       space += rqstp->rq_res.head[0].iov_len;
--      if (space < rqstp->rq_reserved) {
--              struct svc_xprt *xprt = rqstp->rq_xprt;
-+      if (xprt && space < rqstp->rq_reserved) {
-               atomic_sub((rqstp->rq_reserved - space), &xprt->xpt_reserved);
-               rqstp->rq_reserved = space;
---- a/net/sunrpc/svcsock.c
-+++ b/net/sunrpc/svcsock.c
-@@ -1173,7 +1173,7 @@ static int svc_tcp_sendto(struct svc_rqs
- /*
-  * Setup response header. TCP has a 4B record length field.
-  */
--static void svc_tcp_prep_reply_hdr(struct svc_rqst *rqstp)
-+void svc_tcp_prep_reply_hdr(struct svc_rqst *rqstp)
- {
-       struct kvec *resv = &rqstp->rq_res.head[0];