Commit c9c31a36 authored by Trond Myklebust's avatar Trond Myklebust Committed by Linus Torvalds

Fix udp_data_ready() to use the correct skbuff interface for extracting

the XID. Following the introduction of zero-copy under UDP, the data
may be entirely located in pages under skb_shinfo(skb)->frags[].
parent 97ef4805
...@@ -679,6 +679,7 @@ udp_data_ready(struct sock *sk, int len) ...@@ -679,6 +679,7 @@ udp_data_ready(struct sock *sk, int len)
struct rpc_rqst *rovr; struct rpc_rqst *rovr;
struct sk_buff *skb; struct sk_buff *skb;
int err, repsize, copied; int err, repsize, copied;
u32 xid;
read_lock(&sk->sk_callback_lock); read_lock(&sk->sk_callback_lock);
dprintk("RPC: udp_data_ready...\n"); dprintk("RPC: udp_data_ready...\n");
...@@ -701,16 +702,18 @@ udp_data_ready(struct sock *sk, int len) ...@@ -701,16 +702,18 @@ udp_data_ready(struct sock *sk, int len)
goto dropit; goto dropit;
} }
/* Copy the XID from the skb... */
if (skb_copy_bits(skb, sizeof(struct udphdr), &xid, sizeof(xid)) < 0)
goto dropit;
/* Look up and lock the request corresponding to the given XID */ /* Look up and lock the request corresponding to the given XID */
spin_lock(&xprt->sock_lock); spin_lock(&xprt->sock_lock);
rovr = xprt_lookup_rqst(xprt, *(u32 *) (skb->h.raw + sizeof(struct udphdr))); rovr = xprt_lookup_rqst(xprt, xid);
if (!rovr) if (!rovr)
goto out_unlock; goto out_unlock;
task = rovr->rq_task; task = rovr->rq_task;
dprintk("RPC: %4d received reply\n", task->tk_pid); dprintk("RPC: %4d received reply\n", task->tk_pid);
xprt_pktdump("packet data:",
(u32 *) (skb->h.raw+sizeof(struct udphdr)), repsize);
if ((copied = rovr->rq_rlen) > repsize) if ((copied = rovr->rq_rlen) > repsize)
copied = repsize; copied = repsize;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment