Message ID | 1460043899-56894-3-git-send-email-willemdebruijn.kernel@gmail.com |
---|---|
State | Accepted, archived |
Delegated to: | David Miller |
Headers | show |
On Thu, Apr 07, 2016 at 11:44:59AM -0400, Willem de Bruijn wrote: > From: Willem de Bruijn <willemb@google.com> > > Commit e6afc8ace6dd modified the udp receive path by pulling the udp > header before queuing an skbuff onto the receive queue. > > Rxrpc also calls skb_recv_datagram to dequeue an skb from a udp > socket. Modify this receive path to also no longer expect udp > headers. > > Fixes: e6afc8ace6dd ("udp: remove headers from UDP packets before queueing") > > Signed-off-by: Willem de Bruijn <willemb@google.com> > --- > net/rxrpc/ar-input.c | 4 ++-- > 1 file changed, 2 insertions(+), 2 deletions(-) To be explicit: Tested-by: Thierry Reding <treding@nvidia.com>
diff --git a/net/rxrpc/ar-input.c b/net/rxrpc/ar-input.c index 63ed75c..4824a82 100644 --- a/net/rxrpc/ar-input.c +++ b/net/rxrpc/ar-input.c @@ -612,9 +612,9 @@ int rxrpc_extract_header(struct rxrpc_skb_priv *sp, struct sk_buff *skb) struct rxrpc_wire_header whdr; /* dig out the RxRPC connection details */ - if (skb_copy_bits(skb, sizeof(struct udphdr), &whdr, sizeof(whdr)) < 0) + if (skb_copy_bits(skb, 0, &whdr, sizeof(whdr)) < 0) return -EBADMSG; - if (!pskb_pull(skb, sizeof(struct udphdr) + sizeof(whdr))) + if (!pskb_pull(skb, sizeof(whdr))) BUG(); memset(sp, 0, sizeof(*sp));