]> git.baikalelectronics.ru Git - kernel.git/commit
ip6_tunnel, ip6_gre: fix setting of DSCP on encapsulated packets
authorPeter Dawson <petedaws@gmail.com>
Thu, 25 May 2017 20:35:18 +0000 (06:35 +1000)
committerDavid S. Miller <davem@davemloft.net>
Fri, 26 May 2017 18:54:39 +0000 (14:54 -0400)
commitcbd785bb5b6bb60fad2b8c8411e2e2f6a500b3f8
tree47fbb75e52124db162f54e605912f60a36caf20f
parent57d6324c93ce7cc7b1558e7e6c0a2f0848161342
ip6_tunnel, ip6_gre: fix setting of DSCP on encapsulated packets

This fix addresses two problems in the way the DSCP field is formulated
 on the encapsulating header of IPv6 tunnels.
Bugzilla: https://bugzilla.kernel.org/show_bug.cgi?id=195661

1) The IPv6 tunneling code was manipulating the DSCP field of the
 encapsulating packet using the 32b flowlabel. Since the flowlabel is
 only the lower 20b it was incorrect to assume that the upper 12b
 containing the DSCP and ECN fields would remain intact when formulating
 the encapsulating header. This fix handles the 'inherit' and
 'fixed-value' DSCP cases explicitly using the extant dsfield u8 variable.

2) The use of INET_ECN_encapsulate(0, dsfield) in ip6_tnl_xmit was
 incorrect and resulted in the DSCP value always being set to 0.

Commit 83371e59bc9e ("ipv6: fix flow labels when the traffic class
 is non-0") caused the regression by masking out the flowlabel
 which exposed the incorrect handling of the DSCP portion of the
 flowlabel in ip6_tunnel and ip6_gre.

Fixes: 83371e59bc9e ("ipv6: fix flow labels when the traffic class is non-0")
Signed-off-by: Peter Dawson <peter.a.dawson@boeing.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/ipv6/ip6_gre.c
net/ipv6/ip6_tunnel.c