https://mp.weixin.qq.com/s/zPNyrBOhsytkRrZTDTEvpw

介绍riscv-debug的使用实例:配置Triggers功能。

1. Trigger

Trigger是指硬件触发器:A debugger can use hardware triggers to halt a hart when a certain event occurs.

2. Trigger Module

Triggers can:

a. cause a breakpoint exception, entry into Debug Mode,

b. or a trace action without having to execute a special instruction.

This makes them invaluable when debugging code from ROM.

They can trigger:

a. on execution of instructions at a given memory address,

b. or on the address/data in loads/stores.

These are all features that can be useful without having the Debug Module present, so the Trigger Module is broken out as a separate piece that can be implemented separately.

Triggers不会在调试模式触发:

用以下方法检测某个序号的触发器是否支持:

3. 实例1

A. (补)tselect=0:选择第0个触发器;

B. 写tdata1寄存器,其中:

a. type=2:The trigger is an address/data match trigger;

tdata1和mcontrol的地址相同,实际上是同一个寄存器:

mcontrol格式如下:

b. action=1:Enter Debug Mode. (Only supported when the trigger's dmode is 1.)

c. dmode=1:根据b的要求,dmode应该为1,其意义为:

d. match=0:Matches when the value equals tdata2;就是说与tdata2中的值进行匹配;

e. m=s=u=1:触发器在M/S/U模式下触发:

f. execute=1:When set, the trigger fires on the virtual address or opcode of an instruction that is executed. 对执行的指令地址或者指令码进行匹配;结合上面的配置,即指令地址或指令码等于tdata2中的值时,触发器触发;

g. tdata1=0x105c是指低16位的值:

那么高位的值呢?

隐含的要求:

a) type=2;

b) dmode=1;

文档写的比较粗糙,其他位应该为0。

本实例的before体现在mcontrol的timing位:

这一位值为0,意义为:The action for this trigger will be taken just before the instruction that triggered it is executed, but after all preceding instructions are committed.

C. tdata2=0x80001234:待匹配的指令地址为0x80001234;

4. 实例2

与实例1相比,区别如下:

A. 相较于实例1匹配指令地址,这里匹配的是读内存地址:load=1;

B. 相较于实例1中指令执行前触发,这里在读内存之后触发:timing=1:

5. 实例3

这里实例中使用了两个触发器:Trigger 0和Trigger 1.

1) Trigger 0

实现Enter Debug Mode right before a write to an address greater than 0x80007c80:

a. timing=0:在指令执行前触发;

b. match=2:大于0x80007c80:Matches when the value is greater than (unsigned) or equal to tdata2.

c. store=1:匹配a write to an address;

d. tdata2=0x80007c80:保存待匹配的内存地址;

2) Trigger 1

实现Enter Debug Mode right before a write to an address less than 0x80007c80:

a. timing=0;

b. match=3:Matches when the value is less than (unsigned) tdata2;

c. store=1;

d. tdata2=0x80007cf0:注意这里不是0x80007cef,因为要求是包括0x80007cef这个地址,而匹配时是排除tdata2这个地址,所以只能把要求的地址加1之后存入tdata2;

6. 实例4

a. timing=0:在指令执行前触发;

b. store=1:匹配一个写内存操作;

c. match=1:

这里匹配tdata2寄存器的高M位,M的计算方法是XLEN-1减去最低的0位的序号:

a. XLEN=32, XLEN-1=31;

b. 0x81237fff中最低的0位是第15位:

c. 所以M=31-15=16;也就是说匹配tdata2的高16位;

d. 也就是把要写的内存地址的高16位与tdata2的高16位进行匹配,那么可以触发的内存地址的范围即是:0x81230000-0x8123ffff;

7. 实例5

这里匹配针对两个内存地址范围的读操作,需要使用两个Trigger。其中:

a. timing=1:表示读操作完成之后触发;

b. load=1:表示匹配的是读内存操作;

c. chain=1:表示两个trigger组合使用:While this trigger does not match, it prevents the trigger with the next index from matching.

1) Trigger 1

要匹配的内存地址范围是:0xXXXX3090-0xXXXX309f;

A. match=4:Matches when the lower half of the value equals the lower half of tdata2 after the lower half of the value is ANDed with the upper half of tdata2.

a. 首先把待匹配值的低一半V与tdata2的高一半相与:V & 0xfff0;

b. 然后把结果与tdata2的低一半相比较,即(V & 0xfff0) =? 0x3090;

c. 如果相等则触发;效果是匹配的内存地址的低一半是0x3090-0x309f;

B. chain=1:这里只匹配了低一半的地址,还有高一半的地址需要匹配,需要与Trigger 2组合使用;

2) Trigger 2

要匹配的内存地址范围是:0x8675XXXX-0x9675XXXX;

A. match=5:Matches when the upper half of the value equals the lower half of tdata2 after the upper half of the value is ANDed with the upper half of tdata2.

a. 首先把待匹配值的高一半V与tdata2的高一半相与:V & 0xefff;

b. 然后把结果与tdata2的低一半相比较,即(V & 0xefff) =? 0x8675;

c. 如果相等则触发;效果是匹配的内存地址的高一半是0x8675-0x9675;

Rocket - debug - Example: Triggers的更多相关文章

  1. Rocket - debug - TLDebugModuleInner - Hart Bus Access

    https://mp.weixin.qq.com/s/deNMEyJ1idJDVoZwwo0A1A 简单介绍TLDebugModuleInner中核心总线访问(Hart Bus Access). 参考 ...

  2. Rocket - debug - Periphery

    https://mp.weixin.qq.com/s/uGxn-Xec0LkwdaSsCtQBvw 简单介绍Periphery的实现. 1. ExportDebugDMI/ExportDebugJTA ...

  3. Rocket - debug - DebugTransport

    https://mp.weixin.qq.com/s/EcsuTjb4hFF9Ncig9Gfhew 简单介绍DebugTransport的实现. 1. JtagDTMConfig 1) JtagDTM ...

  4. Rocket - debug - TLDebugModule

    https://mp.weixin.qq.com/s/EhUb1z5oiIw6dJ-90ifDJA 简单介绍TLDebugModule中的实现. 1. device device是一个设备描述符,包含 ...

  5. Rocket - debug - TLDebugModuleInner - ROM Generation

    https://mp.weixin.qq.com/s/j_CgHU4PnY82NMwJzOqHYg 简单介绍Variable ROM Generation. 1. jalAbstract jalAbs ...

  6. Rocket - debug - Example: DMI

    https://mp.weixin.qq.com/s/7suuJ7m2BKCpsHk1K2FzJQ 介绍riscv-debug的使用实例:如何使用DMI. 1. dm Debug Module实现了调 ...

  7. Rocket - debug - Example: Read Memory

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

  8. Rocket - debug - Example: Accessing Registers Using Program Buffer

    https://mp.weixin.qq.com/s/8yYLVg-RXX3XX0T431lxeA 介绍riscv debug接口的使用实例:使用Program Buffer读取寄存器. 1. Wri ...

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

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

随机推荐

  1. String、StringBuffer和StringBuilder比较

    从执行速度效率来说: String为字符串常量,一旦创建就不能修改,第一次创建一个String对象,实例化后有初始值:当第二次创建String对象后,再次赋值,表面上看是改变了第一个String对象的 ...

  2. C# 基础至集合-数组、List<T>、ArrayList、LinkedList、HashMap的一些区别

    1:数组 ]; //赋值 strs[] = "; strs[] = "; //修改 strs[] = "burg"; //删除 没法删除 除非转化为可变数组li ...

  3. FOC:在MCU上检验Clark和Park坐标变换是否正确

    文章目录 前言 程序 头文件 clark 变换 C实现 park c 变换实现 仿真 前言 仿真简单,可以参考仿真的结果,但是实际中将代码移植到MCU,会出现一些新的问题,所以需要对坐标变换部分算法进 ...

  4. Linux 内核工作队列之work_struct 学习总结

    前言 编写Linux驱动的时候对于work_struct的使用还是很普遍的,很早之前就在阅读驱动源码的时候就看到了它的踪影,根据其命名大概知道了它的具体作用,但是仍然不知所以,同时,伴随出现的还有de ...

  5. 如何得知某期刊是否被EI收錄?

    转载:http://tul.blog.ntu.edu.tw/archives/4627 若因投稿或評鑑需要,欲得知某期刊是否被 EI 收錄,其實就是確認該期刊是否包含在 EV 平台中的 COMPEND ...

  6. [hdu5525 Product]暴力

    题意:给定n和a[],令N = ∏(1≤i≤n)ia[i],求N的所有约数的积(取模1e9+7) 思路: 假定N因式分解后的结果是2p1*3p2*5p3*...,如何计算答案呢? 单独看2p1这一项, ...

  7. vue登录路由验证(转)

    转载自:https://blog.csdn.net/github_39088222/article/details/80749219 vue的项目的登录状态(如果用vuex状态管理,页面一刷新vuex ...

  8. Linux下几个与磁盘空间和文件尺寸相关的命令

    大家好,我是良许. 硬盘是计算机非常重要的一个部件,不管是代码,还是 UI .声音.文档,抑或是没人时偷偷看的小视频,都需要保存在硬盘里. 对于很多 Linux 服务器,会进行很多的编译操作.而编译操 ...

  9. NullPointerException异常没有异常栈打印问题追踪

    今天去服务器后台看日志,发现有很多NullPointerException异常.我下意识的找异常栈,想看下到底是哪行代码导致了空指针.但是发现日志中只打印出了如下日志: null java.lang. ...

  10. redis 主从哨兵01

    主从复制过程 1.从服务器开始连接主服务器时,会向主服务器发送一个SYNC同步命令 2.主服务器接收到命令后,执行BGSAVE,异步的将写命令保存到一个缓冲区里 3.主服务器执行完BGSAVE之后,就 ...