OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 5891|回复: 2

Keil CMSIS 使用osDelay发现延时时间太慢, EventRecorder时间也慢

[复制链接]

6

主题

56

帖子

0

精华

初级会员

Rank: 2

积分
129
金钱
129
注册时间
2019-1-29
在线时间
67 小时
发表于 2019-2-1 20:03:53 | 显示全部楼层 |阅读模式
1金钱
刚刚学习使用STM32, 目前板子是F407VET6, STLINK

使用一个闪灯的例子,  RTOS选用 Keil RTX5 , 配置每秒1000 tick

发现问题是, 使用osDelay, 实际延时时间是3.1倍.  例如 osDelay(1000) 需要等3.1秒

如果使用调试模式, 在EventRecorder里显示的 Time(sec) , 也是特慢.  现实过了3.1秒, 芯片才走1秒

请问有人遇到过这种问题吗?

最佳答案

查看完整内容[请看2#楼]

已经找到原因了. 是板子上的晶振问题. 找到所有的 #define HSE_VALUE 修改为 ((uint32_t)8000000) 就好了
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

6

主题

56

帖子

0

精华

初级会员

Rank: 2

积分
129
金钱
129
注册时间
2019-1-29
在线时间
67 小时
 楼主| 发表于 2019-2-1 20:03:54 | 显示全部楼层
已经找到原因了.

是板子上的晶振问题.

找到所有的

#define HSE_VALUE   
修改为 ((uint32_t)8000000)

就好了

回复

使用道具 举报

6

主题

56

帖子

0

精华

初级会员

Rank: 2

积分
129
金钱
129
注册时间
2019-1-29
在线时间
67 小时
 楼主| 发表于 2019-2-1 20:07:37 | 显示全部楼层
本帖最后由 ZHDX 于 2019-2-1 20:20 编辑

如果我把行啊面这个代码注释掉,  

//  if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_5) != HAL_OK)
//  {
//    _Error_Handler(__FILE__, __LINE__);
//  }

tick延时问题就解决了. 但HAL_RCC_GetHCLKFreq()只返回16M ,  EventReorder里记录的时间就变得更慢了.

回复

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-6-9 19:19

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表