Linux 下如何使用看门狗

Linux内核有集成WD的选项。将其使能后,系统里就会有watchdog的设备驱动:/dev/watchdog.
这样,在应用程序里只需打开这个设备使用即可:
#include <fcntl.h>
void main(void)
{
    int fdWD;
    char chrTmp;

fdWD = open("/dev/watchdog", O_RDWR); //设备一打开,看门狗也就出洞了。
    for(;;)
    {
        write(fdWD, &chrTmp, 1);   //任一指针就行了,因为内部并未使用;最后的数据非零就行了,因为内部只是判断是否零 来置狗为初值。
        sleep(10);  //在我的板上,  16秒后狗才出动,所以10喂一次也就行了。
    }
}

from:http://blog.csdn.net/liigo/article/details/9227205

Linux 自带了一个 watchdog 的实现,用于监视系统的运行,包括一个内核 watchdog module 和一个用户空间的 watchdog 程序。内核 watchdog 模块通过 /dev/watchdog 这个字符设备与用户空间通信。用户空间程序一旦打开 /dev/watchdog 设备(俗称“开门放狗”),就会导致在内核中启动一个1分钟的定时器(系统默认时间),此后,用户空间程序需要保证在1分钟之内向这个设备写入数据(俗称“定期喂狗”),每次写操作会导致重新设定定时器。如果用户空间程序在1分钟之内没有写操作,定时器到期会导致一次系统 reboot 操作(“狗咬人了”呵呵)。通过这种机制,我们可以保证系统核心进程大部分时间都处于运行状态,即使特定情形下进程崩溃,因无法正常定时“喂狗”,Linux系统在看门狗作用下重新启动(reboot),核心进程又运行起来了。多用于嵌入式系统。

打开 /dev/watchdog 设备(“开门放狗”):

[cpp] view plaincopy

  1. int fd_watchdog = open("/dev/watchdog", O_WRONLY);
  2. if(fd_watchdog == -1) {
  3. int err = errno;
  4. printf("\n!!! FAILED to open /dev/watchdog, errno: %d, %s\n", err, strerror(err));
  5. syslog(LOG_WARNING, "FAILED to open /dev/watchdog, errno: %d, %s", err, strerror(err));
  6. }

每隔一段时间向 /dev/watchdog 设备写入数据(“定期喂狗”):

[cpp] view plaincopy

  1. //feed the watchdog
  2. if(fd_watchdog >= 0) {
  3. static unsigned char food = 0;
  4. ssize_t eaten = write(fd_watchdog, &food, 1);
  5. if(eaten != 1) {
  6. puts("\n!!! FAILED feeding watchdog");
  7. syslog(LOG_WARNING, "FAILED feeding watchdog");
  8. }
  9. }

关闭 /dev/watchdog 设备,通常不需要这个步骤:

[cpp] view plaincopy

  1. close(fd_watchdog);

所需头文件:

[cpp] view plaincopy

  1. #include <unistd.h>
  2. #include <sys/stat.h>
  3. #include <syslog.h>
  4. #include <errno.h>
时间: 2024-10-19 23:25:21

Linux 下如何使用看门狗的相关文章

linux内核中断之看门狗

一:内核中断 linux内核中的看门狗中断跟之前的裸板的中断差不多,在编写驱动之前,需要线把内核自带的watch dog模块裁剪掉,要不然会出现错误:在Device Drivers /Watchdog Timer Support /S3C2410 Watchdo 在内核中,我们处理一个中断,必须先注册一个中断号,注册中断的函数是: 132 request_irq(unsigned int irq, irq_handler_t handler, unsigned long flags, 133 c

Linux 下安装服务器安全狗

1.网上下载服务器安全狗的软件包    32位和64位 wget http://www.safedog.cn/server_safedog_linux.html/safedog_linux32.tar.gz       ##32位 wget http://www.safedog.cn/server_safedog_linux.html/safedog_linux64.tar.gz       ##64位 2.解压文件 [[email protected] /]# tar zxvf safedog

一个软件实现的Linux看门狗—soft_wdt

soft_wdt(下面简称本软件)是一个软件实现的Linux看门狗. 本软件是一款开源.免费软件. 下载地址: https://github.com/sunmingbao/soft-wdt/archive/master.zip 本软件和/drivers/watchdog/softdog.c实现的软件看门狗差点儿一样. 基本的不同点是,前者支持一个看门狗.本软件则支持大量的看门狗. soft_wdt代码编译后.生成一个内核模块soft_wdt.ko. 模块载入后,将创建一个设备文件/dev/sof

Linux 软件看门狗 watchdog —— 开门放狗、定期喂狗、狗咬人了

Linux 自带了一个 watchdog 的实现,用于监视系统的运行,包括一个内核 watchdog module 和一个用户空间的 watchdog 程序. 内核 watchdog 模块通过 /dev/watchdog 这个字符设备与用户空间通信.用户空间程序一旦打开 /dev/watchdog 设备(俗称“开门放狗”),就会导致在内核中启动一个1分钟的定时器(系统默认时间),此后,用户空间程序需要保证在1分钟之内向这个设备写入数据(俗称“定期喂狗”),每次写操作会导致重新设定定时器.如果用户

Linux 软件看门狗 watchdog

Linux 自带了一个 watchdog 的实现,用于监视系统的运行,包括一个内核 watchdog module 和一个用户空间的 watchdog 程序.内核 watchdog 模块通过 /dev/watchdog 这个字符设备与用户空间通信.用户空间程序一旦打开 /dev/watchdog 设备(俗称"开门放狗"),就会导致在内核中启动一个1分钟的定时器(系统默认时间),此后,用户空间程序需要保证在1分钟之内向这个设备写入数据(俗称"定期喂狗"),每次写操作会

Linux 软件看门狗 watchdog 喂狗

Linux 自带了一个 watchdog 的实现,用于监视系统的运行,包括一个内核 watchdog module 和一个用户空间的 watchdog程序.内核 watchdog 模块通过 /dev/watchdog 这个字符设备与用户空间通信.用户空间程序一旦打开 /dev/watchdog 设备(俗称"开门放狗"),就会导致在内核中启动一个1分钟的定时器(系统默认时间),此后,用户空间程序需要保证在1分钟之内向这个设备写入数据(俗称"定期喂狗"),每次写操作会导

基于S3C2440的嵌入式Linux驱动——看门狗(watchdog)驱动解读

本文将介绍看门狗驱动的实现. 目标平台:TQ2440 CPU:s3c2440 内核版本:2.6.30 1. 看门狗概述 看门狗其实就是一个定时器,当该定时器溢出前必须对看门狗进行"喂狗",如果不这样做,定时器溢出后则将复位CPU. 因此,看门狗通常用于对处于异常状态的CPU进行复位. 具体的概念请自行百度. 2. S3C2440看门狗 s3c2440的看门狗的原理框图如下: 可以看出,看门狗定时器的频率由PCLK提供,其预分频器最大取值为255+1:另外,通过MUX,可以进一步降低频率

linux 嵌入式看门狗使用

linux看门狗使用很简单,在应用层使用,只需要ioctl设置一下溢出时间,既可以使用看门狗,定时喂狗即可 前提是kernel支持看门狗 Device Drivers ─> [*] Watchdog Timer Support  ---> 配置好好后,即可make 应用层的使用,直接上代码 #include <stdio.h> #include <sys/types.h> #include <sys/stat.h> #include <fcntl.h&

linux之软看门狗的实现

//softwareWdt.h /* *功能: 监测各线程间的运行状态(软看门狗) * *作者:JDSH * *时间:2015-01-15 22:20 */ #include <stdlib.h> #include <stdio.h> #include <string.h> #include <unistd.h> #include "Typedef.h" #define REQUEST_WDT_MAX_NUM 20 class CSoft