Redian新闻
>
RISC-V给我们带来了什么?

RISC-V给我们带来了什么?

公众号新闻

来源:内容由半导体行业观察(ID:icbank)编译自semiwiki,谢谢。

通常,我们更喜欢把台式机/笔记本电脑的复杂指令集叫做CISC,把智能手机的精简指令集叫做RISC。戴尔和苹果等 OEM 一直在其笔记本电脑中使用 x86 CISC 处理器。让我在这里解释笔记本电脑的设计方法。主板以多核CISC处理器为主要部件,连接GPU、RAM、存储内存等子系统和I/O接口。操作系统在多核处理器上并行运行多个应用程序,管理内存分配和 I/O 操作。


这就是我们使用处理器实现任何电子系统的方式。然而,我们更喜欢使用 RISC 处理器的智能手机系统级芯片,因为它有助于我们减小主板的尺寸和功耗。几乎整个具有多核 RISC CPU、GPU、DSP、无线和接口子系统、SRAM、闪存和 IP 的系统都在 SoC 上实现。OEM Apple 正在遵循这款智能手机的 SoC 设计方法,甚至将他们的 MAC 笔记本作为 OEM 潮流引领者。所有最新的 MAC 书籍都使用他们的 M 系列 SoC,这些 SoC 使用 ARM 的 RISC 处理器。


因此,很明显,英特尔的 x86 或 ARM 的 RISC 处理器的专有 ISA 一直是 Apple、戴尔、三星等 OEM 的选择,但现在为什么我们需要像 RISC-V 这样的开放 ISA,而不是所有这些经过充分验证的ISA。


在今天的情况下,每个人都将 SoC 用于他们的笔记本电脑和智能手机。这种复杂的 SoC 需要通用处理器和专用处理器。为了实现像 Apple 的 M 系列 SoC 这样的芯片,我们需要不同种类的处理器,如 RISC CPU、GPU、DSP、安全处理器、图像处理器、机器学习加速器、安全和神经引擎,基于来自多个 IP 的各种通用和专用 ISA供应商,如图1所示。


图 1:Apple M1 SoC 参考:AnandTech


在这种情况下,主要挑战是:


1.选择并与多家 IP 供应商合作


2.不同的 IP 供应商可能有不同的 IP 许可方案,工程师将无法自由地定制 ISA 和设计,因为他们更愿意满足他们的设计目标。


3.所有专门的 ISA 都不会持续/生存很长时间,从而影响长期产品支持计划和路线图。


4.此外,涉及多个 ISA 和工具链的软件/应用程序开发和更新将具有挑战性。


RISC-V 是一种具有多种扩展功能的通用免许可开放式 ISA。它是一个 ISA,分为一个小的基本整数 ISA,可用作定制加速器和可选标准扩展的基础,以支持通用软件开发。


您可以添加自己的扩展来实现您的专用处理器,或者根据需要自定义基本 ISA,因为它是开放的。没有许可证限制。因此,在未来,我们可以仅使用一个 RISC-V ISA 创建所有通用和专用处理器,并实现任何复杂的 SoC。


什么是 RISC-V,它与其他 ISA 有何不同?


RISC-V 是加州大学伯克利分校的第五个主要 ISA 设计。它是由非营利组织 RISC-V International维护的开放式 ISA,涉及所有利益相关者社区以实施和维护 ISA 规范、黄金参考模型和合规性测试套件。


RISC-V 不是 CPU 实现。它是通用处理器和专用处理器的开放式 ISA。一个完全开放的 ISA,可供学术界和工业界免费使用。


RISC-V ISA 被分成一个小的基本整数 ISA,可单独用作定制加速器或教育目的的基础,以及支持通用软件开发的可选标准扩展


RISC-V 支持应用程序、操作系统内核和硬件实现的 32 位和 64 位地址空间变体。因此,它适用于所有计算系统,从嵌入式微控制器到云服务器,如下所述。

简单的嵌入式微控制器、保护运行 RTOS 的嵌入式系统、运行操作系统的台式机/笔记本电脑/智能手机以及运行多个操作系统的云服务器。


二、RISC-V 基础 ISA


RISC-V 是一个相关 ISA 家族:RV32I、RV32E、RV64I、RV128I。


RV32I/ RV32E/ RV64I/RV128I 是什么意思:


RV——RISC-V


32/64/128 – 定义寄存器宽度 [XLEN] 和地址空间


I – 整数基 ISA


32 个用于所有基本 ISA 的寄存器


E – 嵌入式:只有 16 个寄存器的基本 ISA


(1)RISC-V 寄存器:


所有基本 ISA 都有 32 个寄存器,如图 2 所示,除了 RV32E。只有RV32E base ISA对于简单的嵌入式微控制器只有16个寄存器,但寄存器宽度仍然是32位。


寄存器 X0 硬接线为零。称为程序计数器的特殊寄存器保存要从内存中获取的当前指令的地址。


如图 2 所示,RISC-V 应用程序二进制接口,ABI 定义了寄存器的标准功能。为了简单和一致,软件开发工具通常使用 ABI 名称。根据 ABI,额外的寄存器专用于 X0 到 X15 范围内的保存寄存器、函数参数和临时变量,主要用于 RV32E 基础 ISA,它只需要前 16 个寄存器来实现简单的嵌入式微控制器。但是 RV32I 基础 ISA 将拥有所有 32 个寄存器 X0 到 X31。


图 2:RISC-V 寄存器和 ABI 名称参考:RISC-V 规范


(2)RISC-V内存:


RISC-V hart [硬件线程/核心] 具有用于所有内存访问的 2^XLEN 字节的单字节可寻址地址空间。XLEN 表示整数寄存器的位宽度:32/64/128。


内存字定义为 32 位(4 字节)。相应地,半字为16位(2字节),双字为64位(8字节),四字为128位(16字节)。


内存地址空间是循环的,因此地址 2^XLEN -1 处的字节与地址零处的字节相邻。因此,由硬件完成的内存地址计算忽略溢出,而是环绕模 2^XLEN。


RISC-V 基础 ISA 具有小端或大端存储系统,特权架构进一步定义了大端操作。指令作为 16 位小尾数法包的序列存储在内存中,而不管内存系统的字节顺序如何。


(3)RISC-V 加载存储架构


您可以可视化基于 RISC-V 寄存器和内存的 RISC-V 加载存储架构,如下图 3 所示。


RISC-V处理器根据PC中的地址从主存中取/载指令,译码32位指令,然后ALU进行算术/逻辑/内存读写操作。ALU 的结果将存储回其寄存器或内存中。


图 3:RISC-V 加载存储架构


(4)RISC-V RV32 I 基础 ISA


RV32I base ISA 只有 40 条 Unique Instructions,但简单的硬件实现只需要 38 条指令。RV32I指令可分为:


R-Type:注册到注册说明


I-Type:立即注册、加载、JLR、Ecall 和 Ebreak


S型:商店


B型:分支


J型:跳跃和链接


U 型:立即加载/添加上层


图 4:RV32I 基本 ISA 指令格式


(5)用于优化 RTL 设计的 RISC-V ISA


在这里,我想解释一下 RISC-V ISA 如何使我们能够实现优化的寄存器传输级设计,以满足低功耗和高性能的目标。


如图 4 所示,RISC-V ISA 在所有格式中将源(rs1 和 rs2)和目标(rd)寄存器保持在相同位置以简化解码。


立即数总是经过符号扩展,并且通常被打包到指令中最左边的可用位,并且已被分配以降低硬件复杂性。尤其是,


所有立即数的符号位总是在指令的第 31 位以加速符号扩展电路。


符号扩展是对立即数最关键的操作之一(特别是对于 XLEN>32),在 RISC-V 中,所有立即数的符号位始终保存在指令的第 31 位中,以允许符号扩展与指令解码并行进行。


为了加快解码速度,基础 RISC-V ISA 将最重要的字段放在每条指令的同一位置。正如您在指令格式表中所见,


  • 主要操作码总是在位 0-6 中。

  • 目标寄存器(如果存在)始终位于位 7-11 中。

  • 第一个源寄存器(如果存在)始终位于第 15-19 位。

  • 第二个源寄存器(如果存在)始终位于第 20-24 位。


但是为什么立即位会被打乱呢?想想解码直接场的物理电路。由于它是硬件实现,因此这些位将被并行解码;输出立即数中的每一位都有一个多路复用器来选择它来自哪个输入位。多路复用器越大,成本越高,速度也越慢。


值得注意的是,只需要主要操作码(位 0-6)就可以知道如何解码立即数,因此立即数解码可以与指令其余部分的解码并行完成。


(6)RV32I 基本 ISA 指令



RISC-V ISA 扩展


此处列出了所有 RISC-V ISA 扩展:


图 5:RISC-V ISA 扩展


我们遵循 RISC-V 处理器的命名约定,如下所述:


RISC-V 处理器:RV32I、RV32IMAC、RV64GC


RV32I:整数基础 ISA 实现


RV32IMAC:整数基础 ISA + 扩展:[乘法 + 原子 + 压缩]


RV64GC:64 位 IMAFDC [G-通用:IMAFD]


整数 64 位基本 ISA + 扩展:[乘法 + 原子 + SP 浮动 + DP 浮动 + 压缩]


RISC-V 特权架构


RISC-V 特权架构涵盖了 RISCV 系统的所有方面,超出了我到目前为止所解释的非特权 ISA。特权架构包括特权指令以及运行操作系统和连接外部设备所需的附加功能。


根据 RISC-V 特权规范,我们可以实现从简单的嵌入式控制器到复杂的云服务器的不同类型的系统,如下所述。


应用程序执行环境 – AEE:“裸机”硬件平台,其中 harts 直接由物理处理器线程实现,指令可以完全访问物理地址空间。硬件平台定义了一个从上电复位开始的执行环境。示例:简单且安全的嵌入式微控制器


主管执行环境——参见:RISC-V 操作系统,通过将用户级 harts 多路复用到可用的物理处理器线程并通过虚拟内存控制对内存的访问来提供多个用户级执行环境。


示例:运行类 Unix 操作系统的桌面等系统


Hypervisor Execution Environment – HEE:RISC-V hypervisor,为来宾操作系统提供多个管理级执行环境。


示例:运行多个guest操作系统的云服务器


图 6:RISC-V 特权软件堆栈参考:RISC-V 规范


此外,RISC-V 特权规范定义了各种控制和状态寄存器 [CSR],以实现各种功能,如任何系统的中断、调试和内存管理设施。您可能需要参考规范以探索更多信息。


如本文所述,我们可以使用通用的开放式 RISC-V ISA 高效地实现任何系统,从简单的物联网设备到复杂的智能手机和云服务器。由于单片半导体缩放失败,专业化是提高计算性能的唯一途径。开放式 RISC-V ISA 是模块化的,支持自定义指令,使其成为创建各种专用处理器和加速器的理想选择。


随着 IEEE 标准通用验证方法论的出现,我们在芯片验证方面取得了巨大成功,开放的 RISC-V ISA 也将继承各种专有 ISA 的所有优点,成为行业标准 ISA,引领我们走向未来开放的计算时代。您准备好使用 RISC-V 专业知识迎接这个美好的未来了吗?


★ 点击文末【阅读原文】,可查看本文原文链接!

*免责声明:本文由作者原创。文章内容系作者个人观点,半导体行业观察转载仅为了传达一种不同的观点,不代表半导体行业观察对该观点赞同或支持,如果有任何异议,欢迎联系半导体行业观察。


今天是《半导体行业观察》为您分享的第3243内容,欢迎关注。

推荐阅读


亚洲的芯片“焦虑”

美国芯片设计地位,危险?

MCU的一段往事!


半导体行业观察

半导体第一垂直媒体

实时 专业 原创 深度


识别二维码,回复下方关键词,阅读更多

晶圆|集成电路|设备|汽车芯片|存储|台积电|AI|封装

回复 投稿,看《如何成为“半导体行业观察”的一员 》

回复 搜索,还能轻松找到其他你感兴趣的文章!


点击阅读原文,可查看本文
原文链接!


微信扫码关注该文公众号作者

戳这里提交新闻线索和高质量文章给我们。
相关阅读
“日本芯片教父”投奔中国,曾被美韩搞垮如今“复仇”,他为我们带来了什么?3位新冠康复者的自述:“阳”了之后,我们经历了什么?没有脚本的舞台诗婚姻给男人带来了什么!哈哈哈哈哈哈哈我们#关爱心理健康#系列博文接下来将带来什么?泽连斯基高调访美回顾:他都带走了什么,又留下了什么下流校长摸进女宿被女学生棍棒围殴打到求饶影片曝光“你为什么要碰她?我们做错了什么?”我的世界、模拟人生、GTA头部个人开发者对话:UGC带来了什么?12月14号:高毛利带来了高福利,而不是高福利带来高毛利关于对抗病毒,“三年新冠”为我们带来了哪些启示?大数据和算法给我们的生活带来了什么?我们又应该怎样应对呢?Kong戴冠兰:从明星开源项目进化为API独角兽,我们做对了什么?| GGV OMEGA访谈录当酒店集团进军商业地产,将为我们带来什么?-85万!人口61年来首次负增长,到底给我们带来什么样的提醒!怕年老肌肉流失?背米去来!刚回到房车给我惊呆了,猜猜看见了什么?全美最佳机场休息室即将来临?达美航空会给我们带来惊喜吗?龙卷风健康快递 217张文宏:疫苗为我们带来了非常好的基础免疫朔尔茨在中国的11小时,带来了什么,收获了什么?法国也准备来了……比给我老公买东西更难的,是给我老妈买东西孕期能吃抗生素吗?喂奶能吃吗?孩子呢?抗生素到底帮我们抵抗了什么?当100位科学家云聚会,会为我们这个社会带来什么?长期坚持做一件事,给生活带来了什么改变?| 荐号看万山红遍,层林尽染,百鱼争流--Erin dale park澳洲洪水给动物们带来何种灾难?看到这张照片我哭了“抨击中国不会给你们带来任何好处”巩立姣:除了金牌,22年超过10000000次投球,还带来了什么?天赋和努力同样重要!北京电影学院的学习给张颂文、刘奕君、颜丹晨带来了什么?感谢3点放学的北下关小学,为我们带来的欢乐秋天的杭州真的非常美,强烈建议你们带娃来感受一下!将加州海岸线和西班牙风格融合的丽思卡尔顿,会给我们带来什么惊喜吗?靳东变脸 嬉笑怒骂这一次,我们带孩子全面感受文学魅力维特根斯坦教给我们什么?没有人能代替你思考,除了你自己!
logo
联系我们隐私协议©2024 redian.news
Redian新闻
Redian.news刊载任何文章,不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。文章信息的合法性及真实性由其作者负责,与Redian.news及其运营公司无关。欢迎投稿,如发现稿件侵权,或作者不愿在本网发表文章,请版权拥有者通知本网处理。