APM32F103 RTC内部时钟源秒中断例程测试
- ✨相关篇推荐《【开源电路】STM32F103VCT6开发板》
- 📌本案例来源于官方的SDK固件包:
https://www.geehy.com/support/apm32
源码位置:
APM32F10x_SDK_V1.8\Examples\RTC\RTC_Second
📢案例说明
该案例默认是配置的PE6引脚状态翻转,也就是随RTC秒中断,接在PE6上的LED闪烁一次。
- 该代码同样可以烧录到同类型的STM32F103VC芯片上也可以运行,采用上面自制的开发板在不做任何修改直接烧录,可以看到效果。自制的开发板上的3个led分别是:PE5、PE6、PB5,该工程代码默认定义的2个LED分别是PE5、PE6.
🛠RTC配置
void RTC_Config(void)
{
RCM_EnableAPB1PeriphClock((RCM_APB1_PERIPH_T)RCM_APB1_PERIPH_PMU);
PMU_EnableBackupAccess();
RCM_EnableLSI();
while(RCM_ReadStatusFlag(RCM_FLAG_LSIRDY) == RESET);
RCM_ConfigRTCCLK(RCM_RTCCLK_LSI);
RCM_EnableRTCCLK();
RTC_WaitForSynchro();
RTC_WaitForLastTask();
RTC_EnableInterrupt(RTC_INT_SEC);//使能RTC秒更新中断
RTC_WaitForLastTask();
RTC_ConfigPrescaler(32767);
RTC_WaitForLastTask();
NVIC_EnableIRQRequest(RTC_IRQn, 0, 0);
}
⛳RTC中断回调函数
该回调函数位置:
APM32F10x_SDK_V1.8\Examples\RTC\RTC_Second\Source\apm32f10x_int.c
void RTC_IRQHandler(void)
{
if (RTC_ReadIntFlag(RTC_INT_SEC) != RESET)
{
RTC_ClearIntFlag(RTC_INT_SEC);
APM_MINI_LEDToggle(LED2);
RTC_WaitForLastTask();
}
}
- 📋main函数
int main(void)
{
APM_MINI_LEDInit(LED3);
RTC_Config();
while(1)
{
}
}
📑配置RTC外部时钟源
- 📝RTC配置函数如下:
void RTC_Config(void)
{
RCM_EnableAPB1PeriphClock((RCM_APB1_PERIPH_T)RCM_APB1_PERIPH_PMU);
PMU_EnableBackupAccess();
// RCM_EnableLSI();
// while(RCM_ReadStatusFlag(RCM_FLAG_LSIRDY) == RESET);
// RCM_ConfigRTCCLK(RCM_RTCCLK_LSI);
// RCM_DisableLSI();
RCM_ConfigLSE(RCM_LSE_OPEN);
while(RCM_ReadStatusFlag(RCM_FLAG_LSERDY) == RESET);
RCM_ConfigRTCCLK(RCM_RTCCLK_LSE);//使能外部低速时钟
RCM_EnableRTCCLK();
RTC_WaitForSynchro();
RTC_WaitForLastTask();
RTC_EnableInterrupt(RTC_INT_SEC);//使能RTC秒更新中断
RTC_WaitForLastTask();
RTC_ConfigPrescaler(32767);
RTC_WaitForLastTask();
NVIC_EnableIRQRequest(RTC_IRQn, 0, 0);
}
- ⚡以上配置,不仅可以在APM32F103VC上运行,还可以直接烧录到STM32F103VC上,也可以运行。
在使用外部晶振作为RTC时钟源时不运行情况分析
- 检查外部晶振是否正常,
APM32F103VC
芯片晶振启动有时很困难。 - 当晶振起振慢时,用手摸一下或用电吹风吹一下,晶振又恢复正常了。
原因是当电路板受热时,杂散电容发生变化,正好给晶振提供了一个瞬间的与之匹配的工作条件。
- 解决方案:
- 减少杂散电容对晶振的干涉,对晶振做好屏蔽。
- 尝试适当减小晶振的外接电容。