]> git.baikalelectronics.ru Git - kernel.git/commit
espintcp: handle short messages instead of breaking the encap socket
authorSabrina Dubroca <sd@queasysnail.net>
Wed, 29 Jul 2020 16:38:42 +0000 (18:38 +0200)
committerSteffen Klassert <steffen.klassert@secunet.com>
Thu, 30 Jul 2020 04:51:35 +0000 (06:51 +0200)
commitef806371918a0b82f1cf9aa2ed1596e88c6bb773
tree062191bcf5afdb2bb7e24f707b6021cecf3abb2e
parente5b1b6fb47c8c31207db136c1cc1bc04d8efbe2a
espintcp: handle short messages instead of breaking the encap socket

Currently, short messages (less than 4 bytes after the length header)
will break the stream of messages. This is unnecessary, since we can
still parse messages even if they're too short to contain any usable
data. This is also bogus, as keepalive messages (a single 0xff byte),
though not needed with TCP encapsulation, should be allowed.

This patch changes the stream parser so that short messages are
accepted and dropped in the kernel. Messages that contain a valid SPI
or non-ESP header are processed as before.

Fixes: a601325e92f9 ("xfrm: add espintcp (RFC 8229)")
Reported-by: Andrew Cagney <cagney@libreswan.org>
Signed-off-by: Sabrina Dubroca <sd@queasysnail.net>
Signed-off-by: Steffen Klassert <steffen.klassert@secunet.com>
net/xfrm/espintcp.c