watchdog不管在小系统还是大的project系统中都是必须存在的。在解决线程挂死、系统死循环等都用非常重要的应用,算是系统出问题恢复初始状态的救命稻草。

在kernel中wdt的应用不是非经常见,原因就是相比于裸系统来讲。它的线程会出现一些异步的情况,执行状态easy出现系统不可控的时刻。

对于kernel中应用wdt而言,一般採用了一种通用方法。就是用一个timer进行喂狗操作。

下面选取一个典型的代码进行说明,就用 Atmel AT32AP700X device,在kernel-》drivers-》watchdog->at32ap700x_wdt.c

它的操作方法调用方法是不支持文件操作的,一般执行ioctl的方式进行调用

static long at32_wdt_ioctl(struct file *file,

unsigned int cmd, unsigned long arg)

{

int ret = -ENOTTY;

int time;

void __user *argp = (void __user *)arg;

int __user *p = argp;





switch (cmd) {

case WDIOC_GETSUPPORT:

ret = copy_to_user(argp, &at32_wdt_info,

sizeof(at32_wdt_info)) ? -EFAULT : 0;

break;

case WDIOC_GETSTATUS:

ret = put_user(0, p);

break;

case WDIOC_GETBOOTSTATUS:

ret = put_user(wdt->boot_status, p);

break;

case WDIOC_SETOPTIONS:

ret = get_user(time, p);

if (ret)

break;

if (time & WDIOS_DISABLECARD)

at32_wdt_stop();

if (time & WDIOS_ENABLECARD)

at32_wdt_start();

ret = 0;

break;

case WDIOC_KEEPALIVE:

at32_wdt_pat();

ret = 0;

break;

case WDIOC_SETTIMEOUT:

ret = get_user(time, p);

if (ret)

break;

ret = at32_wdt_settimeout(time);

if (ret)

break;

/* Enable new time value */

at32_wdt_start();

/* fall through */

case WDIOC_GETTIMEOUT:

ret = put_user(wdt->timeout, p);

break;

}





return ret;

}

上面就是函数的样子,这里能够看到主要的命令就是

wdt_settimeout  设置看门狗的最长喂狗时间

wdt_keepalive   喂狗函数命令

他们都相应了自己的函数,这样就能够在上层进行调用了。

接着向下分析。wdt_settimeout

get_user(time, p);

if (ret)

break;

ret = at32_wdt_settimeout(time);

if (ret)

break;

/* Enable new time value */

at32_wdt_start();

调用了三个函数 依次的作用是

get_user(time, p);  查看状态

at32_wdt_settimeout(time);  设置时间间隔

at32_wdt_start();势能看门狗

函数还是能从名字看出来作用的

喂狗函数相同的就是at32_wdt_pat()

这里走进去看一下  static inline void at32_wdt_pat(void)

{

spin_lock(&wdt->io_lock);

wdt_writel(wdt, CLR, 0x42);

spin_unlock(&wdt->io_lock);

}

这里就能看出来就是想clr寄存器里面写一个0x42就等于是喂狗了

再来看看其它的函数吧

static int at32_wdt_settimeout(int time)

{

/*

* All counting occurs at 1 / SLOW_CLOCK (32 kHz) and max prescaler is

* 2 ^ 16 allowing up to 2 seconds timeout.

*/

if ((time < TIMEOUT_MIN) || (time > TIMEOUT_MAX))

return -EINVAL;





/*

* Set new watchdog time. It will be used when at32_wdt_start() is

* called.

*/

wdt->timeout = time;

return 0;

}

设置时间的函数就是推断一下时间是不是超出范围了  假设没有就设置下去好了

start就不看了   就是启动之前检測一下是不是重新启动时间有没有设置  没有的话就设置一个最大值

重点看一下关闭函数

static int at32_wdt_close(struct inode *inode, struct file *file)

{

if (expect_release == 42) {

at32_wdt_stop();

} else {

dev_dbg(wdt->miscdev.parent,

"unexpected close, not stopping watchdog!\n");

at32_wdt_pat();

}

clear_bit(1, &wdt->users);

expect_release = 0;

return 0;

}

这里能够看到wdt 是一旦打开就不能关闭的   这样也是符合常理的  假设能够关闭 也就失去了存在的意义了 。存在被攻击的可能。

下一次解释下ioctl的方法

具体解释kernel中watchdog 驱动程序的更多相关文章

  1. kernel:NMI watchdog: BUG: soft lockup - CPU#6 stuck for 28s! CentOS7linux中内核被锁死

    环境说明:虚拟机 CentOS7中解压一个8G的包时,内核报错 Message from syslogd@cosmo-01 at Apr 25 11:05:59 ... kernel:NMI watc ...

  2. Linux kernel中网络设备的管理

    kernel中使用net_device结构来描述网络设备,这个结构是网络驱动及接口层中最重要的结构.该结构不仅描述了接口方面的信息,还包括硬件信息,致使该结构很大很复杂.通过这个结构,内核在底层的网络 ...

  3. kernel中文件的读写操作可以使用vfs_read()和vfs_write

    需要在Linux kernel--大多是在需要调试的驱动程序--中读写文件数据.在kernel中操作文件没有标准库可用,需要利用kernel的一些函数,这些函数主要有: filp_open() fil ...

  4. (六)kernel中文件的读写操作可以使用vfs_read()和vfs_write

    需要在Linux kernel--大多是在需要调试的驱动程序--中读写文件数据.在kernel中操作文件没有标准库可用,需要利用kernel的一些函数,这些函数主要有: filp_open() fil ...

  5. Linux kernel中常见的宏整理

    0x00 宏的基本知识 // object-like #define 宏名 替换列表 换行符 //function-like #define 宏名 ([标识符列表]) 替换列表 换行符 替换列表和标识 ...

  6. 在 CUDA C/C++ kernel中使用内存

    在 CUDA C/C++ kernel中使用内存 如何在主机和设备之间高效地移动数据.本文将讨论如何有效地从内核中访问设备存储器,特别是 全局内存 . 在 CUDA 设备上有几种内存,每种内存的作用域 ...

  7. java.sql.SQLException: [Microsoft][ODBC 驱动程序管理器] 在指定的 DSN 中,驱动程序和应用程序之间的体系结构不匹配

    今天把sql server 2008 r2装了起来,64位的,然后就迫不及待地体验连接数据库的操作,编程语言是java.我一开始学了一种非常老的连接方式,使用JDBC-ODBC桥.初次使用不太熟练,所 ...

  8. [Microsoft][ODBC 驱动程序管理器] 在指定的 DSN 中,驱动程序和应用程序之间的体系结构不匹配

    环境:  操作系统:64位WIN7   数据库:SQL Server 2000 SP1  开发语言:J2EE 在Servlet连接数据库时出错提示:  [Microsoft][ODBC 驱动程序管理器 ...

  9. 嵌入式 hi3518c平台网卡模式MII与RMII模式在Uboot和kernel中切换小结

    由于公司项目的需要,我们需要在原有的MII的基础上,修改为RMII模式,针对hi3518c平台,我的网卡是LAN8701需要修改的地方有如下几个: 首先我的uboot中env是: bootargs=m ...

随机推荐

  1. Linux下如何从mysql数据库里导出导入数据

    https://blog.csdn.net/u012884402/article/details/47337701 一. 表的导入 1.进入数据库 mysql 数据库名 2.​查看表 show tab ...

  2. SDK_进度条和滑块

    进度条和滑块 进度条和滑块属于通用控件,通用控件的使用需要加 CommCtrl.h 头文件 如何初始化进度条和滑块的数值范围和默认的位置 // 设置默认的范围值SendDlgItemMessage(h ...

  3. jmeter的JDBC Request接口测试

    Jmeter操作Mysql 测试计划添加.jar包 mysql-connector-java-5.1.7-bin.jar用于使Jmeter可以读取Mysql: 线程组添加 JDBC Connectio ...

  4. Java基础(四)--接口和抽象类

    接口和抽象类能够体现OOP的抽象,而接口和抽象类也是日常开发中经常用到的 抽象方法: 抽象方法就是被abstract修饰的方法,只有声明,没有实现,也就是没有方法体 public abstract v ...

  5. 【转载】Appium环境搭建(Windows版)

    注:appium安装到C盘,node.js安装到C盘 一.安装node.js 1.到官网下载node.js:https://nodejs.org/en/download/ 2.获取到安装文件后,直接双 ...

  6. 社交网络图中结点的“重要性”计算 (30 分) C++解法

    社交网络图中结点的"重要性"计算 (30 分) 在社交网络中,个人或单位(结点)之间通过某些关系(边)联系起来.他们受到这些关系的影响,这种影响可以理解为网络中相互连接的结点之间蔓 ...

  7. 如何允许WebGL从本地载入资源

    随着mono-design不断推广,用户越来越多,陆续有电话来询问“为什么3D展现的时候,是一团黑?”,针对这个问题,专门写个帖子说明原因并给出解决方案,并且在mono-design编辑器中加了判断功 ...

  8. STL中栈stack的用法

    头文件: #include <stack> 建立一个栈stack < 类型 > s //例如 stack<int> s 加入一个新的元素s.push( a ) 询问 ...

  9. mybatis传参总结

    注:文章引用部分 mybatis传递参数总结文章内容 一.单个参数 1.基本数据类型 (1)直接使用 List<ChargeRuleDO> tests(long id); <sele ...

  10. ubuntu解压zip文件出现乱码情况解决方法

    使用 unzip datastructure.zip 出现下面的情况: extracting: └╧╗╞/╗·╞ў╤з╧░╝п╜ї/╩¤╛▌╜с╣╣╙ы╦у╖и/╩¤╛▌╜с╣╣╙ы╦у╖иги2гй ...