hwtimer_test.c 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. /*
  2. * Copyright (c) 2006-2021, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. */
  9. #include <rtthread.h>
  10. #include <rtdevice.h>
  11. #include <finsh.h>
  12. #ifdef RT_USING_HWTIMER
  13. #define TIMER "timer0"
  14. static rt_err_t timer_timeout_cb(rt_device_t dev, rt_size_t size)
  15. {
  16. rt_kprintf("enter hardware timer isr\n");
  17. return 0;
  18. }
  19. int hwtimer(void)
  20. {
  21. rt_err_t err;
  22. rt_hwtimerval_t val;
  23. rt_device_t dev = RT_NULL;
  24. rt_tick_t tick;
  25. rt_hwtimer_mode_t mode;
  26. int freq = 10000;
  27. int t = 5;
  28. if ((dev = rt_device_find(TIMER)) == RT_NULL)
  29. {
  30. rt_kprintf("No Device: %s\n", TIMER);
  31. return -1;
  32. }
  33. if (rt_device_open(dev, RT_DEVICE_OFLAG_RDWR) != RT_EOK)
  34. {
  35. rt_kprintf("Open %s Fail\n", TIMER);
  36. return -1;
  37. }
  38. /* 时间测量 */
  39. /* 计数时钟设置(默认1Mhz或支持的最小计数频率) */
  40. err = rt_device_control(dev, HWTIMER_CTRL_FREQ_SET, &freq);
  41. if (err != RT_EOK)
  42. {
  43. rt_kprintf("Set Freq=%dhz Fail\n", freq);
  44. goto EXIT;
  45. }
  46. /* 周期模式 */
  47. mode = HWTIMER_MODE_PERIOD;
  48. err = rt_device_control(dev, HWTIMER_CTRL_MODE_SET, &mode);
  49. tick = rt_tick_get();
  50. rt_kprintf("Start Timer> Tick: %d\n", tick);
  51. /* 设置定时器超时值并启动定时器 */
  52. val.sec = t;
  53. val.usec = 0;
  54. rt_kprintf("SetTime: Sec %d, Usec %d\n", val.sec, val.usec);
  55. if (rt_device_write(dev, 0, &val, sizeof(val)) != sizeof(val))
  56. {
  57. rt_kprintf("SetTime Fail\n");
  58. goto EXIT;
  59. }
  60. rt_kprintf("Sleep %d sec\n", t);
  61. rt_thread_delay(t*RT_TICK_PER_SECOND);
  62. /* 停止定时器 */
  63. err = rt_device_control(dev, HWTIMER_CTRL_STOP, RT_NULL);
  64. rt_kprintf("Timer Stoped\n");
  65. /* 读取计数 */
  66. rt_device_read(dev, 0, &val, sizeof(val));
  67. rt_kprintf("Read: Sec = %d, Usec = %d\n", val.sec, val.usec);
  68. /* 定时执行回调函数 -- 单次模式 */
  69. /* 设置超时回调函数 */
  70. rt_device_set_rx_indicate(dev, timer_timeout_cb);
  71. /* 单次模式 */
  72. mode = HWTIMER_MODE_PERIOD;
  73. err = rt_device_control(dev, HWTIMER_CTRL_MODE_SET, &mode);
  74. /* 设置定时器超时值并启动定时器 */
  75. val.sec = t;
  76. val.usec = 0;
  77. rt_kprintf("SetTime: Sec %d, Usec %d\n", val.sec, val.usec);
  78. if (rt_device_write(dev, 0, &val, sizeof(val)) != sizeof(val))
  79. {
  80. rt_kprintf("SetTime Fail\n");
  81. goto EXIT;
  82. }
  83. /* 等待回调函数执行 */
  84. rt_thread_delay((t + 1)*RT_TICK_PER_SECOND);
  85. EXIT:
  86. err = rt_device_close(dev);
  87. rt_kprintf("Close %s\n", TIMER);
  88. return err;
  89. }
  90. #ifdef RT_USING_FINSH
  91. MSH_CMD_EXPORT(hwtimer, "Test hardware timer");
  92. #endif
  93. #endif /* RT_USING_HWTIMER */