OpenEdv-开源电子网

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

问下delay_ms(500)怎么会延时5秒?

[复制链接]

3

主题

12

帖子

0

精华

新手上路

积分
23
金钱
23
注册时间
2017-5-4
在线时间
6 小时
发表于 2017-5-6 11:12:26 | 显示全部楼层 |阅读模式
1金钱
各位高手,我学习跑马灯寄存器实验,按录像做下载后发现延时有问题,500ms实际延时了5秒,改成50是500ms,不知怎么回事?请高手指点,谢谢!
#include "stm32f4xx.h"
#include "led.h"
#include "delay.h"
int main(void)
{
delay_init(168);

  LED_Init();

   while(1){
    GPIOF->ODR &=~(1<<9);
   GPIOF->ODR &=~(1<<10);
   
   delay_ms(500);
   
   GPIOF->ODR |= 1<<9;
   GPIOF->ODR |= 1<<10;
   
   delay_ms(500);
  
  
  
  
  
  }







}

最佳答案

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

你没有初始化时钟,所以使用的是内部的RC振荡器,F4没记错的话就是16MHz的HSI,你的延时函数初始化是168MHz,但是你的实际频率只有16MHz,差不多就是相差10倍,所以你延时500ms,就延时了5s
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

32

主题

883

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4036
金钱
4036
注册时间
2015-11-14
在线时间
545 小时
发表于 2017-5-6 11:12:27 | 显示全部楼层
你没有初始化时钟,所以使用的是内部的RC振荡器,F4没记错的话就是16MHz的HSI,你的延时函数初始化是168MHz,但是你的实际频率只有16MHz,差不多就是相差10倍,所以你延时500ms,就延时了5s
回复

使用道具 举报

3

主题

12

帖子

0

精华

新手上路

积分
23
金钱
23
注册时间
2017-5-4
在线时间
6 小时
 楼主| 发表于 2017-5-6 11:47:12 | 显示全部楼层
原子哥,我按你的录像来做的,为什么会这样呢?
回复

使用道具 举报

3

主题

12

帖子

0

精华

新手上路

积分
23
金钱
23
注册时间
2017-5-4
在线时间
6 小时
 楼主| 发表于 2017-5-6 11:47:54 | 显示全部楼层
#include "led.h"
#include "stm32f4xx.h"


void LED_Init(void)
{
        RCC->AHB1ENR|= 1<<5;
       
        //F9
        GPIOF->MODER &= ~(3<<2*9);
        GPIOF->MODER |= 1<<(2*9);
        GPIOF->OSPEEDR &= ~(3<<2*9);
        GPIOF->OSPEEDR |=  2<<(2*9);
       
       
        GPIOF->PUPDR &= ~(3<<2*9);
        GPIOF->PUPDR |= 1<<(2*9);
       
       
       
        GPIOF->OTYPER  &= ~(1<<9);
        GPIOF->OTYPER  |= 0<<9;
       
        GPIOF->ODR |= 1<<9;
//        GPIOF->ODR &=~(1<<9);
       
        //F10
        GPIOF->MODER &= ~(3<<2*10);
        GPIOF->MODER |= 1<<(2*10);
        GPIOF->OSPEEDR &= ~(3<<2*10);
        GPIOF->OSPEEDR |=  2<<(2*10);
        GPIOF->PUPDR &= ~(3<<2*10);
        GPIOF->PUPDR |= 1<<(2*10);
        GPIOF->OTYPER  &= ~(1<<10);
        GPIOF->OTYPER  |= 0<<10;
       
        GPIOF->ODR |= 1<<10;  




}
回复

使用道具 举报

3

主题

12

帖子

0

精华

新手上路

积分
23
金钱
23
注册时间
2017-5-4
在线时间
6 小时
 楼主| 发表于 2017-5-6 11:48:31 | 显示全部楼层
就按录像写了这些内容
回复

使用道具 举报

9

主题

162

帖子

0

精华

高级会员

Rank: 4

积分
933
金钱
933
注册时间
2017-3-23
在线时间
255 小时
发表于 2017-5-6 15:35:16 | 显示全部楼层
要看一下硬件的晶振是不是一样,系统的时钟配置是不是一样?比如原来是8M时钟,现在是800K的时钟,那么同样的delay_ms(500);实际延时就会差10倍
回复

使用道具 举报

3

主题

12

帖子

0

精华

新手上路

积分
23
金钱
23
注册时间
2017-5-4
在线时间
6 小时
 楼主| 发表于 2017-5-6 17:58:59 | 显示全部楼层
未知1908 发表于 2017-5-6 15:35
要看一下硬件的晶振是不是一样,系统的时钟配置是不是一样?比如原来是8M时钟,现在是800K的时钟,那么同样 ...

高手,问下硬件的晶振在哪里配置?
回复

使用道具 举报

3

主题

12

帖子

0

精华

新手上路

积分
23
金钱
23
注册时间
2017-5-4
在线时间
6 小时
 楼主| 发表于 2017-5-6 19:54:20 | 显示全部楼层
试了下录像同文件夹的程序,下载后是0.5秒闪一次,把我的mian( )和led.c等文件代替这个文件夹里的文件,也没问题,找不到问题原因?
回复

使用道具 举报

天妒 该用户已被删除
发表于 2017-5-11 23:01:34 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
回复

使用道具 举报

0

主题

3

帖子

0

精华

新手入门

积分
19
金钱
19
注册时间
2018-9-26
在线时间
2 小时
发表于 2018-10-1 21:56:17 | 显示全部楼层
我也是这个问题,使用库函数版跑马灯延时正常,但是寄存器、位操作两个版本的跑马灯延时也扩大了好几倍。找了好久也没找到问题所在。
回复

使用道具 举报

34

主题

331

帖子

0

精华

高级会员

Rank: 4

积分
857
金钱
857
注册时间
2018-9-16
在线时间
240 小时
发表于 2018-10-2 19:55:59 | 显示全部楼层
你的延时函数呢,拿出来看下呗,一般用定时器做就很准了
回复

使用道具 举报

0

主题

6

帖子

0

精华

初级会员

Rank: 2

积分
132
金钱
132
注册时间
2019-6-9
在线时间
23 小时
发表于 2019-7-10 10:14:40 | 显示全部楼层
在主函数先初始化
Stm32_Clock_Init(9);函数
然后初始化
delay_init(72);
我之前也是延时不准就因为初始化顺序不对(我也不知道怎么的,改了顺序延时就正常了)

回复

使用道具 举报

0

主题

1

帖子

0

精华

新手入门

积分
17
金钱
17
注册时间
2019-11-6
在线时间
5 小时
发表于 2019-12-5 17:36:38 | 显示全部楼层
在初始化函数delay_init(168);之前 加上Stm32_Clock_Init(336,8,2,7); 这句函数即可解决
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-22 10:58

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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