mailbox_sample.c 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  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. */
  10. /*
  11. * 程序清单:邮箱例程
  12. *
  13. * 这个程序会创建2个动态线程,一个静态的邮箱对象,其中一个线程往邮箱中发送邮件,
  14. * 一个线程往邮箱中收取邮件。
  15. */
  16. #include <rtthread.h>
  17. #define THREAD_PRIORITY 10
  18. #define THREAD_TIMESLICE 5
  19. /* 邮箱控制块 */
  20. static struct rt_mailbox mb;
  21. /* 用于放邮件的内存池 */
  22. static char mb_pool[128];
  23. static char mb_str1[] = "I'm a mail!";
  24. static char mb_str2[] = "this is another mail!";
  25. static char mb_str3[] = "over";
  26. #ifdef rt_align
  27. rt_align(RT_ALIGN_SIZE)
  28. #else
  29. ALIGN(RT_ALIGN_SIZE)
  30. #endif
  31. static char thread1_stack[1024];
  32. static struct rt_thread thread1;
  33. /* 线程1入口 */
  34. static void thread1_entry(void *parameter)
  35. {
  36. char *str;
  37. while (1)
  38. {
  39. rt_kprintf("thread1: try to recv a mail\n");
  40. /* 从邮箱中收取邮件 */
  41. if (rt_mb_recv(&mb, (rt_ubase_t *)&str, RT_WAITING_FOREVER) == RT_EOK)
  42. {
  43. rt_kprintf("thread1: get a mail from mailbox, the content:%s\n", str);
  44. if (str == mb_str3)
  45. break;
  46. /* 延时100ms */
  47. rt_thread_mdelay(100);
  48. }
  49. }
  50. /* 执行邮箱对象脱离 */
  51. rt_mb_detach(&mb);
  52. }
  53. #ifdef rt_align
  54. rt_align(RT_ALIGN_SIZE)
  55. #else
  56. ALIGN(RT_ALIGN_SIZE)
  57. #endif
  58. static char thread2_stack[1024];
  59. static struct rt_thread thread2;
  60. /* 线程2入口 */
  61. static void thread2_entry(void *parameter)
  62. {
  63. rt_uint8_t count;
  64. count = 0;
  65. while (count < 10)
  66. {
  67. count ++;
  68. if (count & 0x1)
  69. {
  70. /* 发送mb_str1地址到邮箱中 */
  71. rt_mb_send(&mb, (rt_uint32_t)&mb_str1);
  72. }
  73. else
  74. {
  75. /* 发送mb_str2地址到邮箱中 */
  76. rt_mb_send(&mb, (rt_uint32_t)&mb_str2);
  77. }
  78. /* 延时200ms */
  79. rt_thread_mdelay(200);
  80. }
  81. /* 发送邮件告诉线程1,线程2已经运行结束 */
  82. rt_mb_send(&mb, (rt_uint32_t)&mb_str3);
  83. }
  84. int mailbox_sample(void)
  85. {
  86. rt_err_t result;
  87. /* 初始化一个mailbox */
  88. result = rt_mb_init(&mb,
  89. "mbt", /* 名称是mbt */
  90. &mb_pool[0], /* 邮箱用到的内存池是mb_pool */
  91. sizeof(mb_pool) / sizeof(rt_ubase_t), /* 邮箱中的邮件数目,sizeof(rt_ubase_t)表示指针大小 */
  92. RT_IPC_FLAG_PRIO); /* 采用PRIO方式进行线程等待 */
  93. if (result != RT_EOK)
  94. {
  95. rt_kprintf("init mailbox failed.\n");
  96. return -1;
  97. }
  98. rt_thread_init(&thread1,
  99. "thread1",
  100. thread1_entry,
  101. RT_NULL,
  102. &thread1_stack[0],
  103. sizeof(thread1_stack),
  104. THREAD_PRIORITY, THREAD_TIMESLICE);
  105. #ifdef RT_USING_SMP
  106. /* 绑定线程到同一个核上,避免启用多核时的输出混乱 */
  107. rt_thread_control(&thread1, RT_THREAD_CTRL_BIND_CPU, (void*)0);
  108. #endif
  109. rt_thread_startup(&thread1);
  110. rt_thread_init(&thread2,
  111. "thread2",
  112. thread2_entry,
  113. RT_NULL,
  114. &thread2_stack[0],
  115. sizeof(thread2_stack),
  116. THREAD_PRIORITY, THREAD_TIMESLICE);
  117. #ifdef RT_USING_SMP
  118. /* 绑定线程到同一个核上,避免启用多核时的输出混乱 */
  119. rt_thread_control(&thread2, RT_THREAD_CTRL_BIND_CPU, (void*)0);
  120. #endif
  121. rt_thread_startup(&thread2);
  122. return 0;
  123. }
  124. /* 导出到 msh 命令列表中 */
  125. MSH_CMD_EXPORT(mailbox_sample, mailbox sample);