提交 e6193f78 编写于 作者: T Tetsuo Handa 提交者: James Morris

tomoyo: Check address length before reading address family

KMSAN will complain if valid address length passed to bind()/connect()/
sendmsg() is shorter than sizeof("struct sockaddr"->sa_family) bytes.
Signed-off-by: NTetsuo Handa <penguin-kernel@I-love.SAKURA.ne.jp>
Signed-off-by: NJames Morris <jamorris@linux.microsoft.com>
上级 e80b1859
...@@ -505,6 +505,8 @@ static int tomoyo_check_inet_address(const struct sockaddr *addr, ...@@ -505,6 +505,8 @@ static int tomoyo_check_inet_address(const struct sockaddr *addr,
{ {
struct tomoyo_inet_addr_info *i = &address->inet; struct tomoyo_inet_addr_info *i = &address->inet;
if (addr_len < offsetofend(struct sockaddr, sa_family))
return 0;
switch (addr->sa_family) { switch (addr->sa_family) {
case AF_INET6: case AF_INET6:
if (addr_len < SIN6_LEN_RFC2133) if (addr_len < SIN6_LEN_RFC2133)
...@@ -594,6 +596,8 @@ static int tomoyo_check_unix_address(struct sockaddr *addr, ...@@ -594,6 +596,8 @@ static int tomoyo_check_unix_address(struct sockaddr *addr,
{ {
struct tomoyo_unix_addr_info *u = &address->unix0; struct tomoyo_unix_addr_info *u = &address->unix0;
if (addr_len < offsetofend(struct sockaddr, sa_family))
return 0;
if (addr->sa_family != AF_UNIX) if (addr->sa_family != AF_UNIX)
return 0; return 0;
u->addr = ((struct sockaddr_un *) addr)->sun_path; u->addr = ((struct sockaddr_un *) addr)->sun_path;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册