Time定时器的使用
来源:互联网 发布:淘宝天天乐游戏商城 编辑:程序博客网 时间:2024/05/16 10:49
当一个定时器已经被插入到内核动态定时器链表中后,我们还可以修改该定时器的expires值。
函数mod_timer()实现这一点修改注册入计时器列表的handler的起动时间
int mod_timer(struct timer_list *timer, unsigned long expires)
{int ret;
unsigned long flags;
spin_lock_irqsave(&timerlist_lock, flags);
timer->expires = expires;
ret = detach_timer(timer);
internal_add_timer(timer);
spin_unlock_irqrestore(&timerlist_lock, flags);
return ret;}
内核通过函数mod_timer来实现已经激活的定时器超时时间:mod_timer(&my_timer, jiffies+new_delay);mod_timer函数也可以操作那些已经初始化,但还没有被激活的定时器,如果定时器没有激活,mod_timer会激活它。如果调用时定时器未被激活,该函数返回0,否则返回1。一旦从mod_timer函数返回,定时器都将被激活而且设置了新的定时值。
如果需要在定时器超时前停止定时器,可以使用del_timer函数:del_timer(&my_timer);被激活或未被激活的定时器都可以使用该函数,如果定时器还未被激活,该函数返回0;否则返回1。当删除定时器,必须小心一个潜在的竞争条件。当del_timer返回后,可以保证的只是:定时器不会被再激活,但是多处理器上定时器中断可能已经在其他处理上运行了,所以需要等待可能在其他处理器上运行的定时器处理程序都退出,这时需要使用del_timer_sync函数执行删除工作:
del_timer_sync(&my_timer);和del_timer函数不同,del_timer_sync数不能在中断上下文中使用。定时器 API 包括几个比上面介绍的那些更多的功能. 下面的集合是完整的核提供的函数列表:int mod_timer(struct timer_list *timer, unsigned long expires);更新一个定时器的超时时间, 使用一个超时定时器的一个普通的任务(再一次, 关马达软驱定时器是一个典型例子). mod_timer 也可被调用于非激活定时器, 那里你正常地使用 add_timer.int del_timer_sync(struct timer_list *timer);如同 del_timer 一样工作, 但是还保证当它返回时, 定时器函数不在任何 CPU 上运行. del_timer_sync 用来避免竞争情况在 SMP 系统上, 并且在 UP 内核中和 del_timer 相同. 这个函数应当在大部分情况下比 del_timer 更首先使用. 这个函数可能睡眠如果它被从非原子上下文调用, 但是在其他情况下会忙等待. 要十分小心调用 del_timer_sync 当持有锁时; 如果这个定时器函数试图获得同一个锁, 系统会死锁. 如果定时器函数重新注册自己, 调用者必须首先确保这个重新注册不会发生; 这常常同设置一个" 关闭 "标志来实现, 这个标志被定时器函数检查.int timer_pending(const struct timer_list * timer);返回真或假来指示是否定时器当前被调度来运行, 通过调用结构的其中一个不透明的成员.
下面是关于timer的API函数:
增加定时器 void add_timer(struct timer_list * timer);
删除定时器int del_timer(struct timer_list * timer);
修改定时器的expireint mod_timer(struct timer_list *timer, unsigned long expires);
使用定时器的一般流程为:
(1)timer、编写function;
(2)为timer的expires、data、function赋值;
(3)调用add_timer将timer加入列表;
(4)在定时器到期时,function被执行;
(5)在程序中涉及timer控制的地方适当地调用del_timer、mod_timer删除timer或修改timer的expires。
自己简单的例子如下:static int athread(void * unused){init_timer(&my_timer);my_timer.expires = jiffies + 1*HZ; //延时delay_sec秒 每发生一次timer interrupt,Jiffies变数会被加一。 //jiffies是内核中的一个全局变量,用来记录自系统启动一来产生的节拍数。 //unsigned long timeout = jiffies + tick_rate * 2; // 2秒钟后超时 tick_rate 为 时钟频率my_timer.data = 0; //给定时器处理函数传入的参数my_timer.function = my_function; //定时器超时时调用的函数/*最后,激活定时器*/add_timer(&my_timer);/*如果需要改变已经激活的定时器的超时时间,可以调用mod_timer()函数,mod_timer()函数也可以操作已经初始化,但没有激活的定时器.如果调用时定时器未被激活,则函数返回0,否则返回1*/printk("In a thread \n");return 0;}
- Time定时器的使用
- java学习——线程启动的两种方法,Time定时器,synchronized 的使用
- Golang time包的定时器/断续器
- C#中 使用 System.Windows.Forms.Time 定时器
- Go 使用for range time.Tick() 设置定时器
- Unity3d Time的使用
- Unity3d Time的使用
- joda-time的使用
- C++ time 的使用
- unity3d Time 的使用
- Time Profiler的使用
- joda-time的使用
- 函数time的使用
- joda-time的使用
- joda-time的使用
- joda-time的使用
- Joda Time的使用
- Joda-Time的使用
- Android studio 快捷键&配置技巧(不定时更新)
- 7.20 牛客左程云老师第一题(个人学习笔记)
- TCP--三次握手 和 四次分手
- 距离和相似度度量
- iOS 消息推送原理及实现Demo
- Time定时器的使用
- C#之XML基础 xattribute的用法示例
- 关于android 6.0权限问题
- hdu--1811(拓扑排序+并查集)
- POJ-3080-Blue Jeans
- 【9902】挖地雷
- Xilinx petalinux 安装常见错误及解决方法
- react
- Angular 监听路由变化