EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
& C. \3 J, R) ^$ N2 m
0 a* W. R& H6 v5 d! F) m2 b$ p
$ L& P/ E9 H& E3 d! B: C程序的运行时间,对一个系统比较重要。有的地方要求精确延时Nus,有的地方要求程序运行时间不能超过Nus。
; E8 {5 m; a- Z; z所以,今天给大家分享一些常见测量程序(任务)运行时间的方法。 4 v a3 n! r$ k' b8 p- M% q; {( }
0、为什么需要测定程序运行时间?1 k$ k5 h: g: J* _1 s2 u: t* F
软件的时效性决定着系统的快速性,这一句话的前提是在不考虑硬件的限制。不过对于我们大部分项目而言,而是真正限制系统反应速度的还是硬件资源等。
/ ]& ]$ H% i" A! Y/ M比如说我们真实世界与数字世界的窗口-AD采样芯片,我们都需要通过感知外界的一些反馈来对我们的系统做出正确的决策,那么AD芯片的转化速度就成了决定该反馈的速度,进而影响着我们的系统。 再比如,我们要运行一段算法,我们都期待越快越好,但这段算法会牵涉传感器的采集处理。那么这其中要综合考虑传感器采集的最大速率等问题。
& r J) O+ @! Z7 `$ c
* N' z- ~0 E& b6 U) ]$ E `0 I: ~) `所以,我们在项目研发初期就要考虑一些地方程序运行的时间问题。下面为大家总结日常的测量方法,供大家学习参考。 ! P5 Y6 q: q0 l$ s; \8 x$ N
1、IO翻转示波器测量法0 o. S8 A3 z& I" A
该方法简单方便,在测量的起始位置,设置IO为一种状态(低);在测量的结束位置,设置IO为另一个状态(高)。- 2 v' Y: L- j0 P1 @$ t; d% Z% v. F
TEST_IO_LOW(); //被测量代码start //······ //被测量代码end TEST_IO_HIGH();
9 U: J) y2 P) L这种测量方法要考虑添加的IO语句会占用一定时间(具体与你处理器能力有关),比如72M的STM32F1,一个IO翻转,应该在几十ns。
+ l9 R. X8 u: H) I2 v2、捕获IO测量法( C. ]4 n/ S8 f
该方法其实和示波器法类似,都属于外部测量方法,不过该方法的好处是能够弥补任务运行时间变化较大导致示波器测量显示难以辨识最长时间的问题。" S) H/ Q0 f. W; O6 q
大体实现思路我们可以把IO翻转信号看成一个脉冲宽度来进行测量,只需要通过编程在用另外一款尽量高端的或者是主频更高的芯片通过捕获功能结合定时器进行时间记录即可,这样我们既可以获得程序运行的时间,还可以通过编程的思路,进行一段长时间内的脉宽的最大值、平均值等来更好的表征程序运行的状况。) p, ~( L" I' a. ]5 a4 V F: T) X- u
该方法的缺点该办法的精度等得由外部芯片来决定,不过对于大部分应用是满足的。
4 Z. Q; x% y2 x6 F! Q' E5 e3、内部定时器法 : @( k0 |" l; j" V
该方法与上面的捕获IO方法是类似的,在 嵌入式系统中经常会遇到时间戳的使用,同时还能获得CPU的利用率,其实方法都是一样的,系统中会开启一个核心定时器,该定时器一般不会受到外部的干扰等,通过该定时器在任务的开头和结尾分别安插标志,从而获得这段时间内的定时器计数,从而计算出程序运行时间。 9 ]; |9 }8 o, B8 W4 v
该方法在我们的小型或者资源不足的芯片上使用得不多,因为我们很少有多余的定时器来进行额外的处理,同时由于定时器处理需要一定的时间,以及一些额外的计算等都会导致测量时间上的误差,如果该误差在能够接受的范围还是可以采用该方法的。
; |3 G) W5 r: P2 V' Y4.仿真器法
7 W. p H' x8 D0 {/ `7 v) E+ d& [目前许多芯片的调试仿真器都会具备测量仿真程序的多方面性能的功能,比如说KEIL或者CCS集成开发环境也都基本支持测量程序运行时间的,一般都是测量断点之间的程序所运行时间,用户需要在开发环境中进行芯片当前的晶振、主频等等方面参数的设置以后基本能够获得一个运行时间结果。
" T* J% q" h: \% M8 |: _1 [$ j2 r" i6 _
' _9 t9 z" g5 O" z: b
5 Z- c3 I' G9 ?4 f6 N" c, q
|