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

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

3天内不再提示

一个超级实用的单片机调试组件

硬件攻城狮 来源:CSDN-booksyhay 作者:CSDN-booksyhay 2023-04-10 11:15 次阅读

DWT跟踪组件

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

e44dfcc0-d6a9-11ed-bfe3-dac502259ad0.png

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

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

Cortex-M中的DWT

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

e474b0c2-d6a9-11ed-bfe3-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

e4aff45c-d6a9-11ed-bfe3-dac502259ad0.pnge4e8afe0-d6a9-11ed-bfe3-dac502259ad0.png

关于DWT_CYCCNT

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

e51fd826-d6a9-11ed-bfe3-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】

e5491c54-d6a9-11ed-bfe3-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);
 
}

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

    关注

    6035

    文章

    44553

    浏览量

    634766
  • 计数器
    +关注

    关注

    32

    文章

    2256

    浏览量

    94485
  • 调试
    +关注

    关注

    7

    文章

    578

    浏览量

    33924
  • DWT
    DWT
    +关注

    关注

    0

    文章

    20

    浏览量

    11136
  • Cortex-M
    +关注

    关注

    2

    文章

    229

    浏览量

    29755

原文标题:一个超级实用的单片机调试组件!

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

收藏 人收藏

    评论

    相关推荐

    单片机串口模块调试方法

    笔者在调试某Cortex-M3内核单片机时遇到问题,此单片机不具备在线仿真功能,因此调试代码
    发表于 07-28 15:48 1538次阅读
    <b class='flag-5'>单片机</b>串口模块<b class='flag-5'>调试</b>方法

    单片机的在线调试方法

    本文主要讲述的是单片机的在线调试方法。
    发表于 04-22 16:43 34次下载

    ARM单片机开发调试方法

    ARM单片机开发调试方法
    发表于 07-25 13:21 36次下载

    超级单片机软件工具

    超级单片机软件工具 软件工具
    发表于 11-01 17:16 179次下载

    单片机开发调试应注意的问题

    单片机开发调试应注意的问题 1、使用总线不外引的单片机 ·是最正统的单片机使用模式 ·符合小型、简单、可靠、廉价的单片机设计初衷
    发表于 03-26 12:30 1752次阅读

    单片机多功能调试助手

    单片机多功能调试助手。
    发表于 01-12 16:52 7次下载

    单片机多功能调试助手

    单片机多功能调试助手 串口、USB等调试用。
    发表于 03-11 10:34 8次下载

    单片机项目的开发和设计及调试等资料说明

    本文档的主要内容详细介绍的是单片机项目的开发和设计及调试等资料说明。仿照书中实例按步骤完成以下项目的开发、硬件软件的设计和调试
    发表于 05-30 08:00 0次下载
    <b class='flag-5'>单片机</b>的<b class='flag-5'>一</b><b class='flag-5'>个</b>项目的开发和设计及<b class='flag-5'>调试</b>等资料说明

    单片机系统硬件的静态调试和动态调试综述

    单片机系统硬件的静态调试和动态调试综述
    发表于 07-18 10:59 2次下载

    超级实用的单片机调试组件

    DWT 中有剩余的计数器,它们典型地用于程序代码的“性能速写”(profiling)。通过编程它们,就可以让它们在计数器溢出时发出事件(以跟踪数据包的形式)。
    发表于 05-23 10:01 373次阅读
     <b class='flag-5'>一</b><b class='flag-5'>个</b><b class='flag-5'>超级</b>实用的<b class='flag-5'>单片机</b><b class='flag-5'>调试</b><b class='flag-5'>组件</b>!

    单片机开发调试工具有哪些?

    单片机调试有条不紊的过程,用于查找和减少单片机程序中的错误数量,使其按预期工作。有时候,单片机
    的头像 发表于 07-07 12:29 1523次阅读

    单片机调试时的那些技术

    单片机调试时的那些技术
    的头像 发表于 10-18 17:56 864次阅读
    <b class='flag-5'>单片机</b><b class='flag-5'>调试</b>时的那些技术

    应用单片机开发的ST LINK调试器设计制作

    调试ST单片机的过程中,ST-LINK是很好使用的调试工具。今天,我们就根据网络上的设计方案进行简化,设计制作
    发表于 03-06 10:26 1112次阅读
    应用<b class='flag-5'>单片机</b>开发的ST LINK<b class='flag-5'>调试</b>器设计制作

    单片机基本io功能调试过程

    单片机基本IO功能的调试过程涉及多个步骤,旨在确保IO口能够正确地执行输入和输出操作。以下是调试过程,涵盖了从准备阶段到实际测试的关键步
    的头像 发表于 09-14 14:38 562次阅读

    单片机Debug工具性能对比 单片机调试常用命令

    单片机(Microcontroller Unit, MCU)调试是嵌入式开发中的重要环节,它帮助开发者发现和修复代码中的错误,优化程序性能。不同的
    的头像 发表于 12-19 09:56 159次阅读