【嵌入式】窗户看门狗定时器概念详解+例题解析

简介: 题目嵌入式系统使用WWDG窗口看门狗模块监视用户程序运行,假设看门狗的喂狗时间为20ms,PCLK1频率为36MHz,WDGTB[1:0]=10b。请计算看门狗的定时计数值(给出计算过程),并写出看门狗的初始化函数(注:使用寄存器方式程序)
本文首发于稀土掘金。该平台的作者 逐光而行 也是本人。

题目

嵌入式系统使用WWDG窗口看门狗模块监视用户程序运行,假设看门狗的喂狗时间为20ms,PCLK1频率为36MHz,WDGTB[1:0]=10b。请计算看门狗的定时计数值(给出计算过程),并写出看门狗的初始化函数(注:使用寄存器方式程序)

看门狗定时器工作原理

image.png

  1. 该值由其中的WDGTB位决定。如WDGTB[1:0]=10b,则分的频数为$2^2=4$
  2. WWDG_CFR寄存器详情:

image.png

  1. WWDG_CR寄存器详情:

image.png

  1. WWDG_SR寄存器

看门狗中断时该位为1,可手动写入0清0该位
image.png

  1. 补充

image.png

计算看门狗的定时计数值

有如下公式成立:
image.png

定时计数值指的是T[5:0]+1。

题目给的喂狗时间就是Twwdg

所以可求出定时计数值是43(10),即0x2B(16)

后面赋值 CR的时候要加上基值0x40

初始化函数主体部分的编写及代码解析

RCC->APB1ENR |=(1ul<<11);

RCC_APB1ENR的第11位置1,表示打开看门狗定时器时钟源

wwDG->CR=0X6B;

给看门狗计数器赋初值为0x6B

wwDG->CFR=(1uL<<9)|(2uL<<7)|(0x7F<<0);

  • 给wwDG_CFR第9位置1(设置看门狗中断位);
  • 2表示1/4分频;
  • 设置窗口大小为0x7F(即后六位 最大 值),使T[6:0]始终小于窗口值,使窗口值不起作用

wwDG->SR=0;
当发生看门狗中断时,该位变为1,初始先手动置0

wwDG->CR|=(1uL<<7);
wwDG_CR 第7位置1,启动看门狗

NVIC_EnableIRQ(wwDG_IRQn);
调用CMSIS库函数打开看门狗NVIC中断

完整代码如下:如有需要自取:

void wwDoginit(void){
    RCC->APB1ENR |=(1ul<<11);
    wwDG->CR=0X6B;
    wwDG->CFR=(1uL<<9)|(3uL<<7)|(0x7F<<0);
    wwDG->SR=0;
    wwDG->CR|=(1uL<<7);
    NVIC_EnableIRQ(wwDG_IRQn);
}

后记

看学校发的ppt文字描述看得我云里雾里,最终忍不住抽出一点时间把文字梳理成了图像,并且结合例题去理解。整理不易,希望也可以帮到大家!如有错误,恳请指出哈~!

附录

上述自己画的图可能还不够清晰和准确,以下补充STMA32F103手册中相关位的含义图,分别对应于各行代码。

RCC_APB1ENR 开启看门狗
image.png

WWDG_CR 设置定时计数值且启用看门狗

image.png

WWDG_CFR

image.png

相关文章
|
存储 JSON 数据格式
ElasticSearch基础概念解析
以上就是ElasticSearch的基础概念。理解了这些概念,你就可以更好地使用ElasticSearch,像使用超级放大镜一样,在数据海洋中找到你需要的珍珠。
365 71
|
XML Java 开发者
Spring底层架构核心概念解析
理解 Spring 框架的核心概念对于开发和维护 Spring 应用程序至关重要。IOC 和 AOP 是其两个关键特性,通过依赖注入和面向切面编程实现了高效的模块化和松耦合设计。Spring 容器管理着 Beans 的生命周期和配置,而核心模块为各种应用场景提供了丰富的功能支持。通过全面掌握这些核心概念,开发者可以更加高效地利用 Spring 框架开发企业级应用。
456 18
|
调度 开发者
核心概念解析:进程与线程的对比分析
在操作系统和计算机编程领域,进程和线程是两个基本而核心的概念。它们是程序执行和资源管理的基础,但它们之间存在显著的差异。本文将深入探讨进程与线程的区别,并分析它们在现代软件开发中的应用和重要性。
584 4
|
消息中间件 存储 负载均衡
Apache Kafka核心概念解析:生产者、消费者与Broker
【10月更文挑战第24天】在数字化转型的大潮中,数据的实时处理能力成为了企业竞争力的重要组成部分。Apache Kafka 作为一款高性能的消息队列系统,在这一领域占据了重要地位。通过使用 Kafka,企业可以构建出高效的数据管道,实现数据的快速传输和处理。今天,我将从个人的角度出发,深入解析 Kafka 的三大核心组件——生产者、消费者与 Broker,希望能够帮助大家建立起对 Kafka 内部机制的基本理解。
650 2
|
算法 Java 数据库连接
Java连接池技术,从基础概念出发,解析了连接池的工作原理及其重要性
本文详细介绍了Java连接池技术,从基础概念出发,解析了连接池的工作原理及其重要性。连接池通过复用数据库连接,显著提升了应用的性能和稳定性。文章还展示了使用HikariCP连接池的示例代码,帮助读者更好地理解和应用这一技术。
318 1
|
存储 NoSQL MongoDB
MongoDB 概念解析
10月更文挑战第12天
377 0
MongoDB 概念解析
|
供应链 网络协议 数据安全/隐私保护
|
算法 测试技术 C语言
深入理解HTTP/2:nghttp2库源码解析及客户端实现示例
通过解析nghttp2库的源码和实现一个简单的HTTP/2客户端示例,本文详细介绍了HTTP/2的关键特性和nghttp2的核心实现。了解这些内容可以帮助开发者更好地理解HTTP/2协议,提高Web应用的性能和用户体验。对于实际开发中的应用,可以根据需要进一步优化和扩展代码,以满足具体需求。
1283 29
|
前端开发 数据安全/隐私保护 CDN
二次元聚合短视频解析去水印系统源码
二次元聚合短视频解析去水印系统源码
526 4
|
JavaScript 算法 前端开发
JS数组操作方法全景图,全网最全构建完整知识网络!js数组操作方法全集(实现筛选转换、随机排序洗牌算法、复杂数据处理统计等情景详解,附大量源码和易错点解析)
这些方法提供了对数组的全面操作,包括搜索、遍历、转换和聚合等。通过分为原地操作方法、非原地操作方法和其他方法便于您理解和记忆,并熟悉他们各自的使用方法与使用范围。详细的案例与进阶使用,方便您理解数组操作的底层原理。链式调用的几个案例,让您玩转数组操作。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~

推荐镜像

更多
  • DNS