历史上的今天

今天是:2024年08月22日(星期四)

正在发生

2018年08月22日 | STM32 内核复位 与 系统复位 区别及程序实现

发布者:等放假的Lwj 来源: eefocus关键字:STM32  内核复位  系统复位 手机看文章 扫描二维码
随时随地手机看文章

1 写在前面

某些系统允许复位,但对外设又有特殊要求:某一个IO状态不能因为复位而改变,某一个定时器计数器不能改变等。

例子:A系统通过一个IO控制B系统的电源,而这个IO置高时才开启B系统的电源。

正常工作过程中,B系统只有收到A系统关机命令任务才会进行关机(也就是说不能掉电关机),而A系统在工作过程中有复位的需求。

这个时候如果使用常规的复位方式,就会复位IO,不符合要求。如果有一种方式只复位内核而不复位外设就好了。

接下来就介绍两种复位的实现方式。

2 关于复位

说到复位,我们都不会陌生,系统基本都有一个复位按键。

复位的种类有很多:上电复位、掉电复位、复位引脚复位、看门狗复位、软件复位等。

上面说的复位按键,也就是对应复位引脚复位;而本文说的内核复位与系统复位是属于软件复位。

3 内核复位与系统复位的区别

本文说的内核是指处理器内核,也就是MPU(Microprocessor Unit)。比如STM32F103,其内核就是Cortex-M3内核。

而这里的系统就是包含内核和外设,也就是MCU(Microcontroller Unit),对于STM32F103来说,就是Cortex-M3内核+各种外设接口。

内核复位:只复位Cortex-M3处理器,而不复位外设如GPIO、TIM、USART、SPI等的寄存器

系统复位:即复位Cortex-M3处理器,又复位外设寄存器。

因此,我们常说的复位一般指的是系统复位。

4 内核复位与系统复位的函数源代码

本文以Cortex-M3(STM32F103)为例来说明,其他芯片类似。

编写了4个复位函数,内核复位(C语言)、内核复位(汇编)和系统复位(C语言)、系统复位(汇编):

void NVIC_CoreReset(void);  //内核复位(C语言)

void NVIC_CoreReset_a(void);  //内核复位(汇编)

void NVIC_SystemReset(void);  //系统复位(C语言)

void NVIC_SystemReset_a(void);  //系统复位(汇编)


在ST官方库中的core_cm3.h文件中已经提供了NVIC_SystemReset的C语言源代码。


Cortex-M3允许由软件触发复位序列,用于特殊的调试或维护。在Cortex-M3中,有两种方法可以实现自我复位。


第一种方法:置位 NVIC 中应用程序中断与复位控制寄存器(AIRCR)的 VECTRESET 位(位偏移:0)。


4.1 NVIC_CoreReset内核复位


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


编写的NVIC_CoreReset函数C语言源码:


static __INLINE 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,这是和系统复位唯一的区别。


第二种方法:置位 NVIC 中应用程序中断与复位控制寄存器(AIRCR)的 SYSRESETREQ位(位偏移:2)。


4.2 NVIC_SysReset系统复位


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


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


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


core_cm3.h中提供的NVIC_SystemReset函数C语言源码:


static __INLINE void NVIC_SystemReset(void)

{

  SCB->AIRCR  = ((0x5FA << SCB_AIRCR_VECTKEY_Pos)      | 

                 (SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) | 

                 SCB_AIRCR_SYSRESETREQ_Msk);            

  __DSB();     /* Ensure completion of memory access */ 

  while(1);     /* wait until reset */

}


汇编版函数:


__asm void NVIC_SysReset_a(void)

{

    LDR R0, =0xE000ED0C

    LDR R1, =0x05FA0004

    STR R1, [R0]

    deadloop_Sys

    B deadloop_Sys

}


【参考】 CM3(STM32)内核复位与系统复位区别及应用 —— https://blog.csdn.net/ybhuangfugui/article/details/73354918


关键字:STM32  内核复位  系统复位 引用地址:STM32 内核复位 与 系统复位 区别及程序实现

上一篇:STM32 ISP烧录过程
下一篇:STM32F10x的复位与时钟控制

推荐阅读

据科技日报报道,德国马普计算机科学研究所与澳大利亚弗林德斯大学合作,开发出了一种通过眼球运动判断人物性格的软件。研究人员借助人工智能(AI)可以基本确定被观察对象是否属于神经质、友好、外向、认真和好奇等性格特征。将计算机科学应用于学习和解释人类行为是一项新的热门课题,马普计算机科学研究所安德里亚斯·布林领导的研究小组开发出了这款采...
摩托罗拉在新机One Action中加入了不同于以往的功能,通过这些功能想把运动相机的活也给干了。据悉,One Action名字中的Action,取的便是跟运动相机Action Camera 相同的意思。摩托罗拉希望这款产品能在某些场景下为使用者带来更好的录影体验,为了实现这一点,他们在主流的12MP f/1.8光圈主摄像头和5MP景深相机外,又专门加入了一颗录影专用的16MP、...
近日获悉,哈崎机器人(HachiBot)宣布完成数千万美元Pre-A轮融资,由北极光创投领投、梅花天使创投等基金和个人跟投。其中,微软全球原执行副总裁沈向洋及酷我音乐创始人、北京大学人工智能创新中心主任雷鸣为投资人和顾问。谌振宇认为,机器人迈进千家万户的时代即将到来。“根据我的经验判断,这个时间点类似于1995年的互联网时代和2008年的移动Mobil...
近日,三星显示宣布正式推出 UPC(Under Panel Camera,屏下摄像头)技术。  IT之家了解到,该技术能将智能手机前置摄像头嵌入显示面板,从而消除摄像头小孔。三星首次将该技术应用于近期发布的 Galaxy Z Fold3 上的可折叠显示屏。  据介绍,三星显示的 UPC 技术,是通过提高面板透光率的“Eco² OLED”和优化像素孔径技术实现的。...

史海拾趣

问答坊 | AI 解惑

检修时候有了方向:监控系统常见问题解答

1. 编程是否正确,有无遗漏之处。    A. 使用分控键盘时,对监视器的分配和授权的编程是否正确。   B. 设置报警监控和录像时,有否正确连接报警设备。编程是否合理(相关设备的数据冲突)。   C. 连接外部受控设备。如快球、解码器、报警 ...…

查看全部问答∨

一个计算振荡电路的工具以及它的VB源代码

请大家把已有的东西改造成自己的工具 …

查看全部问答∨

如何能编好单片机的程序(9)

       ErrHandle:     FREE(fname);     FREE(lname);     FREE(mname);     ReportError(ERR_NO_MEMOEY);    } 也只有在这种情况下,goto语句会让你的程序更易读,更容易维护。(在用嵌C来对数据库设置游标操作时 ...…

查看全部问答∨

c#编程 在wince 如何自动拨号ADSL 和 GPRS

c#编程 在wince 如何自动拨号ADSL 和 GPRS…

查看全部问答∨

Wince6.0 R2 如何设置才能显示中文,我都显示下划线~

VS2005 + Wince 6.0 R2 编译的OS,显示不了中文, 中文都显示为下划线。 我将 GB18030 Data Converter 去掉重新编译还是下划线, 谢谢,帮忙给个建议~…

查看全部问答∨

用tornado主机和目标机联机超时

我的目标机已经用软盘正确引导,但是主机和目标机联机时总是显示超时,连接不上?应该怎么办啊?请问在连接时要注意什么问题啊?谢谢!…

查看全部问答∨

verilog程序问题

在verilog中能否和C语言一样设置全局变量之类的东西。如果可以的话,应该怎么设置。…

查看全部问答∨

signal express调用labview的VIs,求助

额,在做毕业设计,学习labview……一穷二白。 然后老师非要我用signal express调用labview 的VIs,希望以此强化signal express的功能。 就是加一些自己做的VI模块,然后供signal express调用。 按照signal express的说明书(英文的,吐血)自 ...…

查看全部问答∨

中断

感觉它好模糊。。。中断的是哪几个引脚控制?…

查看全部问答∨

多个zigbee网络中,新设备选网问题

大家好:请教一个Zigbee的问题,假设两个zigbee网络特别近,我新买一个zigbee设备来加入自己的网。问题是:我这个zigbee设备怎么知道往哪加呢? (用的Zstack协议)…

查看全部问答∨
小广播
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

更多每日新闻

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved