用户工具

站点工具


icore4t_27
银杏科技有限公司旗下技术文档发布平台
技术支持电话0379-69926675-801
技术支持邮件Gingko@vip.163.com
版本 日期 作者 修改内容
V1.0 2020-09-26 gingko 初次建立




STM32CubeMX教程二十七——WWDG看门狗实验

1.在主界面选择File–>New Project 或者直接点击ACCEE TO MCU SELECTOR 2.出现芯片型号选择,搜索自己芯片的型号,双击型号,或者点击Start Project进入配置 在搜索栏的下面,提供的各种查找方式,可以选择芯片内核,型号,等等,可以帮助你查找芯片。本实验选取的芯片型号为:STM32H750IBKx。 3.配置RCC,使用外部时钟源 4.时基源选择SysTick 5.将PA10,PB7,PB8设置为GPIO_Output,PH7设置为GPIO_Input 6.引脚模式配置 7.配置WWDG1 8.开启中断 9.时钟源设置,选择外部高速时钟源,配置为最大主频 10.工程文件的设置, 这里就是工程的各种配置 我们只用到有限几个,其他的默认即可 IDE我们使用的是 MDK V5.27 11.点击Code Generator,进行进一步配置

  • Copy all used libraries into the project folder
  • 将HAL库的所有.C和.H都复制到所建工程中
    • 优点:这样如果后续需要新增其他外设又可能不再用STM32CubeMX的时候便会很方便
    • 缺点:体积大,编译时间很长
  • Copy only the necessary library files
  • 只复制所需要的.C和.H(推荐)
    • 优点:体积相对小,编译时间短,并且工程可复制拷贝
    • 缺点:新增外设时需要重新用STM32CubeMX导入
  • Add necessary library files as reference in the toolchain project configuration file
  • 不复制文件,直接从软件包存放位置导入.C和.H
    • 优点:体积小,比较节约硬盘空间
    • 缺点:复制到其他电脑上或者软件包位置改变,就需要修改相对应的路径
  • 自行选择方式即可

12.然后点击GENERATE CODE 创建工程 创建成功,打开工程。




实验二十七:WWDG看门狗实验——复位ARM

一、 实验目的与意义

  1. 了解STM32 WWDG结构
  2. 了解STM32 WWDG特征
  3. 掌握WWDG的使用方法
  4. 掌握STM32 HAL库中WWDG属性的配置方法
  5. 掌握KEIL MDK 集成开发环境使用方法

二、 实验设备及平台

  1. iCore4T 双核心板。点击购买
  2. iCore4T 扩展底板
  3. JLINK(或相同功能)仿真器。点击购买
  4. Micro USB线缆。
  5. Keil MDK 开发平台。
  6. STM32CubeMX开发平台。
  7. 装有WIN XP(及更高版本)系统的计算机。

三、 实验原理

1.STM32H7窗口看门狗WWDG简介

  • 数字列表项目IWDG看门狗存在这样一个问题,如果在喂狗的间隔期间,程序跑飞后又正确归位,独立看门狗无法发现这样的错误,程序将存在很大的危险。与IWDG看门狗不同,WWDG看门狗需要在一个规定的时间范围内喂狗才有效,这样可以较为有效的解决IWDG看门狗存在的问题。可以根据WWDG看门狗通常被用来监测由外部干扰或不可预见的逻辑条件造成的应用程序背离正常的运行序列而产生的软件故障。
  • WWDG通常被用来监测由外部干扰或不可预见的逻辑条件造成的应用程序背离正常的运行序列而产生的软件故障。除非递减计数器的值在T6位(WWDG→CR的第六位)变成0前被刷新,看门狗电路在达到预置的时间周期时,会产生一个MCU复位。在递减计数器达到窗口配置寄存器(WWDG→CFR)数值之前,如果7位的递减计数器数值(在控制寄存器中)被刷新,那么也将产生一个MCU复位。这表明递减计数器需要在一个有限的时间窗口中被刷新。他们的关系可以用下图说明。

  • 图中,T[6:0]就是WWDG_CR的低七位,W[6:0]即是WWDG→CFR的低七位。T[6:0]就是窗口看门狗的计数器,而W[6:0]则是窗口看门狗的上窗口,下窗口值是固定的(0X40)。当窗口看门狗的计数器在上窗口值之外被刷新,或者低于下窗口值都会产生复位。上窗口值(W[6:0])是由用户自己设定的,根据实际要求来设计窗口值,但是一定要确保窗口值大于0X40,否则窗口就不存在了。

窗口看门狗的超时公式如下:

其中:

  • Twwdg:WWDG 超时时间
  • PCLK1:PCLK1 的时钟频
  • WDGTB:WWDG 的预分频系数
  • T[5:0]:窗口看门狗的计数器低 6 位

2.WWDG框图

3.WWDG寄存器

控制寄存器( WWDG_CR) 位 31:8 保留,必须保持复位值。 位 7 WDGA:激活位 (Activation bit)

  • 此位由软件置 1,只有复位后才由硬件清零。当 WDGA = 1 时,看门狗可产生复位。
  • 普通列表项目0:禁止看门狗
  • 普通列表项目1:使能看门狗

位 6:0 T[6:0]: 7 位计数器 (7-bit counter)( MSB 到 LSB)

  • 这些位用来存储看门狗计数器的值,每隔 (4096 x 2WDGTB[2:0]) PCLK 个周期递减一次。当它从0x40 递减到 0x3F( T6 清零)时会产生复位。

配置寄存器 (WWDG_CFR) 位 31:14 保留,必须保持复位值。

位 13:11 WDGTB[2:0]: 定时器时基 (Timer base) 可按如下方式修改预分频器的时基:

  • 000: CK 计数器时钟 (PCLK div 4096) 分频器 1
  • 001: CK 计数器时钟 (PCLK div 4096) 分频器 2
  • 010: CK 计数器时钟 (PCLK div 4096) 分频器 4
  • 011: CK 计数器时钟 (PCLK div 4096) 分频器 8
  • 100: CK 计数器时钟 (PCLK div 4096) 分频器 16
  • 101: CK 计数器时钟 (PCLK div 4096) 分频器 32
  • 110: CK 计数器时钟 (PCLK div 4096) 分频器 64
  • 111: CK 计数器时钟 (PCLK div 4096) 分频器 128

位 10 保留,必须保持复位值。

位 9 EWI: 提前唤醒中断 (Early wakeup interrupt)

  • 置 1 后,只要计数器值达到 0x40 就会产生中断。此中断只有在复位后才由硬件清零。

位 8:7 保留,必须保持复位值。

位 6:0 W[6:0]: 7 位窗口值 (7-bit window value)

  • 这些位包含用于与递减计数器进行比较的窗口值。

状态寄存器 (WWDG_SR)

位 31:1 保留,必须保持复位值。

位 0 EWIF: 提前唤醒中断标志 (Early wakeup interrupt flag) 当计数器值达到 0x40 时此位由硬件置 1。它必须由软件通过写入 0 来清零。写入 1 不起作用。如果不使能中断,此位也会被置 1。

本实验中iCore4T使用的是常开带复位按键,当按键没有按下时,ARM芯片的ARM_KEY引脚读取到的值是高电平,按键按下后读取到的值为低电平,按键没有按下时正常喂狗,当按键按下后停止喂狗。

四、 实验程序

1.主函数:

int main(void)
{
    int cnt = 0;
  HAL_Init();
  SystemClock_Config();
    i2c.initialize();
    axp152.initialize();
    axp152.set_dcdc1(3500);//[ARM & FPGA BK1/2/6 &OTHER]
    axp152.set_dcdc2(1200);//[FPGA INT & PLL D]
    axp152.set_aldo1(2500);//[FPGA PLL A]
    axp152.set_dcdc4(3300);//[POWER_OUTPUT] 
    axp152.set_dcdc3(3300);//[FPGA BK4][Adjustable]
    axp152.set_aldo2(3300);//[FPGA BK3][Adjustable]
    axp152.set_dldo1(3300);//[FPGA BK7][Adjustable]
    axp152.set_dldo2(3300);//[FPGA BK5][Adjustable]
    HAL_Delay(300);
  MX_GPIO_Init();
  MX_WWDG1_Init();
  MX_USART2_UART_Init();
 
    usart2.initialize(115200);
    usart2.printf("Hello,I am iCore4T!\r\n");
    LED_ON;
  while (1)
  {
        while(ARM_KEY_VALUE == KEY_DOWN){//按键没按下则正常喂狗
        }
        HAL_Delay(30);                          //30ms喂狗一次
        HAL_WWDG_Refresh(&hwwdg1);              //喂狗    
        usart2.printf("Hello,I am iCore4T! %d\r\n",cnt++);//打印文本,并且数值不断增大
  }
 
}

2.WWDG1初始化函数:

void MX_WWDG1_Init(void)
{
 
  hwwdg1.Instance = WWDG1;
  hwwdg1.Init.Prescaler = WWDG_PRESCALER_16;//窗口看门狗预分频系数为16
  hwwdg1.Init.Window = 100;//上限窗口值为100
  hwwdg1.Init.Counter = 127;//计数器的值为127
  hwwdg1.Init.EWIMode = WWDG_EWI_ENABLE;//打开提前唤醒
  if (HAL_WWDG_Init(&hwwdg1) != HAL_OK)
  {
    Error_Handler();
  }
}

3.喂狗函数:

HAL_WWDG_Refresh(WWDG_HandleTypeDef *hwwdg)

4.看门狗中断处理函数:

HAL_WWDG_IRQHandler(WWDG_HandleTypeDef *hwwdg)

功能:判断中断是否正常,并进入中断回调函数。 WWDG 中断服务程序,如果发生了此中断,表示程序已经出现了故障,这是一个死前中断。在此中断服务程序中应该干最重要的事,比如保存重要的数据等。

5.提前唤醒中断服务函数:

HAL_WWDG_IRQHandler(WWDG_HandleTypeDef *hwwdg)

用户可写入代码,在MCU死前,执行重要操作。

五、 实验步骤

  1. 把仿真器与iCore4T的SWD调试口相连(直接相连或者通过转接器相连);
  2. 把iCore4T通过Micro USB线与计算机相连,为iCore4T供电;
  3. 打开Keil MDK 开发环境,并打开本实验工程;
  4. 烧写程序到iCore4T上;
  5. 也可以进入Debug 模式,单步运行或设置断点验证程序逻辑。

六、 实验现象

在没有按下ARM_KEY按键时,终端输出文本,并且数值不断增大,当一直按下ARM_KEY按键,ARM不断复位,打印的数值不断循环,不会一直增大。

icore4t_27.txt · 最后更改: 2022/04/01 10:47 由 sean