timer.c 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. #include "timer.h"
  2. #include <common/kprint.h>
  3. #include <exception/softirq.h>
  4. #include <mm/slab.h>
  5. #include <driver/timers/HPET/HPET.h>
  6. #include <process/process.h>
  7. struct timer_func_list_t timer_func_head;
  8. // 定时器循环阈值,每次最大执行10个定时器任务
  9. #define TIMER_RUN_CYCLE_THRESHOLD 10
  10. void test_timer()
  11. {
  12. printk_color(ORANGE, BLACK, "(test_timer)");
  13. }
  14. void timer_init()
  15. {
  16. timer_jiffies = 0;
  17. timer_func_init(&timer_func_head, NULL, NULL, -1UL);
  18. register_softirq(TIMER_SIRQ, &do_timer_softirq, NULL);
  19. struct timer_func_list_t *tmp = (struct timer_func_list_t *)kmalloc(sizeof(struct timer_func_list_t), 0);
  20. timer_func_init(tmp, &test_timer, NULL, 5);
  21. timer_func_add(tmp);
  22. kdebug("timer func initialized.");
  23. }
  24. void do_timer_softirq(void *data)
  25. {
  26. // todo: 修改这里以及softirq的部分,使得timer具有并行性
  27. struct timer_func_list_t *tmp = container_of(list_next(&timer_func_head.list), struct timer_func_list_t, list);
  28. int cycle_count = 0;
  29. while ((!list_empty(&timer_func_head.list)) && (tmp->expire_jiffies <= timer_jiffies))
  30. {
  31. timer_func_del(tmp);
  32. tmp->func(tmp->data);
  33. kfree(tmp);
  34. ++cycle_count;
  35. // 当前定时器达到阈值
  36. if (cycle_count == TIMER_RUN_CYCLE_THRESHOLD)
  37. break;
  38. tmp = container_of(list_next(&timer_func_head.list), struct timer_func_list_t, list);
  39. }
  40. }
  41. /**
  42. * @brief 初始化定时功能
  43. *
  44. * @param timer_func 队列结构体
  45. * @param func 定时功能处理函数
  46. * @param data 传输的数据
  47. * @param expire_ms 定时时长(单位:ms)
  48. */
  49. void timer_func_init(struct timer_func_list_t *timer_func, void (*func)(void *data), void *data, uint64_t expire_ms)
  50. {
  51. list_init(&timer_func->list);
  52. timer_func->func = func;
  53. timer_func->data = data;
  54. timer_func->expire_jiffies = cal_next_n_ms_jiffies(expire_ms); // 设置过期的时间片
  55. }
  56. /**
  57. * @brief 初始化定时功能
  58. *
  59. * @param timer_func 队列结构体
  60. * @param func 定时功能处理函数
  61. * @param data 传输的数据
  62. * @param expire_us 定时时长(单位:us)
  63. */
  64. void timer_func_init_us(struct timer_func_list_t *timer_func, void (*func)(void *data), void *data, uint64_t expire_us)
  65. {
  66. list_init(&timer_func->list);
  67. timer_func->func = func;
  68. timer_func->data = data;
  69. timer_func->expire_jiffies = cal_next_n_us_jiffies(expire_us); // 设置过期的时间片
  70. // kdebug("timer_func->expire_jiffies=%ld",cal_next_n_us_jiffies(expire_us));
  71. }
  72. /**
  73. * @brief 将定时功能添加到列表中
  74. *
  75. * @param timer_func 待添加的定时功能
  76. */
  77. void timer_func_add(struct timer_func_list_t *timer_func)
  78. {
  79. struct timer_func_list_t *tmp = container_of(list_next(&timer_func_head.list), struct timer_func_list_t, list);
  80. if (list_empty(&timer_func_head.list) == false)
  81. while (tmp->expire_jiffies < timer_func->expire_jiffies)
  82. tmp = container_of(list_next(&tmp->list), struct timer_func_list_t, list);
  83. list_add(&tmp->list, &(timer_func->list));
  84. }
  85. /**
  86. * @brief 将定时功能从列表中删除
  87. *
  88. * @param timer_func
  89. */
  90. void timer_func_del(struct timer_func_list_t *timer_func)
  91. {
  92. list_del(&timer_func->list);
  93. }
  94. uint64_t sys_clock(struct pt_regs *regs)
  95. {
  96. return timer_jiffies;
  97. }
  98. uint64_t clock()
  99. {
  100. return timer_jiffies;
  101. }