常见的cache侧信道攻击方法

Prime+Probe

  1. 攻击者用自己的数据填充特定的cache组 (Prime)
  2. 等待目标受害者执行, 更新缓存
  3. 重新读取Prime阶段填充的数据, 测量并记录各个cache组的读取时间 (Probe)

Flush+Reload

  1. 将共享内存中特定位置的缓存数据逐出 (Flush)
  2. 等待目标受害者执行, 更新缓存
  3. 重新加载Flush阶段逐出的内存块, 测量并记录cache组的重载时间 (Reload)

Flush+Flush

  1. 通过Flush清空缓存的原始数据
  2. 等待目标受害者运行, 更新缓存, 并刷新共享缓存行, 测量刷新时间
  3. 根据测量时间判断原始数据是否被重新加载进缓存

Evict+Time

  1. 受害者执行, 并记录其执行时间
  2. 使用Evict方法覆盖cache组中的数据
  3. 再次执行受害者进程, 并第2次记录执行时间 (Time), 如果时间不一致且执行时间变长则说明程序运行时读取了缓存中的数据

Prime+Count

  1. 攻击者使用自身地址空间中的内容填充缓存 (Prime)
  2. 等待受害者执行, 更新缓存
  3. 攻击者通过PMU (performance monitor unit, PMU) 检测发生缓存未命中事件的个数 (Count)

Prime+Abort

  1. 打开TSX (transactional synchronization extensions)事务
  2. 攻击者用自己的数据填充特定的cache组 (Prime)
  3. 等待受害者执行
  4. 如果发生Abort, 则表示某些程序已经访问了目标cache组 (Abort)

Reload+Reflush

  1. 攻击者和受害者需要共享内存, 受害者要用到的数据是w, 假设insertion age为2
  2. 攻击者将目标地址与w--1个数据(0--evw--2)放入cache, 置cache为insertion age
  3. 等待受害者访问cache
  4. 如果受害者访问了目标, 则目标块的age减1, 其余age不变
  5. 如果受害者没有访问目标,则所有的age均不变
  6. 检索信息(强制miss+Reload): 攻击者访问evw--1来强制产生一个cache miss, 逐出组的位置由受害者是否访问了该目标决定
  7. 如果受害者访问了目标, 按照逐出策略, 逐出第1个age为3的块并将其置为insertion age
  8. 如果受害者没有访问目标, 按照逐出策略, 逐出目标块并将其置为insertion age
  9. 刷新 (Refresh)状态: 刷新cache, 重载 (Reload) 目标并将其置为insertion age, 然后再Reload被evw--1逐出的数据
相关推荐
m0_7381207239 分钟前
Solar月赛(应急响应)——攻击者使用什么漏洞获取了服务器的配置文件?
运维·服务器·安全·web安全·网络安全
dog2503 小时前
TCP RTO 与丢包检测
网络·网络协议·tcp/ip
希赛网3 小时前
HCIA-Datacom认证笔记:IP路由基础——核心概念与路由分类
网络·笔记·网络协议·tcp/ip·智能路由器
网络研究院4 小时前
从内部保护你的网络
网络·安全·风险·成本·措施
zzc9215 小时前
USRP捕获手机/路由器数据传输信号波形(中)
网络·5g·wifi·路由器·双工通信·手机信号
ALLSectorSorft5 小时前
相亲小程序个人资料管理系统模块搭建
服务器·网络·数据库·python·sql
zhyoobo5 小时前
IPv4 与 IPv6:网络世界的世代更替与未来之路
网络·http·ipv4·ipv6
wanhengidc6 小时前
高防服务器租用:保障数据安全
服务器·网络·安全
大梦南柯6 小时前
ospf综合实验
网络·智能路由器
无望__wsk7 小时前
ospf笔记
服务器·网络·笔记