μCOS-Ⅱ的用户指南

上传人:飞****9 文档编号:132603671 上传时间:2020-05-18 格式:DOC 页数:5 大小:21.50KB
返回 下载 相关 举报
μCOS-Ⅱ的用户指南_第1页
第1页 / 共5页
μCOS-Ⅱ的用户指南_第2页
第2页 / 共5页
μCOS-Ⅱ的用户指南_第3页
第3页 / 共5页
μCOS-Ⅱ的用户指南_第4页
第4页 / 共5页
μCOS-Ⅱ的用户指南_第5页
第5页 / 共5页
亲,该文档总共5页,全部预览完了,如果喜欢就下载吧!
资源描述

《μCOS-Ⅱ的用户指南》由会员分享,可在线阅读,更多相关《μCOS-Ⅱ的用户指南(5页珍藏版)》请在金锄头文库上搜索。

1、参考手册 本章提供了C/OS-的用户指南。 每一个用户可以调用的内核函数都按字母顺序加以说明,包括: z 函数的功能描述 z 函数原型 z 函数名称及源代码 z 函数使用到的常量 z 函数参数 z 函数返回值 z 特殊说明和注意点OSInit( ) Void OSInit(void);所属文件 调用者 开关量 OS_CORE.C 启动代码 无 OSinit()初始化C/OS-,对这个函数的调用必须在调用 OSStart()函数之前,而 OSStart()函数真正开始运行多任务。注意/警告 必须先于 OSStart()函数的调用OSIntEnter( ) Void OSIntEnter(void

2、); 所属文件 调用者 开关量 OS_CORE.C 中断 无 OSIntEnter()通知C/OS-一个中断处理函数正在执行,这有助于C/OS-掌握中断嵌套的情况。OSIntEnter()函数通常和 OSIntExit()函数联合使用。 注意/警告 在任务级不能调用该函数。 如果系统使用的处理器能够执行自动的独立执行读取-修改-写入的操作, 那么就可以直接递增中断嵌套层数(OSIntNesting) ,这样可以避免调用函数所带来的额外的开销。 OSIntExit( ) void OSIntExit(void);所属文件 调用者 开关量 OS_CORE.C 中断 无 OSIntExit()通知C

3、/OS-一个中断服务已执行完毕,这有助于C/OS-掌握中断嵌套的情况。通常 OSIntExit()和 OSIntEnter()联合使用。当最后一层嵌套的中断执行完毕后,如果有更高优先级的任务准备就绪,C/OS-会调用任务调度函数,在这种情况下,中断返回到更高优先级的任务而不是被中断了的任务。 注意/警告 在任务级不能调用该函数。并且即使没有调用 OSIntEnter()而是使用直接递增 OSIntNesting的方法,也必须调用 OSIntExit()函数。OSMboxAccept( ) Void *OSMboxAccept(OS_EVENT *pevent); 所属文件 调用者 开关量 OS

4、_MBOX.C 任务或中断 OS_MBOX_EN OSMboxAccept()函数查看指定的消息邮箱是否有需要的消息。不同于 OSMboxPend()函数,如果没有需要的消息,OSMboxAccept()函数并不挂起任务。如果消息已经到达,该消息被传递到用户任务并且从消息邮箱中清除。通常中断调用该函数,因为中断不允许挂起等待消息。 参数 pevent 是指向需要查看的消息邮箱的指针。当建立消息邮箱时,该指针返回到用户程序。 (参考OSMboxCreate()函数) 。返回值 如果消息已经到达,返回指向该消息的指针;如果消息邮箱没有消息,返回空指针。注意/警告 必须先建立消息邮箱,然后使用。OS

5、MboxCreate( ) OS_EVENT *OSMboxCreate(void *msg); 所属文件 调用者 开关量 OS_MBOX.C 任务或启动代码 OS_MBOX_EN OSMboxCreate()建立并初始化一个消息邮箱。消息邮箱允许任务或中断向其他一个或几个任务发送消息。 参数 msg 参数用来初始化建立的消息邮箱。如果该指针不为空,建立的消息邮箱将含有消息。 OSMboxPend( )Void *OSMboxPend ( OS_EVNNT *pevent, INT16U timeout, int8u *err ); 所属文件 调用者 开关量 OS_MBOX.C 任务 OS_M

6、BOX_EN OSMboxPend()用于任务等待消息。消息通过中断或另外的任务发送给需要的任务。消息是一个以指针定义的变量,在不同的程序中消息的使用也可能不同。若调用OSMboxPend()函数时消息邮箱已经存在需要的消息,那么该消息被返回给 OSMboxPend()的调用者,消息邮箱中清除该消息。如果调用 OSMboxPend()函数时消息邮箱中没有需要的消息,OSMboxPend()函数挂起当前任务直到得到需要的消息或超出定义等待超时的时间。如果同时有多个任务等待同一个消息,C/OS-默认最高优先级的任务取得消息并且任务恢复执行。一个由OSTaskSuspend()函数挂起的任务也可以接

7、受消息,但这个任务将一直保持挂起状态直到通过调用 OSTaskResume()函数恢复任务的运行。 参数 pevent 是指向即将接受消息的消息邮箱的指针。该指针的值在建立该消息邮箱时可以得到。(参考 OSMboxCreate()函数) 。 Timeout 允许一个任务在经过了指定数目的时钟节拍后还没有得到需要的消息时恢复运行。 如果该值为零表示任务将持续的等待消息。最大的等待时间为 65,535 个时钟节拍。这个时间长度并不是非常严格的,可能存在一个时钟节拍的误差,因为只有在一个时钟节拍结束后才会减少定义的等待超时时钟节拍。Err 是指向包含错误码的变量的指针。OSMboxPend()函数返

8、回的错误码可能为下述几种: z OS_NO_ERR :消息被正确的接受。 z OS_TIMEOUT :消息没有在指定的周期数内送到。 z OS_ERR_PEND_ISR :从中断调用该函数。虽然规定了不允许从中断调用该函数,但C/OS-仍然包含了检测这种情况的功能。 z OS_ERR_EVENT_TYPE :pevent 不是指向消息邮箱的指针。 返回值 OSMboxPend()函数返回接受的消息并将 *err 置为 OS_NO_ERR。如果没有在指定数目的时钟节拍内接受到需要的消息,OSMboxPend()函数返回空指针并且将 *err 设置为OS_TIMEOUT。 注意/警告 必须先建立消

9、息邮箱,然后使用。 不允许从中断调用该函数。OSMboxPost( ) INT8U OSMboxPost(OS_EVENT *pevent, void *msg); 所属文件 调用者 开关量 OS_MBOX.C 任务或中断 OS_MBOX_EN OSMboxPost()函数通过消息邮箱向任务发送消息。消息是一个指针长度的变量,在不同的程序中消息的使用也可能不同。如果消息邮箱中已经存在消息,返回错误码说明消息邮箱已满。OSMboxPost()函数立即返回调用者,消息也没有能够发到消息邮箱。如果有任何任务在等待消息邮箱的消息,最高优先级的任务将得到这个消息。如果等待消息的任务优先级比发送消息的任务

10、优先级高,那么高优先级的任务将得到消息而恢复执行,也就是说,发生了一次任务切换。 参数 pevent 是指向即将接受消息的消息邮箱的指针。该指针的值在建立该消息邮箱时可以得到。(参考 OSMboxCreate()函数) 。 Msg 是即将实际发送给任务的消息。消息是一个指针长度的变量,在不同的程序中消息的使用也可能不同。不允许传递一个空指针,因为这意味着消息邮箱为空。 返回值 OSMboxPost()函数的返回值为下述之一: z OS_NO_ERR :消息成功的放到消息邮箱中。 z OS_MBOX_FULL :消息邮箱已经包含了其他消息,不空。 z OS_ERR_EVENT_TYPE :pev

11、ent 不是指向消息邮箱的指针。 注意/警告 必须先建立消息邮箱,然后使用。不允许传递一个空指针,因为这意味着消息邮箱为空。OSMboxQuery( ) INT8U OSMboxQuery(OS_EVENT *pevent, OS_MBOX_DATA *pdata); 所属文件 调用者 开关量 OS_MBOX.C 任务或中断 OS_MBOX_EN OSMboxQuery()函数用来取得消息邮箱的信息。用户程序必须分配一个 OS_MBOX_DATA 的数据结构,该结构用来从消息邮箱的事件控制块接受数据。通过调用 OSMboxQuery()函数可以知道任务是否在等待消息以及有多少个任务在等待消息,

12、还可以检查消息邮箱现在的消息。 参数 pevent 是指向即将接受消息的消息邮箱的指针。该指针的值在建立该消息邮箱时可以得到。(参考 OSMboxCreate()函数) 。 Pdata 是指向 OS_MBOX_DATA 数据结构的指针,该数据结构包含下述成员: Vo i d *OSMsg; /* 消息邮箱中消息的复制 */ INT8U OSEventTblOS_EVENT_TBL_SIZE; /*消息邮箱等待队列的复制*/ INT8U OSEventGrp; 返回值 OSMboxQuery()函数的返回值为下述之一: z OS_NO_ERR :调用成功 z OS_ERR_EVENT_TYPE :pevent 不是指向消息邮箱的指针。 注意/警告必须先建立消息邮箱,然后使用。

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > 教学/培训

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号