资料介绍
重温下 CPU 是什么鬼
中央处理单元(CPU)主要由运算器、控制器、寄存器三部分组成,从字面
意思看运算器就是起着运算的作用,控制器就是负责发出 CPU 每条指令所需要
的信息,寄存器就是保存运算或者指令的一些临时文件,这样可以保证更高的速
度。
CPU 有着处理指令、执行操作、控制时间、处理数据四大作用,打个比喻来
说,CPU 就像我们的大脑,帮我们完成各种各样的生理活动。因此如果没有 CPU,
那么电脑就是一堆废物,无法工作。移动设备其实很复杂,这些 CPU 需要执行
数以百万计的指示,才能使它向我们期待的方向运行,而 CPU 的速度和功率效
率是至关重要的。速度影响用户体验,而效率影响电池寿命。最完美的移动设备
是高性能和低功耗相结合
要了解 X86 和 ARM,就得先了解复杂指令集(CISC)和精简指令集(RISC)
从 CPU 发明到现在,有非常多种架构,从我们熟悉的 X86,ARM,到不太熟
悉的 MIPS,IA64,它们之间的差距都非常大。但是如果从最基本的逻辑角度来
分类的话,它们可以被分为两大类,即所谓的“复杂指令集”与“精简指令集”系统,
也就是经常看到的“CISC”与“RISC”。 Intel 和 ARM 处理器的第一个区别是,前者
使用复杂指令集(CISC),而后者使用精简指令集(RISC)。属于这两种类中的各
种架构之间最大的区别,在于它们的设计者考虑问题方式的不同。
我们可以继续举个例子,比如说我们要命令一个人吃饭,那么我们应该怎么
命令呢?我们可以直接对他下达“吃饭”的命令,也可以命令他“先拿勺子,然后
舀起一勺饭,然后张嘴,然后送到嘴里,最后咽下去”。从这里可以看到,对于
命令别人做事这样一件事情,不同的人有不同的理解,有人认为,如果我首先给
接受命令的人以足够的训练,让他掌握各种复杂技能(即在硬件中实现对应的复
杂功能),那么以后就可以用非常简单的命令让他去做很复杂的事情——比如只
要说一句“吃饭”,他就会吃饭。但是也有人认为这样会让事情变的太复杂,毕竟
接受命令的人要做的事情很复杂,如果你这时候想让他吃菜怎么办?难道继续训
练他吃菜的方法?我们为什么不可以把事情分为许多非常基本的步骤,这样只需
要接受命令的人懂得很少的基本技能,就可以完成同样的工作,无非是下达命令
的人稍微累一点——比如现在我要他吃菜,只需要把刚刚吃饭命令里的“舀起一
勺饭”改成“舀起一勺菜”,问题就解决了,多么简单。这就是“复杂指令集”和“精
简指令集”的逻辑区别。
从几个方面比较 ARM 与 X86 架构
Intel 和 ARM 的处理器除了最本质的复杂指令集(CISC)和精简指令集(RISC)
的区别之外,下面我们再从以下几个方面对比下 ARM 和 X86 架构。
一、制造工艺
ARM 和 Intel 处理器的一大区别是 ARM 从来只是设计低功耗处理器,Intel
的强项是设计超高性能的台式机和服务器处理器。
一直以来,Intel 都是台式机的服务器行业的老大。然而进入移动行业时,Intel
依然使用和台式机同样的复杂指令集架构,试图将其硬塞入给移动设备使用的体
积较小的处理器中。但是 Intel i7 处理器平均发热率为 45 瓦。基于 ARM 的片上
系统(其中包括图形处理器)的发热率最大瞬间峰值大约是 3 瓦,约为 Intel i7
处理器的 1/15。其最新的 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 位计算的需求后,于 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 向移动设备推出了异构计算。这意味着处
理器中的核可以有不同的性能和功耗。当设备正常运行时,使用低功耗核,而当
你运行一款复杂的游戏时,使用的是高性能的核
- SH7086 中央处理器板 M3A-HS86 用户手册
- CPU、MCU、MPU、DSP、FPGA介绍
- 1971旗舰cpu intel_科普丨CPU、MCU、MPU、DSP、FPGA各是什么?有什么区别?
- CPU、MCU、MPU、DSP的区别
- 《嵌入式 - 嵌入式大杂烩》一文搞懂CPU、MPU、MCU、SOC的联系与区别
- CPU、MCU、MPU及DSP的区别和介绍
- CPU、MCU、MPU、DSP的区别和介绍
- CPU、MPU、MCU、SOC 介绍
- CPU、MPU、MCU、SoC、MCM介绍
- 详细介绍8310各组成部分原理 8次下载
- PLC系统是如何组成的 13次下载
- 树莓派的ARM与x86和Windows与Linux的背景资料说明
- TMS320C28xCPU和指令集参考指南 70次下载
- 探秘X86架构CPU流水线 25次下载
- 80X86CPU 252次下载
- 中央处理器的工作原理及基本结构 1620次阅读
- 处理器和cpu是一个东西吗 cpu和主板的区别 1.4w次阅读
- CPU和GPU之间的主要区别 605次阅读
- CPU超频和倍频技术介绍 1209次阅读
- X86架构与Arm架构的区别 1.9w次阅读
- CPU架构是由哪些部分组成的 5481次阅读
- CPU(中央处理器)的组成部分及工作原理 1.6w次阅读
- CPU架构有多少种?X86与ARM有哪些不同之处?看完这篇你就懂了 5.7w次阅读
- 关于ARM架构与x86的概述以及应用的全面解析 6893次阅读
- 医疗设备逐渐从X86转到ARM平台主要原因是什么 4302次阅读
- 8086CPU引脚图及功能_8086CPU组成部分 6.7w次阅读
- 中央处理器cpu性能排名 2w次阅读
- x86 cpu详细介绍 x86 cpu遵循原则与生产厂家 3431次阅读
- cpu的相关技术参数及其处理技术 2084次阅读
- 多方位对比ARM和x86 CPU两大架构现在发展如何? 2508次阅读
下载排行
本周
- 1TC358743XBG评估板参考手册
- 1.36 MB | 330次下载 | 免费
- 2开关电源基础知识
- 5.73 MB | 6次下载 | 免费
- 3100W短波放大电路图
- 0.05 MB | 4次下载 | 3 积分
- 4嵌入式linux-聊天程序设计
- 0.60 MB | 3次下载 | 免费
- 5基于FPGA的光纤通信系统的设计与实现
- 0.61 MB | 2次下载 | 免费
- 6基于FPGA的C8051F单片机开发板设计
- 0.70 MB | 2次下载 | 免费
- 751单片机窗帘控制器仿真程序
- 1.93 MB | 2次下载 | 免费
- 8基于51单片机的RGB调色灯程序仿真
- 0.86 MB | 2次下载 | 免费
本月
- 1OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234315次下载 | 免费
- 2555集成电路应用800例(新编版)
- 0.00 MB | 33564次下载 | 免费
- 3接口电路图大全
- 未知 | 30323次下载 | 免费
- 4开关电源设计实例指南
- 未知 | 21548次下载 | 免费
- 5电气工程师手册免费下载(新编第二版pdf电子书)
- 0.00 MB | 15349次下载 | 免费
- 6数字电路基础pdf(下载)
- 未知 | 13750次下载 | 免费
- 7电子制作实例集锦 下载
- 未知 | 8113次下载 | 免费
- 8《LED驱动电路设计》 温德尔著
- 0.00 MB | 6653次下载 | 免费
总榜
- 1matlab软件下载入口
- 未知 | 935054次下载 | 免费
- 2protel99se软件下载(可英文版转中文版)
- 78.1 MB | 537796次下载 | 免费
- 3MATLAB 7.1 下载 (含软件介绍)
- 未知 | 420026次下载 | 免费
- 4OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234315次下载 | 免费
- 5Altium DXP2002下载入口
- 未知 | 233046次下载 | 免费
- 6电路仿真软件multisim 10.0免费下载
- 340992 | 191185次下载 | 免费
- 7十天学会AVR单片机与C语言视频教程 下载
- 158M | 183278次下载 | 免费
- 8proe5.0野火版下载(中文版免费下载)
- 未知 | 138040次下载 | 免费
评论
查看更多