0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

DWT跟踪组件使用方法

硬件攻城狮 来源:技术让梦想更伟大 作者:技术让梦想更伟大 2022-10-09 10:14 次阅读

DWT跟踪组件

跟踪组件:数据观察点与跟踪(DWT)

a4574ab0-416f-11ed-96c9-dac502259ad0.png

DWT 中有剩余的计数器,它们典型地用于程序代码的“性能速写”(profiling)。通过编程它们,就可以让它们在计数器溢出时发出事件(以跟踪数据包的形式)。

最典型地,就是使用 CYCCNT寄存器来测量执行某个任务所花的周期数,这也可以用作时间基准相关的目的(操作系统中统计 CPU使用率可以用到它)。

Cortex-M中的DWT

在Cortex-M里面有一个外设叫DWT(Data Watchpoint and Trace),是用于系统调试及跟踪。

a48285cc-416f-11ed-96c9-dac502259ad0.png

它有一个32位的寄存器叫CYCCNT,它是一个向上的计数器,记录的是内核时钟运行的个数,内核时钟跳动一次,该计数器就加1,精度非常高,如果内核时钟是72M,那精度就是1/72M = 14ns,而程序的运行时间都是微秒级别的,所以14ns的精度是远远够的。

最长能记录的时间为:59.65s。计算方法为2的32次方/72000000。

当CYCCNT溢出之后,会清0重新开始向上计数。

使用方法

要实现延时的功能,总共涉及到三个寄存器:DEMCR 、DWT_CTRL、DWT_CYCCNT,分别用于开启DWT功能、开启CYCCNT及获得系统时钟计数值。

DEMCR

想要使能DWT外设,需要由另外的内核调试寄存器DEMCR的位24控制,写1使能(划重点啦,要考试!!)。DEMCR的地址是0xE000 EDFC

a4bf8c56-416f-11ed-96c9-dac502259ad0.pnga4e0356e-416f-11ed-96c9-dac502259ad0.png

关于DWT_CYCCNT

使能DWT_CYCCNT寄存器之前,先清0。让我们看看DWT_CYCCNT的基地址,从ARM-Cortex-M手册中可以看到其基地址是0xE000 1004,复位默认值是0,而且它的类型是可读可写的,我们往0xE000 1004这个地址写0就将DWT_CYCCNT清0了。

a4fea044-416f-11ed-96c9-dac502259ad0.png

关于CYCCNTENA

CYCCNTENA Enable the CYCCNT counter. If not enabled, the counter does not count and no event is generated for PS sampling or CYCCNTENA. In normal use, the debugger must initialize the CYCCNT counter to 0.

它是DWT控制寄存器的第一位,写1使能,则启用CYCCNT计数器,否则CYCCNT计数器将不会工作。

【https://developer.arm.com/documentation/ddi0337/e/system-debug/dwt/summary-and-description-of-the-dwt-registers?lang=en】

a5172556-416f-11ed-96c9-dac502259ad0.png

综上所述

想要使用DWT的CYCCNT步骤:

先使能DWT外设,这个由另外内核调试寄存器DEMCR的位24控制,写1使能

使能CYCCNT寄存器之前,先清0。

使能CYCCNT寄存器,这个由DWT的CYCCNTENA 控制,也就是DWT控制寄存器的位0控制,写1使能

寄存器定义:

//0xE000EDFCDEMCRRWDebugExceptionandMonitorControlRegister.
//使能DWT模块的功能位
#defineDEMCR(*(unsignedint*)0xE000EDFC)
#defineTRCENA(0x01<< 24) // DEMCR的DWT使能位  
  
//0xE0001000 DWT_CTRL RW The Debug Watchpoint and Trace (DWT) unit  
//使能CYCCNT计数器开始计数
#define DWT_CTRL        ( *(unsigned int *)0xE0001000 )  
#define CYCCNTENA       ( 0x01 << 0 ) // DWT的SYCCNT使能位
 
//0xE0001004 DWT_CYCCNT RW Cycle Count register,   
//CYCCNT计数器的内部值(32位无符号)
#define DWT_CYCCNT      ( *(unsigned int *)0xE0001004) //显示或设置处理器的周期计数值  

用法示例:

vvolatileunsignedint*DWT_CYCCNT;
volatileunsignedint*DWT_CONTROL;
volatileunsignedint*SCB_DEMCR;

voidreset_timer(){
DWT_CYCCNT=(int*)0xE0001004;//addressoftheregister
DWT_CONTROL=(int*)0xE0001000;//addressoftheregister
SCB_DEMCR=(int*)0xE000EDFC;//addressoftheregister
*SCB_DEMCR=*SCB_DEMCR|0x01000000;
*DWT_CYCCNT=0;//resetthecounter
*DWT_CONTROL=0;
}

voidstart_timer(){
*DWT_CONTROL=*DWT_CONTROL|1;//enablethecounter
}

voidstop_timer(){
*DWT_CONTROL=*DWT_CONTROL|0;//disablethecounter
}

unsignedintgetCycles(){
return*DWT_CYCCNT;
}

main(){
....
reset_timer();//resettimer
start_timer();//starttimer
//Codetoprofile
...
myFunction();
...
stop_timer();//stoptimer
numCycles=getCycles();//readnumberofcycles
...
}

示例2:

#definestart_timer()*((volatileuint32_t*)0xE0001000)=0x40000001//EnableCYCCNTregister
#definestop_timer()*((volatileuint32_t*)0xE0001000)=0x40000000//DisableCYCCNTregister
#defineget_timer()*((volatileuint32_t*)0xE0001004)//GetvaluefromCYCCNTregister

/***********
*Howtouse:
*uint32_tit1,it2;//startandstopflag
start_timer();//startthetimer.
it1=get_timer();//storecurrentcycle-countinalocal
//dosomething
it2=get_timer()-it1;//Derivethecycle-countdifference
stop_timer();//Iftimerisnotneededanymore,stop
print_int(it2);//Displaythedifference
****/

示例3:

#defineDWT_CR*(uint32_t*)0xE0001000

#defineDWT_CYCCNT*(uint32_t*)0xE0001004

#defineDEM_CR*(uint32_t*)0xE000EDFC

#defineDEM_CR_TRCENA(1<< 24)
 
#define  DWT_CR_CYCCNTENA                (1 <<  0)
 
/* 初始化时间戳 */
 
void CPU_TS_TmrInit(void)
 
{
 
        /* 使能DWT外设 */
        DEM_CR |= (uint32_t)DEM_CR_TRCENA;               
 
        /* DWT CYCCNT寄存器计数清0 */
        DWT_CYCCNT = (uint32_t)0u;
       
 
        /* 使能Cortex-M3 DWT CYCCNT寄存器 */
        DWT_CR |= (uint32_t)DWT_CR_CYCCNTENA;
 
}
 
uint32_t OS_TS_GET(void)
{       
 
        return ((uint32_t)DWT_CYCCNT);
 
}

审核编辑:彭静
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 寄存器
    +关注

    关注

    31

    文章

    5282

    浏览量

    119761
  • 计数器
    +关注

    关注

    32

    文章

    2251

    浏览量

    94245
  • DWT
    DWT
    +关注

    关注

    0

    文章

    20

    浏览量

    11120

原文标题:分享一个超实用的单片机调试技巧!DWT组件

文章出处:【微信号:mcu168,微信公众号:硬件攻城狮】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    详解DWT跟踪组件的单片机调试技巧

    DWT 中有剩余的计数器,它们典型地用于程序代码的“性能速写”(profiling)。通过编程它们,就可以让它们在计数器溢出时发出事件(以跟踪数据包的形式)。
    发表于 10-03 06:42 651次阅读

    ComponentCodelab——Tablist的使用方法

    让开发者了解HarmonyOS应用开发常用布局和常用组件之Tablist的使用方法,体验从工程创建到代码、布局的编写,再到编译构建、部署和运行的全过程。
    发表于 05-08 22:04

    DWT的相关资料下载

    特定应用场景下定时器外设资源是十分稀缺的。在留言区有位大佬提到可以使用DWT,我就研究了一番。02、DWT在Cortex-M里面有一个外设叫DWT(DataWatchpoint andTrace),是用于系统调试及
    发表于 02-07 09:19

    AT32使用内核DWT寄存器设定延时时间

    (Cortex-M 内核)GPIO快速使用方法硬件资源AT-START-F403A V1.x 实验板;软件资源该 Demo 以 AT32F403A 为例,BSP 版本
    发表于 07-19 20:18

    如何使用或启用STM32CubeIDE DWT

    我有一块 STM32L031K6 Nucleo 板……我想使用 DWT.. 但我变成了这个错误:../Core/Src/../Inc/stm32_delay.h:35:30: error: 'DWT
    发表于 01-30 06:38

    示波器的使用方法

    数字万用表使用方法和示波器的使用方法详解。
    发表于 03-14 10:38 32次下载

    电力电缆局部放电测量DWT技术

    从主要测试方法、信号提取电路和信号波形、离散小波变换(DWT)的滤波器本质特性实例分析了电力电缆局部放 电的现场测量和降噪分析技术。根据离散小波降噪的母小波选择、分解尺度选择和阈值算法等3个关键
    发表于 08-30 17:47 10次下载
    电力电缆局部放电测量<b class='flag-5'>DWT</b>技术

    示波器的使用方法(三):示波器的使用方法详解

    示波器的使用方法并非很难,重点在于正确使用示波器的使用方法。往期文章中,小编对模拟示波器的使用方法和数字示波器的使用方法均有所介绍。为增进大家对示波器的
    的头像 发表于 12-24 20:37 3130次阅读

    罗森伯格HFM电缆组件使用方法

    组件使用方法,目的是阐述安装使用过程中的注意事项,避免错误的操作。   1 2 表:HFM线端连接器 连接器和电缆组件的安装过程涉及到线缆组件与板端连接器的插入、拔出和线束的布置等过
    的头像 发表于 01-18 15:33 3409次阅读

    STM32“隐藏的定时器”-DWT

    特定应用场景下定时器外设资源是十分稀缺的。在留言区有位大佬提到可以使用DWT,我就研究了一番。02、DWT在Cortex-M里面有一个外设叫DWT(DataWatchpoint andTrace),是用于系统调试及
    发表于 12-04 14:51 1次下载
    STM32“隐藏的定时器”-<b class='flag-5'>DWT</b>

    DWT跟踪组件调试

    DWT跟踪组件 跟踪组件:数据观察点与跟踪(DWT)
    的头像 发表于 06-22 14:24 942次阅读
    <b class='flag-5'>DWT</b><b class='flag-5'>跟踪</b><b class='flag-5'>组件</b>调试

    射频电缆组件使用方法和注意事项

    射频电缆组件使用方法和注意事项  射频电缆组件是一类广泛应用于通信系统、无线电设备和其他射频设备中的重要电子组件。它们在传输高频信号时扮演着关键的角色,因此使用和安装时需要特别注意一
    的头像 发表于 01-05 15:08 554次阅读

    揭秘单片机调试利器值之DWT跟踪组件

    DWT 中有剩余的计数器,它们典型地用于程序代码的“性能速写”(profiling)。通过编程它们,就可以让它们在计数器溢出时发出事件(以跟踪数据包的形式)。
    发表于 02-28 13:55 660次阅读
    揭秘单片机调试利器值之<b class='flag-5'>DWT</b><b class='flag-5'>跟踪</b><b class='flag-5'>组件</b>

    太阳能组件检测设备的使用方法简单吗?

      JD-EL4太阳能组件检测设备的使用方法简单而直观,通常设计为用户友好型,以确保操作便捷、高效。以下将详细介绍太阳能组件检测设备的使用方法及相关特点:   1. 简洁直观的操
    的头像 发表于 05-21 17:09 357次阅读

    LangChain框架关键组件使用方法

    LangChain,开发者可以轻松构建基于RAG或者Agent流水线的复杂应用体系,而目前我们已经可以在LangChain的关键组件LLM,Text Embedding和Reranker中直接调用OpenVINO进行模型部署,提升本地RAG和Agent服务的性能,接下来就让我们一起看下这些
    的头像 发表于 08-30 16:55 453次阅读
    LangChain框架关键<b class='flag-5'>组件</b>的<b class='flag-5'>使用方法</b>