netfilter: nfnetlink: Improve input length sanitization in nfnetlink_rcv
authorMateusz Jurczyk <mjurczyk@google.com>
Wed, 7 Jun 2017 13:50:38 +0000 (15:50 +0200)
committerPablo Neira Ayuso <pablo@netfilter.org>
Mon, 17 Jul 2017 11:27:46 +0000 (13:27 +0200)
commitf55ce7b024090a51382ccab2730b96e2f7b4e9cf
tree6cfd4a816f196108b3e802b4adb8769cf6d1b95a
parent533da29b584de5ae0e9dafafbe52809f59cb5300
netfilter: nfnetlink: Improve input length sanitization in nfnetlink_rcv

Verify that the length of the socket buffer is sufficient to cover the
nlmsghdr structure before accessing the nlh->nlmsg_len field for further
input sanitization. If the client only supplies 1-3 bytes of data in
sk_buff, then nlh->nlmsg_len remains partially uninitialized and
contains leftover memory from the corresponding kernel allocation.
Operating on such data may result in indeterminate evaluation of the
nlmsg_len < NLMSG_HDRLEN expression.

The bug was discovered by a runtime instrumentation designed to detect
use of uninitialized memory in the kernel. The patch prevents this and
other similar tools (e.g. KMSAN) from flagging this behavior in the future.

Signed-off-by: Mateusz Jurczyk <mjurczyk@google.com>
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
net/netfilter/nfnetlink.c