×

【大白分享】处理器芯片架构或者指令集之RISC-V架构
  

山东_朱文鑫 25341人觉得有帮助

{{ttag.title}}
本帖最后由 山东_朱文鑫 于 2023-5-31 23:58 编辑

大家好,我是大白,努力的意义,不在于一定会让你取得多大的成就,只是让你在平凡的日子里,泪得比原来的那个自己更好一点。依旧感谢各位小伙伴的一路支持与陪伴。

本篇依旧借上篇文章国产化之路介绍以及信息汇总一篇通,从中介绍了国产化相关的背景信息,以及个人整合的一下信息材料与各位小伙伴进行分享学习,小伙伴们每天在说的X86、ARM等架构,真正的了解这些架构的原理与底层吗?

【大白分享】国产化之路介绍以及信息汇总一篇通(操作系统、服务器、数据库、中间件、CPU架构):https://bbs.sangfor.com.cn/forum.php?mod=viewthread&tid=256585






RISC-V是一个基于精简指令集(RISC)原则的开源指令集架构(ISA),V表示为第五代RISC(精简指令集计算机),表示此前已经有四代RISC处理器原型芯片。每一代RISC处理器都是在同一人带领下完成,那就是加州大学伯克利分校的David A. Patterson教授。与大多数ISA相反,RISC-V ISA可以免费地用于所有希望的设备中,允许任何人设计、制造和销售RISC-V芯片和软件。图1展示了此前的四代RISC处理器原型芯片。它虽然不是第一个开源的指令集(ISA),但它很重要,因为它是第一个被设计成可以根据具体场景、可以选择适合的指令集的指令集架构。基于RISC-V指令集架构可以设计服务器CPU,家用电器cpu,工控cpu和用在比指头小的传感器中的cpu。




RISC-V的状态:

    1.完全开源,对指令集使用,RISC-V基金会不收取高额的授权费。开源采用宽松的BSD协议,企业完全自由免费使用,同时也容许企业添加自有指令集拓展而不必开放共享以实现差异化发展。

    2.架构简单,这也是RISC-V架构的设计哲学。在处理器领域,X86与ARM架构的发展过程也伴随了现代处理器架构技术的不断发展成熟,为了能够保持架构的向后兼容性,其不得不保留许多过时的定义,导致其指令数目多,指令冗余严重,文档数量庞大,所以操作系统或者开发应用门槛就会很高。

    3.模块化,RISC-V架构不仅短小精悍,而且其不同的部分还能以模块化的方式组织在一起,从而试图通过一套统一的架构满足各种不同的应用场景。


    4.开源实现,RISC-V架构开源状态下,共同对多个模块进行完善处理,成为多兼容的稳定架构指令集。



RISC-V架构特点:


    1.六种格式指令相比较X86的指令来讲简化太多,并且所有的指令都是 32 位长,这简化了指令解码。ARM-32, 还有更典型的 x86-32 都有许多不同的指令格式,使得解码部件在低端实现中偏昂贵,在中 高端处理器设计中容易带来性能挑战。

    2.RISC-V 指令提供三个寄存器操作数,而不是 像 x86-32 一样,让源操作数和目的操作数共享一个字段。当一个操作天然就需要有三个不 同的操作数,但是 ISA 只提供了两个操作数时,编译器或者汇编程序程序员就需要多使用 一条 move(搬运)指令,来保存目的寄存器的值。

    3.在 RISC-V 中对于所有指令,在解码指令之前,就可以先访问寄存器。在许多其他的 ISA 中,某些指令字段在部分指令中被重用作为源目的地,在其他指令中又被作为目的操作数(例如,ARM-32 和 MIPS-32)。

    4.这些格式的立即数字段总是符号扩展,符号位总是在指令中最高位。这意味着可能成为关键路径的立即数符号扩展,可以在指令解码之前进行。

六种格式指令:



    1.寄存器-寄存器操作的 R 类型指令

    2.短立即数和访存 load 操作的 I 型指令

    3.访存 store 操作的 S 型指令

    4.条件跳转操 作的 B 类型指令

    5.长立即数的 U 型指令

    6.无条件跳转的 J 型指令

    opcode :指令操作码

    imm:代码立即数

    func3和funct7:代表指令对应的功能

    rs1:源寄存器1

    rs2:源寄存器2

    rd:目标寄存器(RSIC-V 一个指令可以提供三个寄存器操作


RSIC-V 寄存器说明:

寄存器ABI 名称说明
x0zero0值寄存器,硬编码为0,写入数据忽略,读取数据为0
x1ra用于返回地址(return address)
x2sp用于栈指针(stack pointer)
x3gp用于通用指针 (global pointer)
x4tp用于线程指针 (thread pointer)
x5t0用于存放临时数据或者备用链接寄存器
x6~x7t1~t2用于存放临时数据寄存器
x8s0/fp需要保存的寄存器或者帧指针寄存器
x9s1需要保存的寄存器
x10~x11a0~a1函数传递参数寄存器或者函数返回值寄存器
x12~x17a2~a7函数传递参数寄存器
x18~x27s2-s11需要保存的寄存器
x28~x31t3~t6用于存放临时数据寄存器

RISC-V的特权架构:
    到目前为止RISC-V 对通用计算的支持所有指令都在用户模式(应用程序的代码在此模式下运行)下可用。

主要介绍两种新的权限模式:
1.运行最可信的代码的机器模式(machine mode)。
2.监管者模式(supervisor mode)为 Linux,FreeBSD 和 Windows 等操作系统 提供使用

机器模式
    机器模式(缩写为 M 模式,M-mode)是 RISC-V 中 hart(hardware thread,硬件线程)可以执行的最高权限模式。在 M 模式下运行的 hart 对内存,I/O 和一些对于启动和配 置系统来说必要的底层功能有着完全的使用权。

    机器模式最重要的特性是拦截和处理异常的能力。RISC-V 将 异常分为两类。

1是同步异常,这类异常在指令执行期间产生,如访问了无效的存储器地址或执行了具有无效操作码的指令时。

2是中断,它是与指令流异步的外部事件,比如鼠标的单击。RISC-V 中实现精确例外:保证异常之前的所有指令都完整地执行了,而后续的指令都没有开始执行(或等同于没有执行)。

监管者模式
    更复杂的 RISC-V 处理器用和几乎所有通用架构相同的方式处理这些问题:使用基于页面的虚拟内存。这个功能构成了监管者模式(S 模式)的核心,这是一种可选的权限模式,旨在支持现代类 Unix 操作系统,如 Linux,FreeBSD 和 Windows。S 模式比 U 模式权限更高,但比 M 模式低。与 U 模式一样,S 模式下运行的软件不能使用 M 模式的 CSR 和 指令,并且受到 PMP 的限制。S 模式提供了一种传统的虚拟内存系统,它将内存划分为固定大小的页来进行地址转 换和对内存内容的保护。

裸机程序基本示意图:


操作系统基本示意图:


虚拟化基本示意图:



    SBI就是对所有RISC-V硬件平台的共性功能做了抽象,为运行在S模式的操作系统提供统一的服务接口。在Linux里,内核空间和用户空间之间多了个系统调用层,SBI就类似于系统调用层。

RISC-V五级流水线32位单发射的RV32I处理器流水线结构示意图如下:



本篇主要是详解处理器芯片RISC-V架构下的底层架构以及相关的结构信息进行知识补充学习,以及各个组成模块下的交互方式。

RISC-V相关学习文献: RISCV参考文献.zip (4.54 MB, 下载次数: 6)

RISC-V官网参考学习链接:https://wiki.riscv.org/spacedirectory/view.action

中国开放指令生态(RISC-V)联盟链接:http://crva.ict.ac.cn/wjxz/202202/t20220217_19660.html


以上就是本次的处理器芯片架构或者指令集之RISC-V架构的帖子,感谢大家的参阅支持,一同学习,向大家提供更加优质的技术信息!

励志分享超清壁纸语句~~:



水激石则鸣,人激志则宏。——出自秋瑾


好的今天就到这里,老样子,感谢各位大神的参阅,孩子为了挣豆子不容易,孩子家里穷没豆子吃饭了!!!


打赏鼓励作者,期待更多好文!

打赏
3人已打赏

一个无趣的人 发表于 2023-8-11 10:42
  
楼主的文章图文并茂,清晰易懂,看完这波操作可以轻松上手了,如遇到问题再向楼主请教~
新手378833 发表于 2023-11-13 08:52
  
感谢分享,有助于工作!!!
新手716814 发表于 2023-11-13 08:57
  
感谢分享,有助于工作!!!
新手626351 发表于 2023-11-13 09:04
  
感谢分享,有助于工作!!!
发表新帖
热门标签
全部标签>
安全效果
西北区每日一问
技术盲盒
技术笔记
干货满满
【 社区to talk】
每日一问
信服课堂视频
GIF动图学习
新版本体验
技术咨询
2023技术争霸赛专题
功能体验
产品连连看
标准化排查
通用技术
秒懂零信任
技术晨报
自助服务平台操作指引
安装部署配置
原创分享
排障笔记本
玩转零信任
排障那些事
SDP百科
技术争霸赛
深信服技术支持平台
以战代练
升级&主动服务
畅聊IT
答题自测
专家问答
技术圆桌
在线直播
MVP
网络基础知识
升级
安全攻防
上网策略
测试报告
日志审计
问题分析处理
流量管理
每日一记
运维工具
云计算知识
用户认证
解决方案
sangfor周刊
VPN 对接
项目案例
SANGFOR资讯
专家分享
技术顾问
信服故事
功能咨询
终端接入
授权
设备维护
资源访问
地址转换
虚拟机
存储
迁移
加速技术
产品预警公告
信服圈儿
S豆商城资讯
「智能机器人」
追光者计划
社区帮助指南
答题榜单公布
纪元平台
卧龙计划
华北区拉练
天逸直播
山东区技术晨报
文档捉虫活动
齐鲁TV
华北区交付直播
每周精选
2024年技术争霸赛
北京区每日一练
场景专题
故障笔记
高手请过招
高频问题集锦
社区新周刊
POC测试案例
全能先锋系列
云化安全能力

本版版主

12
185
6

发帖

粉丝

关注

121
314
351

发帖

粉丝

关注

本版达人

LoveTec...

本周分享达人

新手24116...

本周提问达人