【瑞萨RA_FSP】IWDT——独立看门狗定时器

news2025/1/16 15:39:57

文章目录

  • 一、IWDT简介
  • 二、IWDT功能框图剖析
    • 1. IWDT 时钟源
      • (1) 计数器时钟
      • (2) 独立看门狗超时时间计算
    • 2. IWDT 模块电路功能讲解
    • 3. 独立看门狗(IWDT)与看门狗(WDT)功能对比
    • 4. 怎么使用IWDT
  • 三、IWDT实验
    • 1. 硬件设计
    • 2. 文件结构
    • 3. FSP配置
    • 4. NMI 和 复位
    • 5. WDT初始化函数
    • 6. 喂狗函数
    • 7.NMI中断服务函数
    • 8. 主函数


一、IWDT简介

IWDT (Independent Watchdog Timer) 由一个14位的向下计数器组成,用于从应用程序中的意外错误中恢复。 应用程序必须在允许的计数窗口内进行刷新计时器,如果允许计数器下溢或者是在有效刷新周期外刷新的话, IWDT将复位MCU或生成不可屏蔽中断(NMI)。

IWDT特性:

  • 使用自带时钟源 (IWDTCLK)

  • 使用14位下行计数器进行计数

  • 可以设置安全属性 TrustZone

二、IWDT功能框图剖析

在这里插入图片描述

1. IWDT 时钟源

(1) 计数器时钟

独立看门狗时钟来自 IWDTCLK , IWDTCLK 最大的时钟频率是 15000Hz ,可以使用 RA 配置编辑器的 BSP 设置 IWDTCLK 分频器。 从计数器第一次刷新到产生复位或NMI中断的最大时间要比35秒略少一点。

(2) 独立看门狗超时时间计算

首先,独立看门狗的输入时钟频率为 15000hz

时钟分频比等于 256

将循环周期设为 2048 cycles

那么,可以得到独立看门狗的时钟频率 15000Hz / 256 = 58.59hz

周期时间等于 1/58.59hz = 17.067 ms

最终计算出设置的超时时间 = 17.067 ms x 2048 cycles = 34.95 秒

Tips: cycles :配置的循环周期次数,此数值越大,超时时间越长。

2. IWDT 模块电路功能讲解

当 “功能选择寄存器0” 中的 “IWDT启动模式选择位(OFS0.IWDTSTRT)” 为 “自动启动模式” 时,才能使用 IWDT ,否则IWDT将被禁用。 在重置状态下,“功能选择寄存器0 (OFS0)” 中的各项设置如下:

复位状态解除后,计数器自动从IWDT超时时间选择位(OFS0.IWDTTOPS[1:0])中选择的值开始倒数。 在此之后,只要程序继续正常操作并且在刷新允许的时间内刷新计数器,每次刷新计数器并继续下计数时,计数器中的值都会重置。 只要这个过程继续,IWDT就不会输出复位信号。然而,如果由于程序崩溃或由于在刷新允许的时间外尝试刷新时发生了刷新错误而导致计数器不足, IWDT将断言重置信号或不可屏蔽中断请求/中断请求(IWDT_NMIUNDF)。

复位信号或不可屏蔽中断请求/中断请求产生后,计数器计数1个周期后重新加载超时时间, 在down计数器中设置超时时间的值,开始计数。复位输出或中断请求输出可以用IWDT复位中断请求选择位(OFS0.IWDTRSTIRQS)进行选择。 不可屏蔽中断请求或中断请求可以通过IWDT下流/刷新错误中断启用位进行选择(NMIER.IWDTEN)。

下图显示了在以下条件下的操作示例:

  • 自启动模式(OFS0.Iwdtstrt = 0)

  • 启用了不可屏蔽中断请求输出(OFS0.Iwdtrstirqs = 0)

  • 窗口结束位置为0% (OFS0.IWDTRPES[1:0] = 10b)

  • 窗口起始位置为100% (OFS0.IWDTRPSS[1:0] = 10b)

在这里插入图片描述

3. 独立看门狗(IWDT)与看门狗(WDT)功能对比

独立看门狗(IWDT)与看门狗(WDT)的不同点如下:

  1. 时钟源不一样,WDT使用外部时钟电路作为时钟源,而IWDT为了稳定性和安全性自带时钟源。

  2. WDT可以设置寄存器启动和自启动两种模式,然而在大多数 MCU上面, IWDT只能够设置成自启动这一种模式。

  3. WDT是内核外设,而IWDT是片上外设。

而独立看门狗(IWDT)与看门狗(WDT)也有很多相似点,主要如下:

  1. 都可以选择复位的范围(窗口值)。

  2. 都可以设置在睡眠模式下是否启动。

  3. 都可以设置NMI中断和复位重启。

4. 怎么使用IWDT

独立看门狗一般用来检测和解决由程序引起的故障,比如一个程序正常运行的时间是50ms, 在运行完这个段程序之后紧接着进行喂狗,设置独立看门狗的定时溢出时间为60ms, 比需要监控的程序50ms多一点, 如果超过60ms还没有喂狗,那就说明监控的程序出故障了, 跑飞了,那么就会产生系统复位,让程序重新运行。

三、IWDT实验

1. 硬件设计

  • IWDG一个
  • 按键一个
  • LED两个

IWDG属于单片机内部资源,不需要外部电路,需要一个外部的按键和LED,通过按键来喂狗,喂狗成功LED亮,喂狗失败,程序重启,LED灭一次。 使用LED灯和按键。

2. 文件结构

IWDT
├─ ......
└─ src
   ├─ led
   │  ├─ bsp_led.c
   │  └─ bsp_led.h
   ├─ iwdt
   │  ├─ bsp_iwdt.c
   │  └─ bsp_iwdt.h
   └─ hal_entry.c

3. FSP配置

首先打开 “IWDT” 项目的 FSP 配置界面,接下来要在这个界面里配置芯片的引脚及其相应的功能。

双击 configuration.xml 打开配置界面: 然后点开依次点击 Stacks -> New Stack -> Search… 里输入 IWDT 选着 Independent Watchdog。

在这里插入图片描述

并且在堆栈中配置独立看门狗的名称以及NMI回调函数。
在这里插入图片描述
然后点击 BSP 的属性settings界面,找到 OFSO register settings -> WDT 去设置 WDT 的属性。

在这里插入图片描述
要注意,对于寄存器启动的看门狗实验只能在新建的堆栈选项中进行配置, 而对于自启动看门狗实验只能在BSP的堆栈中进行配置,在模块堆栈中进行配置是没有用的。 在本实验中为了防止看门狗超时时间过长,影响实验效率,故把看门狗的周期设定为16周期, 最大超时时间也就是2.1秒左右。

配置完成之后可以按下快捷键“Ctrl + S”保存, 最后点右上角的 “Generate Project Content” 按钮,让软件自动生成配置代码即可。

4. NMI 和 复位

NMI就是会执行一个中断服务函数,这个中断函数是不能够被打断的,拥有最高的中断优先级。 一般是用在一些重要的数据上面,如果直接复位,这些数据将不被保存,这个时候我们可以写一个服务程序去保存重要数据, 这也是看门狗最重要的功能。 可以在NMI中断程序中通过软件复位或跳转到程序开头进行程序的重新运行。

复位就是在不断电的情况下,把当前 MCU 及运行数据清零后的启动。在本实验中使用NMI,也就是不可屏蔽中断来进行试验。

5. WDT初始化函数

/*初始化看门狗并启动计数器*/
void IWDT_Init(void)
{
   //如果使用J-Link调试器进行调试的话需要加上这一句话
   R_DEBUG->DBGSTOPCR_b.DBGSTOP_WDT = 0;

   //初始化看门狗(WDT)模块
   R_IWDT_Open(&g_iwdt0_ctrl, &g_iwdt0_cfg);

}

6. 喂狗函数

/*喂狗*/
void IWDT_Feed(void)
{
   /*喂狗,刷新递减计数器的值*/
   R_IWDT_Refresh(&g_iwdt0_ctrl);
}

7.NMI中断服务函数

NMI不可屏蔽中断函数

/* 当看门狗NMI发生时中断回调 */
void iwdt_callback (wdt_callback_args_t * p_args)
{
   /*防止编译器产生关于函数中没有使用形参的警告*/
   (void) p_args;

   /*蓝色LED亮,请注意,在这里LED灯函数为代指,
    *实际应用中,这里应该放最重要的函数,比如保存重要数据等*/
   LED1_OFF;
   LED2_ON;
   R_BSP_SoftwareDelay(3, BSP_DELAY_UNITS_SECONDS);

   /* 通过软件复位MCU*/
   __NVIC_SystemReset();
}

8. 主函数

/*按键中断回调函数*/
void key1_callback(external_irq_callback_args_t *p_args)
{
   (void) p_args;

   /*按键按下触发中断,进行喂狗操作*/
   IWDT_Feed();
}

void hal_entry(void)
{
   /*红色LED亮3秒*/
   LED1_ON;
   R_BSP_SoftwareDelay(3,BSP_DELAY_UNITS_SECONDS);

   /*按键中断初始化*/
   g_external_irq_on_icu.open(&key1_ctrl, &key1_cfg);
   g_external_irq_on_icu.enable(&key1_ctrl);

   /*初始化看门狗并开启计数器*/
   IWDT_Init();

   while(1)
   {
      /*红色LED灯灭,在这里只是代指,
       *实际上这部分应该写需要被WDT监控的程序*/
   }

#if BSP_TZ_SECURE_BUILD
   /* Enter non-secure code */
   R_BSP_NonSecureEnter();
#endif
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/678610.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

交通 | 考虑供需交互下的航空网络优化问题

编者按: 本文提出了一种包含供需交互作用的航空网络规划模型 (ANPSD),该模型同时考虑了航线选择、航班频率和机队组成等问题,还捕捉了航空公司的供应和乘客需求之间的相互依赖关系。作者将需求实证函数与 ANPSD 模型相结合,开发了…

代码随想录算法训练营第四十四天|完全背包、518. 零钱兑换 II 、377. 组合总和 Ⅳ

完全背包 有N件物品和一个最多能背重量为W的背包。第i件物品的重量是weight[i],得到的价值是value[i] 。每件物品都有无限个(也就是可以放入背包多次),求解将哪些物品装入背包里物品价值总和最大。 完全背包和01背包问题唯一不同…

【数据结构】顺序表,链表

前言 小亭子正在努力的学习编程,接下来将开启 javaEE 的学习~~ 分享的文章都是学习的笔记和感悟,如有不妥之处希望大佬们批评指正~~ 同时如果本文对你有帮助的话,烦请点赞关注支持一波, 感激不尽~~ 目录 前言 顺序表 ArrayList ArrayLi…

K8S存储值之PV和PVC

1. 概念: 1.1. PersistentVolume (PV): 是由管理员设置的存储,它是群集的一部分。就像节点是集群中的资源一样,PV也是集群中的资源。PV是Volume之类的卷插件,但具有独立于使用PV的Pod的生命周期。此API对象包含存储实…

数字图像处理-图像复原与重建

文章目录 一、图像退化/复原过程的模型二、噪声模型2.1噪声的空间和频率特性2.2一些重要的噪声概率密度函数2.2.1高斯噪声2.2.2瑞利噪声2.2.3爱尔兰(伽马)噪声2.2.4指数噪声2.2.5均匀噪声2.2.6脉冲(椒盐)噪声 2.3周期噪声 三、只存…

【ABAP】数据类型(四)「类型组TYPE-POOL」

💂作者简介: THUNDER王,一名热爱财税和SAP ABAP编程以及热爱分享的博主。目前于江西师范大学本科在读,同时任汉硕云(广东)科技有限公司ABAP开发顾问。在学习工作中,我通常使用偏后端的开发语言ABAP,SQL进行任务的完成,对SAP企业管理系统,SAP ABAP开发和数据库具有较…

基于电容电流前馈与电网电压全前馈的三相LCL并网逆变器谐波抑制MATLAB仿真

基于电容电流前馈+电网电压全前馈的三相并网逆变器谐波抑制MATLAB仿真资源-CSDN文库https://download.csdn.net/download/weixin_56691527/87940934模型简介: 测试环境为MATLAB2021b 一共包含两个模型:一个是传统无改进模型,一个…

chatgpt赋能python:Python画运动轨迹:探索世界的足迹

Python画运动轨迹:探索世界的足迹 作为一门快速发展的编程语言,Python在数据分析、机器学习、Web开发等多个领域中发挥着举足轻重的作用。其中,画运动轨迹是Python可视化库中较为常见的应用之一。本文将介绍使用Python画运动轨迹的方法&…

chatgpt赋能python:Python画点函数:如何绘制并掌握基础图形?

Python画点函数:如何绘制并掌握基础图形? Python是一个极为强大的编程语言,它可以用来编写各种应用程序,包括绘图。绘图是Python的重要特性之一,它提供了各种绘图函数,包括画点函数。Python的画点函数是一…

chatgpt赋能python:Python的frozenset:一种不可变的集合类型

Python的frozenset:一种不可变的集合类型 在Python中,集合是一种基本的数据类型。它们是无序的、可变的、且不允许重复的元素。但是,有时候我们需要一个不可变的集合,即一旦创建就不允许进行修改操作的集合。这就是frozenset的作…

【STM32 】芯片命名、内核、产品系列

文章目录 一、半导体公司介绍二、STM32 芯片2.1 芯片命名2.2 Cortex-M内核2.3 STM32 系列 一、半导体公司介绍 STM32是STMicroelectronics(意法半导体)公司的一系列32位微控制器,基于ARM Cortex-M内核,具有高性能、低功耗、丰富的…

【软件设计师暴击考点】软件工程知识高频考点【二】

👨‍💻个人主页:元宇宙-秩沅 👨‍💻 hallo 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍💻 本文由 秩沅 原创 👨‍💻 收录于专栏:软件…

chatgpt赋能python:Python的Pipe:快速高效的数据传输工具

Python的Pipe:快速高效的数据传输工具 如果你是一名Python工程师,那么你一定会非常了解数据传输的重要性。Python的Pipe就是一种可以让你快速高效地传输数据的工具。在本文中,我们将对Python的Pipe进行详细介绍,探讨它的优点、如…

Linux命令(35)之shutdown

Linux命令之shutdown 1.shutdown介绍 linux命令shutdown主要用来重启、关闭服务器。 2.shutdown用法 shutdown [参数] shutdown常用参数 参数说明-c取消即将执行的关机程序-k 仅仅向每个登录用户发出警告信息,并不真正关机 -h关机(halt)-H关机(halt)-P关机(powe…

chatgpt赋能python:Python中的figsize:使用和优化

Python中的figsize:使用和优化 在数据分析和可视化领域,Python被广泛使用。matplotlib是一个流行的Python可视化库,用于创建各种类型的图形。在matplotlib中,figsize是一个非常有用的参数,可以控制图形的大小。 什么…

3、数据库操作语句:MySql函数

1、数学函数 1)单行函数可以嵌套 例如:select truncate(round(123.456,2),0) from dual;//结果:123 2)三角函数 举例: ATAN2(M,N)函数返回两个参数的反正切值。 与ATAN(X)函数相比,ATAN2(M,N)需要两个参…

git图形化提交报错“error: cannot spawn C:\Program Files (x86)\Git\bin\ssh.exe: ”

一,问题现象 gitTortoise在push代码到服务器的时候出现如下错误: 报错信息: git.exe push --all --progress "origin" error: cannot spawn C:\Program Files (x86)\Git\bin\ssh.exe: No such file or directory fatal: unable t…

blfs:为lfs虚拟机增加桌面03

编译安装Qt5.15 我比较好奇,当前只安装了twm(X.org提供的简单的窗口管理器),这个时候Qt的界面是怎么样的一个呈现。 Qt5.15安装 required和recommanded必装,optional中涉及到runtime的建议安装。其他的看需要再安装。…

彻底解决Springboot中路径参数带 (%2F)的问题

彻底解决Springboot中路径参数带/(%2F)的问题 背景 前两天突然出现了一个线上问题,有同事反应我提供的接口报400的错误。接口路径如下 PATCH /v1/basic/owners/{owner_code}/skus/{sku},经过排查发现是sku参数中有/因此springboot转义后直接报错了。由…

chatgpt赋能python:Python画的图是放置在什么位置合适?

Python画的图是放置在什么位置合适? Python作为一门流行的编程语言,已经被广泛应用于数据科学和机器学习的领域。在这些领域,数据可视化是一个重要的环节。Python提供了许多强大的可视化工具,可以帮助我们更好地了解和分析数据。…