九鼎创展论坛

标题: s3c6410在linux下的WATCHDOG TIMER(看门狗定时器)驱动(1) [打印本页]

作者: armeasy    时间: 2014-10-17 19:41
标题: s3c6410在linux下的WATCHDOG TIMER(看门狗定时器)驱动(1)

还是先说下整体结构,又要说到大家很熟悉的平台设备了,同样看门狗定时器也是作为平台设备存在的,但与以前的不同的地方是,看门狗定时器是一种混杂设备,先介绍下混杂设备。

1、混杂设备

1.1、混杂设备并没有明确的定义。它的主设备号是10,不同的设备用次设备号区分。混杂设备用结构体miscdevice表示,源码如下:

struct miscdevice  {
int minor; 次设备号
const char *name; 设备名
const struct file_operations *fops;设备的操作函数,与字符设备相同
struct list_head list; 链接混杂设备的链表
struct device *parent;指向父设备
struct device *this_device;指向设备结构体
};

对应的看下看门狗中的定义:

在S3c2410_wdt.c (linux2.6.28\drivers\watchdog)文件中

static struct miscdevice s3c2410wdt_miscdev = {
.minor  = WATCHDOG_MINOR,
.name = "watchdog",
.fops = &s3c2410wdt_fops,
};

其中还有:

/* kernel interface */
static const struct file_operations s3c2410wdt_fops = {
.owner  = THIS_MODULE,
.llseek  = no_llseek,
.write  = s3c2410wdt_write,
.unlocked_ioctl= s3c2410wdt_ioctl,
.open = s3c2410wdt_open,
.release  = s3c2410wdt_release,
};

1.2、混杂设备的注册和注销

内核提供了misc_register用于注册一个混杂设备。

/**
* misc_register-register a miscellaneous device
* @misc: device structure

int misc_register(struct miscdevice * misc)

同样对应的内核提供了misc_deregister用于混杂设备的注销。

/**
* misc_deregister - unregister a miscellaneous device
* @misc: device to unregister

int misc_deregister(struct miscdevice *misc)

2、再来看看门狗定时器作为平台设备存在

static struct platform_driver s3c2410wdt_driver = {
.probe  = s3c2410wdt_probe,
.remove  = s3c2410wdt_remove,
.shutdown  = s3c2410wdt_shutdown,
.suspend  = s3c2410wdt_suspend,
.resume  = s3c2410wdt_resume,
.driver  = {
.owner  = THIS_MODULE,
.name = "s3c2410-wdt",
},
};


static char banner[] __initdata =
KERN_INFO "S3C2410 Watchdog Timer, (c) 2004 Simtec Electronics\n";

static int __init watchdog_init(void)
{
printk(banner);
return platform_driver_register(&s3c2410wdt_driver);
}
static void __exit watchdog_exit(void)
{
platform_driver_unregister(&s3c2410wdt_driver);
}
module_init(watchdog_init);
module_exit(watchdog_exit);

看到这些,你可能都看腻了。没办法,接着来,平台设备的资源定义在

Devs.c (linux2.6.28\arch\arm\plat-s3c64xx)文件中:

/* Watchdog */
static struct resource s3c_wdt_resource[] = {
[0] = {
.start = S3C64XX_PA_WATCHDOG,
.end   = S3C64XX_PA_WATCHDOG + S3C64XX_SZ_WATCHDOG - 1,
.flags = IORESOURCE_MEM,
},
[1] = {
.start = IRQ_WDT,
.end   = IRQ_WDT,
.flags = IORESOURCE_IRQ,
}
};

平台设备定义在同一个文件中:

struct platform_device s3c_device_wdt = {
.name             = "s3c2410-wdt",
.id               = -1,
.num_resources    = ARRAY_SIZE(s3c_wdt_resource),
.resource         = s3c_wdt_resource,
};

EXPORT_SYMBOL(s3c_device_wdt);

3、S3c2410_wdt.c (linux2.6.28\drivers\watchdog)文件开头一些变量的含义(参考于网络和书籍),如下所示:

(1)、static int nowayout = WATCHDOG_NOWAYOUT;nowayout为1表示不允许关闭看门狗,为0表示可以关闭。与CONFIG_WATCHDOG_NOWAYOUT配置相关,当配置为不允许关闭时,应用层调用close函数将不能关闭看门狗#ifdef CONFIG_WATCHDOG_NOWAYOUT#define WATCHDOG_NOWAYOUT        1#else#define WATCHDOG_NOWAYOUT        0#endif(2)、static int tmr_margin = CONFIG_S3C2410_WATCHDOG_DEFAULT_TIME;默认的喂狗时间#define CONFIG_S3C2410_WATCHDOG_DEFAULT_TIME  (15)(3)、static int tmr_atboot = CONFIG_S3C2410_WATCHDOG_ATBOOT;表示系统启动时就能使用看门狗。为1表示能,为0表示不能。 #define CONFIG_S3C2410_WATCHDOG_ATBOOT  (0)(4)、static int soft_noboot;表示看门狗的工作方式,看门狗可以作为定时器使用,也可以作为复位使用。soft_noboot为1时看门狗将作为一般的中断定时器使用,为0时作为可复位电路的看门狗,默认为0(5)、static int debug;  调式模式(6)、module_param(tmr_margin,  int, 0);module_param(tmr_atboot,  int, 0);module_param(nowayout,    int, 0);module_param(soft_noboot, int, 0);module_param(debug,          int, 0);驱动程序模块参数,如果在加载驱动模块时没有设定这些参数,则这些参数将采用默认值。(7)、typedef enum close_state {        CLOSE_STATE_NOT,不允许关闭        CLOSE_STATE_ALLOW = 0x4021允许关闭} close_state_t;用来标识看门狗是否允许关闭。4、万变不离其宗,下一篇就要说平台设备对应的probe函数了,你做好准备了吗?下篇见。





欢迎光临 九鼎创展论坛 (http://bbs.9tripod.com/) Powered by Discuz! X3.2