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的更多相关文章

  1. Rocket - debug - Example: Accessing Registers Using Abstract Command

    https://mp.weixin.qq.com/s/RdJzE06mMkh2x__vVj_fEA 介绍riscv debug接口的使用实例:使用抽象命令读取寄存器. 1. Read s0 using ...

  2. Rocket - debug - TLDebugModuleInner - Program Buffer Access

    https://mp.weixin.qq.com/s/EJVqw7JPjjaib68tENl5AQ 简单介绍TLDebugModuleInner中的Program Buffer Access. 1. ...

  3. Rocket - debug - TLDebugModuleInner - Program Buffer

    https://mp.weixin.qq.com/s/kjhJJ3moRQzxHt6pJOXEgg 简单介绍TLDebugModuleInner中Program Buffer寄存器的实现. 1. pr ...

  4. Rocket - debug - TLDebugModuleInner

    https://mp.weixin.qq.com/s/jkiHceU0HaJbHGvHiU-QOA 简单介绍TLDebugModuleInner的实现. 1. 引入全局配置 1) cfg 引入Debu ...

  5. Rocket - debug - TLDebugModuleOuter

    https://mp.weixin.qq.com/s/9nMo6IYmDCz7S-ALFx824g 简单介绍TLDebugModuleOuter的实现. 1. DebugModuleAccessTyp ...

  6. Rocket - debug - TLDebugModuleInner - DMI Register Control and Status

    https://mp.weixin.qq.com/s/tI41wu0xaIQ5PRq6F82tNw 简单介绍TLDebugModuleInner中生成DMI控制和状态寄存器使用到的状态. 1. abs ...

  7. Rocket - debug - TLDebugModuleInner - Abstract Command Decoding & Generation

    https://mp.weixin.qq.com/s/0zKSTktxgzo5uCUphqaWSQ 介绍抽象命令的解码和生成. 1. accessRegisterCommandReg accessRe ...

  8. Rocket - debug - Example: Quick Access

    https://mp.weixin.qq.com/s/SxmX-CY2tqvEqZuAg-EXiQ 介绍riscv-debug的使用实例:配置Quick Access功能. 1. Quick Acce ...

  9. Rocket - debug - Example: Write Memory

    https://mp.weixin.qq.com/s/on1LugO9fTFJstMes3T2Xg 介绍riscv-debug的使用实例:使用三种方法写内存. 1. Using System Bus ...

随机推荐

  1. Spring Cloud Alibaba系列(一)nacos作为服务注册中心

    Spring Cloud Alibaba各组件版本关系 Spring Cloud Alibaba Version Sentinel Version Nacos Version RocketMQ Ver ...

  2. G. Yash And Trees 线段树 + dfs序 + bitset

    这个是要用bitset 一个大整数的二进制 学习推荐博客 这个题目大意就是:给你n,m 还有一个序列,还有一个一棵树,有一种操作一种询问 操作是给你一个节点 把这个节点及其子节点都加上x 询问是 给你 ...

  3. CSS的基础使用

    一,css是什么? CSS全称为“层叠样式表” ,与HTML相辅相成,实现网页的排版布局与样式美化 二,CSS使用方式 1.行内样式/内联样式(单一页面中使用) 借助于style标签属性,为当前的标签 ...

  4. maven项目变成web项目

    具体步骤如图所示: 第一步:建议一个Maven Webapp项目  第二步:右击项目,选择属性,找到project facets,点击tuntimes标签选择apache tomcat v6.0选中P ...

  5. python语法学习第六天--字典

    字典:可变容器类型,用键值对的形式采用花括号储存(键唯一) 语法:d={key1:value1,key2:value2} 访问字典中的值: 字典名[键名]#若字典中不存在则报错 更改字典: 添加值:字 ...

  6. 1025 PAT Ranking (25分) 思路分析 +满分代码

    题目 Programming Ability Test (PAT) is organized by the College of Computer Science and Technology of ...

  7. PC端软件配置

    一,cmder软件安装 二,Snipaste软件安装 三,vwmare虚拟机安装 四,sublime安装 五,notepad++安装 六,Python环境 anaconda navigator安装 七 ...

  8. 【雕爷学编程】Arduino动手做(43)---单路继电器模块

    37款传感器与模块的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止37种的.鉴于本人手头积累了一些传感器和模块,依照实践(动手试试)出真知的理念,以学习和交流为目的,这里准备 ...

  9. sound of the genuine

    “There is something in every one of you that waits and listens for the sound of the genuine in yours ...

  10. Java基础之抽象类和接口

    今天来说说抽象类和接口的实现以及它们的区别.我们知道抽象类和接口都是对具体事物的抽象,接口在实现上比抽象类更加抽象,抽象类中可以有普通方法和变量,而接口中只有抽象方法和不可变常量.但是从另一个角度看, ...