LV.12 D15 WDT实验 学习笔记

这篇具有很好参考价值的文章主要介绍了LV.12 D15 WDT实验 学习笔记。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

 一、WDT简介

WDT

        Watch Dog Timer即看门狗定时器,其主要作用是当发生软件故障时可产生复位信号使SOC复位,其本质是一个计数器 

 LV.12 D15 WDT实验 学习笔记,学习,笔记,arm开发

LV.12 D15 WDT实验 学习笔记,学习,笔记,arm开发

工作原理

        CPU正常工作时,需要定时往看门狗计数器里刷新一个比较大的值,来保证看门狗计数器中的值不会减到0。CPU一旦遇到错误后,就没办法刷新看门狗计数器的值,减到0之后,就会向CPU发送复位信号,让CPU复位。

二、Exynos_4412下的WDT控制器

 LV.12 D15 WDT实验 学习笔记,学习,笔记,arm开发

LV.12 D15 WDT实验 学习笔记,学习,笔记,arm开发 

        看门狗计时器使用的原始时钟是100MHz的PCLK,接着提供了两个预分频器,一级分频器能存储0-255,所以可以降低1-256倍,通过WTCON[15:8]来设置,二级分频器可以在一级分频器的基础上再进行固定倍数降低,通过WTCON[4:3]来设置。WTCNT会按照这个频率往下减,减到0后,会对外发送信号,由WTCON[2]和WTCON[0]来决定发送的是中断信号还是复位信号。

LV.12 D15 WDT实验 学习笔记,学习,笔记,arm开发

 周期的计算公式:1/(PCLK/(一级分频器+1)/二级分频器)

周期是频率的倒数

三、WDT寄存器详解

 LV.12 D15 WDT实验 学习笔记,学习,笔记,arm开发

WTCON:控制看门狗定时器的功能

WTCNT: 存储递减寄存器中的值

WTDAT和WTCLRINT用于中断,本次实验主要使用复位功能,暂时用不上。

LV.12 D15 WDT实验 学习笔记,学习,笔记,arm开发

LV.12 D15 WDT实验 学习笔记,学习,笔记,arm开发

 四、WDT编程

先新建一个工程文件

LV.12 D15 WDT实验 学习笔记,学习,笔记,arm开发

 interface.c

#include "exynos_4412.h"

void Delay(unsigned int Time)
{
	while(Time--);
}

int main()
{
	/*设置一级分频*/
	WDT.WTCON = WDT.WTCON | (0xFF << 8);
	/*设置二级分频器*/
	WDT.WTCON = WDT.WTCON | (0x3 << 3);
	/*WTCON递减频率 = PLCK(100000000)/(0xFF + 1)/128
	 * 				= 3052
	 */
	/*禁止WDT产生中断信号*/
	WDT.WTCON = WDT.WTCON & (~(1 << 2));
	/*使能WDT产生复位信号*/
	WDT.WTCON = WDT.WTCON | 1;
	/*设置计数器的值*/
	WDT.WTCNT = (3052 * 5);
	/*使能WDT,计数器开始递减*/
	WDT.WTCON = WDT.WTCON | (1 << 5);

	while(1)
	{
		printf("WDT.WTCNT = %d\n", WDT.WTCNT);
		Delay(100000);
	}
	return 0;
}

LV.12 D15 WDT实验 学习笔记,学习,笔记,arm开发

 

#include "exynos_4412.h"

void Delay(unsigned int Time)
{
	while(Time--);
}

int main()
{
	/*设置一级分频*/
	WDT.WTCON = WDT.WTCON | (0xFF << 8);
	/*设置二级分频器*/
	WDT.WTCON = WDT.WTCON | (0x3 << 3);
	/*WTCON递减频率 = PLCK(100000000)/(0xFF + 1)/128
	 * 				= 3052
	 */
	/*禁止WDT产生中断信号*/
	WDT.WTCON = WDT.WTCON & (~(1 << 2));
	/*使能WDT产生复位信号*/
	WDT.WTCON = WDT.WTCON | 1;
	/*设置计数器的值*/
	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;
}

LV.12 D15 WDT实验 学习笔记,学习,笔记,arm开发

此时只有程序出错,导致不能喂狗,才会复位。文章来源地址https://www.toymoban.com/news/detail-740072.html

到了这里,关于LV.12 D15 WDT实验 学习笔记的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • verilog学习笔记- 15)动态数码管显示实验

    目录 简介: 实验任务: 硬件设计: 程序设计: 下载验证: 由于一般的静态驱动操作虽然方便,但占用的 I/0 口较多,例如要驱动6 位 8 段数码管,以静态驱动方式让数码管各个位显示不同的数值,如“123456”,需要占用6 × 8 = 48个I/O 口,虽然对于 FPGA 这种 I/O 口较多的芯片

    2024年02月07日
    浏览(48)
  • 物联网||不一样的点灯实验(2)|通过使用CMSIS库函数实现点灯实验-学习笔记(12)

    根据 Enable the GPIO AHB clock using the following function: __HAL_RCC_GPIOx_CLK_ENABLE(). 初始化需首先调用 __HAL_RCC_GPIOx_CLK_ENABLE() 需要将头文件包含在代码中去。 加入初始化stm32f4xx_hal_gpio.c中的void HAL_GPIO_Init(GPIO_TypeDef *GPIOx, GPIO_InitTypeDef *GPIO_Init),增加函数:HAL_GPIO_Init(GPIO_TypeDef *GPIOx, GPIO_Ini

    2024年02月14日
    浏览(50)
  • ARM day7 day8 UART串口、PWM蜂鸣器、WDT看门狗、ADC数模转换

            GPA1_0: RXD2         GPA1_1: TXD2         1)对外设置 (GPIO)             GPA1CON: 0x11400020   3:0-0x2(RXD2)  7:4-0x2(TXD2)         2)对内设置(uart)             ULCON2: 0x13820000   0x3             UCON2:  0x13820004   1:0-01(polling)  3:2-01(polling)             UTRSTAT2: 0-1(r

    2024年02月21日
    浏览(37)
  • QT学习笔记-oracle oci数据库驱动交叉编译并移植到ARM开发板

    在上一文《QT学习笔记-QT安装oracle oci驱动》中介绍了在Windows环境下使用QT访问oracle数据库时遇到驱动无法加载问题的解决办法,大体思路是对QT源码中数据库驱动的源码oci进行编译,要想通过编译需要依赖对应数据库的头文件和库(可以通过下载oracle instant client),编译通过

    2024年02月13日
    浏览(57)
  • 【ARM64 常见汇编指令学习 12 -- ARM 汇编函数 的学习】

    上篇文章:ARM64 常见汇编指令学习 11 – ARM 汇编宏 .macro 的学习 下篇文章:ARM64 常见汇编指令学习 13 – ARM 汇编 ORG 伪指令学习 ARM汇编中的函数定义并不像高级语言那样有特定的语法,但通常可以通过 标签(label) 和 子程序调用指令 (如BL,BLX) 来实现类似于函数的功能。 例如

    2024年02月14日
    浏览(49)
  • 实验四 QUARTUS开发环境实验 设计半加器、全加器和四位全加器 blueee的学习笔记

    一、实验目的 1、通过实验,能熟悉QUARTUS开发环境,能够掌握QUARTUS的原理图输入法设计电路,掌握使用相关仿真工具进行功能和时序仿真的方法; 2、通过实验,加深对全加器电路的理解,并能使用QUARTUS的原理图输入法完成全加器的设计,并能在QUARTUS中完成相关的仿真验证

    2024年02月05日
    浏览(98)
  • 【C++练级之路】【Lv.15】AVL树(双子旋转,领略绝对平衡之美)

    快乐的流畅:个人主页 个人专栏:《C语言》《数据结构世界》《进击的C++》 远方有一堆篝火,在为久候之人燃烧! 之前讲解了二叉搜索树,最优情况下它具有非常好的搜索性能,但是在极端场景下,它可能退化为单支树,可以形象地称为歪脖子树~ 这样的话,它搜索的时间

    2024年03月25日
    浏览(40)
  • Qt5.12.6配置Android Arm开发环境(Linux)

    1.安装jdk 2.安装android studio 3.安装sdk 与ndk  设置代理  安装SDK工具  安装SDK Platform 安装QT   选择JDK 1.8安装路径,SDK与NDK路径  如出现Platform SDK或者Platform Build Tools未安装,点击Update Installed  配置成功后可看到ARMv7与AMD-v8a kits Qt Version也可看到ARMv7与AMD-v8a   如果 有安装了CMake,也

    2024年01月21日
    浏览(51)
  • 【ARM AMBA5 CHI 入门 12 -- CHI 总线学习 】

    请阅读 【ARM AMBA 总线 文章专栏导读】

    2024年02月10日
    浏览(46)
  • 【ARM AMBA5 CHI 入门 12 -- CHI 基础学习 】

    请阅读 【ARM AMBA 总线 文章专栏导读】

    2024年02月06日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包