804|2

7219

帖子

195

TA的资源

五彩晶圆(高级)

楼主
 

《嵌入式软件的时间分析》第五章软件时间分析方法-运行时间测量学习 [复制链接]

 

 

软件时间分析方法这一章主要学习了运行时间的测量

最古老的时间分析方法就是利用端口引脚进行运行时测量。

利用示波器或者逻辑分析仪对端口引脚上的信号进行可视化和测量,来测试总执行时间。

这个其实是非常常用,如果你想测量这段代码等占用的时间,最常用的就是通过这种古老的端口测量方法。

 

在STM32的应用中,还特地引入了SEV,这个SEV比书中举例的ATMEGA8的PORTB的配置简单很多,直接调用sev()就可以实现端口的拉高拉低,sev函数只占用一个时钟周期,假设时钟是100MHz

 

 

 

一个时钟周期也就是10ns,如果是STM32F4,主频接近180M,那占用的时间就更加短。参考例程

GPIO_InitStruct.Pin = GPIO_PIN_10;

GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;

GPIO_InitStruct.Pull = GPIO_PULLDOWN;

GPIO_InitStruct.Speed = GPIO_SPEED_HIGH;

GPIO_InitStruct.Alternate = GPIO_AF15_EVENTOUT;

HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);

 

第二种方法:

不使用端口和仪器的时间测量方法

端口引脚或外部测量方法并不是一直可以使用,外部测量设备有时候可能手上正好没有,就需要使用其它方便的操作方法,比如硬件定时器作为测量的基础。

配置好定时器周期后,定时器值存储在测量元素的开头,在测量元素的结尾时读出这个值,这俩个值的差值就是总运行时间。

 

用STM32来举例

start_cnt=__HAL_TIM_GET_COUNTER(&TIM1_Handler); //获取定时器的值,开始计时

HAL_GPIO_WritePin(GPIOA,GPIO_PIN_1,GPIO_PIN_SET);

delay_ms(20);

HAL_GPIO_WritePin(GPIOA,GPIO_PIN_1,GPIO_PIN_RESET);      /

delay_ms(20);

end_cnt=__HAL_TIM_GET_COUNTER(&TIM1_Handler);  //获取结束时的定时器的计数值

end_cnt和start_cnt的差值就是运行的时间

 

此帖出自汽车电子论坛

最新回复

实时系统中运行时间长度是必须要关注的  详情 回复 发表于 2024-7-6 10:23
点赞 关注

回复
举报

203

帖子

0

TA的资源

一粒金砂(中级)

沙发
 
实时系统中运行时间长度是必须要关注的
此帖出自汽车电子论坛

点评

是的,这个时间需要重点关注 很重要  详情 回复 发表于 2024-7-6 11:16
 
 

回复

7219

帖子

195

TA的资源

五彩晶圆(高级)

板凳
 
combat 发表于 2024-7-6 10:23 实时系统中运行时间长度是必须要关注的

是的,这个时间需要重点关注 很重要

此帖出自汽车电子论坛
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表