白皮书笔记五

由于竞争条件导致的 TCP 紧急指针状态混淆 (CVE-2019-12263)

我们发现的最后一个紧急指针漏洞的变种是影响所有使用 IPnet 堆栈(v6.5 及更高版本)的 VxWorks 设备的竞争条件,并可能导致紧急指针的状态混乱。与前面展示这种状态混淆的结果的示例类似,这种竞争条件可能导致用户任务缓冲区的内存损坏,从而导致在充当 TCP 服务器或 TCP 客户端的目标设备上可触发远程代码执行漏洞。竞争条件的原因是,各种变量作为一个整体来表示紧急指针的状态,但在用户任务访问它们时,内核任务(tNet0)可能会单独更改这些变量(在 iptcp_usr_get_from_recv_queue 中)。如果用户任务以不同于内核任务的优先级运行,或者如果在多核环境中使用 SMP(对称多处理),则可能会发生这种情况。没有锁或互斥锁来防止这种性质的竞争条件发生。
我们可以在 iptcp_usr_get_from_recv_queue 中的这段熟悉的代码中看到一起表示紧急指针状态的各种变量:
在这里插入图片描述
此代码假定 TCB_STATE_URG_RECEIVED 与设置 tcb->recv.urg_ptr 变量一起设置。它还取决于同时设置 tcb->recv.seq_nextsock->ipcom.rcv_bytes,并且 tcb->recv.urg_ptr 也与这些变量一起设置。
例如,如果正在获取 sock->ipcom.rcv_bytes 值和 tcb->recv.seq_next 值之间的 len 计算被抢占,同时接收的任何新段将任意增加该函数中的该两个获取值之间的差值。这将使攻击者能够使 len 变量下溢,从而导致前面描述的易受攻击的情况。这种竞争条件的其他例子也可能导致这种下溢。
如果执行 recv() 调用的任务的优先级低于 IPnet 任务的优先级,则这种竞争条件是可能发生的,因此一旦从网络接收到新数据包,它将立即被抢占。 在任何情况下,在多核 SMP 系统上也是可能的,无论优先级如何。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Pekingkenny

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值