你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

【实测教程】STM32L4之看门狗IWDG实验

[复制链接]
STMCU小助手 发布时间:2023-1-14 18:52
一、开发板平台简介:
1、开发板资源简介

(1)开发板主芯片型号:STM32L431RCT6
(2)开发板主芯片封装:LQFP-64_10x10x05P
(3)开发板主芯片内核:ARM® Cortex®-M4
(4)开发板主芯片主频:80MHz
(5)开发板主芯片Flash大小:256KB
(6)开发板主芯片RAM大小:64KB

bb91345227434ee7a43a34bf3fe366e6.png

929c0cce04aa4115a8623703982bf3e1.png

2、LED灯资源
(1) STM32L431RCT6开发板共5个LED灯资源,其中一个红色LED为系统指示灯,指示开发板供电系统是否正常,如供电系统正常,红色LED为上电常亮状态,硬件原理图如下图所示:

0f177691c5814f16a508bcfa747f87ac.png

(2)其他四个LED灯为黄绿色可控LED,高电平点亮、低电平熄灭,计划用LED常亮验证看门狗的作用,硬件原理图如下图所示:

e923ad767b8448b7ac37c4ed693724bd.png

​3、看门狗工作原理
在由单片机构成的微型计算机系统中单片机的工作常常会受到来自外界电磁场的干扰,造成程序的跑飞,而陷入死循环;或者因为用户配置代码出现BUG,导致芯片无法正常工作,出于对单片机运行状态进行实时监测的考虑,便产生了一种专门用于监测单片机程序运行状态的模块或者芯片,俗称“看门狗”(watchdog) 。

独立看门狗(IWDG)由专用的低速时钟(LSI)驱动(40kHz),即使主时钟发生故障它仍有效。独立看门狗适合应用于需要看门狗作为一个在主程序之外 能够完全独立工作,并且对时间精度要求低的场合。
窗口看门狗由从APB1时钟(36MHz)分频后得到时钟驱动。通过可配置的时间窗口来检测应用程序非正常的过迟或过早操作。 窗口看门狗最适合那些要求看门狗在精确计时窗口起作用的程序。

ee279a92a0b14df5aeede0df13dcdfe0.png

本次看门狗的实验通过独立看门狗实现。


  二、看门狗实验过程
1、新建STM32CubeMX基础工程

(1)打开STM32CubeMX,点击“File”-->"New Project"

2399170347904e959c855fefd5877f84.png

(2)等待打开主芯片选项界面(大约1分钟时间)。

d74d2fdc60c9440483e2b7cf8d928e7f.png

(3)昨天搜索框中输入(或选择)所需的主芯片型号(因为我们用的是STM32L431RCT6开发板,所以此处选择STM32L431RC),然后在右下角选择STM32L431RCTx(因为开发板主芯片是STM32L431RCT6),左键双击即可打开新建的项目。

7b80345238d74bea82ce70e1a348f7b4.png

(4)选择时钟源。
(1)因为开发板上有8M外部时钟,硬件原理图如下所示,所以此处选择使用外部高速时钟(HSE)。

3f65707eca104663a3dede6d25dfa961.png

(5)因为我们没有用到外部低速时钟(LSE),此处不做处理,如下图所示。

72119b971f62410fa8344f7f9fb9f389.png

2、配置GPIO控制LED
(1)查开发板原理图得,LED1、LED2、LED3、LED4的控制引脚分别为:
LED1——PC0
LED2——PC1
LED3——PC2
LED4——PC3

(2)配置LED的控制引脚为输出,输出频率、输出方式默认即可。

鼠标左键点击PC0,选择“GPIO_Output”,表示设置该引脚为输出模式。
鼠标左键点击PC1,选择“GPIO_Output”,表示设置该引脚为输出模式。
鼠标左键点击PC2,选择“GPIO_Output”,表示设置该引脚为输出模式。
鼠标左键点击PC3,选择“GPIO_Output”,表示设置该引脚为输出模式。

492907c1e71149819adbaee4516a2af4.png

c75d3f10ba2e427d9c1a10fad9bf5471.png

(3)也根据自己的需求配置GPIO的参数,如输出方式、输出频率、上拉下拉等。因为GPIO控制LED的要求比较低,此处采用默认参数即可,不用修改。

38ff4b80e1c5495ba3076a5158fd91fa.png

​​3、配置IWDG参数

309e5486e4f14d2f8d5033b15e2acf40.png

psc:32,j计数值:1000-1
独立看门狗频率:32000/32=1000HZ(查手册可得STM32L431RCT6内部LSI时钟频率32Khz)。
所以从1000减到0,所需的超时时间为1s。

对应不同预分频系数的PRER值:

d791c7eb4c2441b3b69ed99ebe72413e.png

3、配置项目工程参数
(1)配置时钟树,用于系统内部时钟,以及各个外设时钟等。此处选择外部8M晶振作为主时钟频率,内部最大倍频80MHz。

f3ecedd9323f4463b69539906b3c1199.png

(2)完成配置工程。
备注:需要注意代码生成过程中的继承关系,如图所示:需要保留开发者自己编写的代码时,请根据配置设置,不然生成代码后会删除自己编写的代码(从这个方面也可以看出开发者备份自己的代码是多么的重要。)

efdb616174f54925b6eac31109f227b5.png
​​
41c3f2716e4e4eda8f62fa3a1d871322.png

(3)生成代码。
备注:使用Generate CODE生成工程代码前,请确保文件路径无中文,否则会生成项目失败。

8eaa7d0babea40ee93f158481a6ee471.png

(4)工程代码生成成功。

e8f46d59a1fb4af589feb613fdff17b4.png

三、在KEIL 5中编写代码
1、使用KEIL 5(MDK)打开项目工程文件
源码使用说明:使用前必须把项目工程复制到无中文路径的文件夹下使用。
(1)找到刚才新建工程的存储路径,安装项目名称,打开项目工程.uvprojx。

bcd4797c7da0458dabfa49a6f67a9c58.png

2、添加LED+看门狗验证程序
(1)在main.c文件中,初始化LED1、LED2、LED3、LED4并默认初始化状态为熄灭,进入while循环常亮,并添加喂狗函数。

备注:自己添加的代码需要在 /* USER CODE BEGIN 3 */和 /* USER CODE END 3 */之间添加,否则STM32CubeMX更新代码时,会造成自己添加的代码丢失。

0be5c19e82114761b8f17119038f0d90.png

(2)main 函数代码如下所示:
  1. int main(void)
  2. {
  3.   /* USER CODE BEGIN 1 */

  4.   /* USER CODE END 1 */

  5.   /* MCU Configuration--------------------------------------------------------*/

  6.   /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
  7.   HAL_Init();

  8.   /* USER CODE BEGIN Init */

  9.   /* USER CODE END Init */

  10.   /* Configure the system clock */
  11.   SystemClock_Config();

  12.   /* USER CODE BEGIN SysInit */

  13.   /* USER CODE END SysInit */

  14.   /* Initialize all configured peripherals */
  15.   MX_GPIO_Init();
  16.   MX_IWDG_Init();
  17.   /* USER CODE BEGIN 2 */
  18.   HAL_GPIO_WritePin(GPIOC,GPIO_PIN_0,GPIO_PIN_RESET);//指示灯熄灭
  19.   HAL_GPIO_WritePin(GPIOC,GPIO_PIN_1,GPIO_PIN_RESET);
  20.   HAL_GPIO_WritePin(GPIOC,GPIO_PIN_2,GPIO_PIN_RESET);
  21.   HAL_GPIO_WritePin(GPIOC,GPIO_PIN_3,GPIO_PIN_RESET);
  22.   HAL_Delay(500);
  23.   /* USER CODE END 2 */

  24.   /* Infinite loop */
  25.   /* USER CODE BEGIN WHILE */
  26.   while (1)
  27.   {
  28.     /* USER CODE END WHILE */

  29.     /* USER CODE BEGIN 3 */
  30.         HAL_IWDG_Refresh(&hiwdg);                        //1S内喂狗                          
  31.                 HAL_GPIO_WritePin(GPIOC,GPIO_PIN_0,GPIO_PIN_SET);//指示灯常亮
  32.                 HAL_GPIO_WritePin(GPIOC,GPIO_PIN_1,GPIO_PIN_SET);
  33.         HAL_GPIO_WritePin(GPIOC,GPIO_PIN_2,GPIO_PIN_SET);
  34.         HAL_GPIO_WritePin(GPIOC,GPIO_PIN_3,GPIO_PIN_SET);
  35.                 HAL_Delay(500);
  36.                
  37.   }
  38.   /* USER CODE END 3 */
  39. }
复制代码

3、设置编程仿真下载模式
(1)选择Options for target ...>>Debug>>J-Link/J-JTRACE Cortex,点击Settings>>选择Port(SW),可以看到搜索成功SW Device,表示芯片可用,可以下载。

edefb6b9a2a14be3b1221ad6d5c7a8a2.png
​​
(2)点击编译,完成后提示“0 error(s),0 warning(s)”。

6a7e14d4a6c7419897ed550d010a9cd2.png

(3)点击Download(或者快捷键F8),即可下载程序。

99bdf89cc1f64cc7aee4b4d768206f24.png
​​

(4) 如果下载程序后,没有看到LED1、LED2、LED3、LED4点亮,可以按下述方式设置一下(Reset and run表示下载后自动复位和重启运行)。或者重新彻底断电再次上电(或按开发板的Reset按键复位MCU即可)。

9f8aa1a4e8f04041bcf5cb183facd100.png
​​
4、独立看门狗效果展示
        程序烧录到开发板后,即可看到LED1、LED2、LED3、LED4初始化后常亮,说明看门狗喂狗正常。如果屏蔽看门狗喂狗函数,则可以看到指示灯闪烁,说明系统超时复位,LED灯重新进行了初始化。

————————————————
版权声明:智能小屋ZYXC


收藏 评论0 发布时间:2023-1-14 18:52

举报

0个回答

所属标签

相似分享

官网相关资源

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版