FLUSH+RELOAD技术
FLUSH+RELOAD技术是PRIME+PROBE技术的变体,攻击间谍进程和目标进程的共享页。在共享页中,间谍进程可以确保一个特定的内存的映射从整个cache的层级中剔除。间谍进程就是使用这一点去监控所有的内存映射。这个攻击的方式是Gullasch 等人提出技术为基础的,增加了对虚拟化和多核条件下的适应。
一个攻击轮由三个阶段。在第一阶段中,被监控的内存的映射从cache中被剔除,在第三阶段之前,间谍进程允许目标访问内存。在第三阶段,间谍进程重新载入内存行,测量重新载入的时间。如果在等待的阶段,目标进程访问了指定的内存空间,那么这个内存的空间就在cache中有记录,重载就只需要很短的时间。另一方面,如果目标没有访问指定的内存空间,则这个空间就需要从内存中提取,重载话费更长的时间。图3(a)和(b)分别显示了无目标进程访问和有目标进程访问的时间线。
如图3(c)所示,目标进程访问可能和间谍的重载阶段重叠,在这种情况下,目标进程访问不会触发缓存的填充。相反,目标进程会使用重载阶段的缓存数据。因此,间谍进程就错过了访问机会。类似的,也发生在部分覆盖的情况。就像图3(D),重载发生在目标进程访问数据时。由于目标进程和间谍进程代码执行是无关的,因此增加等待的时间可以减少由于重叠而丢失访问的概率。另一方面,增加等待的时间也削弱了攻击的粒度。
提高攻击分辨率而不增加错误率的方法的就是提高针对指定区域提高访问速率,例如使用循环体。攻击无法区分不同访问,但是,如图3(e),丢失的几率很小。
由于目标进程的处理器的内存入口随机化,多处理器优化可能出现错误。这些优化包括数据的预提取以开辟空间和乱序执行。在分析攻击结果的时候,攻击着必须意识到优化和发展,并过滤他们的影响。我们的攻击代码如下,这个代码测量在内存地址读取数据的时间,然后剔除cache中的内存的映射。这个测量使用内嵌汇编指令的方式执行。
int probe(char *adrs) {
volatile unsigned long time; asm __volatile__ (
" mfence \n"
" lfence \n"
" rdtsc \n"
" lfence \n"
" movl %%eax, %%esi \n"
" movl (%1), %%eax \n"
" lfence \n"
" rdtsc \n"
" subl %%esi, %%eax \n"
" clflush 0(%1) \n"
: "=a" (time)
: "c" (adrs)
: "%esi", "%edx");
return time < threshold;
}
汇编代码需要一个输入,地址,储存在%ecx中(16行)。变量time是返回值,他是读取%eax寄存器中地址储存值的时间(15行)。第10行读取%ecx中地址指向4个bytes,地址由adrs变量指向。
为了测量此次读取所需要的时间,我们使用处理器的时间戳计数器。在第7行rdtsc指令读取64位计数器,低32bits在%eax中,%edx中储存高32bits。由于我们测量的时间很短,所以我们只是用低位,忽略%edx中的高位。第9行将计数器复制到%ESI。读取内存之后,再次调用,时间戳计数器(12行)。第13行,减去计数器的值,把结果放在寄存器%eax中。这个技术的关键是在cache中剔除指定的内存映射的能力。这个功能使用在14行中clflush这个指令。clflush指令可以从所有的cache层次中剔除指定的内存映射,包括所有核心的L1层和L2层。剔除所核心的映射,确保下次目标进程被映射到L3层上。
mfence和ifence指令的作用是使指令连续化。处理器可能在执行指令的时候是并行化或者不按顺序的。如果没有连续化,指令可能被分割执行。lfence指令可以使指令部分连续。他确保这个指令后面的指令不会在它之前执行。mfence指令作用于储存操作。然而,他不针对其他指令,无法有效的分割。英特尔推荐使用cpuid进行指令串行化,然而,在虚拟化环境中,虚拟机管理器中cpuid仿真耗时过长(1000个周期以上),无法提供攻击所需的粒度。18行比较两个rdtsc指令与预定阈值之间的时间差。应为之前已经被清除了映射关系,如果返回的时间差小于阈值,则表明另一个进程访问了内存行,超过的话,则没有访问。
攻击中阈值的选择是依赖于系统,为了找到测试系统的阈值,我们使用代码测试内存和L1缓存的加载时间(为了测量L1的时间,我们移除14行的clflush指令)。在centos6.5系统,HP Elite 8300电脑的测试,如图5,电脑使用i5-3470处理器。
来自L1cache缓存的数据经历了44个周期(注意,这里包括了rdtsc和fence指令的执行时间,因此比单一指令时间更长)。从内存加载数据的时间,超过百分之98的时间在270到290个周期之间。其余分布在880个周期,大约200个在1140到1175个周期。内存访问,没有小于200个时钟周期。
这个时间取决于硬件和软件环境,戴尔PowerEdge T420,从L1载入需要33到43个,而内存需要230个周期,在相同的硬件条件下,使用KVM虚拟化,有百分之0.02从内存载入需要6000个周期。
基于测量结果和英特尔文档,我们将阈值设置为120个周期。
FLUSH+RELOAD技术的更多相关文章
- Meltdown论文翻译【转】
转自:http://www.wowotech.net/basic_subject/meltdown.html#6596 摘要(Abstract) The security of computer sy ...
- CPU Meltdown和Spectre漏洞分析
一.背景: 1月4日,国外爆出了整个一代处理器都存在的灾难性漏洞:Meltdown和Spectre. 几乎影响了全球20年内所有cpu处理器:这两个漏洞可以使攻击者通过利用并行运行进程的方式来破坏处理 ...
- intel:spectre&Meltdown侧信道攻击(三)—— raw hammer
今天介绍raw hammer攻击的原理:这次有点“标题党”了.事实上,raw hammer是基于DRAM内存的攻击:所以理论上,只要是用了DRAM内存的设备,不论是什么cpu(intel.amd,或则 ...
- 【转】Yeoman:Web 应用开发流程与工具
原文转自:http://blog.jobbole.com/62098/ 随着 Web 2.0 和 HTML 5 的流行,现在的 Web 应用所能提供的功能和交互能力比之前传统的 Web 应用要强大很多 ...
- Meltdown Attack
1. 引言 2018年1月3日,Google Project Zero(GPZ)团队安全研究员Jann Horn在其团队博客中爆出CPU芯片的两组漏洞,分别是Meltdown与Spectre. Mel ...
- MySql(十一):MySQL性能调优——常用存储引擎优化
一.前言 MySQL 提供的非常丰富的存储引擎种类供大家选择,有多种选择固然是好事,但是需要我们理解掌握的知识也会增加很多.本章将介绍最为常用的两种存储引擎进行针对性的优化建议. 二.MyISAM存储 ...
- 数据库分享一: MySQL的Innodb缓存相关优化
无论是对于哪一种数据库来说,缓存技术都是提高数据库性能的关键技术,物理磁盘的访问速度永 远都会与内存的访问速度永远都不是一个数量级的.通过缓存技术无论是在读还是写方面都可以大大提 高数据库整体性能. ...
- MySQL性能调优与架构设计——第11章 常用存储引擎优化
第11章 常用存储引擎优化 前言: MySQL 提供的非常丰富的存储引擎种类供大家选择,有多种选择固然是好事,但是需要我们理解掌握的知识也会增加很多.每一种存储引擎都有各自的特长,也都存在一定的短处. ...
- 深入理解“骑士”漏洞 VoltJockey
先理解一下题目:VoltJockey: Breaching TrustZone by Software-Controlled Voltage Manipulation over Multi-core ...
随机推荐
- 推荐算法之因子分解机(FM)
在这篇文章我们将介绍因式分解机模型(FM),为行文方便后文均以FM表示.FM模型结合了支持向量机与因子分解模型的优点,并且能够用了回归.二分类以及排序任务,速度快,是推荐算法中召回与排序的利器.FM算 ...
- java 子线程定时去更改主线程的变量
在一次代码编写场景,需要post一些数据,同时携带获得的token,(但是token的有效时间是7200s),但是post需要很多次,很长时间,不可能2小时候中断程序,手动去获取token,这样效率太 ...
- 代码质量:SonarQube
SonarQube SonarQube的安装 jenkins(十四):Jenkins和sonarqube集成 https://www.cnblogs.com/sunyllove/p/9895373.h ...
- [CentOS7]sed 指定字符前后添加内容
指定字符前面添加 sed -i 's/指定的字符/需要添加的字符&/' 文件名称 修改Linux启动配置 将 GRUB_CMDLINE_LINUX="rd.lvm.lv=centos ...
- vertical-align和line-height的理解及实例
line-height 字符实际大小和font-size的关系: 下图中不同字体font-size都是100px 测量了一下每个 span 的高度:Helvetica 115px,Gruppo 97p ...
- Class Literal(Java)
前言 上一节我们讨论过通过关键字synchronized实现线程同步,同时最主要了解到在Java中className.class所代表的具体含义,在博客写完后,感觉还是有点迷糊,然后再次深入了解后,原 ...
- JS循环解决任意日期间的间隔天数
用JS循环解决任意日期间的间隔天数,并求截止日期是周几 y1=1900 m1=1 d1=1 y2=2000 m2=5 d2=3 days=0 ydays=0 mdays=0 ddays=d2-d1 f ...
- javascript30--day01--Drum kit
相关视频链接:https://www.bilibili.com/video/av8481988/?p=3 Drum kit 做题思路(1)监听键盘事件 addEventListener(‘事件名’,执 ...
- 在服务器上搭建远端git仓库
推荐使用运行Liunx的机器 请获取root权限后进行下面操作 安装git # 检查是否安装了git如果有版本号就无需再安装 git -v # 安装git sudo apt-get install g ...
- echarts配置环形饼图的参数,以及牵引线显示百分比,中间数据
最近项目有多处是用echarts的,有环形图,折线图,饼图,总结了一下. 本次主要讲环形图,折线图在下期. 这个是最终的效果图.下面附上代码 //三种占比 var myChartType = echa ...