STM32软件复位(基于库文件V3.5)

本文详细解析了STM32软件复位过程,包括使用库文件V3.5提供的函数进行系统复位的方法,并强调了在发出复位请求前设置FAULTMASK的重要性。文章还介绍了在程序跳转前初始化堆栈指针的操作,确保复位操作的正确性和可靠性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

STM32软件复位(基于库文件V3.5)
 
void SoftReset(void)
{
__set_FAULTMASK(1);      // 关闭所有中端
NVIC_SystemReset();// 复位
}


  在官方软件库的 core_cm3.h 文件里 直接提供了 系统复位的函数 
  
static __INLINE void NVIC_SystemReset(void)
{
  SCB->AIRCR  = ((0x5FA << SCB_AIRCR_VECTKEY_Pos)      | 
                           (SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) | 
                           SCB_AIRCR_SYSRESETREQ_Msk);                   /* Keep priority group unchanged */
  __DSB();                                                                                       /* Ensure completion of memory access */              
  while(1);                                                                                        /* wait until reset */
}
  
但是不是直接调用这个函数就OK了? 
  
在Cortex-M3权威指南中有这么一句话 
  
这里有一个要注意的问题:从SYSRESETREQ 被置为有效,到复位发生器执行复位命令, 
往往会有一个延时。在此延时期间,处理器仍然可以响应中断请求。但我们的本意往往是要 
让此次执行到此为止,不要再做任何其它事情了。所以,最好在发出复位请求前,先把 
FAULTMASK 置位。 


所以最好在将FAULTMASK 置位才万无一失。 
  
同样官方 core_cm3.h 文件里也直接提供了该函数 
  
static __INLINE void __set_FAULTMASK(uint32_t faultMask)
{
  register uint32_t __regFaultMask       __ASM("faultmask");
  __regFaultMask = (faultMask & 1);
}


  ==========================================================================================================
如果要保持好之前配置好的寄存器不变的话,那么你在程序跳转之前要先初始化堆栈。
应该这样:
__set_MSP(*(__IO uint32_t*)  0x08000000);    要先初始化堆栈指针
((void (*) (void)) (*(vu32 *)0x08000004) ();                    这句才是程序跳转,注意了,是(*(vu32 *)0x08000004

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值