diff options
author | Eric W. Biederman <ebiederm@xmission.com> | 2015-03-07 23:23:23 +0100 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2015-03-09 00:30:06 +0100 |
commit | aa7da9375677d31dd53ed6253f55cb19e3075811 (patch) | |
tree | ac11af07cf40a14c90b6bbd00c3c795719516992 | |
parent | mpls: Better error code for unsupported option. (diff) | |
download | linux-aa7da9375677d31dd53ed6253f55cb19e3075811.tar.xz linux-aa7da9375677d31dd53ed6253f55cb19e3075811.zip |
mpls: Correct the ttl decrement.
According to RFC3032 section 2.4.2 packets with an outgoing
ttl of 0 MUST NOT be forwarded. According to section 2.4.1
an outgoing TTL of 0 comes from an incomming TTL <= 1.
Therefore any packets that is received with a ttl <= 1 should
not have it's ttl decremented and forwarded.
Signed-off-by: "Eric W. Biederman" <ebiederm@xmission.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | net/mpls/af_mpls.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/net/mpls/af_mpls.c b/net/mpls/af_mpls.c index 5c99e3fc1b72..e120074157de 100644 --- a/net/mpls/af_mpls.c +++ b/net/mpls/af_mpls.c @@ -162,7 +162,7 @@ static int mpls_forward(struct sk_buff *skb, struct net_device *dev, skb_forward_csum(skb); /* Verify ttl is valid */ - if (dec.ttl <= 2) + if (dec.ttl <= 1) goto drop; dec.ttl -= 1; |