繁简之争:为什么手机芯片都是 ARM

RISC 和 CISC 指令集

之前的文章《揭秘 CPU 是如何执行计算机指令的》中说到,如果从软件的角度来讲,CPU 就是一个执行各种计算机指令(Instruction Code)的逻辑机器

计算机指令集是计算机指令的集合,包括各种类型的指令,例如数据传输指令(用于在内存和寄存器之间移动数据)、算术运算指令(如加法、减法、乘法、除法等)、逻辑运算指令(与、或、非等)、控制转移指令(用于改变程序执行的流程,如跳转、分支等)。

CISC (复杂计算机指令集计算机)和 RISC(精简指令集计算机)是两种不同的计算机指令集架构。

CISC 是早期的计算机指令集架构,最早出现在 20 世纪 70 年代早期。为了性能考虑,很多功能都是通过硬件电路来实现的。为了少用内存,指令长度是可变的。

到了 20 世纪 80 年代早期,RISC 开始登上了历史的舞台。当时,加州大学伯克利分校的大卫·帕特森教授 发现,实际在 CPU 运行的程序里,80% 的时间都是在使用 20% 的简单指令。于是选择把指令"精简"到 20% 的简单指令。而原先的复杂指令,则通过用简单指令组合 起来来实现,让软件 来实现硬件的功能。

RISC 与 CISC 之争

20 世纪 80 年代,计算机体系结构领域关于 RISC 指令集和 CISC 指令集优缺点的争论十分激烈。RISC 的支持者声称在给定硬件数量的情况下,通过结合简约式指令集设计、高级编译技术和流水线化的处理器实现,他们能够得到更强的计算能力。而 CISC 的拥趸反驳说要完成一个给定的任务只需要用较少的 CISC 指令,而且这样的机器能够获得较高的总体性能。

CISC 和 RISC 可以参考下面对比图:

在 20 世纪 90 年代早期,争论逐渐平息,因为事实已经很清楚了,无论是单纯的 RISC 还是单纯的 CISC 都不如结合两者思想精华的设计。RISC 机器发展进化的过程中,引入了更多的指令,而许多这样的指令都需要执行多个周期。今天的 RISC 机器的指令表中有几百条指令,几乎与"精简指今集机器"的名称不相待了。

比较新的 CISC 机器也利用了高性能流水线结构,它们读取 CISC 指令,并动态地翻译成比较简单的、像 RISC 那样的操作的序列。由于动态翻译通常可以在实际指令执行前进行,处理器可以保持很高的执行率。

为什么手机芯片是 ARM

ARM 是"Advanced RISC Machines "的缩写。从名字可以看出来,ARM 的芯片是基于 RISC 架构的。

不过,ARM 能在移动端战胜 Intel,并不是因为 RISC 架构。21 世纪的今天,CISC 和 RISC 架构的分界已经没有那么明显了。Intel 和 AMD 的 CPU 也都是采用译码成 RISC 风格的微指令来运行。而 ARM 的芯片,一条指令同样需要多个时钟周期,有乱序执行和多发射。ARM 真正能够战胜 Intel,我觉得主要是因为下面这两点原因。

第一点是功耗优先的设计。一个 4 核的 Intel i7 的 CPU,设计的时候功率就是 130W。而一块 ARM A8 的单个核心的 CPU,设计功率只有 2W。两者之间差出了 100 倍。在移动设备上,功耗是一个远比性能更重要的指标。ARM 的 CPU,主频更低,晶体管更少,高速缓存更小,乱序执行的能力更弱。所有这些,都是为了功耗所做的妥协。

第二点则是低价。ARM 公司并没有垄断 CPU 的生产和制造,只是进行 CPU 设计,然后把对应的知识产权授权出去,让其他的厂商来生产 ARM 架构的 CPU。它甚至还允许这些厂商可以基于 ARM 的架构和指令集,设计属于自己的 CPU。像苹果、三星、华为,它们都是拿到了基于 ARM 体系架构设计和制造 CPU 的授权。ARM 自己只是收取对应的专利授权费用。多个厂商之间的竞争,使得 ARM 的芯片在市场上价格很便宜。

"遥遥领先"算什么

之前在小红书发布笔记的时候,有朋友留言问"遥遥领先"(麒麟芯片)算什么?

我没找到官方公布的相关说明,但是我觉得遥遥领先麒麟芯片也肯定是基于精简指令集的,也必然是大核+小核协同工作的,因为这样可以平衡性能和功耗。欢迎懂行的指导~

未来是属于 RISC-V 的

不过,ARM 并不是开源的。所以,在 ARM 架构逐渐垄断移动端芯片市场的时候,"开源硬件"也慢慢发展起来了。一方面,MIPS 在 2019 年宣布开源;另一方面,RISC-V 项目 也越来越受到大家的关注。而 RISC 概念的发明人,图灵奖的得主大卫·帕特森教授从伯克利退休之后,成了 RISC-V 国际开源实验室的负责人,开始推动 RISC-V 这个"CPU 届的 Linux "的开发。可以想见,未来的开源 CPU,也多半会像 Linux 一样,逐渐成为一个业界的主流选择。

相关推荐
韦德斯13 小时前
嵌入式Linux的RTC读写操作应用
linux·运维·c语言·arm开发·实时音视频
byte轻骑兵13 小时前
嵌入式 ARM Linux 系统构成全解:从硬件到应用层层剖析
linux·arm开发·arm·嵌入式开发
思尔芯S2C16 小时前
面向未来的智能视觉参考设计与汽车架构,思尔芯提供基于Arm技术的创新方案
arm开发·架构·汽车·iot·fpga原型验证·prototyping·智慧视觉
Linux运维技术栈17 小时前
基于CVE安全公告号,全面修复麒麟ARM系统OpenSSH漏洞
安全·系统安全·arm
TeYiToKu1 天前
笔记整理—linux驱动开发部分(13)块设备
linux·c语言·驱动开发·笔记·嵌入式硬件·arm
Eternal-Student1 天前
【docker了解】如何将x86镜像转换为适用于Jetson的ARM镜像
arm开发·docker·容器
不怕犯错,就怕不做2 天前
修复kernel编译栈帧大小异常问题error: the frame size of 1928 bytes is larger than 1024 bytes
linux·arm开发·驱动开发
憧憬一下3 天前
UART硬件介绍
arm开发·嵌入式硬件·串口·嵌入式·linux驱动开发
Petal9909123 天前
UEFI学习笔记(十八):ARM电源管理之PSCI和SCMI概述
arm开发·笔记·学习·uefi
古月居GYH4 天前
一文了解ARM内部架构
arm开发·架构