thread_resume.c 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. /*
  2. * Copyright (c) 2006-2021, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. *
  8. */
  9. /*
  10. * 程序清单:唤醒线程
  11. *
  12. * 这个例子中将创建两个动态线程,低优先级线程将挂起自身,然后
  13. * 高优先级线程将在一定时刻后唤醒低优先级线程。
  14. */
  15. #include <rtthread.h>
  16. #include "tc_comm.h"
  17. /* 指向线程控制块的指针 */
  18. static rt_thread_t tid1 = RT_NULL;
  19. static rt_thread_t tid2 = RT_NULL;
  20. /* 线程1入口 */
  21. static void thread1_entry(void* parameter)
  22. {
  23. /* 低优先级线程1开始运行 */
  24. rt_kprintf("thread1 startup%d\n");
  25. /* 挂起自身 */
  26. rt_kprintf("suspend thread self\n");
  27. rt_thread_suspend(tid1);
  28. /* 主动执行线程调度 */
  29. rt_schedule();
  30. /* 当线程1被唤醒时 */
  31. rt_kprintf("thread1 resumed\n");
  32. }
  33. static void thread_cleanup(rt_thread_t tid)
  34. {
  35. if (tid == tid1)
  36. {
  37. tid1 = RT_NULL;
  38. }
  39. if (tid == tid2)
  40. {
  41. tid = RT_NULL;
  42. }
  43. }
  44. /* 线程2入口 */
  45. static void thread2_entry(void* parameter)
  46. {
  47. /* 延时10个OS Tick */
  48. rt_thread_delay(10);
  49. /* 唤醒线程1 */
  50. rt_thread_resume(tid1);
  51. rt_kprintf("thread2: to resume thread1\n");
  52. /* 延时10个OS Tick */
  53. rt_thread_delay(10);
  54. /* 线程2自动退出 */
  55. }
  56. int thread_resume_init()
  57. {
  58. /* 创建线程1 */
  59. tid1 = rt_thread_create("thread",
  60. thread1_entry, RT_NULL, /* 线程入口是thread1_entry, 入口参数是RT_NULL */
  61. THREAD_STACK_SIZE, THREAD_PRIORITY, THREAD_TIMESLICE);
  62. if (tid1 != RT_NULL)
  63. {
  64. tid1->cleanup = thread_cleanup;
  65. rt_thread_startup(tid1);
  66. }
  67. else
  68. tc_stat(TC_STAT_END | TC_STAT_FAILED);
  69. /* 创建线程2 */
  70. tid2 = rt_thread_create("thread",
  71. thread2_entry, RT_NULL, /* 线程入口是thread2_entry, 入口参数是RT_NULL */
  72. THREAD_STACK_SIZE, THREAD_PRIORITY - 1, THREAD_TIMESLICE);
  73. if (tid2 != RT_NULL)
  74. {
  75. tid2->cleanup = thread_cleanup;
  76. rt_thread_startup(tid2);
  77. }
  78. else
  79. tc_stat(TC_STAT_END | TC_STAT_FAILED);
  80. return 0;
  81. }
  82. #ifdef RT_USING_TC
  83. static void _tc_cleanup()
  84. {
  85. /* 调度器上锁,上锁后,将不再切换到其他线程,仅响应中断 */
  86. rt_enter_critical();
  87. /* 删除线程 */
  88. if (tid1 != RT_NULL && tid1->stat != RT_THREAD_CLOSE)
  89. rt_thread_delete(tid1);
  90. if (tid2 != RT_NULL && tid2->stat != RT_THREAD_CLOSE)
  91. rt_thread_delete(tid2);
  92. /* 调度器解锁 */
  93. rt_exit_critical();
  94. /* 设置TestCase状态 */
  95. tc_done(TC_STAT_PASSED);
  96. }
  97. int _tc_thread_resume()
  98. {
  99. /* 设置TestCase清理回调函数 */
  100. tc_cleanup(_tc_cleanup);
  101. thread_resume_init();
  102. /* 返回TestCase运行的最长时间 */
  103. return 25;
  104. }
  105. /* 输出函数命令到finsh shell中 */
  106. FINSH_FUNCTION_EXPORT(_tc_thread_resume, a thread resume example);
  107. #else
  108. /* 用户应用入口 */
  109. int rt_application_init()
  110. {
  111. thread_resume_init();
  112. return 0;
  113. }
  114. #endif