stm32 看门狗 BKP(HAL库)

发布者:mlgb999最新更新时间:2019-03-09 来源: eefocus关键字:stm32  看门狗  BKP  HAL库 手机看文章 扫描二维码
随时随地手机看文章

(一)概述


stm32有两个看门狗:硬件看门狗(LSI 40KHz,时间精度不高)和窗口看门狗(APB1)。


(二)硬件看门狗实现代码


IWDG_HandleTypeDef hiwdg;

 

// 硬件看门狗初始化

static void MX_IWDG_Init(IWDG_HandleTypeDef *pHiwdg)

{

    pHiwdg->Instance = IWDG;

    pHiwdg->Init.Prescaler = IWDG_PRESCALER_4;

    pHiwdg->Init.Reload = 0xFFF; // Tout = ((4 * 2^prer) * rlr) / 40 = 409ms,看门狗溢出时间

 

    if (HAL_IWDG_Init(pHiwdg) != HAL_OK)

    {

        Error_Handler();

    }

}

 

int main(void)

{

     ........

     MX_IWDG_Init(&hiwdg);

     ........

     HAL_IWDG_Start(&hiwdg);

 

    while (1)

    {

        ........

        HAL_IWDG_Refresh(&hiwdg);

    }

    

}

(三)初始上电获取硬件看门狗复位状态


if (__HAL_RCC_GET_FLAG(RCC_FLAG_IWDGRST) != RESET)

{

    

}/* 硬件看门狗复位 */

 

__HAL_RCC_CLEAR_RESET_FLAGS();

(四)看门狗复位后IO状态的保持方法


法一:硬件方式,锁存器。


法二:软件方式,当需要关注的IO状态改变时,立马存在Flash中,初始上电判断复位类型是硬件看门狗,就进行Flash读取和IO操作。该方式的缺点:由于stm32的Flash写操作是页写,每次写之前,都要先擦除,而且Flash的写次数有限,故经常写,Flash经常写的区域有可能被写坏。


法三:软件方式,BKP+初始判断处理(stm32F103RC大容量,备份寄存器是42个16位的寄存器)。


// BKP

#define BKP_DATA_LEN               16   

#define BKP_MAX_DATA_LEN           42

#define BKP_INTERVAL_POINT         10

 

// 写备份寄存器

void BKP_Write(uint8_t *pSourcedata, uint32_t num)

{

assert_param(num <= BKP_MAX_DATA_LEN);


volatile uint32_t *pDestData;


RCC->APB1ENR |= (1 << 27 | 1 << 28); // 电源接口时钟/备份时钟开启

PWR->CR |= 1 << 8; // 允许写入后备寄存器


if (num > BKP_INTERVAL_POINT)

{

pDestData = &(BKP->DR1);


for (uint32_t i = 0; i < BKP_INTERVAL_POINT; i++)

{

*(pDestData + i) = *(pSourcedata + i);

}


pDestData = &(BKP->DR11);


for (uint32_t i = 0; i < (num - BKP_INTERVAL_POINT); i++)

{

*(pDestData + i) = *(pSourcedata + i + BKP_INTERVAL_POINT);

}

}

else

{

pDestData = &(BKP->DR1);


for (uint32_t i = 0; i < num; i++)

{

*(pDestData + i) = *(pSourcedata + i);

}

}

}

 

// 读备份寄存器

void BKP_Read(uint8_t *pReadData, uint32_t num)

{

assert_param(num <= BKP_MAX_DATA_LEN);


volatile uint32_t *pSourceData;


if (num > BKP_INTERVAL_POINT)

{

pSourceData = &(BKP->DR1);


for (uint32_t i = 0; i < BKP_INTERVAL_POINT; i++)

{

*(pReadData + i) = *(pSourceData + i);

}


pSourceData = &(BKP->DR11);


for (uint32_t i = 0; i < (num - BKP_INTERVAL_POINT); i++)

{

*(pReadData + i + BKP_INTERVAL_POINT) = *(pSourceData + i);

}

}

else

{

pSourceData = &(BKP->DR1);


for (uint32_t i = 0; i < num; i++)

{

*(pReadData + i) = *(pSourceData + i);

}

}

}

 

关键字:stm32  看门狗  BKP  HAL库 引用地址:stm32 看门狗 BKP(HAL库)

上一篇:基于STM32的DAC8760 菊花链驱动
下一篇:STM32的四种IO输出模式

推荐阅读最新更新时间:2024-03-16 16:25

STM32在程序运行过程中关闭定时器重新打开后定时器不工作的
问题:数码管显示程序放在定时TIM2中断函数里面扫描,想要实现在关闭某一功能的时候数码管不显示。 刚开始的想法是开关关闭,关闭定时器时钟;开关打开,打开定时器时钟;(但实验证明再次打开开关时定时器2却不工作:表现为数码管不显示) 解决办法: 开关关闭,关闭定时器更新中断(即TIM_ITConfig(TIM2,TIM_IT_Update,DISABLE);) 开关再次打开,开启定时器更新中断(即TIM_ITConfig(TIM2,TIM_IT_Update,ENABLE);) 关闭中断可以达到不进入定时去中断服务函数,同样达到数码管不显示的目的。
[单片机]
解决STM32 SPI 半残废 NSS无法拉高
众所周知,STM32 SPI是个半残废,NSS无法自动拉高,所以使用SPI 从机会一直使能,当主机是一对多的时候,就会出现SPI从机互相干扰的问题。 我利用GPIO中断,代替NSS引脚,使用过程如下代码所示 1.初始化SPI 的IO口,其中NSS引脚先不管。 void GPIO_SPI12_Config(void) { GPIO_InitTypeDef GPIO_InitStructure; //----- 第1步:打开SPI部件的时钟 --------------------------------------------------------------------------------------------
[单片机]
STM32晶振不起振
1.外部晶振虚焊 2.外部晶振的电容不匹配,可能是器件盒里面混入了大容值电容 3.芯片挂了 4.STM32f103有内部晶振。刚刚上电时,所有Clock都是源于内部晶振,所以当片内没有程序或内部程序没有使能外部晶振时,外部晶振是不会起振的。 在RCC_Configuration(void)看相关设置,有没有启动外部晶振HSE. PS:如果使用内部RC振荡器而不使用外部晶振,请按照下面方法处理: 1)对于100脚或144脚的产品,OSC_IN应接地,OSC_OUT应悬空。 2)对于少于100脚的产品,有2种接法:  2.1)OSC_IN和OSC_OUT分别通过10K电阻接地。此方法可提高EMC性能。  2.2)分别重映射OSC_
[单片机]
STM32用DAC播放WAV数据源程序
编译运行很好,接在扩音机上,8000HZ的量化噪声也没有听到。 KEIL5下编译,PA5口声音输出,可以用一根线连接在蜂鸣器口上。 单片机源程序如下: #include system.h #include SysTick.h #include led.h #include usart.h #include key.h #include dac.h /******************************************************************************* * 函 数 名 : main * 函数功能 : 主函数 * 输 入
[单片机]
意法的90纳米STM32微控制器内置独特闪存加速器
    意法半导体宣布取得两项重大技术进展,促使市场成功的STM32系列微控制器的性能和功耗获得进一步提升,这两项进展分别是:内嵌90纳米制程闪存的微控制器问世;推出业内首款针对工业标准的ARM Cortex-M3内核优化的自适应实时(ART)存储器加速器。     意法半导体的首批采用90nm嵌入式闪存制程生产的STM32微控制器的运行速度更快,功耗更低,外设集成度更高,片上存储密度更大。90nm嵌入式闪存技术的性能已经在智能卡和汽车电子IC上得到实证。意法半导体已于2009年发布了内嵌90nm 闪存的微控制器的样片。     由于ARM Cortex-M3的性能高于闪存技术,在运行频率较高时,处理器必须等待闪存,意法半
[单片机]
STM32单片机串口空闲中断+DMA接收不定长数据
在上一篇文章STM32单片机串口空闲中断接收不定长数据中介绍了利用串口空闲中断接收不定长数据,这种方式有一个问题就是串口每接收到一个字节就会进入一次中断,如果发送的数据比较频繁,那么串口中断就会不停打断主程序运行,影响系统运行。那么能不能在串口接收数据过程中不要每接收一个数据中断一次,只有在一帧数据接收结束完成后只中断一次? 用串口的空闲中断加上DMA功能,就可以实现每帧数据接收完成后只中断一次,而在数据接收过程中,由DMA存储串口接收到的每个字节。 关于串口的空闲检测和DMA在STM32参考手册中有详细介绍。 下面看如何初始化串口空闲中断和 DMA。 void uart2_init( u16 baud )
[单片机]
<font color='red'>STM32</font>单片机串口空闲中断+DMA接收不定长数据
如何将ThreadX移植到STM32平台
现在一些小型系统中也往往有多任务处理的需求,这就为实时操作系统提供了用武之地。事实上国内外各种各样的RTOS有很多,而且基本都在走开源的路线,ThreadX也不例外,在这一篇中我们就来学习ThreadX初步应用并将其移植到STM32平台中。 1 、前期准备 在开始将ThreadX一直到STM32平台之间我们需要做一些前期准备。首先我们需要准备一个硬件平台,这次我们采用STM32F407IG控制单元来作为目标平台。其次我们需要准备一个该硬件平台下可以正常运行的裸机项目。这两点其实我们都已经具备了。 最主要的我们需要获得ThreadX的源码,这是我们移植它的基础。ThreadX的源码已经开源到Github上,其地址为:http
[单片机]
如何将ThreadX移植到<font color='red'>STM32</font>平台
Event Recoder调试组件在stm32上的使用
本文目标:Event_Recoder调试组件在stm32上的使用 按照本文的描述,应该可以在你所处的硬件上跑通代码。 先决条件:装有编译和集成的开发环境,比如:Keil uVision5。 板子硬件要求:无,属于调试功能。 起源 因为做产品开发,设计东西有时候考虑得多,mcu的并没有多余的串口供使用调试,在调试一些初期进行验证时,必要的调试的打印信息是需要的。 Event Recoder调试组件简介 嵌入式的Event_Recoder调试组件是一种可以在MDK开发环境下使用的高级调试工具,它可以记录软件运行的一些标志信息,并以图形化的形式显示出来。它可以帮助你了解和分析内部操作,支持Keil RTX操作系统调试以及MDK自带的
[单片机]
Event Recoder调试组件在<font color='red'>stm32</font>上的使用
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

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

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

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved