logo资料库

ucos2.52注释.pdf

第1页 / 共115页
第2页 / 共115页
第3页 / 共115页
第4页 / 共115页
第5页 / 共115页
第6页 / 共115页
第7页 / 共115页
第8页 / 共115页
资料共115页,剩余部分请下载后查看
Ucos_II 2.52源码中文译注.pdf
uCOS_II.c.pdf
uCOS_II.h.pdf
uCOS各关键字表.pdf
Sheet1
INCLUDES.c.pdf
OS_CFG.c.pdf
OS_CORE.c.pdf
OS_FLAG.c.pdf
OS_MUTEX.c.pdf
OS_MBOX.c.pdf
OS_Q.c.pdf
OS_MEM.c.pdf
OS_SEM.c.pdf
OS_TASK.c.pdf
OS_TIME.c.pdf
PC.c.pdf
PC.h.pdf
如何在BC4.5下成功编译ucos2.52.pdf
Ucos_II2.52 源码中文译注                                                                                                                          作者:  钟常慰  Ucos_II2.52 是一份非常完美的嵌入式开发系统,在学习 ARM 的基础上,嵌入 ucos 系统 并增加自己的源码是一件不错的选择,目前在市面上已经有了大量的 ucos 嵌入案例,特别 是在 arm 和 dsp 的应用当中,已经成为一种主流,虽然和其它的嵌入式系统相比,ucos 不 是很完善,如没有内存分配、任务级别不多;但却是一个代码简短、条理清晰、实时性及安 全性能很高的嵌入式操作系统。    Ucos_II2.52 对比 2.8 版的 256 个任务而言,任务数量相比过少,但却是目前应用量最大 的一个版本,相对而言,能够满足我们的基本要求,而且增加了很多消息处理,特别是在优 先级别方面,具有不可比拟的优势;我曾试图阅读 ecos 的源码,但还是失败了,还有挑战 linux0.01 版源码的想法,最终我不能不被屈服;对于 Ucos 而言,很多入门者是一个福音, 因为它的代码非常的少,而且能够对应贝贝老师的书本直接参考,他的书本对结构方面讲解 的极为 xian 详细。    在学习 Ucos 的整个过程中,E 文的理解是一个致命的打击,原因是我的 E 文水平很差, 不过 Ucos 还是给了我尝试的动力,在作者的原基础上增加中文译码,也许是一件非常不错 的选择,相信在中国和我这种水平的人多不胜数,中文的注解对源码而言,能够具有极高的 理解价值,可以在极短的时间内,能够充分了解 ucos 的真正含义。  整个翻译过程历时 4 个月,每每在寒冬腊月坐在计算机前面,不断的查阅贝贝老师的书来对 整个 Ucos 进行理解,对每个源码进行逐条翻译,也是一件非常需要勇气的事情,但 E 文的 翻译过程中很多变量是不能完全理解的,所以在翻译过程中不乏错误译文很多,于此带来的 错误还请读者纠正,相信克服种种困难一定会有所了解的。    对于经济窘迫的我来说,曾试图希望卖一点资料来养家糊口,但这种做法根本不现实, 很多的读者可能和我一样,习惯了拿不收费的资料,并对变相收费有一种深恶痛绝的感觉; 想了很多决定还是把它贡献出来,让更多的人来(更容易)了解 ucos,贡献自己的一点力 量。    希望更多的人能加入这种高尚的学习氛围当中来,共同的来把一套完整的 U 系列源码译文 早一日与我们分享,祝愿大家能够早日实现自己的梦想。                                                                                                                      钟常慰  zhongcw1002@126.com 
H:\SOURCE中文源代码\uCOS_II.C 1 1 /* 2 ************************************************************************************************* 3 * uC/OS-II实时控制内核 4 * 主要的包含文件 5 * 6 * 7 * 文 件: uCOS_II.C 包含主要uC/OS-II构造文件 8 * 作 者: Jean J. Labrosse 9 * 中文注解: 钟常慰 zhongcw @ 126.com 译注版本:1.0 请尊重原版内容 10 ************************************************************************************************* 11 */ 12 13 #define OS_GLOBALS //定义全程变量 OS_GLOBALS 14 #include "includes.h" //包含"includes.h"文件,部分C语言头文件的汇总打包文件 15 16 /********************************包含主要uC/OS-II文件*******************************************/ 17 //主要设定的地址,不能有错,可设定相对和绝对地址,否则编译连接出错 18 19 #define OS_MASTER_FILE //定义主要文件,防止是从includes.h中跟随文件 20 #include "\software\ucos-ii\source\os_core.c" //包含内核结构管理文件 21 #include "\software\ucos-ii\source\os_flag.c" //包含时间标志组管理文件 22 #include "\software\ucos-ii\source\os_mbox.c" //包含消息邮箱管理文件 23 #include "\software\ucos-ii\source\os_mem.c" //包含内存管理文件 24 #include "\software\ucos-ii\source\os_mutex.c" //包含互斥型信号管理文件 25 #include "\software\ucos-ii\source\os_q.c" //包含消息队列管理文件 26 #include "\software\ucos-ii\source\os_sem.c" //包含信号量管理文件 27 #include "\software\ucos-ii\source\os_task.c" //包含任务管理文件 28 #include "\software\ucos-ii\source\os_time.c" //包含时间管理文件 29 30 /***************************************结束****************************************************/ 31
H:\SOURCE中文源代码\uCOS_II.H 1 1 /* 2 ************************************************************************************************* 3 * uC/OS-II实时控制内核 4 * 主要的包含文件 5 * 文 件: uCOS_II.H ucos内部函数参数设定 6 * 作 者: Jean J. Labrosse 7 * 中文注解: 钟常慰 zhongcw @ 126.com 译注版本:1.0 请尊重原版内容 8 ************************************************************************************************* 9 */ 10 11 /* 12 ************************************************************************************************* 13 * 混杂的设定 14 ************************************************************************************************* 15 */ 16 17 #define OS_VERSION 251 // 定义uC/OS-II版本号 18 19 #ifdef OS_GLOBALS //如果 OS_GLOBALS 已被声明定义, 紧随代码将会被编译 20 #define OS_EXT //则定义 OS_EXT 21 #else 22 #define OS_EXT extern //否则,定义 OS_EXT 为 extern 23 #endif 24 25 #ifndef FALSE //是否未定义 FALSE 26 #define FALSE 0 //如果是则定义 FALSE 为 0 27 #endif 28 29 #ifndef TRUE //是否未定义 TRUE 30 #define TRUE 1 //如果是则定义 TRUE 为 1 31 #endif 32 33 #define OS_PRIO_SELF 0xFF //定义 OS_PRIO_SELF 为 0xFF 34 #if OS_TASK_STAT_EN > 0 35 #define OS_N_SYS_TASKS 2 //任务体系号码 36 #else 37 #define OS_N_SYS_TASKS 1 38 #endif 39 40 #define OS_STAT_PRIO (OS_LOWEST_PRIO - 1) //统计任务优先级 41 #define OS_IDLE_PRIO (OS_LOWEST_PRIO) //空闲任务优先级 42 43 #define OS_EVENT_TBL_SIZE ((OS_LOWEST_PRIO) / 8 + 1) //事件列表字节 44 #define OS_RDY_TBL_SIZE ((OS_LOWEST_PRIO) / 8 + 1) //就绪列表字节 45 46 #define OS_TASK_IDLE_ID 65535 /* I.D. numbers for Idle and Stat tasks */ 47 #define OS_TASK_STAT_ID 65534 48 49 #define OS_EVENT_EN (((OS_Q_EN > 0) && (OS_MAX_QS > 0)) || (OS_MBOX_EN > 0) || (OS_SEM_EN > 0) || (OS_MUTEX_EN > 0)) 50 51 /*$PAGE*/ 52 /* 53 ********************************************************************************************************* 54 * 任务状态字 TASK STATUS (字节定义在 OSTCBStat中) 55 ********************************************************************************************************* 56 */ 57 #define OS_STAT_RDY 0x00 // (将任务的状态字)处于完毕状态 58 #define OS_STAT_SEM 0x01 // (将任务的状态字)处于SEM状态 59 #define OS_STAT_MBOX 0x02 // (将任务的状态字)处于MBOX状态 60 #define OS_STAT_Q 0x04 // (将任务的状态字)处于Q状态 61 #define OS_STAT_SUSPEND 0x08 // 表示任务被挂起 62 #define OS_STAT_MUTEX 0x10 // (将任务的状态字)处于MUTEX状态 63 #define OS_STAT_FLAG 0x20 // (将任务的状态字)处于FLAG状态 64 65 /* 66 ********************************************************************************************************* 67 * 事件类型(OS_EVENT types) 68 ********************************************************************************************************* 69 */ 70 #define OS_EVENT_TYPE_UNUSED 0 // 定义事件类型的种类(无事件类型------------0) 71 #define OS_EVENT_TYPE_MBOX 1 // 定义事件类型的种类(邮箱为数字序列--------1) 72 #define OS_EVENT_TYPE_Q 2 // 定义事件类型的种类(消息队列为数字序列----2) 73 #define OS_EVENT_TYPE_SEM 3 // 定义事件类型的种类(信号量为数字序列------3) 74 #define OS_EVENT_TYPE_MUTEX 4 // 定义事件类型的种类(互斥型信号量为数字序列4) 75 #define OS_EVENT_TYPE_FLAG 5 // 定义事件类型的种类(事件标志组为数字序列--5)
H:\SOURCE中文源代码\uCOS_II.H 2 76 77 /* 78 ********************************************************************************************************* 79 * 事件标志(EVENT FLAGS) 80 ********************************************************************************************************* 81 */ 82 #define OS_FLAG_WAIT_CLR_ALL 0 // 定义所有指定事件标志位清0 ------ 0 83 #define OS_FLAG_WAIT_CLR_AND 0 // 同上一样 84 85 #define OS_FLAG_WAIT_CLR_ANY 1 // 定义任意指定事件标志位清0 ------ 1 86 #define OS_FLAG_WAIT_CLR_OR 1 // 同上一样 87 88 #define OS_FLAG_WAIT_SET_ALL 2 // 定义所有指定事件标志位置1 ------ 2 89 #define OS_FLAG_WAIT_SET_AND 2 // 同上一样 90 91 #define OS_FLAG_WAIT_SET_ANY 3 // 定义任意指定事件标志位置1 ------ 3 92 #define OS_FLAG_WAIT_SET_OR 3 // 同上一样 93 94 // 如果需要在得到期望标志后,恢复该事件标志,加入此常量 95 96 #define OS_FLAG_CONSUME 0x80 // 定义常量OS_FLAG_CONSUME为0x80 97 98 #define OS_FLAG_CLR 0 // 定义 OS_FLAG_CLR 为清0 99 #define OS_FLAG_SET 1 // 定义 OS_FLAG_SET 为置1 100 101 /* 102 ********************************************************************************************************* 103 * 设置字在'opt'中,适用于 OSSemDel(), OSMboxDel(), OSQDel() 和 OSMutexDel()函数 104 ********************************************************************************************************* 105 */ 106 #define OS_DEL_NO_PEND 0 // 可以选择只能在已经没有任何任务在等待该信号量时,才能删除该信号 量 107 #define OS_DEL_ALWAYS 1 // 不管有没有任务在等待该信号量,立即删除该信号量 108 109 /* 110 ********************************************************************************************************* 111 * OS???PostOpt() OPTIONS(设置) 112 * 113 * 这个设置适用用 OSMboxPostOpt() 和 OSQPostOpt()两个函数. 114 ********************************************************************************************************* 115 */ 116 #define OS_POST_OPT_NONE 0x00 // 发送一个消息(或邮箱)给一个等待消息的任务 117 #define OS_POST_OPT_BROADCAST 0x01 // 发送消息给所有等待队列消息的任务*/ 118 #define OS_POST_OPT_FRONT 0x02 // 以后进先出方式发消息(仿真OSQPostFront()) 119 120 /* 121 ********************************************************************************************************* 122 * 任务设置 TASK OPTIONS (查看OSTaskCreateExt()) 123 ********************************************************************************************************* 124 */ 125 #define OS_TASK_OPT_STK_CHK 0x0001 // 决定是否进行任务堆栈检查 126 #define OS_TASK_OPT_STK_CLR 0x0002 // 决定是否清空堆栈 127 #define OS_TASK_OPT_SAVE_FP 0x0004 // 决定是否保存浮点寄存器的数值。此项操作仅当处理器有浮点硬- 128 // 件时有效。保存操作由硬件相关的代码完成 129 /* 130 ********************************************************************************************************* 131 * 错误代码 ERROR CODES 132 ********************************************************************************************************* 133 */ 134 #define OS_NO_ERR 0 // 函数返回成功; 135 136 #define OS_ERR_EVENT_TYPE 1 // 不是指向事件(相关)类型的指针; 137 #define OS_ERR_PEND_ISR 2 // 在中断服务子程序中调用 OS各种信号类Accept()函数. 138 #define OS_ERR_POST_NULL_PTR 3 // 用户发出空指针。根据规则,这里不支持空指针; 139 #define OS_ERR_PEVENT_NULL 4 // 'pevent'是指空指针; 140 #define OS_ERR_POST_ISR 5 // 试图在中断服务子程序中调用OSMutexPost()函数[释放一个mutex]; 141 #define OS_ERR_QUERY_ISR 6 // 试图在中断子程序中调用OSMutexQuery()[得到mutex当前状态信息] 142 #define OS_ERR_INVALID_OPT 7 // 定义的opt参数无效; 143 #define OS_ERR_TASK_WAITING 8 // 有一个或一个以上的任务在等待消息队列中的消息; 144 145 #define OS_TIMEOUT 10 // 消息没有在指定的周期数内送到; 146 #define OS_TASK_NOT_EXIST 11 // 指定的任务不存; 147 148 #define OS_MBOX_FULL 20 // 消息邮箱已经包含了其他消息,不空; 149 150 #define OS_Q_FULL 30 // 消息队列中已经存满;
H:\SOURCE中文源代码\uCOS_II.H 3 151 152 #define OS_PRIO_EXIST 40 // 优先级为PIP的任务已经存在; 153 #define OS_PRIO_ERR 41 // 参数中的任务原先优先级不存在; 154 #define OS_PRIO_INVALID 42 // 参数指定的优先级大于OS_LOWEST_PRIO; 155 156 #define OS_SEM_OVF 50 // 信号量的值溢出; 157 158 #define OS_TASK_DEL_ERR 60 // 指定要删除的任务不存在 159 #define OS_TASK_DEL_IDLE 61 // 错误操作,试图删除空闲任务(Idle task); 160 #define OS_TASK_DEL_REQ 62 // 当前任务收到来自其他任务的删除请求; 161 #define OS_TASK_DEL_ISR 63 // 错误操作,试图在中断处理程序中删除任务; 162 163 #define OS_NO_MORE_TCB 70 // 系统中没有OS_TCB可以分配给任务了; 164 165 #define OS_TIME_NOT_DLY 80 // 要唤醒的任务不在延时状态; 166 #define OS_TIME_INVALID_MINUTES 81 // 参数错误,分钟数大于59; 167 #define OS_TIME_INVALID_SECONDS 82 // 参数错误,秒数大于59 168 #define OS_TIME_INVALID_MILLI 83 // 则返回参数错误,毫秒数大于999; 169 #define OS_TIME_ZERO_DLY 84 // 四个参数全为0 170 171 #define OS_TASK_SUSPEND_PRIO 90 // 要挂起的任务不存在 172 #define OS_TASK_SUSPEND_IDLE 91 // 试图挂起uC/OS-II中的空闲任务(Idle task) 173 174 #define OS_TASK_RESUME_PRIO 100 // 要唤醒的任务不存在; 175 #define OS_TASK_NOT_SUSPENDED 101 // 要唤醒的任务不在挂起状态 176 177 #define OS_MEM_INVALID_PART 110 // 没有空闲的内存区; 178 #define OS_MEM_INVALID_BLKS 111 // 没有为每一个内存区建立至少2个内存块; 179 #define OS_MEM_INVALID_SIZE 112 // 内存块大小不足以容纳一个指针变量; 180 #define OS_MEM_NO_FREE_BLKS 113 // 内存区已经没有空间分配给内存块; 181 #define OS_MEM_FULL 114 // 内存区已经不能再接受更多释放的内存块。这种情况说明用户程序出 现; 182 #define OS_MEM_INVALID_PBLK 115 // 183 #define OS_MEM_INVALID_PMEM 116 // 'pmem'是空指针; 184 #define OS_MEM_INVALID_PDATA 117 // pdata是空指针; 185 #define OS_MEM_INVALID_ADDR 118 // 非法地址,即地址为空指针; 186 187 #define OS_ERR_NOT_MUTEX_OWNER 120 // 发出mutex的任务实际上并不占用mutex; 188 189 #define OS_TASK_OPT_ERR 130 // 任务用OSTaskCreateExt()函数建立的时候没有指定 OS_TASK_OPT_STK_CHK- 190 // -操作,或者任务是用OSTaskCreate()函数建立的。 191 192 #define OS_ERR_DEL_ISR 140 // 试图在中断服务子程序中删除(消息、邮箱、信号量、消息对列、互 斥型信号量) 193 #define OS_ERR_CREATE_ISR 141 // 试图在中断服务子程序中建立(事件标志组、互斥型信号量); 194 195 #define OS_FLAG_INVALID_PGRP 150 // pgrp是一个空指针; 196 #define OS_FLAG_ERR_WAIT_TYPE 151 // 'wait_type'不是指定的参数之一; 197 #define OS_FLAG_ERR_NOT_RDY 152 // 指定的事件标志没有发生; 198 #define OS_FLAG_INVALID_OPT 153 // opt不是指定的参数之一; 199 #define OS_FLAG_GRP_DEPLETED 154 // 系统没有剩余的空闲事件标志组,需要更改OS_CFG.H中的事件标志组 数目配置 200 201 /*$PAGE*/ 202 /* 203 ********************************************************************************************************* 204 * 事件控制块(EVENT CONTROL BLOCK) 205 ********************************************************************************************************* 206 */ 207 208 #if (OS_EVENT_EN > 0) && (OS_MAX_EVENTS > 0) 209 typedef struct { // 定义一个时间控制块结构(OS_EVENT) 210 INT8U OSEventType; // 事件类型 211 INT8U OSEventGrp; // 等待任务所在的组 212 INT16U OSEventCnt; // 计数器(当事件是信号量时) 213 void *OSEventPtr; // 指向消息或者消息队列的指针 214 INT8U OSEventTbl[OS_EVENT_TBL_SIZE]; // 等待任务列表 215 } OS_EVENT; 216 #endif 217 218 219 /* 220 ********************************************************************************************************* 221 * 事件标志控制块 (EVENT FLAGS CONTROL BLOCK) 222 *********************************************************************************************************
H:\SOURCE中文源代码\uCOS_II.H 4 223 */ 224 //当版本为2.51 且 事件标志允许 且最大事件标志大于0时 225 #if (OS_VERSION >= 251) && (OS_FLAG_EN > 0) && (OS_MAX_FLAGS > 0) 226 typedef struct { // 定义一个OS_FLAG_GRP结构 227 INT8U OSFlagType; // 用来检验指针的类型是否是指向事件标志组的指针 228 void *OSFlagWaitList; // 包含了一个等待事件的任务列表 229 OS_FLAGS OSFlagFlags; // 包含了一系列表明当前事件标志状态的位 230 } OS_FLAG_GRP; // 事件标志组 231 232 233 234 typedef struct { // 定义一个事件标志等待列表节点(OS_FLAG_NODE)结构 235 void *OSFlagNodeNext; // 构建双向OS_FLAG_NODE数据结构链表的后一个链接 236 void *OSFlagNodePrev; // 构建双向OS_FLAG_NODE数据结构链表的前一个链接 237 void *OSFlagNodeTCB; // 指向某个等待事件标志组中的事件标志任务的控制块 238 void *OSFlagNodeFlagGrp; // 是一个反向指回事件标志组的指针 239 OS_FLAGS OSFlagNodeFlags; // 用来指明任务等待事件标志组中的哪些事件标志 240 INT8U OSFlagNodeWaitType; // 指明等待事件标志组中的所有事件标志的发生(与、或) 241 // OS_FLAG_WAIT_AND 与 242 // OS_FLAG_WAIT_ALL 全部 243 // OS_FLAG_WAIT_OR 或 244 // OS_FLAG_WAIT_ANY 任一 245 } OS_FLAG_NODE; 246 #endif 247 248 249 /* 250 ********************************************************************************************************* 251 * 设定一个消息队列的数据结构 (MESSAGE MAILBOX DATA) 252 ********************************************************************************************************* 253 */ 254 255 #if OS_MBOX_EN > 0 256 typedef struct { // 定义一个OS_MBOX_DATA结构 257 void *OSMsg; // 如果消息队列中有消息,它包含指针.OSQOut所指向的队列单元中 258 // 的内容。如果队列是空的,.OSMsg包含一个NULL指针 259 INT8U OSEventTbl[OS_EVENT_TBL_SIZE]; // 消息队列的等待任务列表 260 INT8U OSEventGrp; // 于OSEventTbl[]配合使用 261 } OS_MBOX_DATA; 262 #endif 263 264 /* 265 ********************************************************************************************************* 266 * 设定一个内存的数据结构 (MEMORY PARTITION DATA STRUCTURES) 267 ********************************************************************************************************* 268 */ 269 270 #if (OS_MEM_EN > 0) && (OS_MAX_MEM_PART > 0) 271 typedef struct { // 使用内存控制块(memory control blocks)的数据结构来跟踪每一 272 // 个内存分区,系统中的每个内存分区都有它自己的内存控制块。 273 void *OSMemAddr; // 指向内存分区起始地址的指针 274 void *OSMemFreeList; // 指向下一个空闲内存控制块或者下一个空闲的内存块的指针 275 INT32U OSMemBlkSize; // 是内存分区中内存块的大小,是用户建立该内存分区时指定的 276 INT32U OSMemNBlks; // 是内存分区中总的内存块数量,也是用户建立该内存分区时指定的 277 INT32U OSMemNFree; // 是内存分区中当前可以得空闲内存块数量 278 } OS_MEM; 279 280 281 typedef struct { // 定义一个内存数据结构(OS_MEM_DATA) 282 void *OSAddr; // 指向内存区起始地址的指针 283 void *OSFreeList; // 指向空闲内存块列表起始地址的指针 284 INT32U OSBlkSize; // 每个内存块的大小 285 INT32U OSNBlks; // 该内存区的内存块总数 286 INT32U OSNFree; // 空闲的内存块数目 287 INT32U OSNUsed; // 使用的内存块数目 288 } OS_MEM_DATA; 289 #endif 290 291 /*$PAGE*/ 292 /* 293 ********************************************************************************************************* 294 * 互斥型信号量数据(MUTUAL EXCLUSION SEMAPHORE DATA) 295 ********************************************************************************************************* 296 */ 297 298 #if OS_MUTEX_EN > 0 // 允许(1)或者产生互斥型信号量相关代码
H:\SOURCE中文源代码\uCOS_II.H 5 299 typedef struct { // 定义指向类型为(OS_MUTEX_DATA)的数据结构的指针 300 INT8U OSEventTbl[OS_EVENT_TBL_SIZE]; // 容量大小由ucos_ii.H 301 INT8U OSEventGrp; // 复制等待mutex的任务列表 302 INT8U OSValue; // 当前mutex的值.1表示可以使用,0表示不能使用 303 INT8U OSOwnerPrio; // 占用mutex任务的优先级 304 INT8U OSMutexPIP; // mutex的优先级继承优先级PIP 305 } OS_MUTEX_DATA; 306 #endif 307 308 /* 309 ********************************************************************************************************* 310 * 消息队列数据 (MESSAGE QUEUE DATA) 311 ********************************************************************************************************* 312 */ 313 /* 314 队列控制块是一个用于维护消息队列信息的数据结构,它包含了以下的一些域。这里,仍然在各个变量前加入 315 * 一个[.]来表示它们是数据结构中的一个域。 316 * 1).OSQPtr: 在空闲队列控制块中链接所有的队列控制块。一旦建立了消息队列,该域就不再有用了。 317 * 2).OSQStart: 是指向消息队列的指针数组的起始地址的指针。用户应用程序在使用消息队列之前必须先定义该数组 。 318 * 3).OSQEnd: 是指向消息队列结束单元的下一个地址的指针。该指针使得消息队列构成一个循环的缓冲区。 319 * 4).OSQIn: 是指向消息队列中插入下一条消息的位置的指针。当.OSQIn和.OSQEnd相等时,.OSQIn被调整指向 320 * 消息队列的起始单元。 321 * 5).OSQOut: 是指向消息队列中下一个取出消息的位置的指针。当.OSQOut和.OSQEnd相等时,.OSQOut被调整指 322 * 向消息队列的起始单元。 323 * 6).OSQSize: 是消息队列中总的单元数。该值是在建立消息队列时由用户应用程序决定的。在uC/OS-II中,该值最 324 * 大可以是65,535。 325 * 7).OSQEntries: 是消息队列中当前的消息数量。当消息队列是空的时,该值为0。当消息队列满了以后,该值和 326 * .OSQSize值一样。 在消息队列刚刚建立时,该值为0。 327 */ 328 #if OS_Q_EN > 0 329 typedef struct os_q { // 定义一个OS_Q队列控制块 330 struct os_q *OSQPtr; // 1) 331 void **OSQStart; // 2) 332 void **OSQEnd; // 3) 333 void **OSQIn; // 4) 334 void **OSQOut; // 5) 335 INT16U OSQSize; // 6) 336 INT16U OSQEntries; // 7) 337 } OS_Q; 338 339 340 typedef struct { // 定义一个消息队列数据(OS_Q_DATA)结构 341 void *OSMsg; // 如果消息队列中有消息,它包含指针 342 INT16U OSNMsgs; // 是消息队列中的消息数 343 INT16U OSQSize; // 是消息队列的总的容量 344 INT8U OSEventTbl[OS_EVENT_TBL_SIZE]; 345 INT8U OSEventGrp; //和OSEventTbl[]一起结合,是消息队列的等待任务列表 346 } OS_Q_DATA; 347 #endif 348 349 /* 350 ********************************************************************************************************* 351 * 信号量数据结构 (SEMAPHORE DATA) 352 ********************************************************************************************************* 353 */ 354 355 #if OS_SEM_EN > 0 356 typedef struct { // 定义一个信号量数据结构(OS_SEM_DATA) 357 INT16U OSCnt; // 定义信号量计数值 358 INT8U OSEventTbl[OS_EVENT_TBL_SIZE]; // 定义任务等待列表 359 INT8U OSEventGrp; // 定义等待事件的任务组 360 } OS_SEM_DATA; 361 #endif 362 363 /* 364 ********************************************************************************************************* 365 * 任务堆栈数据 (TASK STACK DATA) 366 ********************************************************************************************************* 367 */ 368 369 #if OS_TASK_CREATE_EXT_EN > 0 370 typedef struct { // 定义一个堆栈数据结构(OS_STK_DATA) 371 INT32U OSFree; // 堆栈中未使用的字节数 372 INT32U OSUsed; // 堆栈中已使用的字节数 373 } OS_STK_DATA;
H:\SOURCE中文源代码\uCOS_II.H 6 374 #endif 375 376 /*$PAGE*/ 377 /* 378 ********************************************************************************************************* 379 * 任务控制块 (TASK CONTROL BLOCK) 380 ********************************************************************************************************* 381 */ 382 383 typedef struct os_tcb { 384 OS_STK *OSTCBStkPtr; //当前TCB的栈顶指针 385 386 #if OS_TASK_CREATE_EXT_EN > 0 //允许生成OSTaskCreateExt()函数 387 void *OSTCBExtPtr; //指向用户定义的任务控制块(扩展指针) 388 OS_STK *OSTCBStkBottom; //指向指向栈底的指针 389 INT32U OSTCBStkSize; //设定堆栈的容量 390 INT16U OSTCBOpt; //保存OS_TCB的选择项 391 INT16U OSTCBId; //否则使用旧的参数 392 #endif 393 394 struct os_tcb *OSTCBNext; //定义指向TCB的双向链接的后链接 395 struct os_tcb *OSTCBPrev; //定义指向TCB的双向链接的前链接 396 397 #if ((OS_Q_EN > 0) && (OS_MAX_QS > 0)) || (OS_MBOX_EN > 0) || (OS_SEM_EN > 0) || (OS_MUTEX_EN > 0) 398 //当以上各种事件允许时 399 OS_EVENT *OSTCBEventPtr; //定义指向事件控制块的指针 400 #endif 401 402 #if ((OS_Q_EN > 0) && (OS_MAX_QS > 0)) || (OS_MBOX_EN > 0) 403 void *OSTCBMsg; //满足以上条件,定义传递给任务的消息指针 404 #endif 405 406 #if (OS_VERSION >= 251) && (OS_FLAG_EN > 0) && (OS_MAX_FLAGS > 0) 407 #if OS_TASK_DEL_EN > 0 408 OS_FLAG_NODE *OSTCBFlagNode; //定义事件标志节点的指针 409 #endif 410 OS_FLAGS OSTCBFlagsRdy; //定义运行准备完毕的任务控制块中的任务? 411 #endif 412 413 INT16U OSTCBDly; //定义允许任务等待时的最多节拍数 414 INT8U OSTCBStat; //定义任务的状态字 415 INT8U OSTCBPrio; //定义任务的优先级 416 417 INT8U OSTCBX; //定义指向任务优先级的低3位,即=priority&0x07 418 INT8U OSTCBY; //定义指向任务优先级的高3位,即=priority>>3 419 INT8U OSTCBBitX; //定义低3位就绪表对应值(0~7),即=OSMapTbl[priority&0x07] 420 INT8U OSTCBBitY; //定义高3位就绪表对应值(0~7),即=OSMapTbl[priority>>3] 421 422 #if OS_TASK_DEL_EN > 0 //允许生成 OSTaskDel() 函数代码函数 423 BOOLEAN OSTCBDelReq; //定义用于表示该任务是否须删除 424 #endif 425 } OS_TCB; 426 427 /*$PAGE*/ 428 /* 429 ********************************************************************************************************* 430 * 全局变量 (GLOBAL VARIABLES) 431 ********************************************************************************************************* 432 */ 433 434 OS_EXT INT32U OSCtxSwCtr; //上下文切换的次数(统计任务计数器) 435 436 #if (OS_EVENT_EN > 0) && (OS_MAX_EVENTS > 0) //如果有消息事件,并且最大消息事件数>0 437 OS_EXT OS_EVENT *OSEventFreeList; //空余事件管理列表指针 438 OS_EXT OS_EVENT OSEventTbl[OS_MAX_EVENTS];//任务等待表首地址 439 #endif 440 //当满足版本大于2.51且事件标志允许且有最大事件标志 441 #if (OS_VERSION >= 251) && (OS_FLAG_EN > 0) && (OS_MAX_FLAGS > 0) 442 OS_EXT OS_FLAG_GRP OSFlagTbl[OS_MAX_FLAGS]; //定义一个事件标志列表 443 OS_EXT OS_FLAG_GRP *OSFlagFreeList; //定义一个空闲的事件标志组 444 #endif 445 446 #if OS_TASK_STAT_EN > 0 //定义允许生产OS_TaskStat()函数 447 OS_EXT INT8S OSCPUUsage; //定义CPU 使用率 448 OS_EXT INT32U OSIdleCtrMax; //定义最大空闲计数值 449 OS_EXT INT32U OSIdleCtrRun; //定义当前的空闲计数值
分享到:
收藏