xref: /nrf52832-nimble/rt-thread/examples/kernel/event_simple.c (revision 104654410c56c573564690304ae786df310c91fc)
1*10465441SEvalZero /*
2*10465441SEvalZero  * 程序清单:事件例程
3*10465441SEvalZero  *
4*10465441SEvalZero  * 这个程序会创建3个动态线程及初始化一个静态事件对象
5*10465441SEvalZero  * 一个线程等于事件对象上以接收事件;
6*10465441SEvalZero  * 一个线程定时发送事件 (事件3)
7*10465441SEvalZero  * 一个线程定时发送事件 (事件5)
8*10465441SEvalZero  */
9*10465441SEvalZero #include <rtthread.h>
10*10465441SEvalZero #include <time.h>
11*10465441SEvalZero #include "tc_comm.h"
12*10465441SEvalZero 
13*10465441SEvalZero /* 指向线程控制块的指针 */
14*10465441SEvalZero static rt_thread_t tid1 = RT_NULL;
15*10465441SEvalZero static rt_thread_t tid2 = RT_NULL;
16*10465441SEvalZero static rt_thread_t tid3 = RT_NULL;
17*10465441SEvalZero 
18*10465441SEvalZero /* 事件控制块 */
19*10465441SEvalZero static struct rt_event event;
20*10465441SEvalZero 
21*10465441SEvalZero /* 线程1入口函数 */
thread1_entry(void * param)22*10465441SEvalZero static void thread1_entry(void *param)
23*10465441SEvalZero {
24*10465441SEvalZero     rt_uint32_t e;
25*10465441SEvalZero 
26*10465441SEvalZero     while (1)
27*10465441SEvalZero     {
28*10465441SEvalZero         /* receive first event */
29*10465441SEvalZero         if (rt_event_recv(&event, ((1 << 3) | (1 << 5)),
30*10465441SEvalZero                           RT_EVENT_FLAG_AND | RT_EVENT_FLAG_CLEAR,
31*10465441SEvalZero                           RT_WAITING_FOREVER, &e) == RT_EOK)
32*10465441SEvalZero         {
33*10465441SEvalZero             rt_kprintf("thread1: AND recv event 0x%x\n", e);
34*10465441SEvalZero         }
35*10465441SEvalZero 
36*10465441SEvalZero         rt_kprintf("thread1: delay 1s to prepare second event\n");
37*10465441SEvalZero         rt_thread_delay(10);
38*10465441SEvalZero 
39*10465441SEvalZero         /* receive second event */
40*10465441SEvalZero         if (rt_event_recv(&event, ((1 << 3) | (1 << 5)),
41*10465441SEvalZero                           RT_EVENT_FLAG_OR | RT_EVENT_FLAG_CLEAR,
42*10465441SEvalZero                           RT_WAITING_FOREVER, &e) == RT_EOK)
43*10465441SEvalZero         {
44*10465441SEvalZero             rt_kprintf("thread1: OR recv event 0x%x\n", e);
45*10465441SEvalZero         }
46*10465441SEvalZero 
47*10465441SEvalZero         rt_thread_delay(5);
48*10465441SEvalZero     }
49*10465441SEvalZero }
50*10465441SEvalZero 
51*10465441SEvalZero /* 线程2入口函数 */
thread2_entry(void * param)52*10465441SEvalZero static void thread2_entry(void *param)
53*10465441SEvalZero {
54*10465441SEvalZero     while (1)
55*10465441SEvalZero     {
56*10465441SEvalZero         rt_kprintf("thread2: send event1\n");
57*10465441SEvalZero         rt_event_send(&event, (1 << 3));
58*10465441SEvalZero 
59*10465441SEvalZero         rt_thread_delay(10);
60*10465441SEvalZero     }
61*10465441SEvalZero }
62*10465441SEvalZero 
63*10465441SEvalZero /* 线程3入口函数 */
thread3_entry(void * param)64*10465441SEvalZero static void thread3_entry(void *param)
65*10465441SEvalZero {
66*10465441SEvalZero     while (1)
67*10465441SEvalZero     {
68*10465441SEvalZero         rt_kprintf("thread3: send event2\n");
69*10465441SEvalZero         rt_event_send(&event, (1 << 5));
70*10465441SEvalZero 
71*10465441SEvalZero         rt_thread_delay(20);
72*10465441SEvalZero     }
73*10465441SEvalZero }
74*10465441SEvalZero 
event_simple_init()75*10465441SEvalZero int event_simple_init()
76*10465441SEvalZero {
77*10465441SEvalZero     /* 初始化事件对象 */
78*10465441SEvalZero     rt_event_init(&event, "event", RT_IPC_FLAG_FIFO);
79*10465441SEvalZero 
80*10465441SEvalZero     /* 创建线程1 */
81*10465441SEvalZero     tid1 = rt_thread_create("t1",
82*10465441SEvalZero                             thread1_entry, RT_NULL, /* 线程入口是thread1_entry, 入口参数是RT_NULL */
83*10465441SEvalZero                             THREAD_STACK_SIZE, THREAD_PRIORITY, THREAD_TIMESLICE);
84*10465441SEvalZero     if (tid1 != RT_NULL)
85*10465441SEvalZero         rt_thread_startup(tid1);
86*10465441SEvalZero     else
87*10465441SEvalZero         tc_stat(TC_STAT_END | TC_STAT_FAILED);
88*10465441SEvalZero 
89*10465441SEvalZero     /* 创建线程2 */
90*10465441SEvalZero     tid2 = rt_thread_create("t2",
91*10465441SEvalZero                             thread2_entry, RT_NULL, /* 线程入口是thread2_entry, 入口参数是RT_NULL */
92*10465441SEvalZero                             THREAD_STACK_SIZE, THREAD_PRIORITY, THREAD_TIMESLICE);
93*10465441SEvalZero     if (tid2 != RT_NULL)
94*10465441SEvalZero         rt_thread_startup(tid2);
95*10465441SEvalZero     else
96*10465441SEvalZero         tc_stat(TC_STAT_END | TC_STAT_FAILED);
97*10465441SEvalZero 
98*10465441SEvalZero     /* 创建线程3 */
99*10465441SEvalZero     tid3 = rt_thread_create("t3",
100*10465441SEvalZero                             thread3_entry, RT_NULL, /* 线程入口是thread3_entry, 入口参数是RT_NULL */
101*10465441SEvalZero                             THREAD_STACK_SIZE, THREAD_PRIORITY, THREAD_TIMESLICE);
102*10465441SEvalZero     if (tid3 != RT_NULL)
103*10465441SEvalZero         rt_thread_startup(tid3);
104*10465441SEvalZero     else
105*10465441SEvalZero         tc_stat(TC_STAT_END | TC_STAT_FAILED);
106*10465441SEvalZero 
107*10465441SEvalZero     return 0;
108*10465441SEvalZero }
109*10465441SEvalZero 
110*10465441SEvalZero #ifdef RT_USING_TC
_tc_cleanup()111*10465441SEvalZero static void _tc_cleanup()
112*10465441SEvalZero {
113*10465441SEvalZero     /* 调度器上锁,上锁后,将不再切换到其他线程,仅响应中断 */
114*10465441SEvalZero     rt_enter_critical();
115*10465441SEvalZero 
116*10465441SEvalZero     /* 删除线程 */
117*10465441SEvalZero     if (tid1 != RT_NULL && tid1->stat != RT_THREAD_CLOSE)
118*10465441SEvalZero         rt_thread_delete(tid1);
119*10465441SEvalZero     if (tid2 != RT_NULL && tid2->stat != RT_THREAD_CLOSE)
120*10465441SEvalZero         rt_thread_delete(tid2);
121*10465441SEvalZero     if (tid3 != RT_NULL && tid3->stat != RT_THREAD_CLOSE)
122*10465441SEvalZero         rt_thread_delete(tid3);
123*10465441SEvalZero 
124*10465441SEvalZero     /* 执行事件对象脱离 */
125*10465441SEvalZero     rt_event_detach(&event);
126*10465441SEvalZero 
127*10465441SEvalZero     /* 调度器解锁 */
128*10465441SEvalZero     rt_exit_critical();
129*10465441SEvalZero 
130*10465441SEvalZero     /* 设置TestCase状态 */
131*10465441SEvalZero     tc_done(TC_STAT_PASSED);
132*10465441SEvalZero }
133*10465441SEvalZero 
_tc_event_simple()134*10465441SEvalZero int _tc_event_simple()
135*10465441SEvalZero {
136*10465441SEvalZero     /* 设置TestCase清理回调函数 */
137*10465441SEvalZero     tc_cleanup(_tc_cleanup);
138*10465441SEvalZero     event_simple_init();
139*10465441SEvalZero 
140*10465441SEvalZero     /* 返回TestCase运行的最长时间 */
141*10465441SEvalZero     return 100;
142*10465441SEvalZero }
143*10465441SEvalZero /* 输出函数命令到finsh shell中 */
144*10465441SEvalZero FINSH_FUNCTION_EXPORT(_tc_event_simple, a simple event example);
145*10465441SEvalZero #else
146*10465441SEvalZero /* 用户应用入口 */
rt_application_init()147*10465441SEvalZero int rt_application_init()
148*10465441SEvalZero {
149*10465441SEvalZero     event_simple_init();
150*10465441SEvalZero 
151*10465441SEvalZero     return 0;
152*10465441SEvalZero }
153*10465441SEvalZero #endif
154