用户名  找回密码
 请使用中文注册

手机号码,快捷登录

手机号码,快捷登录

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

2023-6-8 17:19| 发布者: 开心| 查看: 117| 评论: 0

阅读字号:

摘要: DWT跟踪组件 跟踪组件:数据观察点与跟踪(DWT) DWT 中有剩余的计数器,它们典型地用于程序代码的“性能速写”(profiling)。通过编程它们,就可以让它们在计数器溢出时 ...
    DWT跟踪组件
  跟踪组件:数据观察点与跟踪(DWT)
  

  DWT 中有剩余的计数器,它们典型地用于程序代码的“性能速写”(profiling)。通过编程它们,就可以让它们在计数器溢出时发出事件(以跟踪数据包的形式)。
  最典型地,就是使用 CYCCNT寄存器来测量执行某个任务所花的周期数,这也可以用作时间基准相关的目的(操作系统中统计 CPU使用率可以用到它)。
  Cortex-M中的DWT
  在Cortex-M里面有一个外设叫DWT(Data Watchpoint and Trace),是用于系统调试及跟踪。
  

  它有一个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
  

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

  关于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】
  

  综上所述
  想要使用DWT的CYCCNT步骤:
  先使能DWT外设,这个由另外内核调试寄存器DEMCR的位24控制,写1使能
  使能CYCCNT寄存器之前,先清0。
  使能CYCCNT寄存器,这个由DWT的CYCCNTENA 控制,也就是DWT控制寄存器的位0控制,写1使能
  寄存器定义:
  
//0xE000EDFCDEMCRRWDebugExceptionandMonitorControlRegister.//使能DWT模块的功能位#defineDEMCR(*(unsignedint*)0xE000EDFC)#defineTRCENA(0x01

路过

雷人

握手

鲜花

鸡蛋

最新评论

  • 二极管的正向压降决于二极管的材料和结构
  • 电动车控制器如何简单判断有没有致命损坏
  • 384X的业余测试
  • U9104(SP6018E)引脚功能与实测数据
  • LD5532GS(U9101)引脚功能与实测数据
  • 雷电探测器电路原理图讲解
  • 手机屏蔽器电路图解
  • 9v低电池电量指示器电路图解
  • 基于BLW96的射频放大器电路解析
  • 带闹钟的夜灯电路图解说明
  • 0%

QQ|Archiver|手机版|家电维修论坛 ( 蜀ICP备19011473号-4 川公网安备51102502000164号 )

GMT+8, 2025-5-22 06:01 , Processed in 0.150697 second(s), 22 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

返回顶部