- 创建队列的功能:创建一个等待属性为 FIFO 的消息队列 1;创建一个等待属性为LIFO 的消息队列 2。
- 考察以 FIFO 方式释放消息的消息队列:由任务 TA0、TA1、TA2 等待队列 1 中的消息。TA0、TA1、TA2 使用相同的任务代码(Taskq1 函数)。
- 考察以 LIFO 方式释放消息的消息队列:由任务 TA3、TA4、TA5 等待队列 2 中的消息。TA3、TA4、TA5 使用相同的任务代码(Taskq2 函数)。
- 考察清空消息队列、查询消息队列的功能 查询消息队列的功能: TaskCon 任务向队列 2 中连续发送 6 条消息,然后查询消息数;清空该队列后再查询。
考察删除消息队列的安全性:在任务 TA3、TA4、TA5 等待队列 2 中的消息的过程中,让 TaskCon 删除队列 2;当队列 2 被删除后,检查任务 TA3、TA4、TA5 调用接收消息的函数是否返回错误码。
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 |
|
void TaskQueue1(void* pdata)
{ INT8U err; INT8U id; void* msg; id = *(int*)pdata; while(1) { OSTimeDlyHMSM(0,0,1,0); msg = OSQPend(q1,0,&err); switch(err) { case OS_NO_ERR: /* If it is normally, just print the string.*/ printf("Task_%d got %s \r\n", id, (char*)msg); OSTimeDlyHMSM(0,0,1,0); break; default: /* If the queue is empty or has been deleted, print another string.*/ printf("Queue1 %d is empty! \r\n",id); OSTimeDlyHMSM(0,0,1,0); break; } } } void TaskQueue2(void* pdata) void TaskCon(void* pdata) |
2 3 4 5 6 |
|
GLOBAL INT8U TaskData[N_TASKS];
#define MSG_SIZE 6 GLOBAL void* msg1[MSG_SIZE]; GLOBAL void* msg2[MSG_SIZE]; GLOBAL OS_EVENT *q1; GLOBAL OS_EVENT *q2; |
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
|
#define QUEUE1_STK_SIZE 64
#define QUEUE2_STK_SIZE 64 #define COM_STK_SIZE 64 #define QUEUE_TASK_Prio 20 #define N_TASKS 3 void TaskQueue1(void* pdata); |
2 3 4 5 6 7 8 9 10 |
|
/* 实验四 消息队列 */ for(i = 0; i < N_TASKS; i++) { TaskData[i] = i; OSTaskCreate(TaskQueue1, (void *)&TaskData[i], (OS_STK *)&TASK_QUEUE1_STK[i][QUEUE1_STK_SIZE - 1], QUEUE_TASK_Prio + i); OSTaskCreate(TaskQueue2, (void *)&TaskData[i], (OS_STK *)&TASK_QUEUE2_STK[i][QUEUE2_STK_SIZE - 1], QUEUE_TASK_Prio + i + N_TASKS); } OSTaskCreate(TaskCon, (void *)0, (OS_STK *)&TASK_COM_STK[COM_STK_SIZE - 1], COM_TASK_Prio); |
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
|
int main(void)
{ BSP_Init(); OSInit(); q1 = OSQCreate(msg1,6); q2 = OSQCreate(msg2,6); OSTaskCreate( TaskStart, |