0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

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

颖脉Imgtec 2022-12-15 10:43 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

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


通常,我们更喜欢把台式机/笔记本电脑的复杂指令集叫做CISC,把智能手机的精简指令集叫做RISC。戴尔和苹果等 OEM 一直在其笔记本电脑中使用 x86 CISC 处理器。让我在这里解释笔记本电脑的设计方法。主板以多核CISC处理器为主要部件,连接GPURAM、存储内存等子系统和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.选择并与多家 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。6f8be6e8-7c10-11ed-b116-dac502259ad0.png

图 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 的结果将存储回其寄存器或内存中。

7001e078-7c10-11ed-b116-dac502259ad0.png

图 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 型:立即加载/添加上层

702487a4-7c10-11ed-b116-dac502259ad0.png

图 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 指令

704699de-7c10-11ed-b116-dac502259ad0.png

RISC-V ISA 扩展

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

70cc7d4c-7c10-11ed-b116-dac502259ad0.jpg

图 5:RISC-V ISA 扩展

我们遵循 RISC-V 处理器的命名约定,如下所述:RISC-V 处理器:RV32I、RV32IMAC、RV64GCRV32I:整数基础 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操作系统的云服务器

70e88a82-7c10-11ed-b116-dac502259ad0.png

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

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

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

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

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 处理器
    +关注

    关注

    68

    文章

    20148

    浏览量

    247051
  • RISC
    +关注

    关注

    6

    文章

    485

    浏览量

    86088
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    跃昉科技亮相2025 RISC-V产业发展大会暨RDSA国际论坛

    2025年11月24日,珠海与澳门双城联动,迎来了一场全球RISC-V与人工智能领域的顶级盛会——“2025 RISC-V产业发展大会暨RDSA国际论坛”。
    的头像 发表于 11-30 09:36 245次阅读

    【飞凌T527N开发板试用】异构RISC-V核心使用体验

    、专门用于特定任务的“片上系统服务核心” 。这为整个SoC(系统级芯片)带来了根本性的优势。 T527的异构RISC-V核心主要带来三大层面的好处: 效率与功耗优化 :实现任务分工,大幅提升能效比。如
    发表于 08-19 21:45

    RISC-V 手册

    以下是关于RISC-V的详细介绍,结合其核心技术特点与当前发展现状:核心概念RISC-V(第五代精简指令集)是一种基于精简指令集(RISC)的开源指令集架构(ISA),由加州大学伯克利分校于2010
    发表于 07-28 16:27 11次下载

    2025新思科技RISC-V科技日活动圆满结束

    新思科技深度参与2025 RISC-V中国峰会并于2025年7月16日举办同期活动“新思科技RISC-V科技日”技术论坛,聚焦“从芯片到系统重构RISC-V创新”主题,议题覆盖当前最前沿的技术领域
    的头像 发表于 07-25 17:31 1074次阅读

    FPGA与RISC-V浅谈

    全球半导体产业竞争格局正在经历深刻变革,物联网、边缘计算等新兴技术的蓬勃发展,让RISC-V凭借其开源、精简以及模块化的灵活优势,日益成为业界焦点,也为全球半导体产业注入新的活力与挑战
    发表于 04-11 13:53 544次阅读
    FPGA与<b class='flag-5'>RISC-V</b>浅谈

    思尔芯与玄铁合作IP评测,加速RISC-V生态发展

    引言随着近来Deepseek的横空出世,降低算力需求,为RISC-V带来了更多的创新机遇。RISC-V计算架构搭乘上AI时代的快车,成为新一代数字基础设施算力底座的理想选择,既满足高能效、高性能
    的头像 发表于 04-09 09:24 764次阅读
    思尔芯与玄铁合作IP评测,加速<b class='flag-5'>RISC-V</b>生态发展

    芯来科技亮相RISC-V Day Tokyo 2025

    RISC-V Day Tokyo 2025春季会议于日前在东京大学ITO国际研究中心顺利举行。The RISC-V Day Tokyo作为日本最大的RISC-V活动,汇集了众多优秀的RISC-
    的头像 发表于 03-03 14:07 1016次阅读

    关于RISC-V芯片的应用学习总结

    RISC-V芯片作为一种基于精简指令集计算(RISC)原则的开源指令集架构(ISA)芯片,近年来在多个领域展现出了广泛的应用潜力和显著优势。以下是对RISC-V芯片应用的总结。 RISC-V
    发表于 01-29 08:38

    RISC-V MCU技术

    嘿,咱来聊聊RISC-V MCU技术哈。 这RISC-V MCU技术呢,简单来说就是基于一个叫RISC-V的指令集架构做出的微控制器技术。RISC-V这个啊,2010年的时候,是加州大
    发表于 01-19 11:50

    构建安全计算生态 | RISC-V 安全机制的架构设计

    玄铁RISC-V软硬件技术深度解读系列,将从AI、高性能计算、安全和边缘计算等多个方向,全面介绍玄铁RISC-V软硬件技术实现。本周我们带来RIS
    的头像 发表于 01-10 17:53 2606次阅读
    构建安全计算生态 | <b class='flag-5'>RISC-V</b> 安全机制的架构设计

    risc-v芯片在电机领域的应用展望

    RISC-V作为一种开源的指令集架构,近年来在芯片设计领域崭露头角,并逐渐在电机控制领域展现出其独特优势。随着电机技术的不断进步和应用需求的多样化,RISC-V芯片有望为电机控制带来更高效、更灵
    发表于 12-28 17:20

    RISC-V芯片问题

    RISC-V高端芯片有哪些,目前生态怎样?
    发表于 12-27 16:41

    赛昉科技将亮相RISC-V产业发展大会,带来应用、软件、人才三大核心主题分享

    RISC-V产业发展大会”将于12月28日在北京亦庄通明湖会展中心举办。作为推动RISC-V生态发展的重要力量,赛昉科技将受邀出席此次盛会,带来应用、软件和人才
    的头像 发表于 12-24 11:10 1249次阅读
    赛昉科技将亮相<b class='flag-5'>RISC-V</b>产业发展大会,<b class='flag-5'>带来</b>应用、软件、人才三大核心主题分享

    RISC-V架构及MRS开发环境回顾

    ,但服务器本身对处理快数据的效率不高,因此硬盘不仅存储数据还需要进行处理。(6)RISC-V 带来的机遇和挑战 中国工程院倪光南院士在RISC-V2021中国峰会上发表演讲:RISC-V
    发表于 12-16 23:08

    RISC-V 与 ARM 架构的区别 RISC-V与机器学习的关系

    在现代计算机架构中,RISC-V和ARM是两种流行的处理器架构。它们各自具有独特的特点和优势,适用于不同的应用场景。 1. RISC-V架构 RISC-V(读作“risk-five”)是一种开源
    的头像 发表于 12-11 17:50 4343次阅读