|
@@ -442,8 +442,10 @@ static netdev_tx_t reg_vif_xmit(struct sk_buff *skb, struct net_device *dev)
|
|
int err;
|
|
int err;
|
|
|
|
|
|
err = ipmr_fib_lookup(net, &fl, &mrt);
|
|
err = ipmr_fib_lookup(net, &fl, &mrt);
|
|
- if (err < 0)
|
|
|
|
|
|
+ if (err < 0) {
|
|
|
|
+ kfree_skb(skb);
|
|
return err;
|
|
return err;
|
|
|
|
+ }
|
|
|
|
|
|
read_lock(&mrt_lock);
|
|
read_lock(&mrt_lock);
|
|
dev->stats.tx_bytes += skb->len;
|
|
dev->stats.tx_bytes += skb->len;
|
|
@@ -1728,8 +1730,10 @@ int ip_mr_input(struct sk_buff *skb)
|
|
goto dont_forward;
|
|
goto dont_forward;
|
|
|
|
|
|
err = ipmr_fib_lookup(net, &skb_rtable(skb)->fl, &mrt);
|
|
err = ipmr_fib_lookup(net, &skb_rtable(skb)->fl, &mrt);
|
|
- if (err < 0)
|
|
|
|
|
|
+ if (err < 0) {
|
|
|
|
+ kfree_skb(skb);
|
|
return err;
|
|
return err;
|
|
|
|
+ }
|
|
|
|
|
|
if (!local) {
|
|
if (!local) {
|
|
if (IPCB(skb)->opt.router_alert) {
|
|
if (IPCB(skb)->opt.router_alert) {
|