aboutsummaryrefslogtreecommitdiffstats
path: root/net
diff options
context:
space:
mode:
authorDavid S. Miller <davem@davemloft.net>2015-12-15 15:39:08 -0500
committerWolfgang Wiedmeyer <wolfgit@wiedmeyer.de>2016-03-18 01:51:05 +0100
commit65e2a5e01a1e8db7ec19dacd9aef6cac3b596552 (patch)
tree66cb732a1626683c2de7139b4d1361e0855c40e3 /net
parent7ffbc9118a4b062fdc384e3bccaca9eb55ba7f10 (diff)
downloadkernel_samsung_smdk4412-65e2a5e01a1e8db7ec19dacd9aef6cac3b596552.zip
kernel_samsung_smdk4412-65e2a5e01a1e8db7ec19dacd9aef6cac3b596552.tar.gz
kernel_samsung_smdk4412-65e2a5e01a1e8db7ec19dacd9aef6cac3b596552.tar.bz2
bluetooth: Validate socket address length in sco_sock_bind().
Change-Id: Id051e0c1a5d89ea90e9b058175c37c952cad70bc Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net')
-rw-r--r--net/bluetooth/sco.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/net/bluetooth/sco.c b/net/bluetooth/sco.c
index ac4631d..21aded9 100644
--- a/net/bluetooth/sco.c
+++ b/net/bluetooth/sco.c
@@ -476,6 +476,9 @@ static int sco_sock_bind(struct socket *sock, struct sockaddr *addr, int alen)
if (!addr || addr->sa_family != AF_BLUETOOTH)
return -EINVAL;
+ if (alen < sizeof(struct sockaddr_sco))
+ return -EINVAL;
+
memset(&sa, 0, sizeof(sa));
len = min_t(unsigned int, sizeof(sa), alen);
memcpy(&sa, addr, len);