gtp: update rx_length_errors for abnormally short packets
Based on work by Pravin Shelar. Update appropriate stats when packet transmission isn't possible. Signed-off-by: Jonas Bonn <jonas@norrbonn.se> Acked-by: Harald Welte <laforge@gnumonks.org> Acked-by: Pravin B Shelar <pshelar@ovn.org> Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
parent
29f53b5c00
commit
9716178a3a
@ -189,8 +189,10 @@ static int gtp_rx(struct pdp_ctx *pctx, struct sk_buff *skb,
|
|||||||
|
|
||||||
/* Get rid of the GTP + UDP headers. */
|
/* Get rid of the GTP + UDP headers. */
|
||||||
if (iptunnel_pull_header(skb, hdrlen, skb->protocol,
|
if (iptunnel_pull_header(skb, hdrlen, skb->protocol,
|
||||||
!net_eq(sock_net(pctx->sk), dev_net(pctx->dev))))
|
!net_eq(sock_net(pctx->sk), dev_net(pctx->dev)))) {
|
||||||
return -1;
|
pctx->dev->stats.rx_length_errors++;
|
||||||
|
goto err;
|
||||||
|
}
|
||||||
|
|
||||||
netdev_dbg(pctx->dev, "forwarding packet from GGSN to uplink\n");
|
netdev_dbg(pctx->dev, "forwarding packet from GGSN to uplink\n");
|
||||||
|
|
||||||
@ -206,6 +208,10 @@ static int gtp_rx(struct pdp_ctx *pctx, struct sk_buff *skb,
|
|||||||
|
|
||||||
netif_rx(skb);
|
netif_rx(skb);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
err:
|
||||||
|
pctx->dev->stats.rx_dropped++;
|
||||||
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* 1 means pass up to the stack, -1 means drop and 0 means decapsulated. */
|
/* 1 means pass up to the stack, -1 means drop and 0 means decapsulated. */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user