mailbox_urgent_sample.c 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. /*
  2. * Copyright (c) 2006-2022, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2018-08-24 yangjie the first version
  9. * 2021-01-03 Meco Man add the demo of rt_mb_urgent()
  10. */
  11. /*
  12. * 程序清单:邮箱例程
  13. *
  14. * 这个程序会创建2个动态线程,一个静态的邮箱对象,其中一个线程往邮箱中发送邮件,
  15. * 一个线程往邮箱中收取邮件。
  16. * 本例程也会展示紧急邮件和正常邮件的区别。
  17. */
  18. #include <rtthread.h>
  19. #define THREAD_PRIORITY 10
  20. #define THREAD_TIMESLICE 5
  21. /* 邮箱控制块 */
  22. static struct rt_mailbox mb;
  23. /* 用于放邮件的内存池 */
  24. static char mb_pool[128];
  25. static char mb_urgent[] = "I'm a urgent mail!";
  26. static char mb_normal[] = "I'm a normal mail!";
  27. static char mb_str3[] = "over";
  28. ALIGN(RT_ALIGN_SIZE)
  29. static char thread1_stack[1024];
  30. static struct rt_thread thread1;
  31. /* 线程1入口 */
  32. static void thread1_entry(void *parameter)
  33. {
  34. char *str;
  35. while (1)
  36. {
  37. rt_kprintf("thread1: try to recv a mail\n");
  38. /* 从邮箱中收取邮件 */
  39. if (rt_mb_recv(&mb, (rt_ubase_t *)&str, RT_WAITING_FOREVER) == RT_EOK)
  40. {
  41. rt_kprintf("thread1: get a mail from mailbox, the content:%s\n", str);
  42. if (str == mb_str3)
  43. break;
  44. /* 延时100ms */
  45. rt_thread_mdelay(100);
  46. }
  47. }
  48. /* 执行邮箱对象脱离 */
  49. rt_mb_detach(&mb);
  50. }
  51. ALIGN(RT_ALIGN_SIZE)
  52. static char thread2_stack[1024];
  53. static struct rt_thread thread2;
  54. /* 线程2入口 */
  55. static void thread2_entry(void *parameter)
  56. {
  57. rt_uint8_t count;
  58. count = 0;
  59. while (count < 10)
  60. {
  61. count ++;
  62. /* 分别发送正常邮件和紧急邮件到邮箱中 */
  63. /* 关调度器是为了同时给线程1两封邮件,观察线程1如何处理紧急邮件和正常邮件 */
  64. rt_enter_critical();
  65. rt_mb_send(&mb, (rt_uint32_t)&mb_normal);
  66. rt_mb_urgent(&mb, (rt_uint32_t)&mb_urgent);
  67. rt_exit_critical();
  68. /* 可以看到虽然正常邮件和紧急优先同时发送,但是邮箱选择优先处理紧急邮件 */
  69. /* 延时200ms */
  70. rt_thread_mdelay(200);
  71. }
  72. /* 发送邮件告诉线程1,线程2已经运行结束 */
  73. rt_mb_send(&mb, (rt_uint32_t)&mb_str3);
  74. }
  75. int mailbox_urgent_sample(void)
  76. {
  77. rt_err_t result;
  78. /* 初始化一个mailbox */
  79. result = rt_mb_init(&mb,
  80. "mbt", /* 名称是mbt */
  81. &mb_pool[0], /* 邮箱用到的内存池是mb_pool */
  82. sizeof(mb_pool) / sizeof(rt_ubase_t), /* 邮箱中的邮件数目,sizeof(rt_ubase_t)表示指针大小 */
  83. RT_IPC_FLAG_PRIO); /* 采用PRIO方式进行线程等待 */
  84. if (result != RT_EOK)
  85. {
  86. rt_kprintf("init mailbox failed.\n");
  87. return -1;
  88. }
  89. rt_thread_init(&thread1,
  90. "thread1",
  91. thread1_entry,
  92. RT_NULL,
  93. &thread1_stack[0],
  94. sizeof(thread1_stack),
  95. THREAD_PRIORITY, THREAD_TIMESLICE);
  96. rt_thread_startup(&thread1);
  97. rt_thread_init(&thread2,
  98. "thread2",
  99. thread2_entry,
  100. RT_NULL,
  101. &thread2_stack[0],
  102. sizeof(thread2_stack),
  103. THREAD_PRIORITY, THREAD_TIMESLICE);
  104. rt_thread_startup(&thread2);
  105. return 0;
  106. }
  107. /* 导出到 msh 命令列表中 */
  108. MSH_CMD_EXPORT(mailbox_urgent_sample, mailbox urgent sample);