常见的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逐出的数据
相关推荐
树℡独7 小时前
ns-3仿真之应用层(五)
服务器·网络·tcp/ip·ns3
zhang133830890758 小时前
CG-09H 超声波风速风向传感器 加热型 ABS材质 重量轻 没有机械部件
大数据·运维·网络·人工智能·自动化
酣大智9 小时前
接口模式参数
运维·网络·网络协议·tcp/ip
24zhgjx-lxq10 小时前
华为ensp:MSTP
网络·安全·华为·hcip·ensp
ling___xi10 小时前
《计算机网络》计网3小时期末速成课各版本教程都可用谢稀仁湖科大版都可用_哔哩哔哩_bilibili(笔记)
网络·笔记·计算机网络
REDcker10 小时前
Linux 文件描述符与 Socket 选项操作详解
linux·运维·网络
Up九五小庞11 小时前
用arpspoof实现100%批量切断192.168.110.10 - 192.168.110.100 断网(双向欺骗)--九五小庞
网络·开源
code_li11 小时前
“信息安全”与“网络安全”区别
安全·网络安全·信息安全
躺柒11 小时前
读数字时代的网络风险管理:策略、计划与执行04风险指引体系
大数据·网络·信息安全·数字化·网络管理·网络风险管理
交通上的硅基思维11 小时前
人工智能安全:风险、机制与治理框架研究
人工智能·安全·百度