Commit f63c2c20 authored by Jan Beulich's avatar Jan Beulich Committed by Juergen Gross

xen-netfront: restore __skb_queue_tail() positioning in xennet_get_responses()

The commit referenced below moved the invocation past the "next" label,
without any explanation. In fact this allows misbehaving backends undue
control over the domain the frontend runs in, as earlier detected errors
require the skb to not be freed (it may be retained for later processing
via xennet_move_rx_slot(), or it may simply be unsafe to have it freed).

This is CVE-2022-33743 / XSA-405.

Fixes: 6c5aa6fc ("xen networking: add basic XDP support for xen-netfront")
Signed-off-by: default avatarJan Beulich <jbeulich@suse.com>
Reviewed-by: default avatarJuergen Gross <jgross@suse.com>
Signed-off-by: default avatarJuergen Gross <jgross@suse.com>
parent 2400617d
...@@ -1092,8 +1092,10 @@ static int xennet_get_responses(struct netfront_queue *queue, ...@@ -1092,8 +1092,10 @@ static int xennet_get_responses(struct netfront_queue *queue,
} }
} }
rcu_read_unlock(); rcu_read_unlock();
next:
__skb_queue_tail(list, skb); __skb_queue_tail(list, skb);
next:
if (!(rx->flags & XEN_NETRXF_more_data)) if (!(rx->flags & XEN_NETRXF_more_data))
break; break;
......
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