2025-06-27 00:32:57 +08:00
|
|
|
|
/*
|
2025-07-05 19:47:28 +08:00
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>嵥<EFBFBD><EFBFBD><EFBFBD>¼<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
2025-06-27 00:32:57 +08:00
|
|
|
|
*
|
2025-07-05 19:47:28 +08:00
|
|
|
|
* <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ᴴ<EFBFBD><EFBFBD>3<EFBFBD><EFBFBD><EFBFBD><EFBFBD>̬<EFBFBD>̼߳<EFBFBD><EFBFBD><EFBFBD>ʼ<EFBFBD><EFBFBD>һ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>̬<EFBFBD>¼<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
* һ<EFBFBD><EFBFBD><EFBFBD>̵߳<EFBFBD><EFBFBD><EFBFBD><EFBFBD>¼<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Խ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>¼<EFBFBD><EFBFBD><EFBFBD>
|
|
|
|
|
|
* һ<EFBFBD><EFBFBD><EFBFBD>̶߳<EFBFBD>ʱ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>¼<EFBFBD> (<EFBFBD>¼<EFBFBD>3)
|
|
|
|
|
|
* һ<EFBFBD><EFBFBD><EFBFBD>̶߳<EFBFBD>ʱ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>¼<EFBFBD> (<EFBFBD>¼<EFBFBD>5)
|
2025-06-27 00:32:57 +08:00
|
|
|
|
*/
|
|
|
|
|
|
#include <rtthread.h>
|
|
|
|
|
|
#include <time.h>
|
|
|
|
|
|
#include "tc_comm.h"
|
|
|
|
|
|
|
2025-07-05 19:47:28 +08:00
|
|
|
|
/* ָ<><D6B8><EFBFBD>߳̿<DFB3><CCBF>ƿ<EFBFBD><C6BF><EFBFBD>ָ<EFBFBD><D6B8> */
|
2025-06-27 00:32:57 +08:00
|
|
|
|
static rt_thread_t tid1 = RT_NULL;
|
|
|
|
|
|
static rt_thread_t tid2 = RT_NULL;
|
|
|
|
|
|
static rt_thread_t tid3 = RT_NULL;
|
|
|
|
|
|
|
2025-07-05 19:47:28 +08:00
|
|
|
|
/* <20>¼<EFBFBD><C2BC><EFBFBD><EFBFBD>ƿ<EFBFBD> */
|
2025-06-27 00:32:57 +08:00
|
|
|
|
static struct rt_event event;
|
|
|
|
|
|
|
2025-07-05 19:47:28 +08:00
|
|
|
|
/* <20>߳<EFBFBD>1<EFBFBD><31><EFBFBD>ں<EFBFBD><DABA><EFBFBD> */
|
2025-06-27 00:32:57 +08:00
|
|
|
|
static void thread1_entry(void *param)
|
|
|
|
|
|
{
|
|
|
|
|
|
rt_uint32_t e;
|
|
|
|
|
|
|
|
|
|
|
|
while (1)
|
|
|
|
|
|
{
|
|
|
|
|
|
/* receive first event */
|
|
|
|
|
|
if (rt_event_recv(&event, ((1 << 3) | (1 << 5)),
|
|
|
|
|
|
RT_EVENT_FLAG_AND | RT_EVENT_FLAG_CLEAR,
|
|
|
|
|
|
RT_WAITING_FOREVER, &e) == RT_EOK)
|
|
|
|
|
|
{
|
|
|
|
|
|
rt_kprintf("thread1: AND recv event 0x%x\n", e);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
rt_kprintf("thread1: delay 1s to prepare second event\n");
|
|
|
|
|
|
rt_thread_delay(10);
|
|
|
|
|
|
|
|
|
|
|
|
/* receive second event */
|
|
|
|
|
|
if (rt_event_recv(&event, ((1 << 3) | (1 << 5)),
|
|
|
|
|
|
RT_EVENT_FLAG_OR | RT_EVENT_FLAG_CLEAR,
|
|
|
|
|
|
RT_WAITING_FOREVER, &e) == RT_EOK)
|
|
|
|
|
|
{
|
|
|
|
|
|
rt_kprintf("thread1: OR recv event 0x%x\n", e);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
rt_thread_delay(5);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2025-07-05 19:47:28 +08:00
|
|
|
|
/* <20>߳<EFBFBD>2<EFBFBD><32><EFBFBD>ں<EFBFBD><DABA><EFBFBD> */
|
2025-06-27 00:32:57 +08:00
|
|
|
|
static void thread2_entry(void *param)
|
|
|
|
|
|
{
|
|
|
|
|
|
while (1)
|
|
|
|
|
|
{
|
|
|
|
|
|
rt_kprintf("thread2: send event1\n");
|
|
|
|
|
|
rt_event_send(&event, (1 << 3));
|
|
|
|
|
|
|
|
|
|
|
|
rt_thread_delay(10);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2025-07-05 19:47:28 +08:00
|
|
|
|
/* <20>߳<EFBFBD>3<EFBFBD><33><EFBFBD>ں<EFBFBD><DABA><EFBFBD> */
|
2025-06-27 00:32:57 +08:00
|
|
|
|
static void thread3_entry(void *param)
|
|
|
|
|
|
{
|
|
|
|
|
|
while (1)
|
|
|
|
|
|
{
|
|
|
|
|
|
rt_kprintf("thread3: send event2\n");
|
|
|
|
|
|
rt_event_send(&event, (1 << 5));
|
|
|
|
|
|
|
|
|
|
|
|
rt_thread_delay(20);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int event_simple_init()
|
|
|
|
|
|
{
|
2025-07-05 19:47:28 +08:00
|
|
|
|
/* <20><>ʼ<EFBFBD><CABC><EFBFBD>¼<EFBFBD><C2BC><EFBFBD><EFBFBD><EFBFBD> */
|
2025-06-27 00:32:57 +08:00
|
|
|
|
rt_event_init(&event, "event", RT_IPC_FLAG_FIFO);
|
|
|
|
|
|
|
2025-07-05 19:47:28 +08:00
|
|
|
|
/* <20><><EFBFBD><EFBFBD><EFBFBD>߳<EFBFBD>1 */
|
2025-06-27 00:32:57 +08:00
|
|
|
|
tid1 = rt_thread_create("t1",
|
2025-07-05 19:47:28 +08:00
|
|
|
|
thread1_entry, RT_NULL, /* <20>߳<EFBFBD><DFB3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>thread1_entry, <20><><EFBFBD>ڲ<EFBFBD><DAB2><EFBFBD><EFBFBD><EFBFBD>RT_NULL */
|
2025-06-27 00:32:57 +08:00
|
|
|
|
THREAD_STACK_SIZE, THREAD_PRIORITY, THREAD_TIMESLICE);
|
|
|
|
|
|
if (tid1 != RT_NULL)
|
|
|
|
|
|
rt_thread_startup(tid1);
|
|
|
|
|
|
else
|
|
|
|
|
|
tc_stat(TC_STAT_END | TC_STAT_FAILED);
|
|
|
|
|
|
|
2025-07-05 19:47:28 +08:00
|
|
|
|
/* <20><><EFBFBD><EFBFBD><EFBFBD>߳<EFBFBD>2 */
|
2025-06-27 00:32:57 +08:00
|
|
|
|
tid2 = rt_thread_create("t2",
|
2025-07-05 19:47:28 +08:00
|
|
|
|
thread2_entry, RT_NULL, /* <20>߳<EFBFBD><DFB3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>thread2_entry, <20><><EFBFBD>ڲ<EFBFBD><DAB2><EFBFBD><EFBFBD><EFBFBD>RT_NULL */
|
2025-06-27 00:32:57 +08:00
|
|
|
|
THREAD_STACK_SIZE, THREAD_PRIORITY, THREAD_TIMESLICE);
|
|
|
|
|
|
if (tid2 != RT_NULL)
|
|
|
|
|
|
rt_thread_startup(tid2);
|
|
|
|
|
|
else
|
|
|
|
|
|
tc_stat(TC_STAT_END | TC_STAT_FAILED);
|
|
|
|
|
|
|
2025-07-05 19:47:28 +08:00
|
|
|
|
/* <20><><EFBFBD><EFBFBD><EFBFBD>߳<EFBFBD>3 */
|
2025-06-27 00:32:57 +08:00
|
|
|
|
tid3 = rt_thread_create("t3",
|
2025-07-05 19:47:28 +08:00
|
|
|
|
thread3_entry, RT_NULL, /* <20>߳<EFBFBD><DFB3><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>thread3_entry, <20><><EFBFBD>ڲ<EFBFBD><DAB2><EFBFBD><EFBFBD><EFBFBD>RT_NULL */
|
2025-06-27 00:32:57 +08:00
|
|
|
|
THREAD_STACK_SIZE, THREAD_PRIORITY, THREAD_TIMESLICE);
|
|
|
|
|
|
if (tid3 != RT_NULL)
|
|
|
|
|
|
rt_thread_startup(tid3);
|
|
|
|
|
|
else
|
|
|
|
|
|
tc_stat(TC_STAT_END | TC_STAT_FAILED);
|
|
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef RT_USING_TC
|
|
|
|
|
|
static void _tc_cleanup()
|
|
|
|
|
|
{
|
2025-07-05 19:47:28 +08:00
|
|
|
|
/* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><F3A3ACBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>л<EFBFBD><D0BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>̣߳<DFB3><CCA3><EFBFBD><EFBFBD><EFBFBD>Ӧ<EFBFBD>ж<EFBFBD> */
|
2025-06-27 00:32:57 +08:00
|
|
|
|
rt_enter_critical();
|
|
|
|
|
|
|
2025-07-05 19:47:28 +08:00
|
|
|
|
/* ɾ<><C9BE><EFBFBD>߳<EFBFBD> */
|
2025-06-27 00:32:57 +08:00
|
|
|
|
if (tid1 != RT_NULL && tid1->stat != RT_THREAD_CLOSE)
|
|
|
|
|
|
rt_thread_delete(tid1);
|
|
|
|
|
|
if (tid2 != RT_NULL && tid2->stat != RT_THREAD_CLOSE)
|
|
|
|
|
|
rt_thread_delete(tid2);
|
|
|
|
|
|
if (tid3 != RT_NULL && tid3->stat != RT_THREAD_CLOSE)
|
|
|
|
|
|
rt_thread_delete(tid3);
|
|
|
|
|
|
|
2025-07-05 19:47:28 +08:00
|
|
|
|
/* ִ<><D6B4><EFBFBD>¼<EFBFBD><C2BC><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
|
2025-06-27 00:32:57 +08:00
|
|
|
|
rt_event_detach(&event);
|
|
|
|
|
|
|
2025-07-05 19:47:28 +08:00
|
|
|
|
/* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
|
2025-06-27 00:32:57 +08:00
|
|
|
|
rt_exit_critical();
|
|
|
|
|
|
|
2025-07-05 19:47:28 +08:00
|
|
|
|
/* <20><><EFBFBD><EFBFBD>TestCase״̬ */
|
2025-06-27 00:32:57 +08:00
|
|
|
|
tc_done(TC_STAT_PASSED);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int _tc_event_simple()
|
|
|
|
|
|
{
|
2025-07-05 19:47:28 +08:00
|
|
|
|
/* <20><><EFBFBD><EFBFBD>TestCase<73><65><EFBFBD><EFBFBD><EFBFBD>ص<EFBFBD><D8B5><EFBFBD><EFBFBD><EFBFBD> */
|
2025-06-27 00:32:57 +08:00
|
|
|
|
tc_cleanup(_tc_cleanup);
|
|
|
|
|
|
event_simple_init();
|
|
|
|
|
|
|
2025-07-05 19:47:28 +08:00
|
|
|
|
/* <20><><EFBFBD><EFBFBD>TestCase<73><65><EFBFBD>е<EFBFBD><D0B5>ʱ<EEB3A4><CAB1> */
|
2025-06-27 00:32:57 +08:00
|
|
|
|
return 100;
|
|
|
|
|
|
}
|
2025-07-05 19:47:28 +08:00
|
|
|
|
/* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>finsh shell<6C><6C> */
|
2025-06-27 00:32:57 +08:00
|
|
|
|
FINSH_FUNCTION_EXPORT(_tc_event_simple, a simple event example);
|
|
|
|
|
|
#else
|
2025-07-05 19:47:28 +08:00
|
|
|
|
/* <20>û<EFBFBD>Ӧ<EFBFBD><D3A6><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
|
2025-06-27 00:32:57 +08:00
|
|
|
|
int rt_application_init()
|
|
|
|
|
|
{
|
|
|
|
|
|
event_simple_init();
|
|
|
|
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
}
|
|
|
|
|
|
#endif
|