提交 238ffdc4 编写于 作者: T Tetsuo Handa 提交者: David S. Miller

mISDN: Check address length before reading address family

KMSAN will complain if valid address length passed to bind() is shorter
than sizeof("struct sockaddr_mISDN"->family) bytes.
Signed-off-by: NTetsuo Handa <penguin-kernel@I-love.SAKURA.ne.jp>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
上级 dd3ac9a6
...@@ -710,10 +710,10 @@ base_sock_bind(struct socket *sock, struct sockaddr *addr, int addr_len) ...@@ -710,10 +710,10 @@ base_sock_bind(struct socket *sock, struct sockaddr *addr, int addr_len)
struct sock *sk = sock->sk; struct sock *sk = sock->sk;
int err = 0; int err = 0;
if (!maddr || maddr->family != AF_ISDN) if (addr_len < sizeof(struct sockaddr_mISDN))
return -EINVAL; return -EINVAL;
if (addr_len < sizeof(struct sockaddr_mISDN)) if (!maddr || maddr->family != AF_ISDN)
return -EINVAL; return -EINVAL;
lock_sock(sk); lock_sock(sk);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册