前文中提到过,Netburst架构中,采用了破天荒的31级流水线,但是很快大家就发现流水线深度过犹不及的道理,在Core架构中流水线深度为14。
在P6微架构中,支持3发射超标量流水线。在7代微架构Netburst中,可能是因为流水线太长做多发射不容易的原因,回退成了2发射。8代微架构Core由于是重新设计的,流水线长度也降低是最深14级,它的超标量水平也得以进一步提高,变为4发射。
Core微架构支持L1指令缓存和数据缓存分离,各32KB。每个核心单独有一组。L2缓存是共享的,没有L3缓存。
从Core微架构开始,Intel CPU开始使用micro-ops,每一个x86 CISC指令在取址译码后,会翻译成一个或多个RISC指令,在流水线的后半部分,可以利用RISC CPU的一些技术提高指令的执行效率。
从上面的架构图中可以看到,译码单元包括三个简单译码器和一个复杂译码器,简单译码器的输出为1个micro-op,复杂译码器的输出为4个micro-ops。
坏消息是在这一代微架构中,micro-ops不支持64位指令。
在上一代微架构中,128位SSE指令需要2个周期,现在只需要一个周期。
以前就已经有了,就是初始工作频率很低,根据workload来决定是否切换到高频率。这样可以降低功耗。
虚拟化技术包括CPU虚拟机、内存虚拟化、网络虚拟化等,总之是提供一些硬件和指令来保证多个虚拟机可分享计算存储网络等资源的同时能够互不影响。虚拟化技术可以写一个单独的话题。
英特尔主动管理技术(Active Management Technology) [1] 是一个以硬件为基础的远程管理技术,它是Intel vPro[2] 技术的其中之一。这项技术主要是让IT人员可以从通过OOB的网络连接来查看(Discover)、修复(Heal)以及保护(Protect)桌面型、笔记本电脑,或服务器。
简单来说这东西有点像现代服务器的BMC系统,BMC是在主板上集成一个小CPU,AMT则直接在CPU里面集成了另一个小CPU。这个小CPU或说SoC可以不受用户控制地管理你的网络、内存等。一听就很危险的样子。
硬件安全专家Damien Zammit在BoingBoing博客网站[3]指出Intel在部分CPU内建了一个无法被禁用的名为Intel管理引擎(Intel Management Engine)的子系统来运行AMT,该子系统运行在Intel处理器中处理器内并独立于计算机自身的闭源操作系统,能够直接访问计算机上的存储器并通过Intel的网络接口创建TCP/IP服务器使AMT具备运程控制功能,无论计算机的自身操作系统是否运行了防火墙,而且计算机即使在休眠情况下也能以极低的功耗运行,Zammit指出该子系统封闭源代码且系统固件采用RAS2048位算法加密,无法审计其安全性,也无法判断其是否为NSA的所谓后门,如果系统代码被恶意盗用,每台使用Intel处理器且连接互联网的计算机,都可能使子系统成为暴露的Rootkit。