xref: /nrf52832-nimble/rt-thread/examples/kernel/mbox_send_wait.c (revision 104654410c56c573564690304ae786df310c91fc)
1 /*
2  * 程序清单:邮箱例程_发送阻塞
3  *
4  * 这个程序用来测试邮箱发送时候的阻塞情况。
5  *
6  */
7 #include <rtthread.h>
8 #include "tc_comm.h"
9 
10 /* 指向线程控制块的指针 */
11 static rt_thread_t tid1 = RT_NULL;
12 static rt_thread_t tid2 = RT_NULL;
13 
14 /* 邮箱控制块 */
15 static struct rt_mailbox mb;
16 /* 用于放邮件的内存池 */
17 static char mb_pool[32];
18 
19 static char mb_str1[] = "I'm a mail!";
20 static char mb_str2[] = "this is another mail!";
21 
22 /* 线程1入口 */
thread1_entry(void * parameter)23 static void thread1_entry(void* parameter)
24 {
25     unsigned char* str;
26 
27     while (1)
28     {
29         /* 从邮箱中收取邮件 */
30         if (rt_mb_recv(&mb, (rt_uint32_t*)&str, RT_WAITING_FOREVER) == RT_EOK)
31         {
32             rt_kprintf("thread1: get a mail from mailbox, the content:%s\n", str);
33 
34             /* 延时20个OS Tick */
35             rt_thread_delay(50);
36         }
37     }
38 }
39 
40 /* 线程2入口 */
thread2_entry(void * parameter)41 static void thread2_entry(void* parameter)
42 {
43     rt_uint8_t count;
44     char  *str;
45 
46     count = 0;
47     while (1)
48     {
49         count ++;
50         if (count & 0x1)
51         {
52             /* 发送mb_str1地址到邮箱中 */
53             str = mb_str1;
54         }
55         else
56         {
57             /* 发送mb_str2地址到邮箱中 */
58             str = mb_str2;
59         }
60 
61         /* 不停的发送邮件,如果满了则等待10个tick,然后超时 */
62         if( rt_mb_send_wait(&mb, (rt_uint32_t)str,10) == RT_EOK )
63             rt_kprintf("thread2: sent a mail to mailbox, the content:%s\n", str);
64         else
65             rt_kprintf("thread2: timeout while waiting to send a mail.\n");
66     }
67 }
68 
mbox_send_wait_init()69 int mbox_send_wait_init()
70 {
71     /* 初始化一个mailbox */
72     rt_mb_init(&mb,
73                "mbt",             /* 名称是mbt */
74                &mb_pool[0],       /* 邮箱用到的内存池是mb_pool */
75                sizeof(mb_pool)/4, /* 大小是mb_pool大小除以4,因为一封邮件的大小是4字节 */
76                RT_IPC_FLAG_FIFO); /* 采用FIFO方式进行线程等待 */
77 
78     /* 创建线程1 */
79     tid1 = rt_thread_create("t1",
80                             thread1_entry, RT_NULL, /* 线程入口是thread1_entry, 入口参数是RT_NULL */
81                             THREAD_STACK_SIZE, THREAD_PRIORITY, THREAD_TIMESLICE);
82     if (tid1 != RT_NULL)
83         rt_thread_startup(tid1);
84     else
85         tc_stat(TC_STAT_END | TC_STAT_FAILED);
86 
87     /* 创建线程2 */
88     tid2 = rt_thread_create("t2",
89                             thread2_entry, RT_NULL, /* 线程入口是thread2_entry, 入口参数是RT_NULL */
90                             THREAD_STACK_SIZE, THREAD_PRIORITY, THREAD_TIMESLICE);
91     if (tid2 != RT_NULL)
92         rt_thread_startup(tid2);
93     else
94         tc_stat(TC_STAT_END | TC_STAT_FAILED);
95 
96     return 0;
97 }
98 
99 #ifdef RT_USING_TC
_tc_cleanup()100 static void _tc_cleanup()
101 {
102     /* 调度器上锁,上锁后,将不再切换到其他线程,仅响应中断 */
103     rt_enter_critical();
104 
105     /* 删除线程 */
106     if (tid1 != RT_NULL && tid1->stat != RT_THREAD_CLOSE)
107         rt_thread_delete(tid1);
108     if (tid2 != RT_NULL && tid2->stat != RT_THREAD_CLOSE)
109         rt_thread_delete(tid2);
110 
111     /* 执行邮箱对象脱离 */
112     rt_mb_detach(&mb);
113 
114     /* 调度器解锁 */
115     rt_exit_critical();
116 
117     /* 设置TestCase状态 */
118     tc_done(TC_STAT_PASSED);
119 }
120 
_tc_mbox_send_wait()121 int _tc_mbox_send_wait()
122 {
123     /* 设置TestCase清理回调函数 */
124     tc_cleanup(_tc_cleanup);
125     mbox_send_wait_init();
126 
127     /* 返回TestCase运行的最长时间 */
128     return 300;
129 }
130 /* 输出函数命令到finsh shell中 */
131 FINSH_FUNCTION_EXPORT(_tc_mbox_send_wait, a example of mailbox send wait);
132 #else
133 /* 用户应用入口 */
rt_application_init()134 int rt_application_init()
135 {
136     mbox_send_wait_init();
137 
138     return 0;
139 }
140 #endif
141 
142