macvlan: Fix leaking skb in source mode with nodst option
[ Upstream commite16b859872
] The MACVLAN receive handler clones skbs to all matching source MACVLAN interfaces, before it passes the packet along to match on destination based MACVLANs. When using the MACVLAN nodst mode, passing the packet to destination based MACVLANs is omitted and the handler returns with RX_HANDLER_CONSUMED. However, the passed skb is not freed, leaking for any packet processed with the nodst option. Properly free the skb when consuming packets to fix that leak. Fixes:427f0c8c19
("macvlan: Add nodst option to macvlan type source") Signed-off-by: Martin Willi <martin@strongswan.org> Signed-off-by: David S. Miller <davem@davemloft.net> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
Родитель
8e86fba134
Коммит
8f79ce226a
|
@ -460,8 +460,10 @@ static rx_handler_result_t macvlan_handle_frame(struct sk_buff **pskb)
|
|||
return RX_HANDLER_CONSUMED;
|
||||
*pskb = skb;
|
||||
eth = eth_hdr(skb);
|
||||
if (macvlan_forward_source(skb, port, eth->h_source))
|
||||
if (macvlan_forward_source(skb, port, eth->h_source)) {
|
||||
kfree_skb(skb);
|
||||
return RX_HANDLER_CONSUMED;
|
||||
}
|
||||
src = macvlan_hash_lookup(port, eth->h_source);
|
||||
if (src && src->mode != MACVLAN_MODE_VEPA &&
|
||||
src->mode != MACVLAN_MODE_BRIDGE) {
|
||||
|
@ -480,8 +482,10 @@ static rx_handler_result_t macvlan_handle_frame(struct sk_buff **pskb)
|
|||
return RX_HANDLER_PASS;
|
||||
}
|
||||
|
||||
if (macvlan_forward_source(skb, port, eth->h_source))
|
||||
if (macvlan_forward_source(skb, port, eth->h_source)) {
|
||||
kfree_skb(skb);
|
||||
return RX_HANDLER_CONSUMED;
|
||||
}
|
||||
if (macvlan_passthru(port))
|
||||
vlan = list_first_or_null_rcu(&port->vlans,
|
||||
struct macvlan_dev, list);
|
||||
|
|
Загрузка…
Ссылка в новой задаче