* JLink Info: Reset: Halt core after reset via DEMCR.VC_CORERESET.

在使用STM32F407开发时,遇到程序下载后不运行的故障,主要表现为JLink报错。问题源于正点原子的RTC代码,特别是RTC_Alarm_IRQHandler中断服务函数内的printf语句。即使RTC闹钟中断未启用,该语句也会导致程序无法正常启动。注释掉printf后,程序能正常运行。此问题表明RTC中断服务函数可能在不需要时被调用,影响了程序流程。
摘要由CSDN通过智能技术生成

出现的问题:* JLink Info: Reset: Halt core after reset via DEMCR.VC_CORERESET.* JLink Info: Reset: Reset device via AIRCR.SYSRESETREQ.

环境:STM32F407

在进行RTC部分程序编写的时候使用了正点原子的部分程序。

出现的问题:

程序下载后不运行,在仿真的时候显示

* JLink Info: Reset: Halt core after reset via DEMCR.VC_CORERESET.*

JLink Info: Reset: Reset device via AIRCR.SYSRESETREQ.

点击一次运行也不能运行,连续点击了三次之后程序成功运行,退出仿真后程序也可以继续运行。

但是只要重新下载程序后就可以运行了。

 

解决过程:

将复制过来的正点原子RTC部分的程序全部注释掉后程序成功运行,说明是这部分程序的问题。然后一点点去掉注释。

最终将问题定位到printf这条语句上。

在将这条语句注释点之后问题解决。

//RTC闹钟中断服务函数
void RTC_Alarm_IRQHandler(void)
{    
	if(RTC_GetFlagStatus(RTC_FLAG_ALRAF)==SET)//ALARM A中断?
	{
		RTC_ClearFlag(RTC_FLAG_ALRAF);//清除中断标志
		printf("ALARM A!\r\n");
	}   
	EXTI_ClearITPendingBit(EXTI_Line17);	//清除中断线17的中断标志 											 
}

但是我程序中没有打开这个RTC闹钟中断,而且仿真运行的时候程序也无法运行到这里。

我也试过将led初始化放到程序的最开始,并紧接着while(1)led=0;//打开LED

让STM32只点亮一个LED,但是这个LED也没有亮。当把RTC.c中的printf注释掉后就问题解决。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

  • 10
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值