UPSTREAM: af_key: Fix sadb_x_ipsecrequest parsing
authorHerbert Xu <herbert@gondor.apana.org.au>
Thu, 13 Apr 2017 10:35:59 +0000 (18:35 +0800)
committerMark Salyzyn <salyzyn@google.com>
Mon, 24 Jul 2017 17:23:12 +0000 (10:23 -0700)
commit3715386152f1cd1585273af3ff950d4b0378e524
treeaaaddb0c0d30f5f18593c8f8805be119ae8b4e6e
parentca2ecff8649ee9db3d00fca5fc20e5a972fde18f
UPSTREAM: af_key: Fix sadb_x_ipsecrequest parsing

(cherry picked from commit 096f41d3a8fcbb8dde7f71379b1ca85fe213eded)

The parsing of sadb_x_ipsecrequest is broken in a number of ways.
First of all we're not verifying sadb_x_ipsecrequest_len.  This
is needed when the structure carries addresses at the end.  Worse
we don't even look at the length when we parse those optional
addresses.

The migration code had similar parsing code that's better but
it also has some deficiencies.  The length is overcounted first
of all as it includes the header itself.  It also fails to check
the length before dereferencing the sa_family field.

This patch fixes those problems in parse_sockaddr_pair and then
uses it in parse_ipsecrequest.

Reported-by: Andrey Konovalov <andreyknvl@google.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: Steffen Klassert <steffen.klassert@secunet.com>
Bug: 63963140
Change-Id: Ie8854131293bc8153bfb8cb255161ec8f03667f9
net/key/af_key.c