Kernel 定时器的使用

 

概述:今天带来的是一个内核定时器简单使用的案列。代码如下,具体的分析后续补上。

#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/module.h>
#include <linux/timer.h>


static struct timer_list  test_timer;


void timer_test_callback(unsigned long data)
{
	printk(KERN_INFO"\n%s called at time:%ld. \n", __FUNCTION__, jiffies);
}

static int __init timer_test_init(void)
{
	int  ret;

	printk(KERN_INFO"Timer test begin \n");

	setup_timer(&test_timer, timer_test_callback, 0);
	printk("Setup timer to print in 3000ms (%ld)\n", jiffies);

	ret = mod_timer(&test_timer, jiffies + msecs_to_jiffies(3000));
	if(ret){
		printk("Timer start failed\n");
		return ret;
	}

	return 0;
}

static void __exit timer_test_exit(void)
{
	int ret;
begin:
	ret = del_timer(&test_timer);
	if(ret){
		printk("Timer is using,cant not be del");
		goto begin;
	}

	printk(KERN_INFO"Timer test is unloaded\n");
}


module_init(timer_test_init);
module_exit(timer_test_exit);

MODULE_LICENSE("GPL");

验证结果:

这里有两个问题,一个是时间少了一个数量级,另一个是打印总为负数。

后续接着处理这两个问题。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值