OpenEdv-开源电子网

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

RTC_init()卡在检查外部晶振上,但是外部晶振有起振

[复制链接]

4

主题

52

帖子

0

精华

初级会员

Rank: 2

积分
195
金钱
195
注册时间
2017-4-24
在线时间
44 小时
发表于 2019-5-30 10:52:40 | 显示全部楼层 |阅读模式
10金钱
题主在调试stm32程序时,用到了原子哥的RTC_init()函数进行休眠模式的闹钟唤醒,在用过了网上的小系统板成功后,自己做了板子,但是外部晶振好像除了问题:
出问题的板子芯片图像和晶振图像:

F103芯片

F103芯片
                        

晶振

晶振


但是我用网上买的小系统板是OK的,下面是小系统板的图像:

单片机小系统板

单片机小系统板


两个板子的区别是程序卡在RTC_init(),里面的检查外部晶振这一步:
卡在下面红色的区域,即一直在检查外部晶振最后到了250次然后退出,然后程序卡在这动不了,但是网上的小系统板没这个问题,所以我怀疑是不是芯片和晶振的型号对这个还有影响,求有经验的大神支招
u8 RTC_Init(void)
{
        //检查是不是第一次配置时钟
        u8 temp=0;
        if(BKP->DR1!=0X5050)//第一次配置
        {         
          RCC->APB1ENR|=1<<28;     //使能电源时钟            
                RCC->APB1ENR|=1<<27;     //使能备份时钟            
                PWR->CR|=1<<8;           //取消备份区写保护
                RCC->BDCR|=1<<16;        //备份区域软复位          
                RCC->BDCR&=~(1<<16);     //备份区域软复位结束                   
            RCC->BDCR|=1<<0;         //开启外部低速振荡器
------------------------------------------------------------------------------------------------------------------------------------
            while((!(RCC->BDCR&0X02))&&temp<250)//等待外部时钟就绪         
                {
                        temp++;                                                                           
                        delay_ms(100);
                };
                if(temp>=250)return 1;//初始化时钟失败,晶振有问题            
-----------------------------------------------------------------------------------------------------------------------------------
                RCC->BDCR|=1<<8; //LSI作为RTC时钟             
                RCC->BDCR|=1<<15;//RTC时钟使能          
                  while(!(RTC->CRL&(1<<5)));//等待RTC寄存器操作完成         
            while(!(RTC->CRL&(1<<3)));//等待RTC寄存器同步  
            RTC->CRH|=0X01;                    //允许秒中断
                  RTC->CRH|=1<<1;   //允许闹钟中断
            while(!(RTC->CRL&(1<<5)));//等待RTC寄存器操作完成         
                RTC->CRL|=1<<4;              //允许配置         
                 
                RTC->PRLH=0X0000;
                RTC->PRLL=32767;          //时钟周期设置(有待观察,看是否跑慢了?)理论值:32767                                                                                 
                                                                                            
                RTC_Set(2012,9,7,13,16,55);  //设置时间          
                RTC->CRL&=~(1<<4);           //配置更新
                while(!(RTC->CRL&(1<<5)));   //等待RTC寄存器操作完成                                                                                           
                BKP->DR1=0X5050;  
        //         printf("FIRST TIME\n");
        }else//系统继续计时
        {
            while(!(RTC->CRL&(1<<3)));//等待RTC寄存器同步  
            RTC->CRH|=0X01;                    //允许秒中断
                        RTC->CRH|=1<<1;   //允许闹钟中断
            while(!(RTC->CRL&(1<<5)));//等待RTC寄存器操作完成
        //        printf("OK\n");
        }                                                      
        MY_NVIC_Init(0,0,RTC_IRQn,2);//优先级设置   
        RTC_Get();//更新时间
        return 0; //ok
}                                                     


用示波器是可以检测到晶振是起振了,下面是测得的8M的波形图:
微信图片_20190530105354.jpg 微信图片_20190530105409.jpg

求问大神有没有遇见类似的问题,求解答

最佳答案

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

RTC 晶振是32.768K的吧 你不会没做rtc晶振吧
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

51

主题

2166

帖子

2

精华

论坛元老

Rank: 8Rank: 8

积分
10653
金钱
10653
注册时间
2017-4-14
在线时间
2780 小时
发表于 2019-5-30 10:52:41 | 显示全部楼层
本帖最后由 nashui_sx 于 2019-5-30 11:42 编辑
叮叮蛋炒饭 发表于 2019-5-30 11:33
晶振是8M的,现在的电阻是1M的,请问这个电阻匹配是有影响的吗?
能够工作的,淘宝买的开发板的晶振也是 ...

RTC 晶振是32.768K的吧  你不会没做rtc晶振吧 IMG_20190530_113848.jpg
回复

使用道具 举报

4

主题

52

帖子

0

精华

初级会员

Rank: 2

积分
195
金钱
195
注册时间
2017-4-24
在线时间
44 小时
 楼主| 发表于 2019-5-30 10:56:11 | 显示全部楼层
补上程序卡住的地方
                就是外部晶振那检查不通过,一直返回1
                while(RTC_Init())                //RTC初始化        ,一定要初始化成功
        {
                delay_ms(800);
        }                 

回复

使用道具 举报

51

主题

2166

帖子

2

精华

论坛元老

Rank: 8Rank: 8

积分
10653
金钱
10653
注册时间
2017-4-14
在线时间
2780 小时
发表于 2019-5-30 11:18:51 | 显示全部楼层
在32.768K的晶振引脚上并个上1M(>1m也可以)的电阻试试
回复

使用道具 举报

4

主题

52

帖子

0

精华

初级会员

Rank: 2

积分
195
金钱
195
注册时间
2017-4-24
在线时间
44 小时
 楼主| 发表于 2019-5-30 11:33:30 | 显示全部楼层
nashui_sx 发表于 2019-5-30 11:18
在32.768K的晶振引脚上并个上1M(>1m也可以)的电阻试试

晶振是8M的,现在的电阻是1M的,请问这个电阻匹配是有影响的吗?
能够工作的,淘宝买的开发板的晶振也是8M,并联的电阻是10M,请问这个影响大吗?
回复

使用道具 举报

4

主题

52

帖子

0

精华

初级会员

Rank: 2

积分
195
金钱
195
注册时间
2017-4-24
在线时间
44 小时
 楼主| 发表于 2019-5-30 11:33:51 | 显示全部楼层
nashui_sx 发表于 2019-5-30 11:18
在32.768K的晶振引脚上并个上1M(>1m也可以)的电阻试试

晶振是8M的,现在的电阻是1M的,请问这个电阻匹配是有影响的吗?
能够工作的,淘宝买的开发板的晶振也是8M,并联的电阻是10M,请问这个影响大吗?
回复

使用道具 举报

3

主题

1907

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4106
金钱
4106
注册时间
2018-8-14
在线时间
696 小时
发表于 2019-5-30 11:51:08 | 显示全部楼层
本帖最后由 edmund1234 于 2019-5-30 12:56 编辑

程序是卡在32.768K的点上, 你用示波器量的是8MHz的晶振, 牛头不对马嘴
也没看到你板上有32.768K的晶振, 如果说你没用到RTC, 那就把它从程序中删了吧
回复

使用道具 举报

4

主题

52

帖子

0

精华

初级会员

Rank: 2

积分
195
金钱
195
注册时间
2017-4-24
在线时间
44 小时
 楼主| 发表于 2019-5-30 14:08:11 | 显示全部楼层
nashui_sx 发表于 2019-5-30 11:36
RTC 晶振是32.768K的吧  你不会没做rtc晶振吧

RTC晶振只能是32.768的吗?好像真的没做,可不可以用这个8M的晶振来代替呢
回复

使用道具 举报

2

主题

12

帖子

0

精华

初级会员

Rank: 2

积分
96
金钱
96
注册时间
2018-7-19
在线时间
29 小时
发表于 2019-5-30 14:15:11 | 显示全部楼层
首先,STM32芯片你不接外部8M,内部也有8M可以工作,但是你32,768K晶体没接,RTC没参考时钟肯定会出问题
回复

使用道具 举报

2

主题

12

帖子

0

精华

初级会员

Rank: 2

积分
96
金钱
96
注册时间
2018-7-19
在线时间
29 小时
发表于 2019-5-30 14:16:03 | 显示全部楼层
必须要接32K的晶体
回复

使用道具 举报

51

主题

2166

帖子

2

精华

论坛元老

Rank: 8Rank: 8

积分
10653
金钱
10653
注册时间
2017-4-14
在线时间
2780 小时
发表于 2019-5-30 14:17:42 | 显示全部楼层
叮叮蛋炒饭 发表于 2019-5-30 14:08
RTC晶振只能是32.768的吗?好像真的没做,可不可以用这个8M的晶振来代替呢

不可以,找个贴片的板子上找个空地附铜挖开外接一个吧
找个那种表上用的圆柱的应该更方便点
回复

使用道具 举报

3

主题

1907

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4106
金钱
4106
注册时间
2018-8-14
在线时间
696 小时
发表于 2019-5-30 14:27:03 | 显示全部楼层
32.768可以不接,不用RTC就不用接啊, 但你不可以既不接32.768, 又去打开LSE
回复

使用道具 举报

4

主题

52

帖子

0

精华

初级会员

Rank: 2

积分
195
金钱
195
注册时间
2017-4-24
在线时间
44 小时
 楼主| 发表于 2019-5-30 14:29:06 | 显示全部楼层
edmund1234 发表于 2019-5-30 14:27
32.768可以不接,不用RTC就不用接啊, 但你不可以既不接32.768, 又去打开LSE

好的,理解了,还是硬件知识太单薄了
回复

使用道具 举报

2

主题

12

帖子

0

精华

初级会员

Rank: 2

积分
96
金钱
96
注册时间
2018-7-19
在线时间
29 小时
发表于 2019-5-30 14:35:15 | 显示全部楼层
可以用内部LSI  ,你这板子没LSE位置算是设计失误呀
回复

使用道具 举报

29

主题

136

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1298
金钱
1298
注册时间
2013-1-11
在线时间
448 小时
发表于 2019-5-30 15:17:21 | 显示全部楼层
本帖最后由 aozhouduwang 于 2019-5-30 15:18 编辑

RTC可以用HSE、LSE、LSI,改改程序,不用动硬件。
看你这应该是NB BC95吧,如果批量打板了就该程序吧
回复

使用道具 举报

4

主题

52

帖子

0

精华

初级会员

Rank: 2

积分
195
金钱
195
注册时间
2017-4-24
在线时间
44 小时
 楼主| 发表于 2019-6-5 18:04:27 | 显示全部楼层
cmcc11 发表于 2019-5-30 14:35
可以用内部LSI  ,你这板子没LSE位置算是设计失误呀

失误了
回复

使用道具 举报

4

主题

52

帖子

0

精华

初级会员

Rank: 2

积分
195
金钱
195
注册时间
2017-4-24
在线时间
44 小时
 楼主| 发表于 2019-6-5 18:06:25 | 显示全部楼层
aozhouduwang 发表于 2019-5-30 15:17
RTC可以用HSE、LSE、LSI,改改程序,不用动硬件。
看你这应该是NB BC95吧,如果批量打板了就该程序吧

是的额,还好只是样板,要用到低功耗模式,所以不能用HSE,待机模式会关闭时钟,然后用内部的LSI做RTC时钟好像功耗不小,还有一些问题,还是重新弄板子了,谢谢
回复

使用道具 举报

4

主题

52

帖子

0

精华

初级会员

Rank: 2

积分
195
金钱
195
注册时间
2017-4-24
在线时间
44 小时
 楼主| 发表于 2019-6-5 18:08:06 | 显示全部楼层
cmcc11 发表于 2019-5-30 14:35
可以用内部LSI  ,你这板子没LSE位置算是设计失误呀

内部LSI程序我可以通过,但是功耗好像不小,WFI模式好像根本进不去,睡眠不了的感觉,电池一周就没电了,要用到低功耗模式,所以还是用LSE算了,这个教训有点大啊
回复

使用道具 举报

4

主题

52

帖子

0

精华

初级会员

Rank: 2

积分
195
金钱
195
注册时间
2017-4-24
在线时间
44 小时
 楼主| 发表于 2019-6-5 18:08:44 | 显示全部楼层
edmund1234 发表于 2019-5-30 11:51
程序是卡在32.768K的点上, 你用示波器量的是8MHz的晶振, 牛头不对马嘴
也没看到你板上有32.768K的晶振, ...

是的,我搞错了
回复

使用道具 举报

29

主题

162

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1243
金钱
1243
注册时间
2018-4-25
在线时间
185 小时
发表于 2019-6-10 10:51:29 | 显示全部楼层
叮叮蛋炒饭 发表于 2019-5-30 14:08
RTC晶振只能是32.768的吗?好像真的没做,可不可以用这个8M的晶振来代替呢

可以试下外部8M_128分频    掉电数据会清零,可以上电与上位机同步时间
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-17 03:55

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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