提交 931f2d65 编写于 作者: G Gavrilov Ilia 提交者: Yongqiang Liu

ipv6: Fix out-of-bounds access in ipv6_find_tlv()

stable inclusion
from stable-v4.19.284
commit 04bf69e3de435d793a203aacc4b774f8f9f2baeb
category: bugfix
bugzilla: https://gitee.com/openeuler/kernel/issues/I7J5UF
CVE: NA

--------------------------------

commit 878ecb08 upstream.

optlen is fetched without checking whether there is more than one byte to parse.
It can lead to out-of-bounds access.

Found by InfoTeCS on behalf of Linux Verification Center
(linuxtesting.org) with SVACE.

Fixes: c61a4043 ("[IPV6]: Find option offset by type.")
Signed-off-by: NGavrilov Ilia <Ilia.Gavrilov@infotecs.ru>
Reviewed-by: NJiri Pirko <jiri@nvidia.com>
Reviewed-by: NDavid Ahern <dsahern@kernel.org>
Signed-off-by: NDavid S. Miller <davem@davemloft.net>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: NYongqiang Liu <liuyongqiang13@huawei.com>
上级 a55e9876
...@@ -142,6 +142,8 @@ int ipv6_find_tlv(const struct sk_buff *skb, int offset, int type) ...@@ -142,6 +142,8 @@ int ipv6_find_tlv(const struct sk_buff *skb, int offset, int type)
optlen = 1; optlen = 1;
break; break;
default: default:
if (len < 2)
goto bad;
optlen = nh[offset + 1] + 2; optlen = nh[offset + 1] + 2;
if (optlen > len) if (optlen > len)
goto bad; goto bad;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册