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. ubuntu部署java环境

    一.安装java sudo add-apt-repository ppa:webupd8team/java sudo apt-get update sudo apt-get install oracl ...

  2. 《网络管理》IP地址管理与子网划分

    IP地址管理——ipmaster ipmaster是一款对IP地址进行管理的软件,使用该软件可以提高网络管理员的工作效率.在大型网络中,使用该软件可以有序且高效地实现大中小型企业网IP地址的分配和管理 ...

  3. CAD把当前图上数据保存为一个二进流对象(com接口VB语言)

    主要用到函数说明: MxDrawXCustomFunction::WriteBinStreamEx 把当前图上数据保存为一个二进流对象,详细说明如下: 参数 说明 LPCTSTR pszPasswor ...

  4. CAD控件:网上打开dwg文件时,对dwg文件路径加密的功能

    梦想CAD控件2015.03.12最新更新  1. 增加控件状态栏文字,自定义功能,        C++接口为 :   CStatusBarInformationReactor::CreatePro ...

  5. 牛客多校Round 1

    Solved:1 rank:249 E. Removal dp i,j表示前i个数删除了j个且选择了第i个的答案 类似字符串的dp 预处理一下nex i_k即i后面k第一次出现的位置  就好转移了 # ...

  6. cc.Node—场景树

    对于cc.Node我分了四个模块学习: 1.场景树,2.事件响应,3.坐标系统,4.Action的使用:在此记录经验分享给大家. 场景树 1: creator是由一个一个的游戏场景组成,通过代码逻辑来 ...

  7. 搜索--P1219 N皇后

    题目描述 检查一个如下的6 x 6的跳棋棋盘,有六个棋子被放置在棋盘上,使得每行.每列有且只有一个,每条对角线(包括两条主对角线的所有平行线)上至多有一个棋子. 上面的布局可以用序列2 4 6 1 3 ...

  8. [USACO] 奶牛混合起来 Mixed Up Cows

    题目描述 Each of Farmer John's N (4 <= N <= 16) cows has a unique serial number S_i (1 <= S_i & ...

  9. Python学习-字符串函数操作3

    字符串函数操作 isprintable():判断一个字符串中所有字符是否都是可打印字符的. 与isspace()函数很相似 如果字符串中的所有字符都是可打印的字符或字符串为空返回 True,否则返回 ...

  10. Datatable 插入一行数据到第一行

    var t = $('#passwdHOST').DataTable({ 'searching': true, 'ordering': false, 'autoWidth': false, dom: ...