WDT实验

2023-10-22 15:30
文章标签 实验 wdt

本文主要是介绍WDT实验,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.WDT简介

Watch Dog Timer即看门狗定时器,其主要作用是当发生软件故障时,可产生复位信号使SOC复位,其本质是一个计数器
在这里插入图片描述
WDT工作原理:
在这里插入图片描述

2.Exy4412下的WDT控制器

总览:
Exynos 4412 SCP中的监视器计时器(WDT)是一种计时设备。由于噪声和系统错误导致故障后,您可以使用此设备恢复控制器的操作。您可以使用WDT作为一个普通的16位间隔计时器来请求中断服务。WDT产生复位信号

WDT的特点:

支持具有中断请求的正常时间间隔计时器模式。
如果计时器计数达到0(超时),激活内部重位信号。
支持电平触发的中断机制

WDT使用PCLK作为其源时钟。8位预计算器按PCLK频率生成相应的WDT,并再次划分得到的频率。
在这里插入图片描述
上图显示了WDT的功能方框图。WDT控制(WTCON)指定预调节器值和频率划分因子。有效的预计算值范围从0到(28-1)。您可以选择频率划分因子为: 16、32、64或128。使用此公式来计算WDT时钟频率和每个计时器时钟周期的持续时间:

pclk = 100 MHZ;
t_watchdog = 1/(PCLK/(Prescaler value + 1)/Division_factor)
如果Prescaler value = 255,Division_factor = 128;
则 t_watchdog = 3051;
  1. Register Map Summary
    Base Address: 0x1006_000
RegisterOffsetDescriptionReset Value
WTCON0x0000Watchdog timer control register0x0000_8021
WTDAT0x0004Watchdog timer data register0x0000_8000
WTCNT0x0008Watchdog timer count register0x0000_8000
WTCLRINT0x000CWatchdog timer interrupt clear registerUndefined

本次WDT实验主要是要验证在CPU正常运行时,程序间隔地往WDT中赋值,从而让WDT一直存在,当CPU出现错误时,WDT由于不会再被赋值从而减到0,产生复位信号。
主要用到WTCON和WTCNT两个寄存器。

2.1 WTCON

在这里插入图片描述

2.1WTCNT

在这里插入图片描述

3.WDT编程

#include "exynos_4412.h"
void delay(unsigned int Time)
{while(Time--);
}
int main()
{	/*设置一级分频*/WDT.WTCON = WDT.WTCON | (0xff << 8 );
//	WDT.WTCON = WDT./*设置二级分频*/WDT.WTCON = WDT.WTCON | (0x3 << 3);/**WTCNT递减频率 = pclk/256/128 = 3052** *//*禁止中断*/WDT.WTCON = WDT.WTCON & (~(1 << 2));/*使能WDT产生复位信号*/WDT.WTCON = WDT.WTCON | (1 << 0);/*设置计数器的值*/WDT.WTCNT = (3052 * 5);/*使能WDT,计数器开始递减*/WDT.WTCON = WDT.WTCON | (1 << 5);while(1){printf("WDT.WTCNT = %d\n",WDT.WTCNT);	/*喂狗*/WDT.WTCNT = 3052;delay(100000);}return 0;
}

这篇关于WDT实验的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/262291

相关文章

STM32(十一):ADC数模转换器实验

AD单通道: 1.RCC开启GPIO和ADC时钟。配置ADCCLK分频器。 2.配置GPIO,把GPIO配置成模拟输入的模式。 3.配置多路开关,把左面通道接入到右面规则组列表里。 4.配置ADC转换器, 包括AD转换器和AD数据寄存器。单次转换,连续转换;扫描、非扫描;有几个通道,触发源是什么,数据对齐是左对齐还是右对齐。 5.ADC_CMD 开启ADC。 void RCC_AD

HNU-2023电路与电子学-实验3

写在前面: 一、实验目的 1.了解简易模型机的内部结构和工作原理。 2.分析模型机的功能,设计 8 重 3-1 多路复用器。 3.分析模型机的功能,设计 8 重 2-1 多路复用器。 4.分析模型机的工作原理,设计模型机控制信号产生逻辑。 二、实验内容 1.用 VERILOG 语言设计模型机的 8 重 3-1 多路复用器; 2.用 VERILOG 语言设计模型机的 8 重 2-1 多

61.以太网数据回环实验(4)以太网数据收发器发送模块

(1)状态转移图: (2)IP数据包格式: (3)UDP数据包格式: (4)以太网发送模块代码: module udp_tx(input wire gmii_txc ,input wire reset_n ,input wire tx_start_en , //以太网开始发送信

LTspice模拟CCM和DCM模式的BUCK电路实验及参数计算

关于BUCK电路的原理可以参考硬件工程师炼成之路写的《 手撕Buck!Buck公式推导过程》.实验内容是将12V~5V的Buck电路仿真,要求纹波电压小于15mv. CCM和DCM的区别: CCM:在一个开关周期内,电感电流从不会到0. DCM:在开关周期内,电感电流总会到0. CCM模式Buck电路仿真: 在用LTspice模拟CCM电路时,MOS管驱动信号频率为100Khz,负载为10R(可自

HCIA--实验十:路由的递归特性

递归路由的理解 一、实验内容 1.需求/要求: 使用4台路由器,在AR1和AR4上分别配置一个LOOPBACK接口,根据路由的递归特性,写一系列的静态路由实现让1.1.1.1和4.4.4.4的双向通信。 二、实验过程 1.拓扑图: 2.步骤: (下列命令行可以直接复制在ensp) 1.如拓扑图所示,配置各路由器的基本信息: 各接口的ip地址及子网掩码,给AR1和AR4分别配置

OpenGL/GLUT实践:流体模拟——数值解法求解Navier-Stokes方程模拟二维流体(电子科技大学信软图形与动画Ⅱ实验)

源码见GitHub:A-UESTCer-s-Code 文章目录 1 实现效果2 实现过程2.1 流体模拟实现2.1.1 网格结构2.1.2 数据结构2.1.3 程序结构1) 更新速度场2) 更新密度值 2.1.4 实现效果 2.2 颜色设置2.2.1 颜色绘制2.2.2 颜色交互2.2.3 实现效果 2.3 障碍设置2.3.1 障碍定义2.3.2 障碍边界条件判定2.3.3 障碍实现2.3.

pta-2024年秋面向对象程序设计实验一-java

文章申明:作者也为初学者,解答仅供参考,不一定是最优解; 一:7-1 sdut-sel-2 汽车超速罚款(选择结构) 答案: import java.util.Scanner;         public class Main { public static void main(String[] arg){         Scanner sc=new Scanner(System

如何校准实验中振镜频率的漂移

在实验过程中,使用共振扫描振镜(如Cambridge Technology的8kHz振镜)时,频率漂移是一个常见问题,尤其是在温度变化或长期运行的情况下。为了确保实验的准确性和稳定性,我们需要采取有效的校准措施。本文将介绍如何监测、调节和校准振镜频率,以减少漂移对实验结果的影响。 1. 温度管理和稳定性控制 振镜的频率变化与温度密切相关,温度的升高会导致机械结构的变化,进而影响振镜的共

实验C语言“union”的最基础语法

目标 最近在看Rust的“菜鸟教程”,看到 Rust 枚举类 时我发现它所定义的“枚举类”虽然也能像C语言枚举类那样使用,但是多了些功能:对于某个枚举的成员,还可以附带独特的数据,这让我想起了C语言中的union。 而我事实上对union没有使用经验,我自己写程序的时候不用它,看其他的项目的程序时印象里也没见过它。所以我对union的设计意图理解不深(可能只是为了节省内存?)。本篇的目标是对其

Oracle高级压缩和透明数据加密组合实验

本文参考了实验DB Security - Advanced Compression with Transparent Data Encryption(TDE),其申请地址在这里。 本文只使用了实验中关于高级压缩和在线重定义的部分。并对要点进行说明及对实验进行了简化。 准备:环境设置 原文中的实验环境实际上是改自Oracle示例Sample Schema,其实唯一的改动就是去掉了SALES表中