米尔科技提醒您:您的浏览器版本过低或者使用了兼容模式,为了获得更好的浏览体验,建议使用IE10以上的浏览器或使用极速模式。 请升级浏览器以获得更好的体验!

在MDK中使用 Event Viewer功能

文章来源:米尔科技 发布日期:2021.1.19 浏览次数:1368
Event Viewer可以在时间线上显示线程,中断,和异常情况,.他通过TRACE信息来展示时间轴信息,这些功能可以在 Cortex-M3, M4, M7 设备上实现,但是他也需要仿真器设备来支持,例如 ULINKpro.


具体实现方法有如下两种 ,以STM32为例,
使能4ETM Trace
STM32系列微控制器上使能CoreSight ETM trace 功能
   连接ULink Pro Cortex Debug+ETM通过到目标板,在连接到主机上
  使能Trace Port 接口,相关的介绍在STM32F103xx Reference Manual 手册的TRACE Pin Assignment 章节。(steps listed below)步骤如下:
     配置μVision去捕获ETM Trace 数据(步骤如下):
Enable the Trace Port Interface
使能TRACE  Port 接口
创建一个文档,例如下面的例子,输入下面的信息。
/*-------------------------------------------------------------------
** Define the function to enable the trace port
**-----------------------------------------------------------------*/
FUNC void EnableTPIU(void) {
  _WDWORD(0xE0042004, 0x000000E0);    // Set 4-pin tracing via DBGMCU_CR
}
/*-------------------------------------------------------------------
** Invoke the function at debugger startup
**-----------------------------------------------------------------*/
EnableTPIU();
/*-------------------------------------------------------------------
** Execute upon software RESET
**-----------------------------------------------------------------*/
FUNC void OnResetExec(void)  {
  EnableTPIU();
}
TRACED[0..3]数据输出的引脚是PE3PE6
Trace时钟,TRACECK 是引脚PE2
默认情况下,这些引脚是不用赋值的,需要在 DBGMCU_CR 寄存器的TRACE_IOEN 和 TRACE_MODE位进行配置的。
使用命令 _WDWORD 配置DBGMCU_CR 寄存器,格式如下
_WDWORD(0xE0042004, 0x000000E0);
特殊的函数 OnResetExec() 在软件复位时执行,具体参考TPUI Initialization after RESET (Cortex-M)
打开对话框 Options for Target — Debug 在 the Initialization File选择文件
配置μVision 捕获ETM Trace数据
使能USE,选择Ulink Pro 调试器,点击Settings 打开 Target Driver Setup 对话框
点击Trace 标签
选择Trace Enable 和ETM Trace Enable.
可选的,使能Unlimited Trace 定位整个数据流历史记录,请确认使能这个选项,会增加功耗消耗,请使用电缆供电
设置 Trace Port 为Sync Trace Port with 4-bit Data, 这个设置一定要与创建的Trace.ini 文件相匹配。
    Core Clock 一定要与芯片设置的相匹配。
μVision window下开始调试验证捕获的trace数据。
使能Serial Wire Trace
STM32F系列控制器上使能 Serial Wire Trace
连接ULINKpro到目标板的Cortex Debug接口上,再通过USB连接到电脑上。
   使能 Trace Port接口,在STM32F103xx Reference Manual手册,Pinout and Debug Port Pins 和 TRACE Pin Assignment章节都有描述。
配置μVision捕获trace信息。
Enable the Trace Port Interface
使能Trace Port接口
创建文档,例如Trace.ini, 输入如下代码:
/*-------------------------------------------------------------------
** Define the function to enable the trace port
**-----------------------------------------------------------------*/
FUNC void EnableTPIU(void) {
  _WDWORD(0xE0042004, 0x00000020);    // Set asynchronous communication via DBGMCU_CR
}
/*-------------------------------------------------------------------
** Invoke the function at debugger startup
**-----------------------------------------------------------------*/
EnableTPIU();
使用_WDWORD命令配置DBGMCU_CR 寄存器的TRACE_IOEN 和TRACE_MODE 位,命令如下:
_WDWORD(0xE0042004, 0x00000020);
打开对话框Options for Target — Debug ,在Initialization File中选择Trace.ini 文件
配置μVision捕获Trace数据
在对话框Options for Target — Debug中
使能Use,选择ULINK Pro Cortex Debugger点击Settings打开Target Driver Setup 对话框。
Enable SWJ and select SW.
使能SWJ和选择 SW
选择 Trace 选项。
设置Trace Enable
设置Trace Port 为Serial Wire Output - Manchester 然后使能Autodetect.
Core Clock 设置必须与芯片设置相同。
   在μVision window下开始调试验证捕获的trace数据。


本文来自米尔科技,原文地址: http://www.myir-tech.com/resource/579.asp,转载请注明出处。