Rocket - debug - Example: Accessing Registers Using Program Buffer
https://mp.weixin.qq.com/s/8yYLVg-RXX3XX0T431lxeA
介绍riscv debug接口的使用实例:使用Program Buffer读取寄存器。
1. Write mstatus using program buffer
1) csrw s0 MSTATUS
csrw用于写CSR,这里是把s0写入到mstatus中。
2) ebreak
ebreak被debugger用于把控制权返回给调试环境,这里就是执行完Program Buffer中的程序之后,执行ebreak指令,返回调试环境。
3) Program Buffer
Program Buffer用于存放一小段程序,让被暂停的核心执行:
Program Buffer可以与抽象命令结合使用,使能抽象命令中的postexec位,在执行完该抽象命令后即可执行一次Program Buffer中的指令:
Program Buffer中的指令执行完成之后,需要执行ebreak指令返回调试环境:
4) progbuf0
从progbuf0开始的一组寄存器用于提供对Program Buffer的访问,可访问的寄存器数量取决于progbufsize的值。
5) postexec of Accessing Register Abstract Command
当抽象命令用于访问寄存器时,有一位用于使能postexec。其取值决定了执行完该抽象命令后,是否执行Program Buffer中的指令。
6) 实例
首先,准备Program Buffer:
a. 把指令csrw s0, mstatus写入progbuf0;
b. 把指令ebreak写入progbuf1;
其次,准备抽象命令:
c. 把要写入mstatus寄存器的数值写入到data0寄存器;
d. 写command寄存器,执行抽象命令:把data0中的数据,写入到s0寄存器(x8, regno=0x1008);该抽象命令中,postexec置位,即:在执行完该抽象命令后,执行Program Buffer中的指令。
总结一下,写寄存器过程如下:
a. 把数据写入data0;
b. 执行抽象命令,把data0中的数据,写入到s0;
c. 执行Program Buffer中的csrw指令,把s0写入到mstatus;
d. 执行Program Buffer中的ebreak指令,返回调试环境;
2. Read f1 using program buffer
1) fmv
该指令在riscv-spec中定义,用于在浮点寄存器和整型寄存器之间转移数据:
2) 实例
首先,准备Program Buffer:
a. 把指令fmv.x.s s0, f1写入progbuf0;
b. 把指令ebreak写入progbuf1;
其次,执行抽象命令:
c. 把command寄存器中的postexec置位,transfer=0表明抽象命令不执行传输任务,也就是comand只用于触发执行Program Buffer中的指令;指令执行完之后,f1的值被移动到s0;
d. 写command寄存器,transfer=1, write=0,表示该抽象命令是读寄存器;regno=0x1008表示把s0寄存器的值传入data0中;
e. 读取data0寄存器即可获取到从f1传过来的数据;
Rocket - debug - Example: Accessing Registers Using Program Buffer的更多相关文章
- Rocket - debug - Example: Accessing Registers Using Abstract Command
https://mp.weixin.qq.com/s/RdJzE06mMkh2x__vVj_fEA 介绍riscv debug接口的使用实例:使用抽象命令读取寄存器. 1. Read s0 using ...
- Rocket - debug - TLDebugModuleInner - Program Buffer Access
https://mp.weixin.qq.com/s/EJVqw7JPjjaib68tENl5AQ 简单介绍TLDebugModuleInner中的Program Buffer Access. 1. ...
- Rocket - debug - TLDebugModuleInner - Program Buffer
https://mp.weixin.qq.com/s/kjhJJ3moRQzxHt6pJOXEgg 简单介绍TLDebugModuleInner中Program Buffer寄存器的实现. 1. pr ...
- Rocket - debug - TLDebugModuleInner
https://mp.weixin.qq.com/s/jkiHceU0HaJbHGvHiU-QOA 简单介绍TLDebugModuleInner的实现. 1. 引入全局配置 1) cfg 引入Debu ...
- Rocket - debug - TLDebugModuleOuter
https://mp.weixin.qq.com/s/9nMo6IYmDCz7S-ALFx824g 简单介绍TLDebugModuleOuter的实现. 1. DebugModuleAccessTyp ...
- Rocket - debug - TLDebugModuleInner - DMI Register Control and Status
https://mp.weixin.qq.com/s/tI41wu0xaIQ5PRq6F82tNw 简单介绍TLDebugModuleInner中生成DMI控制和状态寄存器使用到的状态. 1. abs ...
- Rocket - debug - TLDebugModuleInner - Abstract Command Decoding & Generation
https://mp.weixin.qq.com/s/0zKSTktxgzo5uCUphqaWSQ 介绍抽象命令的解码和生成. 1. accessRegisterCommandReg accessRe ...
- Rocket - debug - Example: Quick Access
https://mp.weixin.qq.com/s/SxmX-CY2tqvEqZuAg-EXiQ 介绍riscv-debug的使用实例:配置Quick Access功能. 1. Quick Acce ...
- Rocket - debug - Example: Write Memory
https://mp.weixin.qq.com/s/on1LugO9fTFJstMes3T2Xg 介绍riscv-debug的使用实例:使用三种方法写内存. 1. Using System Bus ...
随机推荐
- E. Count The Blocks
E. Count The Blocks 这是一个计数题,又把我卡自闭了...之前也碰到过类似的题目,这次居然还没有写出来,感觉自己还是太菜了,加油补题吧. 题目大意: 给你一个数字 \(n\),代表的 ...
- 吃零食 csust oj 贪心
吃零食 桌上有n袋零食,不同的零食会有不同的美味程度wi和腐坏程度di,每种零食在一单位时间内美味程度都会下降di,但是不会降到0以下. qwb每一单位时间可以吃掉一袋零食.现在qwb想要在吃完所有零 ...
- qgis控制滚轮转动地图比例尺的变化幅度
需求:在比例尺1万-10万之间,鼠标滚轮转动比例尺的变化幅度为1万重写滚轮事件 void Xx::wheelEvent(QWheelEvent*event){ double curScale = sc ...
- STM32F767ZI NUCLEO144 基于CubeIDE快速开发入门指南
刚入手的NUCLEO-F767ZI:整合官网资源,理清思路,便于快速进行快发: 文章目录 1 NUCLEO 系列 2 NUCLEO-F767ZI 3 环境搭建 3.1 Keil/IAR安装 3.2 C ...
- spark-2.4.5 安装记录
参考 https://data-flair.training/blogs/install-apache-spark-multi-node-cluster/ 下载 spark 地址为 http://sp ...
- 设计模式之GOF23原型模式02
利用序列化和反序列化完成深复制 ByteArrayOutputStream bos=new ByteArrayOutputStream(); ObjectOutputStream oos=new O ...
- 部署SSL站点 IIS+asp.net
使用SSL必须要有证书,今天我们就使用IIS内置的证书完成SSL的部署. 1.打开MMC证书管理器,文件->添加/删除管理单元->证书,双击->确定 2.找到:个人->证书下有 ...
- tp5 一次性插入大量数据时分批处理
如题,加入$arr 中有一万多条数据,如果直接使用insert插入的话就会报错,此时可以使用limit分批插入 $result = Db::connect($this->dbconfig()) ...
- 如何使用Postman生成不同格式测试的报告
Postman还可以生成测试报告,还是多种格式报告? Postman团队开源Newman作为Postman运营工具,该开源库使用命令行方式执行Postman 脚本,并且生成多种格式报告,还支持Post ...
- asp.net MVC3.0 中@Html.Partial,@Html.Action,@Html.RenderPartial,@Html.RenderAction
asp.net MVC3.0 中@Html.Partial,@Html.Action,@Html.RenderPartial,@Html.RenderAction 1.带有Render的方法返回值是v ...