Rocket - debug - Example: Write Memory
https://mp.weixin.qq.com/s/on1LugO9fTFJstMes3T2Xg
介绍riscv-debug的使用实例:使用三种方法写内存。
1. Using System Bus Access
1) Write a word to memory
A. 写sbaddress0寄存器:写入目标内存地址;
B. 写sbdata0寄存器:写入要写入目标内存地址处的值;触发写内存动作:
2) Write a block of memory
A. 写sbcs寄存器:
a. sbaccess=2:访问大小是32bit;
b. sbautoincrement=1:sbaddress is incremented by the access size (in bytes) selected in sbaccess after every system bus access;
B. 写sbaddress0寄存器:写入目标内存地址;
C. 写sbdata0寄存器:写入要写入目标内存地址处的值;触发写内存动作;
D. 写sbdata0寄存器:写入要写入目标内存地址处的值;触发写内存动作;
E. 如此即可逐个把数据写入内存;
2. Using Program Buffer
1) Write a word to memory
A. 准备好Program Buffer:把寄存器s1中的数据写入寄存器s0中的内存地址中;
B. 写data0寄存器:写入目标内存地址;
C. 写command寄存器:写入要执行的抽象命令:把data0寄存器的值拷贝到寄存器s0中;
D. 写data0寄存器:写入待存数据;
E. 写command寄存器:写入要执行的抽象命令:
a. 把data0中的值拷贝到s1中;
b. postexec=1:执行完抽象命令之后,触发Program Buffer的执行;
2) Write a block of memory
A. 准备好Program Buffer:把寄存器s1中的数据写入寄存器s0中的内存地址中,然后把s0中的地址加4;
B. 写data0寄存器:写入目标内存地址;
C. 写command寄存器:写入要执行的抽象命令:把data0寄存器的值拷贝到寄存器s0中;
D. 写data0寄存器:写入待写数据;
E. 写command寄存器:写入要执行的抽象命令:
a. 把data0中的值拷贝到s1中;
b. postexec=1:执行完抽象命令之后,触发Program Buffer的执行;
F. 写abstractauto寄存器:读data0寄存器触发抽象命令的执行;
a. autoexecdata=1: When a bit in this field is 1, read or write accesses to the corresponding data word cause the command in command to be executed again.
G. 写data0寄存器:写入待写数据;触发抽象命令的执行;进而触发Program Buffer的执行;如此循环即可写入全部数据;
H. 最后清除abstractauto寄存器中的autoexecdata位;
3. Using Abstract Memory Access
1) Write a word to memory
A. 写data1寄存器:存入目标内存地址;
B. 写data0寄存器:写入待存数据;
C. 写command寄存器:存入要执行的抽象命令:
a. cmdtype=2:表示命令的类型为Access Memory;
b. aamsize=2:Access the lowest 32 bits of the memory location.
c. aamvirtual=0:Addresses are physical (to the hart they are performed on).
d. write=1:Copy data from arg0 portion of data into the memory location specified in arg1.
这条命令的效果是:把data0寄存器中的数据,写入data1中的地址中;
2) Write a block of memory
这里只介绍一下要点:
a. aampostincrement=1:每次访问完内存之后,都把data1寄存器中的地址加4;
b. abstractauto.autoexecdata=1:读写data0寄存器会触发抽象命令的执行;
Rocket - debug - Example: Write Memory的更多相关文章
- Rocket - debug - Example: Read Memory
https://mp.weixin.qq.com/s/ChXNTbx94WDC72GvmE9bGA 介绍riscv-debug的使用实例:使用三种方法读取内存. 1. Using System Bus ...
- Xcode6 运行程序后,右侧Debug区域的Memory显示空白解决方法
http://chenyh-blog.com/%E8%9B%8B%E7%96%BC%E7%9A%84%E5%86%85%E5%AD%98-%E7%AC%AC%E4%B8%89%E7%AF%87-sdw ...
- Rocket - debug - TLDebugModuleInner - Hart Bus Access
https://mp.weixin.qq.com/s/deNMEyJ1idJDVoZwwo0A1A 简单介绍TLDebugModuleInner中核心总线访问(Hart Bus Access). 参考 ...
- Rocket - debug - Example: Triggers
https://mp.weixin.qq.com/s/zPNyrBOhsytkRrZTDTEvpw 介绍riscv-debug的使用实例:配置Triggers功能. 1. Trigger Trigge ...
- 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 - Example: DMI
https://mp.weixin.qq.com/s/7suuJ7m2BKCpsHk1K2FzJQ 介绍riscv-debug的使用实例:如何使用DMI. 1. dm Debug Module实现了调 ...
随机推荐
- A. Guest From the Past(数学推式子)
\(n元,买塑料杯子a元,买玻璃杯子b元,但玻璃杯子用完后可以卖c元\) \(求最多买的杯子.\) \(---------------------------分割------------------- ...
- Python+Typora博客图片上传
简介 用Typora 写Markdown 1年多了,这个编辑器的确很好用,但就是写完博客复制到博客园时要一个个手动插替换图片非常麻烦.后来发现最新版的Typora 已经支持图片上传功能,在 设置-图像 ...
- Bootstrap Table 3 官方文档
备查 Bootstrap Table 3 官方文档 示例
- OpenCV Error: Unspecified Error(The Function is not implemented)
Ubuntu 或者 Debian 系统显示窗口的时候遇到了这个问题 error: (-2:Unspecified error) The function is not implemented. Reb ...
- 封装组件el-upload通过v-model (一): 上传单张图片
ElementUI 中的el-upload 上传图片 我进行了二次封装.(默认大家都是有一定的vue基础的,细节就不过多的讲了) 在项目中我们主要拿到图片或者其他的一些参数 ,我这里是上传后返回的Gu ...
- JUC(3)---CountDownLatch、CyclicBarrier和AQS
CountDownLatch可以让一个线程等待其他线程完成了各自的工作之后再执行.比如说一个切菜,一个人切肉,都准备完毕之后才能炒肉. 构造方法: public CountDownLatch(int ...
- 【Socket编程】【第一节】【Socket基本原理和套接字】
参考http://c.biancheng.net/view/2351.html 一.scoket套接字(告诉你使用哪种数据传输方式) 这个世界上有很多种套接字(socket),比如 DARPA Int ...
- 「雕爷学编程」Arduino动手做(20)—水银开关模块
37款传感器与模块的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止37种的.鉴于本人手头积累了一些传感器和模块,依照实践出真知(一定要动手做)的理念,以学习和交流为目的,这里 ...
- RN中的常用组件-----图片
1.RN中的常用组件-----图片 本地图片: <Image source={require('../src/assets/x.jpg')}/> 本地图片可以无需指定尺寸(因为导入/打包 ...
- xctf-misc 新手区 wp
目录 this_is_flag pdf SimpalRAR ext3 stegano this_is_flag Most flags are in the form flag{xxx}, for ex ...