ARM、Intel、MIPS处理器啥区别?看完全懂了【转】

转自:http://news.mydrivers.com/1/472/472317.htm

安卓支持三类处理器(CPU):ARM、Intel和MIPS。ARM无疑被使用得最为广泛。Intel因为普及于台式机和服务器而被人们所熟知,然而对移动行业影响力相对较小。MIPS在32位和64位嵌入式领域中历史悠久,获得了不少的成功,可目前Android的采用率在三者中最低。

总之,ARM现在是赢家而Intel是ARM的最强对手。那么ARM处理器和Intel处理器到底有何区别?为什么ARM如此受欢迎?你的智能手机或平板电脑用的是什么处理器到底重要不重要? 

处理器(CPU)

中央处理器(CPU)是你智能设备的大脑。它的任务是通过执行一系列指令来驱动你的设备,包括显示屏、触摸屏、调制解调器等,让一坨塑料金属混合物变成闪亮的智能手机或者平板电脑。

移动设备非常复杂,其中的处理器需要执行数百万行指令才能完成人们希望这些设备去做的事。速度和功耗对处理器来说至关重要。速度影响用户体验,功耗影响电池寿命。完美的移动设备必须有好性能以及低功耗。

这就是为什么选择什么样的处理器很重要。一个超级耗电、反应迟钝的处理器会很快吸干你的电池,而一个考究的、高效的处理器给你带来高性能和长久的电池寿命。

总体而言,ARM和Intel处理器的第一个区别是,前者使用精简指令集(RISC),而后者使用复杂指令集(CISC)。

通俗而言,精简指令集规模较小,更接近原子操作,而复杂指令集规模较大,更加复杂。所谓原子操作,是指每条指令的工作大都可以由处理器在一个操作内完成,例如对两个寄存器做加法。

复杂指令集的指令描述某个意图,但是处理器必须执行3或4个更简单的指令来实现这个意图。例如,可以命令一个复杂指令集处理器对2个数求和,并把结果存入主内存中。为了完成这个命令,处理器首先从地址1中取得第一个数(操作1),然后从地址2中取得另一个数(操作2),然后求和(操作3),等等。

所有的现代处理器都使用一种所谓微指令的概念,这是一个处理器内部的指令集合,用来描述处理器可以做的原子操作。

复杂指令集处理器实际上执行了3条微指令。对精简指令集处理器而言,其指令跟其微指令十分接近,而复杂指令集处理器的指令需要先被转换成一些更精简的微指令(就像前面的复杂指令集处理器做加法的例子中那样)。

也就是说,精简指令集处理器中的解码器(负责告诉处理器到底要干些什么的东东)要简单得多,而简洁意味着高效和低功耗。

制造工艺

ARM和Intel处理器的另外一个主要区别是ARM从来只是设计低功耗处理器。其宗旨是设计低功耗处理器,这是他们的强项。Intel的强项是设计超高性能的台式机和服务器处理器,并且的确做的不错。

Intel是台式机的服务器行业的老大。过去的20年里我所有的PC,笔记本和服务器(除了一个外)用的都是Intel的处理器。然而进入移动行业时,Intel依然使用和台式机同样的复杂指令集架构,试图将其硬塞入给移动设备使用的体积较小的处理器中。

Intel i7处理器平均发热率为45瓦。基于ARM的片上系统(其中包括图形处理器)的发热率最大瞬间峰值大约是3瓦,约为Intel i7处理器的1/15。Intel现如今是个巨头,雇佣了大量的聪明人。

其最新的Atom系列处理器采用了跟ARM处理器类似的温度控制设计,为此Intel必须使用最新的22纳米制造工艺。一般而言,制造工艺的纳米数越小,能量的使用效率越高。ARM处理器使用更低的制造工艺,拥有类似的温控效果。比如,高通晓龙805处理器使用28纳米制造工艺。

64位

对于64位计算,ARM和Intel也有一些显著区别。你知不知道,Intel并没有开发64位版本的x86指令集。这个64位的指令集,名为x86-64(有时简称为x64),实际上是AMD设计开发的。

故事是这样的:Intel想搞64位计算,它知道如果从自己的32位x86架构进化出的64位架构的话,新架构效率会很低,于是它搞了一个新64位处理器项目名为IA64。由此制造出了Itanium系列处理器。

同时AMD知道自己造不出能与IA64兼容的处理器,于是它把x86扩展一下,加入了64位寻址和64位寄存器。最终出来的架构,人称AMD64,成为了64位版本的x86处理器的标准。

IA64项目并不算得上成功,现如今基本被放弃了。Intel最终采用了AMD64。Intel当前给出的移动方案,是采用了AMD开发的64位指令集(有些许差别)的64位处理器。

ARM的故事很不一样:看到移动设备对64位计算的需求后,ARM于2011年发布了ARMv8 64位架构,这是为了下一代ARM指令集架构工作若干年后的结晶。为了基于原有的原则和指令集,开发一个简明的64位架构,ARMv8使用了两种执行模式,AArch32和AArch64。

顾名思义,一个运行32位代码,一个运行64位代码。ARM设计的巧妙之处,是处理器在运行中可以无缝地在两种模式间切换。这意味着64位指令的解码器是全新设计的,不用兼顾32位指令,而处理器依然可以向后兼容。

异构计算

ARM的big.LITTLE架构是一项Intel一时无法复制的创新。在big.LITTLE架构里,处理器可以是不同类型的。传统的双核或者四核处理器中包含同样的2个核或者4个核。一个双核Atom处理器中有两个一模一样的核,提供一样的性能,拥有相同的功耗。

ARM通过big.LITTLE向移动设备推出了异构计算。这意味着处理器中的核可以有不同的性能和功耗。当设备正常运行时,使用低功耗核,而当你运行一款复杂的游戏是,使用的是高性能的核。

这是什么做到的呢?设计处理器的时候,要考虑大量的技术设计的采用与否,这些技术设计决定了处理器的性能以及功耗。

在一条指令被解码并准备执行时,Intel和ARM的处理器都使用流水线。就是说解码的过程是并行的。

第一步从内存中读取指令,第二步检查和解码指令,第三步执行指令,周而复始。流水线的好处在于,当前指令在第二步的时候,下一条指令已经处于第一步。当前指令在第三步中执行的时候,下一条指令正处于第二步,而下下条指令处于第一步中,如此循环。

为了更快地执行指令,这些流水线可以被设计成允许指令们不按照程序的顺序被执行(乱序执行)。一些巧妙的逻辑结构可以判断下一条指令是否依赖于当前的指令执行的结果。Intel和ARM都提供乱序执行逻辑结构,可想而知,这种结构十分的复杂。复杂意味着更多的功耗。

Intel处理器由设计者们选择是否加入乱序逻辑结构。异构计算则没有这方便的问题。ARM Cortex-A53采用顺序执行,因此功耗低一些。而ARM Cortex-A57使用乱序执行,所以更快但更耗电。采用big.LITTLE架构的处理器可以同时拥有Cortex-A53和Cortex-A57核,根据具体的需要决定如何使用这些核。在后台同步邮件的时候,不需要高速的乱序执行,仅在玩复杂游戏的时候需要。在合适的时间使用合适的核。

原则上,处理器中复杂逻辑结构越多性能越高,越少则效率越高,指令流水线只是其中之一,包括浮点运算单元,单指令多数据逻辑(SIMD)(比如ARM的NEON和Intel的SSE/MMX),以及一级缓存二级缓存。

每种Atom片上系统,Intel仅提供一种方案,而ARM以及芯片合作伙伴提供的芯片则有多种方案可以配置。

兼容性

ARM目前是移动处理器的老大。ARM的合作伙伴们基于ARM的设计向移动和嵌入式市场的出货量已经达500亿片。对于安卓,ARM已然成为标准,这对Intel和MIPS而言是个问题。

尽管安卓的主要编程语言是Java,开发者也可以使用现有的代码(比如C或者C++)去开发应用。这些固定平台的应用通常都编译成ARM处理器的程序,不全都会编译成Intel或者MIPS处理器的程序。

为了解决这个问题,Intel和MIPS要使用特殊的转换软件把ARM的指令转换成他们处理器使用的指令。这当然是会降低性能的。

目前MIPS和Intel声称兼容Play Store里大约90%的应用。对于最受欢迎的150个应用,兼容率是100%。一方面兼容率很高,另一方面表明ARM的主导地位,使得其他的处理器设计者需要提供一个兼容层。

总结

制造处理器是一项复杂的业务。ARM,Intel和MIPS都在不懈努力地向移动设备提供最好的技术,而很明显ARM是老大。拥有着低功耗,简明的64位设计,异构计算,以及作为移动计算的标准,看来ARM必能保持其老大的地位。

文章纠错

微信公众号搜索"驱动之家"加关注,每日最新的手机、电脑、汽车、智能硬件信息可以让你一手全掌握。推荐关注!【微信扫描下图可直接关注】

时间: 2024-09-28 19:29:40

ARM、Intel、MIPS处理器啥区别?看完全懂了【转】的相关文章

三种移动处理器(ARM, Intel和MIPS)之间的主要区别

安卓支持3类处理器(CPU):ARM, Intel和MIPS.其中ARM无疑被使用得最为广泛.Intel因为普及于台式机和服务器而被人们所熟知,然而对移动行业影响力相对较小.MIPS在32位和64位嵌入式领域中历史悠久,获得了不少的成功,可目前Android的采用率在三者中最低. 总之,ARM现在是赢家而Intel是ARM的最强对手.那么ARM处理器和Intel处理器到底有何区别?为什么ARM如此受欢迎?你的智能手机或平板电脑用的是什么处理器到底重要不重要? 处理器(CPU) 中央处理器(CPU

ARM是什么处理器

  随着移动设备平台的日益壮大,甚至有取代桌面平台的势头,"ARM"这个词越来越多地出现在人们的视野中,特别是手机或平板处理器上,然而却从不见ARM的处理器,而是"采用ARM最新架构"的处理器.其实,ARM(Adanced RISC Machines),不仅是是一种处理器的通称,也是一个公司名字,还可以认为是一种技术名字. 1991年ARM公司成立于英国Cambridge,主要销售晶片设计技术的授权.目前,采用ARM技术知识产权(IP)核的微处理器,即我们通常说的A

嵌入式X86、ARM、MIPS架构对比 arm芯片将成主流?

在纵观市面上包括商显终端在内的主流物联网设备所采用的芯片时,你会发现ARM已经雄霸半壁江山!ARM的合作伙伴们基于ARM的设计向移动和嵌入式市场的出货量已经达500亿片! 591abb8934313.jpg 对比全球最主要的三大架构X86.ARM.MIPS架构分析, ARM芯片会成为物联网行业的主流? 指令集可分为复杂指令集(CISC)和精简指令集(RISC)两部分,代表架构分别是x86.ARM和MIPS.ARM.X86.MIPS这三大架构大家都不陌生, Intel因为普及于台式机和服务器而被人

Intel最新处理器路线图:10nm大延期

随着Coffee Lake曝光在2018年上市,Intel的处理器路线图又悄然发生了新的变化.不得不说,这是一个看不懂的家族,因为按计划,明年下半年会有10nm的Cannon Lake,结果2018年又回炉重造14nm.所以,Coffee Lake现在被叫做了正统的第八代酷睿,Cannon Lake是改名还是要经历大延期? "咖啡"首次曝光时的路线 至少在权威媒体咕噜看来10nm的确要延期,它们制作的最新图表绘制了比较可能的CPU路径图. 因为Coffee Lake依然是14nm,所以

技嘉GA-H61M-S1主板支持Intel最新处理器内建绘图核心

•抗潮湿–高密度开纤布电路板•抗静电–防静电芯片 和 抗突波–防突波芯片设计•支持 Intel LGA1155第二代酷睿处理器•支持 On/Off Charge优化iPad, iPhone and iPod Touch的充电效能•支持 PCI-Express 第三代传输接口•支持 Intel 最新处理器内建绘图核心HD 2000/3000 (点击图片可查看产品高清大图) 先来了解一下这款技嘉GA-H61M-S1主板规格: 中央处理器(CPU) 支持LGA1155插槽处理器: Intel® Cor

迁移到位于Intel Xeon处理器之上的IBM DB2

迁移到新的数据库平台或硬件架构似乎有些令人畏缩.而组织可能必须通过更改来实现关键业务目标.举例来说,从 Oracle Database 迁移到 IBM® DB2® 有助于削减成本.降低复杂性.将数据库从 Sun SPARC http://www.aliyun.com/zixun/aggregation/13748.html">基础架构迁移到基于 Intel® Xeon® 处理器的 IBM System x® 服务器能够提高数据库性能.整合率.可伸缩性和可用性. 无论最初的目标如何,迁移到基

AMD倒戈x86阵营 ARM架构服务器处理器开始测试

自上世纪80年代初开始,AMD的处理器就一直坚持采用由英特尔发明出的x86架构.不过这家公司在本周二表示,公司首款采用ARM架构的服务器处理器已开始进行测试. ARM架构的处理器目前已被智能手机和平板电脑所广泛采用.和其他众多计划推出ARM架构服务器处理器的公司一样,AMD推出首款采用ARM架构产品的逻辑,便是它们的低成本和低能够,能够产生巨大的经济效应.不过对于像AMD这样的x86忠实拥护者而言,拥抱ARM架构确实令市场感到震惊. AMD负责ARM架构服务器处理器开发工作的安德鲁·http:/

英特尔小心!AMD发ARM架构Opteron处理器

据外媒报道,AMD今日正式推出了首个基于ARM架构的处理器Opteron A1100,希望在数据中心服务器市场挑战英特尔的霸主地位.早在2012年10月,AMD就宣布将采纳ARM架构自主设计相关处理器产品. 2014年初,AMD发布了首款ARM架构处理器Opteron A1100(代号为Seattle).该款处理器主要面向网络.存储.Web服务器和软件开发等领域.经过数年的延迟,AMD今日宣布,Opteron A1100将正式批量出货. AMD表示,这款64位ARM处理器的上市日期确实晚于公司预

c语言-edison连接mpu6050代码看不大懂

问题描述 edison连接mpu6050代码看不大懂 #include "math.h" #include "stdio.h" #include "mraa.h" #include "unistd.h" #define MPU6050_I2C_ADDR 0x68 #define PWR_MGMT_1 0x6B #define SMPLRT_DIV 0x19 #define CONFIG 0x1A #define GYRO_CO