草庐IT

痞子衡嵌入式:聊聊系统看门狗WDOG1在i.MXRT1xxx系统启动中的应用及影响

<font>痞子衡嵌入式 2023-03-28 原文

  大家好,我是痞子衡,是正经搞技术的痞子。今天痞子衡给大家介绍的是系统看门狗WDOG1在i.MXRT1xxx系统启动中的应用及影响

  软件看门狗模块(WDOG)在 MCU 应用里可以说是非常基础的功能模块。对于一个产品级的应用程序,如果它没有使能主控内部的看门狗模块,一般都不能算是一个合格的软件设计。有的时候,硬件工程师觉得软件看门狗不可靠,还会在板级设计里再加入外部看门狗电路。总之看门狗对于产品工作稳定性具有很重要的意义。

  最近有一个 i.MXRT 客户注意到了芯片手册 System Boot 章节里提及了 WDOG 应用,想使能这个功能,并且要确认该功能真实生效以及评估对后续应用程序的影响。借助客户的问题,我们来细聊下这个话题。

一、WDOG模块简介

  首先我们来了解一下 i.MXRT1xxx 系列内部的 WDOG 模块,在i.MXRT1xxx 内部 WDOG 模块一共有三个(WDOG1/2/3),虽然 WDOG 本质上就是个特殊功能定时器,但因为芯片设计时为其赋予的超时触发行为不同,所以其应用场合并不一样。

1.1 系统看门狗WDOG1/2

  WDOG1 和 WDOG2 属于系统看门狗,前者用于系统级复位(产生 WDOG_RESET_B_DEB 信号给 SRC 模块)防止系统发生异常,后者用于系统 SNVS 域安全警报(不会产生复位效果)。不过从模块寄存器角度,WDOG1 和 WDOG2 是一样的,因此除了超时触发行为外,它们其余方面特性是一样的:

1. 模块内部两个计数时钟源是固定的,来自 ipg_clk_32k 以及 anatop_xtal32k_clk 。
2. 模块内部 8bit 定时器(Time-Out Counter)用于产生 WDOG_RESET_B_DEB 复位信号,计时精度固定为 0.5 秒,超时可设范围为 0.5 秒到 128 秒。
3. 模块内部定时器(Power Down Counter)用于产生对外输出的复位信号 WDOG_B,其超时时间固定为 16 秒。
4. 模块对外输出的信号最多有三个: WDOG_RST_B_DEB、WDOG_B、WDOG_ANY(仅 WDOG1)。
5. 模块使能信号 WDOGx->WCR[WDE] 可多次设置(并不是一次复位期间仅可 write one once)。
6. 模块配置寄存器与定时器计数值可直接修改。
7. 模块 Time-Out Counter 默认是关闭的,Power Down Counter 默认是开启的。

1.2 内核看门狗WDOG3(4)

  WDOG3 有时候又叫 RTWDOG(对于 RT1170,还存在用于默认 CM4 从核的 WDOG4),属于内核看门狗,主要用于复位内核,防止程序陷入死循环。其模块寄存器跟 WDOG1/2 完全不同,更接近于一般的定时器模块设计:

1. 模块内部计数时钟源有四种选择,Bus clock / LPO clock / INTCLK / ERCLK 。
2. 模块内部 16bit 定时器(Time-Out Counter)用于产生内核复位信号。
3. 模块使能信号 WDOGx->CS[EN] 可多次设置(但是其属于 write-once 属性)。
4. 模块配置寄存器 write-once bits 与定时器计数值需要特殊 unlock 时序才可以修改。
5. 模块 Time-Out Counter 默认是开启的。

二、系统ROM里对WDOG的使用

  i.MXRT1xxx 系列芯片上电默认都是先执行系统 BootROM,在 BootROM 里会有对看门狗的处理。默认情况下 BootROM 是不启用看门狗做代码执行守护的,只有当用户烧写了指定的 eFuse 位,看门狗功能才会生效。BootROM 并没有使用默认开启的 WDOG3,而是将其关闭并打开了 WDOG1 作为看门狗。

2.1 看门狗使能

  i.MXRT10xx 系列芯片 BootROM 看门狗在 eFuse 里配置如下,包含 eFuse 0x460[21] 使能位与 eFuse 0x6D0[15:13] 超时时间设置。

  i.MXRT1160/1170 芯片 BootROM 看门狗在 eFuse 里配置如下,包含 eFuse 0x9A0[15] 使能位与 eFuse 0x9B0[2:0] 超时时间设置,以及多了 eFuse 0x9B0[5:3] 关于 WDOG_B 外部信号脚选择设置。

  当 Fuse 里使能了看门狗功能后,BootROM 对看门狗模块的配置如下:

void ROM_WDOG_init(void)
{
    uint16_t timeout = get_timeout_value_from_fuse();

    WDOG1->WCR = (uint16_t)(WDOG_WCR_WT(timeout)
                           | WDOG_WCR_WDW_MASK
                           | WDOG_WCR_SRE_MASK
                           | WDOG_WCR_WDA_MASK
                           | WDOG_WCR_WDBG_MASK
                           | WDOG_WCR_SRS_MASK);

    WDOG1->WCR |= (uint16_t)WDOG_WCR_WDE_MASK;
}

2.2 看门狗作用

  对于 i.MXRT10xx 系列,BootROM 看门狗主要用于 Serial Downloader 分支程序下(SDP 模式 BT_MODE = 2'b01,或者 Device Boot 模式 BT_MODE = 2'bx0 下启动失败进入了 Serial Downloader)检测与主机通讯情况,只要在设置的超时时间里没有通信交互行为,看门狗就会复位整个系统(并不是单次通信就可以的,任意超时时间内都得保持交互)。如果在 Device Boot 模式下能够正常启动程序,则看门狗不会被使能。

  对于 i.MXRT1160/1170 系列,BootROM 看门狗不仅在 Serial Downloader 分支程序中有效,其在 Device Boot 模式下(BT_MODE = 2'bx0)也同样被使能了,这样做主要有两个用意:

  • 用意1: 如果因板级电路干扰导致首次启动程序失败,BootROM 正常是直接跳转到了 SDP 模式不会再做启动程序行为。但是使能了看门狗,则在 SDP 模式下等待超时时间后系统复位会重新尝试启动程序,这样不断尝试直到板级干扰消失。
  • 用意2: 如果启动程序成功,BootROM 会直接跳转到目标应用程序,但无法检验目标程序是否能够正常执行。但是使能了看门狗,如果应用程序不对看门狗做有效处理,系统还是会复位回来,这样相当于做了应用程序是否执行的验证。

三、WDOG使能后对i.MXRT开发的影响

  现在回到文章开头提到的客户问题,如何判断 BootROM 中 WDOG 已经生效了,这个其实特别简单,在 SDP 模式下插上 USB 线,在资源管理器里观察是不是有 HID 设备每隔一段时间就会重新枚举一次,没错就是 WDOG 捣的鬼。

  那么对于应用程序的开发,有什么注意事项呢?对于 i.MXRT10xx 其实没有任何影响,而对于 i.MXRT1160/1170,则必须在应用程序里增加对 WDOG1 的处理。在恩智浦提供的头文件 system_MIMXRT1xxx.c 文件里 SystemInit() 函数中其实有关于看门狗相关代码,默认是将全部的看门狗都关一遍(DISABLE_WDOG=1),这部分代码对于 i.MXRT10xx 程序是可以不做的,但是对于 i.MXRT1160/1170 就必须要做了。

  至此,系统看门狗WDOG1在i.MXRT1xxx系统启动中的应用及影响痞子衡便介绍完毕了,掌声在哪里~~~

欢迎订阅

文章会同时发布到我的 博客园主页CSDN主页知乎主页微信公众号 平台上。

微信搜索"痞子衡嵌入式"或者扫描下面二维码,就可以在手机上第一时间看了哦。

有关痞子衡嵌入式:聊聊系统看门狗WDOG1在i.MXRT1xxx系统启动中的应用及影响的更多相关文章

  1. ruby - 将差异补丁应用于字符串/文件 - 2

    对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl

  2. ruby-on-rails - Rails 应用程序之间的通信 - 2

    我构建了两个需要相互通信和发送文件的Rails应用程序。例如,一个Rails应用程序会发送请求以查看其他应用程序数据库中的表。然后另一个应用程序将呈现该表的json并将其发回。我还希望一个应用程序将存储在其公共(public)目录中的文本文件发送到另一个应用程序的公共(public)目录。我从来没有做过这样的事情,所以我什至不知道从哪里开始。任何帮助,将不胜感激。谢谢! 最佳答案 无论Rails是什么,几乎所有Web应用程序都有您的要求,大多数现代Web应用程序都需要相互通信。但是有一个小小的理解需要你坚持下去,网站不应直接访问彼此

  3. ruby - 无法运行 Rails 2.x 应用程序 - 2

    我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby​​:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r

  4. ruby-on-rails - Rails 应用程序中的 Rails : How are you using application_controller. rb 是新手吗? - 2

    刚入门rails,开始慢慢理解。有人可以解释或给我一些关于在application_controller中编码的好处或时间和原因的想法吗?有哪些用例。您如何为Rails应用程序使用应用程序Controller?我不想在那里放太多代码,因为据我了解,每个请求都会调用此Controller。这是真的? 最佳答案 ApplicationController实际上是您应用程序中的每个其他Controller都将从中继承的类(尽管这不是强制性的)。我同意不要用太多代码弄乱它并保持干净整洁的态度,尽管在某些情况下ApplicationContr

  5. ruby-on-rails - 如何在我的 Rails 应用程序 View 中打印 ruby​​ 变量的内容? - 2

    我是一个Rails初学者,但我想从我的RailsView(html.haml文件)中查看Ruby变量的内容。我试图在ruby​​中打印出变量(认为它会在终端中出现),但没有得到任何结果。有什么建议吗?我知道Rails调试器,但更喜欢使用inspect来打印我的变量。 最佳答案 您可以在View中使用puts方法将信息输出到服务器控制台。您应该能够在View中的任何位置使用Haml执行以下操作:-puts@my_variable.inspect 关于ruby-on-rails-如何在我的R

  6. ruby-on-rails - 添加回形针新样式不影响旧上传的图像 - 2

    我有带有Logo图像的公司模型has_attached_file:logo我用他们的Logo创建了许多公司。现在,我需要添加新样式has_attached_file:logo,:styles=>{:small=>"30x15>",:medium=>"155x85>"}我是否应该重新上传所有旧数据以重新生成新样式?我不这么认为……或者有什么rake任务可以重新生成样式吗? 最佳答案 参见Thumbnail-Generation.如果rake任务不适合你,你应该能够在控制台中使用一个片段来调用重新处理!关于相关公司

  7. ruby-on-rails - 如何在 Gem 中获取 Rails 应用程序的根目录 - 2

    是否可以在应用程序中包含的gem代码中知道应用程序的Rails文件系统根目录?这是gem来源的示例:moduleMyGemdefself.included(base)putsRails.root#returnnilendendActionController::Base.send:include,MyGem谢谢,抱歉我的英语不好 最佳答案 我发现解决类似问题的解决方案是使用railtie初始化程序包含我的模块。所以,在你的/lib/mygem/railtie.rbmoduleMyGemclassRailtie使用此代码,您的模块将在

  8. 世界前沿3D开发引擎HOOPS全面讲解——集3D数据读取、3D图形渲染、3D数据发布于一体的全新3D应用开发工具 - 2

    无论您是想搭建桌面端、WEB端或者移动端APP应用,HOOPSPlatform组件都可以为您提供弹性的3D集成架构,同时,由工业领域3D技术专家组成的HOOPS技术团队也能为您提供技术支持服务。如果您的客户期望有一种在多个平台(桌面/WEB/APP,而且某些客户端是“瘦”客户端)快速、方便地将数据接入到3D应用系统的解决方案,并且当访问数据时,在各个平台上的性能和用户体验保持一致,HOOPSPlatform将帮助您完成。利用HOOPSPlatform,您可以开发在任何环境下的3D基础应用架构。HOOPSPlatform可以帮您打造3D创新型产品,HOOPSSDK包含的技术有:快速且准确的CAD

  9. 叮咚买菜基于 Apache Doris 统一 OLAP 引擎的应用实践 - 2

    导读:随着叮咚买菜业务的发展,不同的业务场景对数据分析提出了不同的需求,他们希望引入一款实时OLAP数据库,构建一个灵活的多维实时查询和分析的平台,统一数据的接入和查询方案,解决各业务线对数据高效实时查询和精细化运营的需求。经过调研选型,最终引入ApacheDoris作为最终的OLAP分析引擎,Doris作为核心的OLAP引擎支持复杂地分析操作、提供多维的数据视图,在叮咚买菜数十个业务场景中广泛应用。作者|叮咚买菜资深数据工程师韩青叮咚买菜创立于2017年5月,是一家专注美好食物的创业公司。叮咚买菜专注吃的事业,为满足更多人“想吃什么”而努力,通过美好食材的供应、美好滋味的开发以及美食品牌的孵

  10. 电脑0x0000001A蓝屏错误怎么U盘重装系统教学 - 2

      电脑0x0000001A蓝屏错误怎么U盘重装系统教学分享。有用户电脑开机之后遇到了系统蓝屏的情况。系统蓝屏问题很多时候都是系统bug,只有通过重装系统来进行解决。那么蓝屏问题如何通过U盘重装新系统来解决呢?来看看以下的详细操作方法教学吧。  准备工作:  1、U盘一个(尽量使用8G以上的U盘)。  2、一台正常联网可使用的电脑。  3、ghost或ISO系统镜像文件(Win10系统下载_Win10专业版_windows10正式版下载-系统之家)。  4、在本页面下载U盘启动盘制作工具:系统之家U盘启动工具。  U盘启动盘制作步骤:  注意:制作期间,U盘会被格式化,因此U盘中的重要文件请注

随机推荐