android_kernel_samsung_msm8226/net/ipv4
Alexey Kodanev d01a6d28e0 udp: avoid ufo handling on IP payload compression packets
commit 4b3b45edba9222e518a1ec72df841eba3609fe34 upstream.

commit c146066ab8 ("ipv4: Don't use ufo handling on later transformed
packets") and commit f89c56ce710a ("ipv6: Don't use ufo handling on
later transformed packets") added a check that 'rt->dst.header_len' isn't
zero in order to skip UFO, but it doesn't include IPcomp in transport mode
where it equals zero.

Packets, after payload compression, may not require further fragmentation,
and if original length exceeds MTU, later compressed packets will be
transmitted incorrectly. This can be reproduced with LTP udp_ipsec.sh test
on veth device with enabled UFO, MTU is 1500 and UDP payload is 2000:

* IPv4 case, offset is wrong + unnecessary fragmentation
    udp_ipsec.sh -p comp -m transport -s 2000 &
    tcpdump -ni ltp_ns_veth2
    ...
    IP (tos 0x0, ttl 64, id 45203, offset 0, flags [+],
      proto Compressed IP (108), length 49)
      10.0.0.2 > 10.0.0.1: IPComp(cpi=0x1000)
    IP (tos 0x0, ttl 64, id 45203, offset 1480, flags [none],
      proto UDP (17), length 21) 10.0.0.2 > 10.0.0.1: ip-proto-17

* IPv6 case, sending small fragments
    udp_ipsec.sh -6 -p comp -m transport -s 2000 &
    tcpdump -ni ltp_ns_veth2
    ...
    IP6 (flowlabel 0x6b9ba, hlim 64, next-header Compressed IP (108)
      payload length: 37) fd00::2 > fd00::1: IPComp(cpi=0x1000)
    IP6 (flowlabel 0x6b9ba, hlim 64, next-header Compressed IP (108)
      payload length: 21) fd00::2 > fd00::1: IPComp(cpi=0x1000)

Fix it by checking 'rt->dst.xfrm' pointer to 'xfrm_state' struct, skip UFO
if xfrm is set. So the new check will include both cases: IPcomp and IPsec.

Change-Id: Iaf21122b21604acd528de4d65c6319b1ae3f3fba
Fixes: c146066ab8 ("ipv4: Don't use ufo handling on later transformed packets")
Fixes: f89c56ce710a ("ipv6: Don't use ufo handling on later transformed packets")
Signed-off-by: Alexey Kodanev <alexey.kodanev@oracle.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
[bwh: Backported to 3.2: adjust context]
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
Signed-off-by: Kevin F. Haggerty <haggertk@lineageos.org>
2020-01-06 08:40:28 +01:00
..
netfilter ipv4: Don't do expensive useless work during inetdev destroy. 2019-08-06 12:19:41 +02:00
Kconfig Merge remote-tracking branch 'google-common/deprecated/android-3.4' into lineage-16.0 2019-08-06 11:41:21 +02:00
Makefile
af_inet.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
ah4.c
arp.c
cipso_ipv4.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
datagram.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
devinet.c ipv4: Don't do expensive useless work during inetdev destroy. 2019-08-06 12:19:41 +02:00
esp4.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
fib_frontend.c net: core: add UID to flows, rules, and routes 2019-08-08 15:08:49 +02:00
fib_lookup.h
fib_rules.c
fib_semantics.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
fib_trie.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
gre.c
icmp.c net: add a sysctl to reflect the fwmark on replies 2014-08-01 15:43:25 -07:00
igmp.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
inet_connection_sock.c Revert "net: core: Support UID-based routing." 2019-08-08 15:08:48 +02:00
inet_diag.c Merge remote-tracking branch 'google-common/deprecated/android-3.4' into lineage-16.0 2019-08-06 11:41:21 +02:00
inet_fragment.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
inet_hashtables.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
inet_lro.c
inet_timewait_sock.c
inetpeer.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
ip_forward.c misc: Import SM-G900H kernel source code 2019-08-02 15:14:10 +02:00
ip_fragment.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
ip_gre.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
ip_input.c
ip_options.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
ip_output.c udp: avoid ufo handling on IP payload compression packets 2020-01-06 08:40:28 +01:00
ip_sockglue.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
ipcomp.c
ipconfig.c
ipip.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
ipmr.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
netfilter.c
ping.c Revert "net: core: Support UID-based routing." 2019-08-08 15:08:48 +02:00
proc.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
protocol.c
raw.c net: ipv4: emulate READ_ONCE() on ->hdrincl bit-field in raw_sendmsg() 2020-01-06 08:40:26 +01:00
route.c net: core: add UID to flows, rules, and routes 2019-08-08 15:08:49 +02:00
syncookies.c Revert "net: core: Support UID-based routing." 2019-08-08 15:08:48 +02:00
sysctl_net_ipv4.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
sysfs_net_ipv4.c msm: Create shadow files under /sys/kernel/ipv4 2014-04-28 16:35:44 -07:00
tcp.c Merge remote-tracking branch 'google-common/deprecated/android-3.4' into lineage-16.0 2019-08-06 11:41:21 +02:00
tcp_bic.c
tcp_cong.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
tcp_cubic.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
tcp_diag.c Merge remote-tracking branch 'google-common/deprecated/android-3.4' into lineage-16.0 2019-08-06 11:41:21 +02:00
tcp_highspeed.c
tcp_htcp.c
tcp_hybla.c
tcp_illinois.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
tcp_input.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
tcp_ipv4.c tcp: do not lock listener to process SYN packets 2019-08-06 12:26:31 +02:00
tcp_lp.c
tcp_memcontrol.c
tcp_minisocks.c
tcp_output.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
tcp_probe.c
tcp_scalable.c
tcp_timer.c WLAN subsystem: Sysctl support for key TCP/IP parameters 2014-03-10 11:29:50 -07:00
tcp_vegas.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
tcp_vegas.h
tcp_veno.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
tcp_westwood.c
tcp_yeah.c
tunnel4.c
udp.c udp: consistently apply ufo or fragmentation 2020-01-06 08:40:27 +01:00
udp_diag.c
udp_impl.h
udplite.c
xfrm4_input.c
xfrm4_mode_beet.c
xfrm4_mode_transport.c
xfrm4_mode_tunnel.c Merge tag 'v3.4.113' into lineage-16.0 2019-08-05 14:20:47 +02:00
xfrm4_output.c
xfrm4_policy.c Revert "net: core: Support UID-based routing." 2019-08-08 15:08:48 +02:00
xfrm4_state.c
xfrm4_tunnel.c