仿真器的断点功能是如何实现的?

[复制链接]
711|17
手机看帖
扫描二维码
随时随地手机跟帖
hanwe|  楼主 | 2019-3-13 20:16 | 显示全部楼层 |阅读模式
仿真器的断点功能是如何实现的?
yufe| | 2019-3-13 20:20 | 显示全部楼层
仿真器应该就是用PC软件仿目标MCU,当然这还要一定的目标硬件配合,关键字是"仿"

使用特权

评论回复
llia| | 2019-3-13 20:23 | 显示全部楼层
应该是每条指令仿真完成后判断是否有断点

使用特权

评论回复
hanwe|  楼主 | 2019-3-13 20:25 | 显示全部楼层


仿真器与调试软件进行数据传输的时候,指令是不是要去截获数据流,还是可以有别
的办法可以获得?软件是KEIL。

使用特权

评论回复
langgq| | 2019-3-13 20:28 | 显示全部楼层
就是PC与硬件相互通信

使用特权

评论回复
yufe| | 2019-3-14 14:34 | 显示全部楼层

JTAG仿真 这个是很成熟的了
说一下传统的51的仿真 属于临时发挥 瞎说的
1 首先要能实现PC和MCU的通信 通常用串口 所以一般仿真器是没法仿串口本身的
2 MCU端要驻留一段程序来和PC端的程序来进行交互
3 MCU的应用程序每执行一条指令后都要检查一下是否有断点 这个检查工作当然是交给驻留程序来完成了
4 如何实现运行一条指令后就转到驻留程序呢 可以这样子 让某外部中断一直处于有效状态 例如电平触发中断 这样MCU就得一直去响应中断 而MCU响应中断之前得先完成当前指令 这样就完成了单步的功能 那么断点功能也变得简单了 无非就是需要记录下断点的位置 然后“单步”到此暂停住就是了
5 接下来的寄存器观察变量观察也不是什么难事了 但是是个琐事 需要驻留程序去扫描各寄存器的值 需要仿真软件去调用编译器的MAP文件从而有目的的去扫描存储区

使用特权

评论回复
llia| | 2019-3-14 14:37 | 显示全部楼层

JTAG是调试器,和仿真器有本身区别

使用特权

评论回复
hanwe|  楼主 | 2019-3-14 14:39 | 显示全部楼层
我之前也想了很久,网上的这类信息比较少,有一个想法不知是否正确,我也看过之前的那种占用资源的仿真器的HEX代码,转换成汇编后有很多的RAM的数据定义看不懂,我起初的想法是通过程序的块区切换来完成断点操作,如果用户设定了断点,一旦执行到断点处,会跳入另一个区块执行等待程序,同时将寄存器的数据传给上位机,保存断点地址,跳出后指针恢复到原来的地址继续执行。所以这里又涉及到一个问题就是通讯协议,市面上的那种占用资源的仿真器都是使用MON51的协议,网上也没有公开协议,所以比较郁闷,感觉其他的东西花点时间总是能想出来的,但协议这东西……

使用特权

评论回复
langgq| | 2019-3-14 14:42 | 显示全部楼层
程序断点好弄,数据的就是3楼的办法

使用特权

评论回复
wangzsa| | 2019-3-14 14:45 | 显示全部楼层
严重影响执行速度

使用特权

评论回复
hanwe|  楼主 | 2019-3-14 14:48 | 显示全部楼层
哎,我再考虑考虑吧

使用特权

评论回复
guoyt| | 2019-3-14 14:51 | 显示全部楼层
是啊,仿真器应该就是用PC软件仿目标MCU

使用特权

评论回复
hanwe|  楼主 | 2019-3-14 14:54 | 显示全部楼层
唉,还是没有什么结果,算了,先结贴吧,多谢大家啦

使用特权

评论回复
tongbu2015| | 2019-3-23 22:02 | 显示全部楼层
这个是跟你所用的编程软件相关系的哈

使用特权

评论回复
tongbu2015| | 2019-3-23 22:03 | 显示全部楼层
至于具体是怎么实现的,肯定是编程软件跟仿真器存在一个数据协议的交互的

使用特权

评论回复
smilingangel| | 2019-3-23 23:23 | 显示全部楼层
我平时只是用的,还没仔细的想想是怎样实现的呢

使用特权

评论回复
smilingangel| | 2019-3-23 23:23 | 显示全部楼层
这个跟代码的仿真下载的机制是相关的哈

使用特权

评论回复
smilingangel| | 2019-3-23 23:24 | 显示全部楼层
还有绕不过去的就是程序代码的连接编译的过程的

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

979

主题

8749

帖子

4

粉丝