当前位置: 首页 > news >正文

uboot - 驱动开发 - dw watchdog

说明

  • 公司SOC使用的watchdog模块是新思(Synopsys)的IP。

需求

  • 用户有时会在uboot/kernel中做些开发,新增一些功能(OTA升级等),可能会出现uboot/kernel启动崩溃甚至设备死机等问题,需要在uboot启动阶段开启watchdog监控设备运行实现异常后复位。

实现

  • 前提:dts watchdog节点配置ok。
  • 由于历史原因,根据是否支持DM(Driver model),uboot原生支持两种wdt驱动和使用的配置/实现方式。
  1. 不支持DM,常见于较早版本(uboot,wdt驱动)实现
核心配置项:CONFIG_HW_WATCHDOG
  1. 支持DM
核心配置项:CONFIG_WDT// file: drivers/watchdog/Kconfig
config WDTbool "Enable driver model for watchdog timer drivers"depends on DM....    

不支持DM

配置项

  1. 核心配置
CONFIG_HW_WATCHDOG 
  1. wdt timeout时间
CONFIG_WATCHDOG_TIMEOUT_MSECS
  1. 具体型号的wdt,例如:dw wdt。
CONFIG_DESIGNWARE_WATCHDOG
  • 如果未配置支持DM(CONFIG_WDT),但是配置了硬件wdt,CONFIG_HW_WATCHDOG会自动选上,例如:
config DESIGNWARE_WATCHDOGbool "Designware watchdog timer support"select HW_WATCHDOG if !WDT...

驱动代码

  1. 定义并实现驱动相关功能接口
//file: drivers/watchdog/designware_wdt.c
static int designware_wdt_settimeout(unsigned int timeout)
{....
}static void designware_wdt_enable(void)
{....
}static void designware_wdt_disable(void)
{....
}static unsigned int designware_wdt_is_enabled(void)
{....
}
  1. 定义实现对外接口
//file: drivers/watchdog/designware_wdt.c
#if defined(CONFIG_HW_WATCHDOG)
void hw_watchdog_reset(void)
{...
}void hw_watchdog_init(void)
{// 初始化wdt,并enable...
}void hw_watchdog_disable(void)
{...
}
#endif

uboot中使用

  1. 头文件(watchdog.h)中会定义统一的宏(WATCHDOG_RESET、WATCHDOG_DISABLE)指向驱动文件中实现的hw对外接口,具体使用后面统一说明。
// file: include/watchdog.h
#if defined(CONFIG_WATCHDOG) || defined(CONFIG_HW_WATCHDOG)
#define INIT_FUNC_WATCHDOG_INIT init_func_watchdog_init,
#define INIT_FUNC_WATCHDOG_RESET        init_func_watchdog_reset,
#else
#define INIT_FUNC_WATCHDOG_INIT
#define INIT_FUNC_WATCHDOG_RESET
#endif#ifdef CONFIG_HW_WATCHDOG#if defined(__ASSEMBLY__)#define WATCHDOG_RESET bl hw_watchdog_reset#elseextern void hw_watchdog_reset(void);extern void hw_watchdog_disable(void);#define WATCHDOG_RESET hw_watchdog_reset#define WATCHDOG_DISABLE hw_watchdog_disable#endif /* __ASSEMBLY__ */
#else....
#endif
  1. 由于不支持DM,wdt-uclass.c(DM接口)未使用。

验证

  • 这种方式,整体上执行流程比较固定,uboot启动wdt就会自动运行,支持配置项较少,验证方法只能代码调试。
  • 由于不支持DM,这种模式,不支持wdt cmd。

支持DM

配置项

  1. 核心配置
CONFIG_WDT
CONFIG_WATCHDOG // enable uboot内部使用的喂狗接口,该方式下必需enable
  • 配置CONFIG_WDT后会自动开启CONFIG_WATCHDOG, 如下:
// file: drivers/watchdog/Kconfig
config WDTbool "Enable driver model for watchdog timer drivers"depends on DMimply WATCHDOG...
  1. 自动启动配置(可选配置)
CONFIG_WATCHDOG_AUTOSTART=y   // 自动启动
CONFIG_WATCHDOG_TIMEOUT_MSECS //wdt timeout时间, 默认60s
  1. 具体型号的wdt,例如:dw wdt。
CONFIG_DESIGNWARE_WATCHDOG

驱动代码

  1. 按照DM模型,实现probe等相关接口
  2. 实现DM定义的 wdt 操作接口
//file: include/wdt.h
struct wdt_ops {int (*start)(struct udevice *dev, u64 timeout_ms, ulong flags);int (*stop)(struct udevice *dev);int (*reset)(struct udevice *dev);int (*expire_now)(struct udevice *dev, ulong flags);
}

uboot中使用

  1. wdt cmd使用的是wdt-uclass.c中的统一接口,wdt-uclass.c中的函数再调用具体驱动的接口。
  2. 头文件(watchdog.h)中会定义统一的宏(WATCHDOG_RESET)指向wdt-uclass.c中实现的对外喂狗接口,具体使用后面统一说明。
// file: include/watchdog.h
#ifdef CONFIG_HW_WATCHDOG...
#else/** Maybe a software watchdog?*/#if defined(CONFIG_WATCHDOG)#if defined(__ASSEMBLY__)#define WATCHDOG_RESET bl watchdog_reset#else/* Don't require the watchdog to be enabled in SPL */#if defined(CONFIG_SPL_BUILD) &&                \!defined(CONFIG_SPL_WATCHDOG)#define WATCHDOG_RESET() {}#elseextern void watchdog_reset(void);#define WATCHDOG_RESET watchdog_reset#endif#endif#else/** No hardware or software watchdog.*/#if defined(__ASSEMBLY__)#define WATCHDOG_RESET /*XXX DO_NOT_DEL_THIS_COMMENT*/#else#define WATCHDOG_RESET() {}#endif /* __ASSEMBLY__ */#endif /* CONFIG_WATCHDOG && !__ASSEMBLY__ */
#endif /* CONFIG_HW_WATCHDOG */

验证

  1. 使用cli命令验证
  • enable wdt命令(cmdline)
CONFIG_CMD_WDT=y // wdt cmd
  • 运行效果
uboot# wdt 
wdt - Watchdog sub-systemUsage:
wdt list - list watchdog devices
wdt dev [<name>] - get/set current watchdog device
wdt start <timeout ms> [flags] - start watchdog timer
wdt stop - stop watchdog timer
wdt reset - reset watchdog timer
wdt expire [flags] - expire watchdog timer immediatelyuboot# wdt list
dw-wd@0x27000000 (designware_wdt) // dts配置
uboot# wdt dev dw-wd@0x27000000
uboot# wdt start 30000

uboot中使用

  • 两种配置(是否支持DM)方式,uboot中都是使用统一的宏(WATCHDOG_RESET等)去操作wdt,不同的是宏指向的函数。
  1. 不支持DM,WATCHDOG_RESET指向的是wdt驱动中hw_watchdog_reset函数。
  2. 支持DM,WATCHDOG_RESET指向的是wdt-uclass.c中watchdog_reset函数。
  • uboot初始化时会主动调用INIT_FUNC_WATCHDOG_INIT初始化wdt,不支持DM配置(CONFIG_HW_WATCHDOG),wdt初始化时会直接enable wdt。
//file: common/board_f.c
#if defined(CONFIG_WATCHDOG) || defined(CONFIG_HW_WATCHDOG)
static int init_func_watchdog_init(void)
{
# if defined(CONFIG_HW_WATCHDOG) && \(defined(CONFIG_M68K) || defined(CONFIG_MICROBLAZE) || \defined(CONFIG_SH) || \defined(CONFIG_DESIGNWARE_WATCHDOG) || \defined(CONFIG_IMX_WATCHDOG))hw_watchdog_init(); //该函数,默认实现会配置好wdt,并enableputs("       Watchdog enabled\n");
# endifWATCHDOG_RESET();return 0;
}int init_func_watchdog_reset(void)
{WATCHDOG_RESET();return 0;
}
#endif /* CONFIG_WATCHDOG */
  • uboot是裸机程序,所有操作都是顺序执行,开启wdt后,如有耗时操作需要自己调用WATCHDOG_RESET进行喂狗,进到cli时,uboot cli会间隔调用WATCHDOG_RESET喂狗。

相关文章:

  • 无梯度强化学习:使用遗传算法进化代理
  • 【服务配置文件详解】补充rsyslog服务的配置文件翻译解读
  • 【hcie-cloud】【5】华为云Stack规划设计之华为云Stack标准化配置、缩略语【下】
  • 前端Vue 结合xlxs库实现解析excel文件,并动态组装表头!
  • CMakeFiles文件夹有什么用
  • Xmake v2.8.5 发布,支持链接排序和单元测试
  • 5G毫米波通信中的关键技术
  • 3D物理模拟和视觉特效软件SideFX Houdini mac中文介绍
  • 什么是记忆能力与泛化能力
  • Mac电脑Visio文件编辑查看软件推荐Visio Viewer for Mac
  • C++多态特性
  • 揭秘南卡开放式耳机创新黑科技,核心技术剑指用户痛点
  • RAW图像处理软件Capture One 23 Enterprise mac中文版功能特点
  • Linux学习教程(第一章 简介)1
  • VR全景技术,为养老院宣传推广带来全新变革
  • ES学习笔记(10)--ES6中的函数和数组补漏
  • EventListener原理
  • idea + plantuml 画流程图
  • JavaSE小实践1:Java爬取斗图网站的所有表情包
  • SpingCloudBus整合RabbitMQ
  • UEditor初始化失败(实例已存在,但视图未渲染出来,单页化)
  • vuex 学习笔记 01
  • 安卓应用性能调试和优化经验分享
  • 基于Vue2全家桶的移动端AppDEMO实现
  • 开源SQL-on-Hadoop系统一览
  • 看图轻松理解数据结构与算法系列(基于数组的栈)
  • 力扣(LeetCode)21
  • 使用Envoy 作Sidecar Proxy的微服务模式-4.Prometheus的指标收集
  • 腾讯大梁:DevOps最后一棒,有效构建海量运营的持续反馈能力
  • 为物联网而生:高性能时间序列数据库HiTSDB商业化首发!
  • Redis4.x新特性 -- 萌萌的MEMORY DOCTOR
  • 阿里云移动端播放器高级功能介绍
  • 长三角G60科创走廊智能驾驶产业联盟揭牌成立,近80家企业助力智能驾驶行业发展 ...
  • 机器人开始自主学习,是人类福祉,还是定时炸弹? ...
  • # 飞书APP集成平台-数字化落地
  • #ifdef 的技巧用法
  • (1)(1.8) MSP(MultiWii 串行协议)(4.1 版)
  • (zt)最盛行的警世狂言(爆笑)
  • (博弈 sg入门)kiki's game -- hdu -- 2147
  • (算法设计与分析)第一章算法概述-习题
  • .naturalWidth 和naturalHeight属性,
  • .NET/C# 编译期间能确定的相同字符串,在运行期间是相同的实例
  • .NET/C# 使窗口永不激活(No Activate 永不获得焦点)
  • .NET命名规范和开发约定
  • [ Linux Audio 篇 ] 音频开发入门基础知识
  • [ 英语 ] 马斯克抱水槽“入主”推特总部中那句 Let that sink in 到底是什么梗?
  • [120_移动开发Android]008_android开发之Pull操作xml文件
  • [Android] Upload package to device fails #2720
  • [BSGS算法]纯水斐波那契数列
  • [CocosCreator]Android的增加AndroidX的动态权限
  • [codevs 1288] 埃及分数 [IDdfs 迭代加深搜索 ]
  • [docker] Docker的数据卷、数据卷容器,容器互联
  • [Err] 1055 - Expression #1 of ORDER BY clause is not in GROUP BY clause and contains nonaggregated c
  • [Flex] PopUpButton系列 —— 控制弹出菜单的透明度、可用、可选择状态
  • [GDMEC-无人机遥感研究小组]无人机遥感小组-000-数据集制备