Chinaunix

标题: 遇到timer死锁系统 [打印本页]

作者: heyangya    时间: 2011-04-11 08:51
标题: 遇到timer死锁系统
  1. #include <linux/init.h>
  2. #include <linux/module.h>
  3. #include <linux/jiffies.h>
  4. #include <linux/timer.h>

  5. void timer_fun(unsigned long data)
  6. {
  7. }

  8. static int __init hello_init(void)
  9. {
  10.   struct timer_list timer;
  11.   init_timer(&timer);
  12.   timer.data=0;
  13.   timer.expires=jiffies+1*HZ;
  14.   timer.function=timer_fun;
  15.   add_timer(&timer);
  16.   printk("timer is running now !!\n");
  17.   return 0;
  18. }

  19. static void __exit hello_exit(void)
  20. {
  21. }

  22. module_init(hello_init);
  23. module_exit(hello_exit);

  24. MODULE_AUTHOR("crazycode");
复制代码
我不知道上面的代码有什么问题,但是一加载系统就死锁了,各位帮忙看看,谢谢。
作者: heyangya    时间: 2011-04-11 13:26
在ioctl里面就没有问题了,估计是模块加载的时候不允许做些异步的事情,原理还有待高手指教
作者: accessory    时间: 2011-04-12 06:12
确认是加载,而不是卸载的时候有问题?我印象中MODULE_INIT里面可以加TIMER的。可以看看LDD3, JIT.C 例子代码。
作者: heyangya    时间: 2011-04-12 08:58
回复 3# accessory


    加载的问题,可能timer是局部变量的问题吧




欢迎光临 Chinaunix (http://bbs.chinaunix.net/) Powered by Discuz! X3.2