763|4

194

帖子

4

TA的资源

纯净的硅(初级)

楼主
 

兆易GD32H759I-EVAL 独立看门狗 [复制链接]

  本帖最后由 御坂10032号 于 2024-7-1 02:45 编辑

本章我们要测试的时GD32H759I-EVAL的独立看门狗功能。

 

简介


看门狗定时器(WDGT)是一个硬件计时电路,用来监测由软件故障导致的系统故障。片上有两个看门狗定时器外设, 独立看门狗定时器(FWDGT)和窗口看门狗定时器(WWDGT)。它们使用灵活,并提供了很高的安全水平和精准的时间控制。两个看门狗定时器都是用来解决软件故障问题的。


独立看门狗定时器(FWDGT)有独立时钟源(IRC32K)。因此,即使主时钟失效了,它仍然能保持工作状态,这非常适合于需要独立环境且对计时精度要求不高的场合。

当内部向下计数器的计数值达到0或计数器的值大于窗口寄存器的值,刷新计数器, 独立看门狗会产生一个复位。使能独立看门狗的寄存器写保护功能可以避免寄存器的值被意外的配置篡改。

 

根据GD32H7用户手册的第599页我们得知。 简要来说看门狗就是一个硬件复位电路。使用独立的时钟源提供给看门狗内部的计数器。当设置的计数器递减到0的时候,便会产生一个复位。

那么为了避免在系统运行正常时产生复位,那么就需要程序在计数器递减到0之前来`喂狗` (重置计数器),从而保证程序不会出错。

 

 

 

了解完开门狗的工作原理之后。我们可以看一下如何设置看门狗的时间。IRC32K的时钟,经过分频经过最高12位的计数器进行递减。 如果减到0的话则产生复位。

 

下图为IRC32K时钟在不同分频下,的最小和最大计时时间(即喂狗时间)

 

 

 

那么我们来看下程序怎么编码。

 

 

初始化看门狗:


void init_fwdgt(void)
{
		//使用RCU_IRC32K 作为独立看门狗的时钟
    rcu_osci_on(RCU_IRC32K);
		// 等待时钟稳定
    while(SUCCESS != rcu_osci_stab_wait(RCU_IRC32K));
		//开启写
    fwdgt_write_enable();
		//设置时钟分频
    fwdgt_prescaler_value_config(FWDGT_PSC_DIV64); 
		//设置看门狗的复位时间
    fwdgt_reload_value_config(0x0FFF);
		//关闭写
    fwdgt_write_disable();
		//开启独立看门狗
    fwdgt_enable();
}

喂狗

void feed_dog(void)
{
		//开启写
    fwdgt_write_enable();
		//喂狗,重载Counter
    fwdgt_counter_reload();
		//关闭写
    fwdgt_write_disable();
}

 

这里需要注意的一点就是设置看门狗的时钟分频以及时钟的装载值。可以根据上述的表格进行确定和计算。

 

 

完整代码如下

 

#include "gd32h7xx.h"
#include "systick.h"
#include "bsp_usart.h"
static void cache_enable(void)
{
    /* Enable I-Cache */
    SCB_EnableICache();

    /* Enable D-Cache */
    SCB_EnableDCache();
}


extern uint8_t usart0_receive_data;


void init_fwdgt(void)
{
		//使用RCU_IRC32K 作为独立看门狗的时钟
    rcu_osci_on(RCU_IRC32K);
		// 等待时钟稳定
    while(SUCCESS != rcu_osci_stab_wait(RCU_IRC32K));
		//开启写
    fwdgt_write_enable();
		//设置时钟分频
    fwdgt_prescaler_value_config(FWDGT_PSC_DIV64); 
		//设置看门狗的复位时间
    fwdgt_reload_value_config(0x0FFF);
		//关闭写
    fwdgt_write_disable();
		//开启独立看门狗
    fwdgt_enable();
}


void feed_dog(void)
{
		//开启写
    fwdgt_write_enable();
		//喂狗,重载Counter
    fwdgt_counter_reload();
		//关闭写
    fwdgt_write_disable();
}


int main(void)
{
    cache_enable();

    systick_config();
    usart_init();
    usart_receive_init();

    init_fwdgt();

    if(RESET != rcu_flag_get(RCU_FLAG_FWDGTRST)) {
        rcu_all_reset_flag_clear();
        printf("RCU_FLAG_FWDGTRST reset\r\n");
        while(1) {
					
        }
    }
    while(1) {
				delay_1ms(8000);
        feed_dog();
    }
}


 

上述代码设置的时钟分频为64分频,那么根据用户手册我们得知,如果64分频的话,那么看门狗会在8192ms的时候复位系统。所以只要我们在8192秒之内喂狗的话,那么系统就不会复位

 

喂狗成功实验现象

 

 

实验正常,串口一直没有输出,因为程序在8192ms内执行了喂狗操作。

 

我们将主循环中的延时操作修改一下。比如说8193ms。再进行测试

 

 

 

 

喂狗失败,实验现象

 

 

  此时会发现,由于喂狗的时间大于8192ms,那么独立看门狗触发了复位,系统复位。

 

附件:

2024070102452234.zip (45.86 KB, 下载次数: 0)

最新回复

喂狗,有什么讲究吗?比如,我在中断中喂狗可以吗?   详情 回复 发表于 2024-7-1 14:30
点赞 关注
 
 

回复
举报

6483

帖子

10

TA的资源

版主

沙发
 

独立看门狗定时器(FWDGT)有独立时钟源(IRC32K),这个时钟源的供电是在哪里,怎么喂

点评

数据手册上说明是芯片内部的。喂狗就是重载计数器  详情 回复 发表于 2024-7-1 13:42
个人签名

在爱好的道路上不断前进,在生活的迷雾中播撒光引

 
 
 

回复

194

帖子

4

TA的资源

纯净的硅(初级)

板凳
 
秦天qintian0303 发表于 2024-7-1 09:57 独立看门狗定时器(FWDGT)有独立时钟源(IRC32K),这个时钟源的供电是在哪里,怎么喂

数据手册上说明是芯片内部的。喂狗就是重载计数器

 
 
 

回复

6992

帖子

11

TA的资源

版主

4
 

喂狗,有什么讲究吗?比如,我在中断中喂狗可以吗?

点评

当然可以,你在哪里喂狗都行,你只需要保证你在计数器减到0之前喂狗别让系统重启就可以了  详情 回复 发表于 2024-7-1 15:05
 
 
 

回复

194

帖子

4

TA的资源

纯净的硅(初级)

5
 
lugl4313820 发表于 2024-7-1 14:30 喂狗,有什么讲究吗?比如,我在中断中喂狗可以吗?

当然可以,你在哪里喂狗都行,你只需要保证你在计数器减到0之前喂狗别让系统重启就可以了

 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
推荐帖子
决对好的绿色抓图软件,非常好用,

软件介绍:可抓全图,任一区域,软件输出多种格式,软件为中文版,大小为640K,

LM3S8962远程升级学习心得

这几天看了下LM3S8963远程升级的程序,觉得还是蛮有意思的,和大家分享一下。 首先,让我们看一个最基本的概念: 地址:0xE000 ...

冒死也要向大家推荐的两本书

59641 :congratulate: 59642 本帖最后由 37°男人 于 2011-2-8 14:22 编辑 ]

迅为i.MX6ULL终结者移植ssh服务安装测试

文章目录 1 基本文件的安装 2 生成 Key 文件,并安装 3 修改目标板密钥文件 4 测试 1 基本文件的安装 在文件系统busybox上 ...

蜜袋鼯 第⑨贴 基于RSL10的蜜袋鼯数据监测子系统-设计与实现

本帖最后由 justd0 于 2021-7-19 00:17 编辑 前言 先来回顾下,本项目的整体架构图如下。前面几个帖子,介绍了下运 ...

2021电赛D题基于互联网的摄像测量系统(D题)——双目视频测量系统

本帖最后由 bqgup 于 2021-11-5 19:39 编辑 一、电赛D题 571548 571549571550 二、双目视频系统物体运动轨迹 5 ...

工作之余还是要加强身体锻炼

刚刚进入社会,没有了约束自己的人,熬夜、吃吃喝喝,再加上不锻炼身体,体制越来越差,跑两步就喘得不行。 这跟以前上学的时 ...

使用Verilog给证件照换背景颜色

本帖最后由 1nnocent 于 2022-9-25 11:45 编辑 之前做图像缩放仿真验证时需要读取图片数据进行处理,vivado读取的是raw文件 ...

FPGA实现 MIPI DSI 4线720P

液晶屏概述 显示屏LCD MIPI DSI4 lane,支持分辨率720*1280,60HZ彩色显示。用于对接国产GOWIN的NR-9C的开发板和LATTICE ...

【STM32H7S78-DK】STM32H7S78启动流程详解(Keil版)

开发环境: IDE:MKD 5.38a STM32CubeMX: V6.12.0 开发板:STM32H7S78-DK开发板 MCU:STM32H7S7L8H6H 对 ...

关闭
站长推荐上一条 1/8 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表