内核内存泄露,Intel处理器设计缺陷迫使Linux, Windows重新设计

本文主要是介绍内核内存泄露,Intel处理器设计缺陷迫使Linux, Windows重新设计,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

内核内存泄露,Intel处理器设计缺陷迫使Linux, Windows重新设计

或许其它OS也需要修复

最后更新:Intel处理器基础的设计缺陷迫使Linux和Windows内核重新设计来修复这个芯片级别的bug。

程序员们正在全面检查开源的Linux内核虚拟内存系统。同时,Windows可能会在周二的补丁公布修复措施:这些措施已经在十一月和十二月Windows Insider的测试版中。

但是,这些升级对基于Intel芯片的Linux和Windows会有性能上的影响。这些影响仍在评估(基于任务和处理器型号可能会有30%的下降)。

PostgreSQL SELECT 1 with the KPTI workaround for Intel CPU vulnerability https://t.co/N9gSvML2Fo
Best case: 17% slowdown
Worst case: 23%

— The Register (@TheRegister)

January 2, 2018

类似的系统,比如苹果64位的macOS,也需要升级,这个缺陷是在Intel X86-64硬件级别的,通过微代码的形式来修复是不可能的。它只能通过操作系统级别来修复,或者重新买一个没有设计缺陷的处理器。

影响

这个bug在近近几十年的现代处理器里都有。它允许普通用户程序-从数据库应用到浏览器里的JavaScript,来读取访问受保护的内核内存区域。

解决办法是将内核内存完全从用户进程中分类出来,通过使用Kernel Page Table Isolation(KPTI)。

当运行一些程序进行必要的操作时,比如写入文件或者打开一个网络连接-它就可以临时控制处理器以及内核来执行任务。为了使从用户态到内核态的互相转换尽可能的快,内核会在所有进程的虚拟内存地址空间展现,尽管它对程序不可见。当内核被需要时,程序会启动系统调用,处理器会转换为内核态进入内核。当它完成之后,CPU会被告知转换为用户态,然后重新进入进程。当在用户态时,内核的代码和数据仍然不可见,但是会在进程的页表展现(page table)。

想象内核是一个在云端的上帝,看着地球。他就在那,但是任何正常的事物都看不见它,当然你可以祈祷来看见他。

KPTI补丁将内核移动到一个完全不同的地址空间,所以它不仅对运行的进程不可见,它甚至不在那。尽管这不需要,但是这个缺陷会通过某些方法访问到内核。

这种分离措施的负面影响相对来说代价较大,为了保持在两个分散开的地址空间进行切换(每次系统调用,每次来此硬件的中断)。这些上下文的切换并不是即时生效的,它们会迫使处理器清除掉缓存数据然后从内存中重新载入,导致计算机处理速度的下降。

这个安全漏洞如何被利用

最好的情况,这个漏洞被恶意软件和黑客利用来更容易的渗透其他安全漏洞。

最坏的情况,这个漏洞被程序和登陆用户来读取内核内存的内容。这就很恐怖了。内核内存空间对用户进程和程序是隐藏的,因为它可能包含各种各样的秘密,比如密码,登陆密钥,磁盘的文件缓存等等。想象一段运行在浏览器的JavaScript,或者运行在云服务器上的恶意程序,可以嗅探到敏感的内核数据。

在最好的场景中,利用这个缺陷可以用来打败KASLR:kernl address space layout randomization。这是被各种各样的操作系统用来把内核的组件放在随机的虚拟内存的地址中。这种措施可以打败那些想要在内核利用其他Bug的尝试,典型的:渗透代码,特别是return-oriented programming exploits,这种渗透依赖在已知的内存地址重用计算机指令。

如果你随机的把内核代码放在内存,渗透者就找不到她们需要的内部部件来渗透电脑。处理器漏洞可以被利用来找出内核放在内存中数据和代码,所以将会有大量的软件补丁。

然而,英特尔芯片的漏洞可能比上述更糟糕。在圣诞节期间发往Linux内核邮件列表的一封电子邮件中,AMD称它没有受到影响。

AMD处理器不受内核页表隔离特性保护的攻击类型的限制。AMD的结构不允许的内存引用,包括投机参考,访问权限较高的数据在一个较小的特权模式运行时,访问将导致页面故障。

这里的一个关键词是“投机”(speculative),像英特尔这样的现代处理器执行推测性执行。为了使内部管道遵守指令,CPU核心尽可能猜测接下来要运行什么代码,取它并执行它。

AMD公司的软件工程师Tom Lendacky说,英特尔的CPU在执行speculatively代码时可能没有执行安全检查。似乎可以以这样一种方式来编写软件,使处理器开始执行通常会被阻塞的指令(例如从用户模式读取内核内存),然后在特权级别检查发生之前完成该指令。

这将会允许ring-3-level的用户代码来读取ring-0-level的内核数据。这很不好。

该漏洞的具体细节还没有得到证实,但请考虑一下:Linux和Windows的更新非常重要,正在快速推出。这表明它比KASLR旁路更严重。

同时,为了分离内核和用户地址空间,Linux上的更新是基于一套修复被称为KAISER的补丁,这是在奥地利格拉茨科技大学的科学家创造的。这些研究人员发现可以通过从CPU上的虚拟内存系统的侧信道攻击内核和内存布局信息来打败KASLR。研究小组建议拆分内核和用户空间以防止信息泄漏,他们的研究引发了这一轮补丁。

他们的工作由在七月写了下面博客的Anders Fogh验证。这篇文章描述了他试图通过滥用推测执行从用户模式读取内核内存的尝试。尽管Fogh无法拿出任何工作的概念证明代码,他指出:

我的结果表明,尽管内核模式和用户模式之间存在隔离,但投机执行确实仍在继续。

看来KAISER与Fogh的研究相关,利用虚拟内存布局打破KASLR的实用方法,团队可能已经证明Fogh是正确的,英特尔的x86芯片推测执行可以被利用来访问内核内存。

共享系统

这个bug会影响很多知名的云服务器提供商,包括Amazon EC2, Microsoft Azure, Google Computer Engine,源于一位软件开发人员在博客和Twitter上发表的一篇文章:

目前的安全漏洞显然影响当代英特尔的CPU架构,完全解决需要实现虚拟内存以及硬件的变化。软件的紧急开发正在公开中进行,最近在Linux内核中实现,类似的措施在十一月会出现在NT内核中。在最坏的情况下,修复措施将在典型工作负载下造成明显的性能下降。
潜在的受攻击者包括常见的虚拟化环境,比如Amazon EC2和Google Computer Engine…

Microsoft Azure Cloud–运行大量的Linux以及Windows–将在1月10日进行维护和重新启动,想必会修复上述bug。

Amazon Web Service还通过电子邮件警告客户,预计本星期五将发布一项重大安全更新,但不涉及细节。

英特尔发言人没有置评。

这篇关于内核内存泄露,Intel处理器设计缺陷迫使Linux, Windows重新设计的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1131204

相关文章

Linux线程之线程的创建、属性、回收、退出、取消方式

《Linux线程之线程的创建、属性、回收、退出、取消方式》文章总结了线程管理核心知识:线程号唯一、创建方式、属性设置(如分离状态与栈大小)、回收机制(join/detach)、退出方法(返回/pthr... 目录1. 线程号2. 线程的创建3. 线程属性4. 线程的回收5. 线程的退出6. 线程的取消7.

Linux下进程的CPU配置与线程绑定过程

《Linux下进程的CPU配置与线程绑定过程》本文介绍Linux系统中基于进程和线程的CPU配置方法,通过taskset命令和pthread库调整亲和力,将进程/线程绑定到特定CPU核心以优化资源分配... 目录1 基于进程的CPU配置1.1 对CPU亲和力的配置1.2 绑定进程到指定CPU核上运行2 基于

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

Linux在线解压jar包的实现方式

《Linux在线解压jar包的实现方式》:本文主要介绍Linux在线解压jar包的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux在线解压jar包解压 jar包的步骤总结Linux在线解压jar包在 Centos 中解压 jar 包可以使用 u

linux解压缩 xxx.jar文件进行内部操作过程

《linux解压缩xxx.jar文件进行内部操作过程》:本文主要介绍linux解压缩xxx.jar文件进行内部操作,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、解压文件二、压缩文件总结一、解压文件1、把 xxx.jar 文件放在服务器上,并进入当前目录#

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

在Linux中改变echo输出颜色的实现方法

《在Linux中改变echo输出颜色的实现方法》在Linux系统的命令行环境下,为了使输出信息更加清晰、突出,便于用户快速识别和区分不同类型的信息,常常需要改变echo命令的输出颜色,所以本文给大家介... 目python录在linux中改变echo输出颜色的方法技术背景实现步骤使用ANSI转义码使用tpu

linux hostname设置全过程

《linuxhostname设置全过程》:本文主要介绍linuxhostname设置全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录查询hostname设置步骤其它相关点hostid/etc/hostsEDChina编程A工具license破解注意事项总结以RHE

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.