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

出现的问题:* 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注释掉后就问题解决。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

你可能感兴趣的:(stm32)