ARM-M与RISC-V(32bit)的区别--基于CM4与Nuclei_N300
1 systick与core timer
ARM Cortex-M内核包含了一个SysTick定时器,SysTick 是一个24 位的倒计数定时器,当计到0 时,将从RELOAD 寄存器中自动重装载定时初值。
而RISC-V内核中自带一个core timer, core timer是一个64位的定时器, 可以用于产生定时器中断或软件中断
SysTick或core timer等内核定时器, 常用于作为RTOS的心跳时钟
2 中断与异常
在ARMv7中中断是异常的一种特例
而在RISC-V内核中, 中断与异常是严格区分的, 异常与中断均属于Trap(陷阱), 其中中断是异步的,可以被屏蔽 , 异常是同步的, 不可被屏蔽, 并且异常处理时, 硬件会自动关闭全局中断
3 NVIC与ECLIC
NVIC与ELCIC均是ARM-M与RISC-V内核实现的中断控制器, 但是在以下方面有不同之处
3.1 向量中断与非向量中断
NVIC中, 所有的中断都是向量中断, ISR地址由中断向量表保存
ECLIC中, 中断分为向量中断和非向量中断, 两者在下方的中断优化策略的支持中有所不同, 同时ECLIC也有一张中断向量表, 非向量中断共用一个ISR, 再从ISR中判断中断源
3.2 中断优化
3.2.1 中断硬件保护现场
ARM-M中, 中断触发后, 硬件会自动将寄存器信息保存到栈中
而在RISC-V中, 中断触发后, 硬件不会自动保存, 需要软件编写中断上下文的保存与恢复
3.2.2 中断咬尾
ARM-M中, 中断咬尾是一个重要的中断优化
RISC-V中, 非向量中断是支持中断咬尾的, 而向量中断不支持中断咬尾
3.2.3 中断晚到
ARM-M中支持中断晚到优化
RISC-V中不支持中断晚到优化
3.3.4 中断嵌套
ARM-M中支持中断嵌套
RISC-V中非向量中断支持中断嵌套, 向量中断需要软件实现中断上下文的保存与恢复, 并且处理器内核在响应中断后,mstatus寄存器中的MIE域将会被硬件自动更新成为0(意味着中断被全局关闭,从而无法响应新的中断)。因此向量处理模式默认是不支持中断嵌套的,为了达到向量处理模式且又能够中断嵌套的效果, 需要软件实现一些特殊的入栈操作: 0
首先保存CSR寄存器mepc、mcause、msubm入堆栈。保存这几个CSR寄存器是为了保证后续的中断嵌套能够功能正确,因为新的中断响应会重新覆盖mepc、mcause、msubm的值,因此需要将它们先保存入堆栈。
重新打开中断的全局使能,即,设置mstatus寄存器的MIE域为1。打开中断全局使能后,新的中断便可以被响应,从而达到中断嵌套的效果。
在中断服务程序的结尾处同样需要添加对应的恢复上下文出栈操作。并且在CSR寄存器mepc、mcause、msubm出堆栈之前,需要将中断全局使能再次关闭,以保证mepc、mcause、msubm恢复操作的原子性(不被新的中断所打断)。
3.3.5 中断仲裁
NVIC中, 中断仲裁机制由中断优先级号来划分, 中断优先级数字越小, 优先级越高, 同时可以进行优先级分组
ECLIC中, 中断仲裁机制是由四个因素决定:中断level、中断priority、中断 ID号、中断阈值,这四个因素的判定顺序是中断level>中断priority>中断ID号> 中断阈值,其中前三个因素都是数字越大表明仲裁优先级高,最后一个因素只有当 中断level的数值大于中断阈值时,中断才会生效。
4 PendSV异常与软件中断
ARM-M中, 支持PendSV异常挂起, PendSV是一个最低优先级的异常(中断), 优点是可以在保证高优先级的中断优先执行, 在无中断时及时响应, 常常被RTOS用来实现上下文的保存与切换
RISC-V中, 没有PendSV异常, 但是core timer支持软件中断, 可以将该中断设置为最低优先级, 来实现中断挂起的功能, 来实现与PendSV相同的功能
5 特权模式
ARM-M中, 特权模式分为用户模式与特权模式
RISC-V中, 特权模式划分如下

| 特权级 | 名称 | 访问权限 | 典型应用 |
| M-mode | 机器模式 | 访问所有CSR、物理内存、中断控制器 | Bootloader/安全监控 |
| S-mode | 监管模式 | 受限CSR、虚拟内存管理(通过satp) | 操作系统内核 |
| U-mode | 用户模式 | 最小权限,受限内存访问 | 应用程序 |
Nuclei_N系列仅支持两种特权模式: 机器模式和用户模式 其中机器模式又分出有4个子模式
ARM-M与RISC-V(32bit)的区别--基于CM4与Nuclei_N300的更多相关文章
- ARM、Intel、MIPS处理器啥区别?看完全懂了
安卓支持三类处理器(CPU):ARM.Intel和MIPS.ARM无疑被使用得最为广泛.Intel因为普及于台式机和服务器而被人们所熟知,然而对移动行业影响力相对较小.MIPS在32位和64位嵌入式领 ...
- ARM、Intel、MIPS处理器啥区别?看完全懂了【转】
转自:http://news.mydrivers.com/1/472/472317.htm 安卓支持三类处理器(CPU):ARM.Intel和MIPS.ARM无疑被使用得最为广泛.Intel因为普及于 ...
- ARM 处理器:RISC与CISC 是什么?【转】
转自:https://blog.csdn.net/willsun2017/article/details/83388990 完全看懂 ARM 处理器:RISC与CISC 是什么? 历史.架构一次看透 ...
- ARM、X86和AI处理器的区别
ARM.X86和AI处理器的区别 目前主要的处理器架构有: X86: Intel, AMD, 海光, 兆芯 ARM: 华为,飞腾,华芯通,Cavium,Ampere,富士通,亚马逊 POWER:IBM ...
- posix和system v有什么区别/?
posix和system v有什么区别/?现在在应用时应用那一标准浮云484212 | 浏览 243 次 2014-11-06 10:362014-11-19 22:36 最佳答案们是有关信号量的两组 ...
- ARM概论(Advanced RISC Machines)
简介 ARM7是32 位通用微处理器ARM(Advanced RISC Machines)家族中的一员,具有比较低的电源消耗和良好的性价比, 基于(精简指令)RISC结构,指令集和相关的译码机制与微程 ...
- ARM菜鸟:JLINK与JTAG的区别
调试ARM,要遵循ARM的调试接口协议,JTAG就是其中的一种.当仿真时,IAR.KEIL.ADS等都有一个公共的调试接口,RDI就是其中的一种,那么我们如何完成RDI-->ARM调试协议(JT ...
- C++:vector中的v.at(0)和v[0]的区别
设v是一个vector的对象, 如果v是非空的,则v.at(0)和v[0]是没有区别的,都是取数组中第一个值: 如果v是空的,则v.at(0)会抛出异常(exception std::out_of_r ...
- docker 挂载主机目录 -v 和 --mount区别
使用-v 时,如果宿主机上没有这个文件,也会自动创建, 但是如果使用--mount时,宿主机中没有这个文件会报错找不到这个文件,并创建失败
- [Linux]CPU架构/指令集:RISC / CISC | arm | amd | X86/i386 | aarch64
1 前言 本文是解决在软件开发.软件交付过程中,常常需要找寻与服务器硬件的CPU架构适配的软件包时,开发者和交付者又时常摸不着头脑.[迷迷糊糊]地就下载了某个所谓"适配".&quo ...
随机推荐
- js技术之获取当前元素的上一个/下一个兄弟级元素等元素的方法(获取上一个/下一个input)
一.说明 jQuery获取: jQuery.parent(expr),找父亲节点,可以传入expr进行过滤,比如$("span").parent()或者$("span&q ...
- Vue3 组件通信方式小结
也是零零散散用 vue3 来搞一些前端的页面, 每次在组件通信, 主要是传数据这块总是忘记, 大多无非父传子, 子传父等情况, 这里再来做一个小结. 父传子 Props 最常见的就是父组件给子组件传递 ...
- Python基础 - 控制结构
控制结构: 顺序, 分支, 循环, 理解了, 其实编程就入门一半了. 条件表达式 条件表达式的值只要不是:0 . None. False. 空列表. 空元组. 空集合. 空字典. 空字符串. 空ran ...
- 10个让你成为CSS画家的技巧,不容错过
@charset "UTF-8"; .markdown-body { line-height: 1.75; font-weight: 400; font-size: 15px; o ...
- 私有网盘部署-Cloudreve网盘
前言 关于私有网盘,企业级网盘可选可道云,filebroser,seafile等.关于私有网盘,笔者推荐Cloudreve. 无论是从使用角度看,WebDa.离线下载.分享管理.文件检索,还是管理角度 ...
- Scipy中的稀疏矩阵的编码方式
import numpy as np from scipy import sparse (1)COO( Coordinate) 最直观的就是COO格式.它用了1维的数组来表示2维的矩阵,每个数组的长度 ...
- Windows系统 C/C++程序编译后首次执行时间很长 断网则正常执行 的解决方法
Windows系统 C/C++程序编译后首次执行时间很长 断网则正常执行 的解决方法 如果您遇到此类问题,可以与我联系.我可尝试帮助您解决此问题,2SADFC4F%2$@!0$#@$%2!@#$3#! ...
- 使用spring-boot-starter-mail发送邮件,HTML,附件
前言 这里使用的是spring-boot-starter-mail, 当然了,你也可以使用com.sun.mail(javax.mail),Hutool对这个进行了封装, 但是我的项目是springb ...
- 微信小程序生成海报方案
前段时间因为业务需求,需要在微信小程序里分享海报,于是在网上找到了这个方案.此处主要是搬运了网上的内容,加上我自己融合的组件的下载内容.具体如下: 第一步:下载组件 下载组件:Painter 一款轻量 ...
- Opencv学习:回到原点!关于一些基础的函数
opencv简单的图片读取和显示 1.图像读取 Mat img = imread("C:/clip.png", 1); imshow("fang2", img ...