datasheet

STM32软件复位的实现方法

2019-06-13来源: eefocus关键字:STM32  软件复位  实现方法

前些天写程序的时候,需要做一个自动复位的功能,也就是当收到外部通讯设备复位指令时,主设备立刻执行复位操作。当时是想到的用看门狗实现。但是觉得似乎不太妥当,因为看门狗的复位是需要一定的时间。而在这段时间内系统还是处于正常运行当中,而且所有中断都会正常响应。这恰好与要实现的功能南辕北辙。需求是当收到复位指令时,系统停止执行后面的所有操作,包含中断响应。所以看门狗无法实现。 


我用的是STM32F103芯片,了解这颗芯片能用来复位的只有5种,外部复位、独立/窗口看门狗、软件复位功耗管理。看来我能用的也就只有软件复位了。但是我查了所有STM32F103芯片相关的资料,还是没有找到具体的实现方法,最多是提到过这种复位寄存器SYSRESETRQ位。不过功夫不负有心人,我还是找到了线索,STM32F103芯片手册中提到这种复位属于内核部分,于是我翻看了cortex-m3内核相关书藉才找到,在此分享一下,表达一个喜悦之情。 


共有两种实现方法,具体方法实现如下: CM3允许由软件触发复位序列。 


第一种方法,是通过置位NVIC中应用程序中断与复位控制寄存器(AIRCR)的VECTRESET位(位偏移:0),如下所示: 

LDR R0, =0XE000ED0C  ;NVIC AIRCR address 

LDR R1, =0X05FA0001  ;置位VECTRESET位,前面的0X5FA是访问钥匙、 STR R1, [R0]     ;触发复位序列 deadloop 

B    deadloop   ;该死循环保证后面的指令不可能被执行到 

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


复位的第二种方法,置位同一个寄存器中的SYSRESETREQ位,这种复位则是会波及整个芯片上的电路:它会使CM3微控制器把送往系统复位发生器的请求线置为有效。但是,系统复位发生器不是CM3的一部分,而是芯片厂商实现的,因此,不同的芯片对此复位的响应也不同。因此读者需要认真 参阅该芯片的规格书,明白发生片内复位时,各外设和功能模块都会回到什么状态,或者有哪些功能模块受到影响(比如,STM32系列有后备存储区,该区就被特殊对待)。SYSRESETRQ的使用代码如下面代码段演示: LDR R0, =0XE000ED0C NVIC AIRCR address 

LDR R1, =0X05FA0004 置位SYSRESETRQ,前面的0X05FA是访问钥匙 STR R1, [R0]     ;触发复位序列 deadloop 

B    deadloop  ;该死循环保证后面的指令不会被执行到   

这里要注意一个问题:从SYSRESETRQ被置为有效,到复位发生器执行复位命令,往往会有一个延时。在些延时期间内,处理器仍然可以响应中断请求。但我们的本意往往是要让此次执行到此为止,不要再执行任何操作。所以,最好在发出复位请求前,先把FAULTMASK置位。 


这两种方法都是对CM3内核寄存器直接操作的,调试的时候可以试试看,不过正常情况下,没事不要瞎玩儿啊!


关键字:STM32  软件复位  实现方法

编辑:什么鱼 引用地址:http://www.eeworld.com.cn/mcu/ic464496.html
本网站转载的所有的文章、图片、音频视频文件等资料的版权归版权所有人所有,本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如果本网所选内容的文章作者及编辑认为其作品不宜公开自由传播,或不应无偿使用,请及时通过电子邮件或电话通知我们,以迅速采取适当措施,避免给双方造成不必要的经济损失。

上一篇:STM32如何使用内部时钟源当系统时钟
下一篇:STM32F4系统时钟设置之二

关注eeworld公众号 快捷获取更多信息
关注eeworld公众号
快捷获取更多信息
关注eeworld服务号 享受更多官方福利
关注eeworld服务号
享受更多官方福利

推荐阅读

STM32 FSMC 外部使用SRAM

数据,以及与硬盘等外部存储器交换的数据。只要计算机在运行中,CPU就会把需要运算的数据调到内存中进行运算,当运算完成后CPU再将结果传送出来,内存的运行也决定了计算机的稳定运行。SRAM怎么用:使用STM32的FSMC功能,将SRAM映射为单片机的的内部地址,进行指针操作。图中 A0~A18为地址线(即 2^19=512K,1K=1024); IO0~15 为数据线,总共 16根数据线, CS2 和 CS1 都是片选信号,不过 CS2 是高电平有效CS1 是低电平有效; OE 是输出使能信号( 读信号); WE 为写使能信号; UB 和LB 分别为高字节控制和低字节控制信号。 (1)FSMC-外部SRAM 编程流程分析
发表于 2019-06-17
STM32 FSMC 外部使用SRAM

STM32F042 基于CubeMX HAL库CAN的配置

"stm32f0xx_hal.h" CAN_HandleTypeDef hcan;  CAN_FilterConfTypeDef  sFilterConfig;static CanTxMsgTypeDef        TxMessage;static CanRxMsgTypeDef        RxMessage; void SystemClock_Config(void);static void MX_GPIO_Init(void);static void
发表于 2019-06-17
STM32F042 基于CubeMX HAL库CAN的配置

STM32F407 SPI flash

STM32F407 SPI接口:STM32F4XX时钟计算HCLK=168M PCLK1 =HCLK/4 =42M PCLK2 =HCLK/2 =84MSPI2、SPI3在PCLK1,最大时钟为42MSPI1在PCLK2,最大时钟为84MSTM32F4 支持的最大SPI时钟为37.5Mbits/s 因此需要分频。例程选择SPI2 分频后为21M串行Flash W25Q64BVSSIG (最高支持80MHz)。测试:全部写入0XAA 数据长度8192K 擦除:20.798 写入耗时42.599S 读:9.008S百度的参照时间擦除:8.9S 写入22.5S 读出 1.8S  校验时间1.8S 芯片特点
发表于 2019-06-17
STM32F407 SPI flash

STM32F4 USART1 TX RX FIFO

。***********************************************************************************************************///#include "stm32f4xx.h"#include "bspdebug_usartbsp_debug_uart.h"#include "bsp.h"#include <stdio.h>#define  debug_uart_tx_buf_size  1*1024#define  debug_uart_rx_buf_size  1*1024static uint8_t g_TxBuf
发表于 2019-06-17

STM32 SRAM内存管理

; 者: 硬石嵌入式开发团队  * 版    本: V1.0  * 编写日期: 2015-10-04  * 功    能: 动态内存分配管理实现  ******************************************************************************  * 说明:  * 本例程配套硬石stm32开发板YS-F1Pro使用。  *   * 淘宝:  * 论坛:http://www.ing10bbs.com  *  
发表于 2019-06-17

STM32F03开发板--系统时钟设置SysTick

首先我先分析下startup_stm32f0xx.s启动代码,其中/* Call the clock system intitialization function.*/  bl  SystemInit/* Call the application's entry point.*/  bl main发现开发板上电启动过程中,先调用了SystemInit()函数,再进入main()函数。SystemInit()函数在文件system_stm32f0xx.c中,它的作用是设置系统时钟SYSCLK。下面是SystemInit()源码:void SystemInit (void){ 
发表于 2019-06-17
STM32F03开发板--系统时钟设置SysTick

小广播

何立民专栏

单片机及嵌入式宝典

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

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