点击上方“小麦大叔”,选择“置顶/星标公众号”

福利干货,第一时间送达

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步骤:

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

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

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

寄存器定义:

//0xE000EDFC DEMCR RW Debug Exception and Monitor Control Register.
//使能DWT模块的功能位
#define DEMCR           ( *(unsigned int *)0xE000EDFC )
#define TRCENA          ( 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) //显示或设置处理器的周期计数值

用法示例:

vvolatile unsigned int *DWT_CYCCNT  ;
volatile unsigned int *DWT_CONTROL ;
volatile unsigned int *SCB_DEMCR   ;void reset_timer(){DWT_CYCCNT   = (int *)0xE0001004; //address of the registerDWT_CONTROL  = (int *)0xE0001000; //address of the registerSCB_DEMCR    = (int *)0xE000EDFC; //address of the register*SCB_DEMCR   = *SCB_DEMCR | 0x01000000;*DWT_CYCCNT  = 0; // reset the counter*DWT_CONTROL = 0;
}void start_timer(){*DWT_CONTROL = *DWT_CONTROL | 1 ; // enable the counter
}void stop_timer(){*DWT_CONTROL = *DWT_CONTROL | 0 ; // disable the counter
}unsigned int getCycles(){return *DWT_CYCCNT;
}main(){....reset_timer(); //reset timerstart_timer(); //start timer//Code to profile...myFunction();...stop_timer(); //stop timernumCycles = getCycles(); //read number of cycles ...
}

示例2:

#define start_timer()    *((volatile uint32_t*)0xE0001000) = 0x40000001  // Enable CYCCNT register
#define stop_timer()   *((volatile uint32_t*)0xE0001000) = 0x40000000  // Disable CYCCNT register
#define get_timer()   *((volatile uint32_t*)0xE0001004)               // Get value from CYCCNT register/***********
* How to use:
*       uint32_t it1, it2;      // start and stop flag                                            start_timer();          // start the timer.it1 = get_timer();      // store current cycle-count in a local// do somethingit2 = get_timer() - it1;    // Derive the cycle-count differencestop_timer();               // If timer is not needed any more, stop
print_int(it2);                 // Display the difference
****/

示例3:

#define  DWT_CR      *(uint32_t *)0xE0001000#define  DWT_CYCCNT  *(uint32_t *)0xE0001004#define  DEM_CR      *(uint32_t *)0xE000EDFC#define  DEM_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);}

原文地址:https://blog.csdn.net/booksyhay/article/details/109028712

转自公众号:技术让梦想更伟大

版权声明:本文来源网络,版权归原作者所有。版权问题,请联系删除。

往期推荐

超全汇总!常见的芯片封装大全!

一个基于QT的开源串口调试工具

一个低成本的FOC控制方案分享

盘点14个著名的软件开源项目,你知道几个?

一个超级实用的单片机调试技巧!DWT组件相关推荐

  1. 继续分享 5 个实用的 vs 调试技巧

    前言 我在上一篇文章????<5 个非常实用的 vs 调试技巧> 中分享了 5 个我认为非常值得了解的 vs 调试技巧,本周继续分享 5 个很基础但同样实用的调试技巧. 1. 条件断点 作 ...

  2. python实用大全pdf_超级实用干货|九大技巧,带你用Python玩转PDF

    原标题:超级实用干货|九大技巧,带你用Python玩转PDF 尽管PDF最开始是由Adobe发明的,但它现在已经成为国际标准组织ISO维护的公开标准了.大家可以在Python中通过PyPDF2包来处理 ...

  3. 这10个实用的Javascript调试技巧,你知道吗?

    见过太多同学调试Javascript只会用简单的console.log甚至alert,看着真为他们着急.因为大多数同学追求优雅而高效地写代码,却忽略了如何优雅而高效地调试代码,不得不说是有点" ...

  4. 超级实用的vue小技巧,用了之后直呼好棒~

    实用的vue小技巧,来源于真实企业实战 -- 记得收藏~ 1. 原型注入 2. 对象冻结 3.img 加载失败 4. 递归组件 5. 解决繁乱的template -- render函数 6. 延迟更新 ...

  5. 蓝海创意云丨介绍一个超级实用的CG后期制作管理工具~

    今天介绍安捷秀超级实用的CG后期制作管理模块,CG后期制作模块主要面向CG.VFX.三维动画等影视行业,帮助企业高效管理项目,提高工作效力,助力影视作品保质.保量.如期完成. 下面我们来看看如何使用C ...

  6. ps背景不变换字_分享五个超级实用的PS小技巧

    今天西瓜给大家分享五个PS的小技巧,特别容易上手操作而且很实用! 1.利用剪切蒙版给衣服加图案 首先第一步我们打开素材,使用快速选择工具,把裙子选出来,然后Ctrl+J复制出来 打开花纹背景素材,Ct ...

  7. java8中stream最实用总结和调试技巧

    文章目录 背景 stream介绍 1. 什么是流? 2. 流的构成 3.流的操作类型 stream使用 1. 流的构造与转换 2. 流的操作 在idea中如何调试stream 总结 背景 java8推 ...

  8. 分享一个非常实用的视频剪辑技巧

    很多刚开始学习剪辑的宝贝们,虽然有素材在手,但却不知道如何高效剪辑好视频,于是乎,今天小编给大家安利一个新的剪辑技巧,下面一起来试试,希望能给大家带来帮助. 流畅的剪辑过程 第一步,粗剪,把有关的视频 ...

  9. 超级实用的电脑小技巧大全

    技巧一: 一些用户正在经历缓慢和间歇性的下载速度. 解决方案: 比如小编在下载界面做了温馨提示,要求用户在使用本软件前,退出电脑上安装的任何杀毒软件(360安全卫士.QQ管家.金山卫士.百度卫士等), ...

  10. 分享 :几个超级实用的excel小技巧

    在excel中输入m³,大部分同学会想到设置上标,但如果被单元格引用,它就会被打回原形. 也可以用Alt+179输入,但需要在小键盘上输入数字,有的同学笔记本没有小键盘.绕了一圈,兰色是要说最简单方法 ...

最新文章

  1. bert-as-service使用
  2. YOLO v1到YOLO v4(上)
  3. LYDSY模拟赛day2 Divisors
  4. Android Textview 一行居中 两行居左
  5. python学习实例(4)
  6. 口红会染唇是什么意思_别只知道露华浓了!这些平价口红,我吹爆!
  7. 2016美国计算机科学硕士,美国计算机科学硕士MS in Computer Science TOP10学校录取要求提醒...
  8. 银行数据部门如何管理跟使用数据?来围观星球中老师的答案
  9. java集合讲解_Java集合详解
  10. WinSock Socket 池
  11. android shape 绘制气泡图,气泡图-自定义 shape
  12. 【HDOJ 2020.09.29】一些语法水题ByVJ
  13. Q131:PBRT-V3,对比SurfaceInteration和MediumInteraction(笔记)
  14. ios 图片合成 处理合成模糊 水印 模板图片合成
  15. Linux系统下安装flash player插件
  16. qt 取消按钮点击效果_Qt 对话框里添加确定取消按钮
  17. Redis的性能瓶颈
  18. WTL 自绘控件库 (CQsRadioBox)
  19. (多元)偏正态分布、正态分布、对数正态分布的随机数的产生(R语言)
  20. 云渲染技术在虚拟仿真医疗培训中的应用

热门文章

  1. C++ 学生信息管理程序练习
  2. linux 翻录cd,Linux下一个CD翻录 创CUE 压缩flac攻略
  3. 用Python爬了我的微信好友,他们是这样的...
  4. 停止员工拖延症!工时管理系统的作用之一
  5. 支付宝AR抢红包?前端轻松就破解~
  6. 分布式项目Maven打包出现Could not resolve dependencies for project、Could not find artifact问题解决
  7. 2021-04-17 ffmpeg视频合并报错;视频合并中间添加空白
  8. 不想安装环境,我如何与前端工程师远程协作开发?
  9. java 时间显示毫秒_Java程序以毫秒为单位显示日期和时间
  10. 帝国CMS系统自动生成sitemap.xml网站地图的教程