Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1260315
  • 博文数量: 548
  • 博客积分: 7597
  • 博客等级: 少将
  • 技术积分: 4224
  • 用 户 组: 普通用户
  • 注册时间: 2010-12-15 13:21
个人简介

嵌入式软件工程师&&太极拳

文章分类

全部博文(548)

文章存档

2014年(10)

2013年(76)

2012年(175)

2011年(287)

分类: 嵌入式

2012-05-10 17:20:43

三:一个简单的实例(timer.c):
 /****************************************
 * 作者:蔡肖飞                             *
 * 时间:2008年11月27日             *
 * 名称:timer.c                           *
 * 说明:本程序用于学习linux内核 *
 * 中定时器的基本使用                *
 *****************************************/
 #include
#include
#include
#include //jiffies在此头文件中定义
#include
#include
struct timer_list mytimer;//定义一个定时器
void  mytimer_ok(unsigned long arg)
{
           printk("Mytimer is ok\n");
           printk("receive data from timer: %d\n",arg);
   }
 
static int __init hello_init (void)
{
    printk("hello,world\n");
    init_timer(&mytimer);     //初始化定时器
    mytimer.expires = jiffies+100;//设定超时时间,100代表1秒
    mytimer.data = 250;    //传递给定时器超时函数的值
    mytimer.function = mytimer_ok;//设置定时器超时函数
    add_timer(&mytimer); //添加定时器,定时器开始生效
    return 0;
}
   
static void __exit hello_exit (void)
 
{
    del_timer(&mytimer);//卸载模块时,删除定时器
    printk("Hello module exit\n");
}
 
module_init(hello_init);
module_exit(hello_exit);
MODULE_AUTHOR("CXF");
MODULE_LICENSE("Dual BSD/GPL");
四:交叉编译后,放到开发板上:
#insmod timer.o
可以发现过一秒后定时器过期函数被执行了,打印出了信息,250也被正确传递
了,呵呵!
#rmmod timer
  实验完成。
五:进一步理解定时器:
      在上面的定时器超时函数mytimer_ok(unsigned long arg)中,添加如下
代码:
mytimer.expires = jiffies+100;//设定超时时间,100代表1秒
 mytimer.function = mytimer_ok;//设置定时器超时函数
add_timer(&mytimer); //添加定时器,定时器开始生效
交叉编译后,放到开发板上
#insmod timer.o
  发现每隔一秒,mytimer_ok函数就执行一次,这是因为每次定时器到期后,都
又重新给它设置了一个新的超时时间,并且新的超时函数指向自己,形成一个递
归,所以就会一直执行下去。
  #rmmod timer
可以卸载模块,当然打印也就结束了,注意因为定时器超时函数不停的打印信息
,导致输入上面的命令时会被定时器超时函数不停的打印信息淹没,不用管他,
耐心的把上面的命令输完就可以成功卸载。

本文来自:我爱研发网(52RD.com) - R&D大本营
详细出处:
阅读(511) | 评论(0) | 转发(0) |
0

上一篇:norflash文档

下一篇:w90x900驱动

给主人留下些什么吧!~~