看门狗应用编程

本文详细介绍了Linux系统中看门狗机制的工作原理及其应用程序编程流程。包括如何通过ioctl指令进行设备节点操作,如获取支持的功能、设置及获取超时时间等,并提供了具体的ioctl指令示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

1、设备节点

1.1、/dev/watchdogX

1.2、/dev/watchdog

2、ioctl 指令

2.1、常用ioctl 指令

2.2、WDIOC_GETSUPPORT操作

2.2.1、watchdog_info结构体

2.1.2、选项options

2.3、WDIOC_GETTIMEOUT操作

2.4、WDIOC_SETTIMEOUT操作

2.5、WDIOC_SETOPTIONS操作

2.5.1、选项

2.6、WDIOC_KEEPALIVE指令

3、看门狗应用编程流程


1、设备节点

1.1、/dev/watchdogX

Linux 系统中所注册的看门狗外设,都会在/dev/目录下生成对应的设备节点,设备节点名称通常为 watchdogX

1.2、/dev/watchdog

代表系统默认的看门狗设备。

2、ioctl 指令

下面的宏定义在头文件<linux/watchdog.h>中。

#define WDIOC_GETSUPPORT        _IOR(WATCHDOG_IOCTL_BASE, 0, struct watchdog_info)
#define WDIOC_GETSTATUS         _IOR(WATCHDOG_IOCTL_BASE, 1, int)
#define WDIOC_GETBOOTSTATUS     _IOR(WATCHDOG_IOCTL_BASE, 2, int)
#define WDIOC_GETTEMP           _IOR(WATCHDOG_IOCTL_BASE, 3, int)
#define WDIOC_SETOPTIONS        _IOR(WATCHDOG_IOCTL_BASE, 4, int)
#define WDIOC_KEEPALIVE         _IOR(WATCHDOG_IOCTL_BASE, 5, int)
#define WDIOC_SETTIMEOUT        _IOWR(WATCHDOG_IOCTL_BASE, 6, int)
#define WDIOC_GETTIMEOUT        _IOR(WATCHDOG_IOCTL_BASE, 7, int)
#define WDIOC_SETPRETIMEOUT     _IOWR(WATCHDOG_IOCTL_BASE, 8, int)
#define WDIOC_GETPRETIMEOUT     _IOR(WATCHDOG_IOCTL_BASE, 9, int)
#define WDIOC_GETTIMELEFT       _IOR(WATCHDOG_IOCTL_BASE, 10, int)

2.1、常用ioctl 指令

ioctl 指令说明
WDIOC_GETSUPPORT获取看门狗支持哪些功能
WDIOC_GETTIMEOUT获取看门狗超时时间
WDIOC_SETTIMEOUT设置看门狗超时时间
WDIOC_SETOPTIONS用于开启或关闭看门狗
WDIOC_KEEPALIVE喂狗操作

2.2、WDIOC_GETSUPPORT操作

获取看门狗支持哪些功能。

struct watchdog_info info;
ioctl(fd, WDIOC_GETSUPPORT, &info)

2.2.1、watchdog_info结构体

struct watchdog_info {
        __u32 options;          /* Options the card/driver supports */
        __u32 firmware_version; /* Firmware version of the card */
        __u8  identity[32];     /* Identity of the board */
};
字段说明
options记录了设备支持哪些功能或选项
firmware_version 记录了设备的固件版本号
identity 描述性字符串

2.1.2、选项options

#define WDIOF_OVERHEAT          0x0001  /* Reset due to CPU overheat */
#define WDIOF_FANFAULT          0x0002  /* Fan failed */
#define WDIOF_EXTERN1           0x0004  /* External relay 1 */
#define WDIOF_EXTERN2           0x0008  /* External relay 2 */
#define WDIOF_POWERUNDER        0x0010  /* Power bad/power fault */
#define WDIOF_CARDRESET         0x0020  /* Card previously reset the CPU */
#define WDIOF_POWEROVER         0x0040  /* Power over voltage */
#define WDIOF_SETTIMEOUT        0x0080  /* Set timeout (in seconds) */
#define WDIOF_MAGICCLOSE        0x0100  /* Supports magic close char */
#define WDIOF_PRETIMEOUT        0x0200  /* Pretimeout (in seconds), get/set */
#define WDIOF_ALARMONLY         0x0400  /* Watchdog triggers a management or
                                           other external alarm not a reboot */
#define WDIOF_KEEPALIVEPING     0x8000  /* Keep alive ping reply */
常见选项说明
WDIOF_SETTIMEOUT 设备支持设置超时时间
WDIOF_KEEPALIVEPING 设备支持“喂狗”操作

2.3、WDIOC_GETTIMEOUT操作

获取看门狗超时时间。

ioctl(fd, WDIOC_GETTIMEOUT,&timeout);

2.4、WDIOC_SETTIMEOUT操作

设置看门狗超时时间。

ioctl(fd, WDIOC_SETTIMEOUT,&timeout);

2.5、WDIOC_SETOPTIONS操作

使用 WDIOC_SETOPTIONS 指令可以开启或停止看门狗。

ioctl(fd, WDIOC_SETOPTIONS,&option);

2.5.1、选项

#define WDIOS_DISABLECARD       0x0001  /* Turn off the watchdog timer */
#define WDIOS_ENABLECARD        0x0002  /* Turn on the watchdog timer */
说明
WDIOS_DISABLECARD停止看门狗
WDIOS_ENABLECARD开启看门狗

2.6、WDIOC_KEEPALIVE指令

WDIOC_KEEPALIVE 指令用于喂狗。

ioctl(fd, WDIOC_KEEPALIVE, NULL);

3、看门狗应用编程流程

1)open()函数打开看门狗

2)使用WDIOC_GETSUPPORT获取看门狗支持哪些功能

3)使用WDIOC_SETOPTIONS指令停止看门狗

4)对看门狗进行设置(如设置超时时间)

5)使用WDIOC_SETOPTIONS指令开启看门狗

9)使用WDIOC_KEEPALIVE指令喂狗

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值