0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

STM32复位来源 以及系统和内核复位区别

黄工的嵌入式技术圈 来源:黄工的嵌入式技术圈 作者:黄工的嵌入式技术 2020-02-28 17:13 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

最近有朋友问了些关于STM32复位的问题,今天结合前面文章再次总结一下复位相关知识。

1STM32的复位和时钟控制

RCC:Reset and Clock Control

每一块STM32中都有这么一个RCC复位和时钟控制模块。

STM32的复位为三类:系统复位、电源复位和后备域复位。

系统复位:

1. NRST引脚上的低电平(外部复位)

2. 窗口看门狗计数终止(WWDG复位)

3. 独立看门狗计数终止(IWDG复位)

4. 软件复位(SW复位)

5. 低功耗管理复位

电源复位:

1. 上电/掉电复位(POR/PDR复位)

2. 从待机模式中返回

备份区域复位:

1. 软件复位,备份区域复位可由设置备份域控制寄存器(RCC_BDCR)中的BDRST位产生。

2. 在VDD和VBAT两者掉电的前提下, VDD或VBAT上电将引发备份区域复位。

2STM32的复位来源

在很多应用中,都会判断是什么引起的复位。

比如:判断为看门狗引起的复位,我们进行xxx操作。软件引起的复位,我们又执行xxx操作。

在STM32RCC模块中,有这么一个寄存器:控制/状态寄存器 (RCC_CSR):

这个寄存器就会记录各种复位的状态,我们直接读取这个寄存器(库函数有读寄存器接口)就能知道是什么引起的复位。

3STM32的复位来源例程

之前我提供了一个简单Demo,STM32F103ZE(Keil)_复位来源(寄存器版):

http://pan.baidu.com/s/1hskScba

4STM32系统和内核复位

内核复位:它会使STM32内核(Cortex-M)进行复位,而不会影响其外设,如GPIO、TIM、USART、SPI等这些寄存器的复位。

系统复位:这个复位会使整个芯片的所有电路都进行复位,系统默认的函数接口NVIC_SystemReset就是系统复位(位于core_cm*.h)。

1.NVIC_CoreReset内核复位

CM3 允许由软件触发复位序列,用于特殊的调试或维护目的。在CM3中,有两种方法可以执行自我复位。第一种方法,是通过置位 NVIC 中应用程序中断与复位控制寄存器(AIRCR)的VECTRESET 位(位偏移:0)。

这种复位的作用范围覆盖了整个CM3处理器中,除了调试逻辑之外的所有角落,但是它不会影响到 CM3 处理器外部的任何电路,所以单片机上的各片上外设和其它电路都不受影响。

C语言版函数:

void NVIC_CoreReset(void){__DSB(); //置位VECTRESET SCB->AIRCR = ((0x5FA << SCB_AIRCR_VECTKEY_Pos) | (SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) |SCB_AIRCR_VECTRESET_Msk); __DSB(); while(1);}

汇编版函数:

__asm void NVIC_CoreReset_a(void){ LDR R0, =0xE000ED0C LDR R1, =0x05FA0001 //置位VECTRESET STR R1, [R0] deadloop_Core B deadloop_Core}

内核主要注意:

SCB_AIRCR_VECTRESET_Msk

LDR R1, =0x05FA0001

它是和系统复位唯一的区别。

2.NVIC_SysReset系统复位

系统复位是置位同一个寄存器中的 SYSRESETREQ 位。这种复位则会波及整个芯片上的电路:它会使 CM3 处理器把送往系统复位发生器的请求线置为有效。但是系统复位发生器不是CM3的一部分,而是由芯片厂商实现,因此不同的芯片对此复位的响应也不同。因此,读者需要认真参阅该芯片规格书,明白当发生片内复位时,各外设和功能模块都会回到什么样的初始状态,或者有哪些功能模块不受影响(比如, STM32系列的芯片有后备存储区,该区就被特殊对待)。

大多数情况下,复位发生器在响应 SYSRESETREQ 时,它也会同时把 CM3 处理器的系统复位信号(SYSRESETn)置为有效。通常, SYSRESETREQ 不应复位调试逻辑。

这里有一个要注意的问题:从 SYSRESETREQ 被置为有效,到复位发生器执行复位命令,往往会有一个延时。在此延时期间,处理器仍然可以响应中断请求。但我们的本意往往是要让此次执行到此为止,不要再做任何其它事情了。所以,最好在发出复位请求前,先把FAULTMASK置位。因此,我在提供源代码中有这么一句:__set_FAULTMASK(1);,也就是置位FAULTMASK。


C语言版函数:

voidNVIC_SysReset(void){ __DSB(); SCB->AIRCR = ((0x5FA << SCB_AIRCR_VECTKEY_Pos) | (SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) | SCB_AIRCR_SYSRESETREQ_Msk); __DSB(); while(1);}

汇编版函数:

__asm void NVIC_SysReset_a(void){ LDR R0, =0xE000ED0C LDR R1, =0x05FA0004 STR R1, [R0] deadloop_Sys B deadloop_Sys}

内核复位与系统源代码和相近,差异在于SYSRESETREQ和SYSRESETREQ这两位。

关于复位的知识,在实际项目中应用的比较多。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • STM32
    +关注

    关注

    2312

    文章

    11189

    浏览量

    374515
  • 引脚
    +关注

    关注

    16

    文章

    2119

    浏览量

    55999
  • 电复位
    +关注

    关注

    0

    文章

    5

    浏览量

    6191
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    JL杰理AC696N开发板开发蓝牙音频方案之电源管理进阶:内核电压调节与长按复位

    前面聊了复位源查询和IO唤醒配置,这些都是低功耗的基础。但在实际产品中,电源管理还有几个坑值得单独拎出来说。内核电压什么时候该提、SD卡供电脚怎么控制、长按复位怎么配才能不误触发——这些配置看着
    的头像 发表于 03-28 00:18 269次阅读
    JL杰理AC696N开发板开发蓝牙音频方案之电源管理进阶:<b class='flag-5'>内核</b>电压调节与长按<b class='flag-5'>复位</b>

    SGM823:集成复位、看门狗和手动复位功能的微处理器监控电路

    SGM823:集成复位、看门狗和手动复位功能的微处理器监控电路 在电子设计领域,微处理器的稳定运行至关重要。SGM823作为一款功能强大的微处理器监控电路,为系统的可靠性提供了有力保障。今天,我们
    的头像 发表于 03-23 17:20 613次阅读

    SGM802:低功耗微处理器复位电路的理想之选

    SGM802:低功耗微处理器复位电路的理想之选 在电子设备的设计中,微处理器复位电路起着至关重要的作用,它能确保系统在各种情况下都能稳定、可靠地运行。今天,我们就来详细了解一下SGMICRO公司推出
    的头像 发表于 03-23 16:45 760次阅读

    深度解析DS1830/A复位序列器:特性、操作与应用

    深度解析DS1830/A复位序列器:特性、操作与应用 在电子系统设计中,复位序列器是确保系统稳定启动和可靠运行的关键组件。今天我们就来深入探讨DALLAS SEMICONDUCTOR(
    的头像 发表于 02-28 15:10 271次阅读

    MAX6443–MAX6452:具备长手动复位设置周期的微处理器复位电路

    MAX6443–MAX6452:具备长手动复位设置周期的微处理器复位电路 在电子设备的设计中,微处理器复位电路起着至关重要的作用,它能确保设备在各种情况下稳定运行。今天我们就来详细了解一下
    的头像 发表于 02-27 14:45 306次阅读

    如何用软件实现系统复位

    看门狗的工作过程是怎样的? 如何用软件实现系统复位
    发表于 01-08 06:15

    CW32在不同复位方式对应的复位范围

    上电复位 / 掉电复位(POR/BOR) 整个 MCU 引脚输入复位(NRST) 整个 MCU(除 RTC 外) IWDT/WWDT 复位 M0+
    发表于 12-22 09:44

    什么是内核LOCKUP故障复位

    当 CPU 遇到严重异常(如读取到的指令无效、访问 FLASH 时位宽和目标地址不匹配),会将 PC 指针停在当前地址处锁定,并产生内核 LOCKUP 故障复位信号。 芯片上电后,LOCKUP 复位
    发表于 12-15 08:33

    CW32F030支持的6种系统复位方式分享

    CW32F030 支持的6种系统复位方式: •上电复位 / 掉电复位(POR/BOR) •引脚输入复位(NRST) •IWDT/WWDT
    发表于 12-15 06:31

    内核LOCKUP故障复位方法

    当 CPU 遇到严重异常(如读取到的指令无效、访问 FLASH 时位宽和目标地址不匹配),会将 PC 指针停在当前地址处锁定,并产生内核 LOCKUP 故障复位信号。芯片上电后,LOCKUP 复位
    发表于 12-11 07:15

    用于稳定电源设计的复位IC应用实例

    现代电子设备正面临电压波动、浪涌电压以及输入电源不稳定等问题。如果缺乏适当的电压监测与复位保护功能,系统可能会出现误动作、异常复位,甚至导致硬件损坏。
    的头像 发表于 12-08 09:41 732次阅读
    用于稳定电源设计的<b class='flag-5'>复位</b>IC应用实例

    揭秘RESET复位键:引脚设计如何支撑硬件系统的重启通路

    RESET复位键在电子设备中承担着重启通路的核心角色,当系统因软件故障、硬件冲突或电源波动陷入异常时,它能通过硬件层面的强制复位,使设备快速脱离故障状态。这一功能的实现基于引脚功能与硬件设计的深度
    的头像 发表于 11-28 15:18 458次阅读
    揭秘RESET<b class='flag-5'>复位</b>键:引脚设计如何支撑硬件<b class='flag-5'>系统</b>的重启通路

    GraniStudio:轴复位例程

    功能说明 实现单轴复位、两轴同时复位以及两轴顺序复位功能。 2.1通过初始化运控板卡算子连接格拉尼总线型运控卡,导入工程自动进行连接,此算子为使用运控控制板卡的第一项操作,后续运控算子
    的头像 发表于 08-22 16:05 775次阅读
    GraniStudio:轴<b class='flag-5'>复位</b>例程

    GraniStudio零代码平台轴复位算子支持多少个轴同时复位,有哪些回零模式?

    GraniStudio平台在轴复位的功能上未对同时复位的轴数进行硬性限制,理论上支持任意数量轴同步复位,需要考虑的是在做多轴同步复位时要评估机械安全风险,建议提前确认机械在多轴同时
    的头像 发表于 07-07 18:02 774次阅读
    GraniStudio零代码平台轴<b class='flag-5'>复位</b>算子支持多少个轴同时<b class='flag-5'>复位</b>,有哪些回零模式?

    复位电路的核心功能和主要类型

    复位电路(Reset Circuit) 是数字系统中的关键功能模块,用于确保设备在上电、电压波动或异常状态下可靠复位至初始状态。其设计直接影响系统的稳定性和抗干扰能力。
    的头像 发表于 06-30 14:24 1850次阅读
    <b class='flag-5'>复位</b>电路的核心功能和主要类型