Rocket - debug - Example: Selecting Harts
https://mp.weixin.qq.com/s/HjG5S9binyniG_amC3Dr5Q
介绍riscv-debug的使用实例:如何选择核心,执行Halt/Resume请求。
1. Selecting Harts
可以有多个核心连接在一个调试模块上,如果要让一个核心暂停、重新执行、复位,或者执行调试命令,需要先选择目标核心。
A. Selecting a Single Hart
可以在hartsel中填入目标核心的编号,选择单个核心:
B. Selecting Multiple Harts
也可以使用核心数组窗口(hart array window)编号(hawindowsel)来选择一组核心,再使用掩码(hawindow)来选择窗口中的核心,来选择多个核心:
2. dmcontrol
选择核心,需要使用dmcontrol寄存器:
其中:
A. hartsello/hartselhi组成20位的hartsel,用于填入目标核心编号选择核心:
B. hasel用于区分是使用hartsel单选一个核心,还是使用hartsel和hawindow多选多个核心:
C. haltreq:用于请求被选中的核心暂停;
D. resumereq:用于请求被选中的核心继续执行;
E. hartreset:用于请求被选中的核心复位;
F. setresethaltreq:用于请求被选中的核心在复位时暂停;
3. halt summary
用于确定某个核心是否处于暂停状态。顾名思义,这里只是一个摘要。
A. halt summary 0
以hartsel的高15位选择一个窗口,低5位选择一个比特,每个比特代表一个核心是否暂停。
haltsum0可以确定一个核心是否处于暂停状态。
B. halt summary 1
以hartsel高10位选择一个窗口,低5位选择一个比特,该比特代表最低5位表示的32个核心中是否有核心暂停。
haltsum1可以用于快速确定某核心是否处于暂停状态。因为一个比特代表32个核心,所以如果haltsum1无法做出判断,需要继续使用haltsum0进行判断。
C. halt summary 2
以高5位选择一个窗口,低5位选择一个比特,该比特代表最低10位表示的1024个核心中,是否有核心处于暂停状态。
D. halt summary 3
以高5位选择一个比特,该比特代表低15位表示的32768个核心中,是否有一个核心处于暂停状态。
4. Checking for Halted Harts
若要确定某一个核心是否暂停,还是使用hartsel&haltsum0最快。
若要确定一个范围的核心是否暂停,可以使用hartsel&haltsum3/haltsum2/haltsum1来进行确定。
5. Halting
6. Running
7. Single Step
Rocket - debug - Example: Selecting Harts的更多相关文章
- Rocket - debug - TLDebugModuleInner - Hart Bus Access
https://mp.weixin.qq.com/s/deNMEyJ1idJDVoZwwo0A1A 简单介绍TLDebugModuleInner中核心总线访问(Hart Bus Access). 参考 ...
- Rocket - debug - Periphery
https://mp.weixin.qq.com/s/uGxn-Xec0LkwdaSsCtQBvw 简单介绍Periphery的实现. 1. ExportDebugDMI/ExportDebugJTA ...
- Rocket - debug - DebugTransport
https://mp.weixin.qq.com/s/EcsuTjb4hFF9Ncig9Gfhew 简单介绍DebugTransport的实现. 1. JtagDTMConfig 1) JtagDTM ...
- Rocket - debug - TLDebugModule
https://mp.weixin.qq.com/s/EhUb1z5oiIw6dJ-90ifDJA 简单介绍TLDebugModule中的实现. 1. device device是一个设备描述符,包含 ...
- Rocket - debug - TLDebugModuleInner - ROM Generation
https://mp.weixin.qq.com/s/j_CgHU4PnY82NMwJzOqHYg 简单介绍Variable ROM Generation. 1. jalAbstract jalAbs ...
- Rocket - debug - TLDebugModuleInner - Program Buffer Access
https://mp.weixin.qq.com/s/EJVqw7JPjjaib68tENl5AQ 简单介绍TLDebugModuleInner中的Program Buffer Access. 1. ...
- Rocket - debug - Example: DMI
https://mp.weixin.qq.com/s/7suuJ7m2BKCpsHk1K2FzJQ 介绍riscv-debug的使用实例:如何使用DMI. 1. dm Debug Module实现了调 ...
- Rocket - debug - Example: Triggers
https://mp.weixin.qq.com/s/zPNyrBOhsytkRrZTDTEvpw 介绍riscv-debug的使用实例:配置Triggers功能. 1. Trigger Trigge ...
- Rocket - debug - Example: Accessing Registers Using Program Buffer
https://mp.weixin.qq.com/s/8yYLVg-RXX3XX0T431lxeA 介绍riscv debug接口的使用实例:使用Program Buffer读取寄存器. 1. Wri ...
随机推荐
- Tarjan缩点割点(模板)
描述:https://www.luogu.com.cn/problem/P3387 给定一个 nn 个点 mm 条边有向图,每个点有一个权值,求一条路径,使路径经过的点权值之和最大.你只需要求出这个权 ...
- C. Four Segments 前缀后缀
C. Four Segments 这种分成了三个节点一般都可以处理一下前缀处理一下后缀,或者处理一下前面的这个点,处理一下后面的这个点,然后再枚举中间这个点. 如果和中间这个点有关的,那么就可以换一下 ...
- Vue列表实现滚动到指定位置样式改变
这个需求大概是这样子: 我做的一个聊天Demo,在搜索框搜索用户,可以滚动到指定的用户.然后成选中状态. 这是目前状态,我搜索 南宫仆射 ,想要下面的用户列表直接滚动到 南宫仆射 并改变CSS样式. ...
- 【Hadoop离线基础总结】Hue与Impala集成
Hue与Impala集成 1.修改hue.ini配置文件 [impala] server_host=node03 server_port=21050 impala_conf_dir=/etc/impa ...
- C# 数据操作系列 - 3. ADO.NET 离线查询
0. 前言 在上一篇中,我故意留下了查询的示范没讲.虽然说可以通过以下代码获取一个DataReader: IDataReader reader = command.ExecuteReader(); 然 ...
- Vant 顶部导航栏【van-tabs】Bug
Vant 顶部导航栏[van-tabs]Bug 如果在外面包裹div控制显示隐藏会出现导航条不准确的bug 代码 <div class="selWrap" v-show=&q ...
- python小游戏-pygame模块
一.tkinter模块的GUI 基本上使用tkinter来开发GUI应用需要以下5个步骤: 导入tkinter模块中我们需要的东西. 创建一个顶层窗口对象并用它来承载整个GUI应用. 在顶层窗口对象上 ...
- 关于fromdata的上传文件问题
<div <label>上传pdf</label> <input id="fileId" type="file" accep ...
- fakebook
0x01 查看robots.txt 发现user.php.bak文件 得到源码 <?php class UserInfo { public $name = ""; publi ...
- R的安装以及包安装
今天看论文,需要用到R语言的库,于是又折腾了半天.. 其实并没有什么太大的问题,只是在第三方包的下载方面还有python中使用R方面遇到了问题: 第三方包的导入 其实在网上有 ...