在内核模块中实现多个定时器的最佳方法是什么

时间:2013-10-09 14:23:55

标签: memory timer kernel free kernel-module

我正在尝试构建e内核模块,用户空间程序将使用它来设置定时器。我将它作为角色设备实现。在内核模块中实现多个定时器的最佳方法是什么?

目前我有一个'timer_list *',坐'计时器'。我每次得到一个新的定时器请求时都会从堆中分配内存,然后每次分配内存时都使用setup_timer()和mod_timer()来设置定时器。但我只使用一个指向timer_list结构的指针。但我关注的是,一旦调用回调函数,如何释放分配给'timer'的内存,因为'timer'的当前值可能不指向调用其回调函数的结构。

所以,我考虑将结构的地址作为参数传递给回调函数,然后在该地址上调用kfree()。​​

struct timer_list *timer;
timer = kmalloc(sizeof(struct timer_list), GFP_KERNEL);
setup_timer(timer, my_callback, (unsigend long)timer);

我的回调函数如下所示:

void my_callback (unsigned long data)
{
      struct timer_list *timer = (struct timer_list*)data;
      printk("%d\n", timer->data);
      kfree(timer);
}

在这种情况下,当我尝试打印timer->数据表示该特定地址没有页面时,我遇到了分段错误。 因此,当调用回调函数时,是否释放了分配给timer_list的memoery。在那种情况下,我不必担心释放内存。

另外,有没有更好的方法来实现这个东西。另外,为了跟踪所有定时器(比如检查是否存在定时器),是否可以维护链接列表或者有一些内核函数来检查它?

1 个答案:

答案 0 :(得分:1)

在某种程度上,您必须跟踪所有计时器。例如,您可以使用list(请参阅list.h)待处理的计时器。然后,您可以循环列表以检查是否有任何计时器已过期并释放其内存(并从列表中删除)。您可以在分配新计时器之前执行此操作。

timer_list未自动释放,因为您可以使用mod_timer()重新编程