第三讲 嵌入式实时操作系统

第三讲 嵌入式实时操作系统

ID:5564738

大小:3.51 MB

页数:81页

时间:2017-11-18

第三讲 嵌入式实时操作系统_第1页
第三讲 嵌入式实时操作系统_第2页
第三讲 嵌入式实时操作系统_第3页
第三讲 嵌入式实时操作系统_第4页
第三讲 嵌入式实时操作系统_第5页
资源描述:

《第三讲 嵌入式实时操作系统》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、嵌入式操作系统第三讲嵌入式实时操作系统一、嵌入式实时操作系统C/OS二、嵌入式Linux三、WinCE第三讲、嵌入式实时操作系统分析本节提要132嵌入式实时操作系统C/OS嵌入式LinuxWinCE一、嵌入式实时操作系统C/OSC/OS简介内核结构-任务以及调度机制C/OS的移植C/OS简介1、C/OS——microCOS,微控制器操作系统2、C/OS简介美国人JeanLabrosse1992年完成应用面覆盖了诸多领域,如照相机、医疗器械、音响设备、发动机控制、高速公路电话系统、自动提款机等1998年C/O

2、S–II网站www.ucos-ii.com公开源代码可移植性(Portable)绝大部分C/OS-II的源码是用移植性很强的ANSIC写的。和微处理器硬件相关的那部分是用汇编语言写的。C/OS-II可以在绝大多数8位、16位、32位以至64位微处理器、微控制器、数字信号处理器(DSP)上运行。可裁剪(Scalable)可以只使用C/OS-II中应用程序需要的那些系统服务,这样可以减少产品中的C/OS-II所需的存储器空间(RAM和ROM)。这种可剪裁性是靠条件编译实现的。C/OS的性能特点占先式(Preemptiv

3、e)多任务C/OS-II可以管理64个任务,然而,目前这一版本保留8个给系统。应用程序最多可以有56个任务。可确定性全部C/OS-II的函数调用与服务的执行时间具有可确定性。任务栈每个任务有自己单独的栈,C/OS-II允许每个任务有不同的栈空间,以便压低应用程序对RAM的需求。C/OS的性能特点系统服务C/OS-II提供很多系统服务,例如邮箱、消息队列、信号量、块大小固定的内存的申请与释放、时间相关函数等。中断管理中断可以使正在执行的任务暂时挂起,如果优先级更高的任务被该中断唤醒,则高优先级的任务在中断嵌套全部退出

4、后立即执行,中断嵌套层数可达255层。稳定性与可靠性C/OS的性能特点内核结构任务管理时间管理任务之间通信与同步C/OS的内核结构任务task典型的一个无限循环。voidmytask(void*pdata){for(;;){dosomething;waiting;dosomething;}}C/OS–II2.5版本支持64个任务,每个任务一个特定的优先级。优先级越高,数字越小。(Windows、Linux?)系统占用了8个任务,保留优先级为0、1、2、3、OS_LOWEST_PRIO-3、OS_LOWEST_PRIO-

5、2、OS_LOWEST_PRIO-1、OS_LOWEST_PRIO-0。建立任务OSTaskCreate()OSTaskCreateExtended()INT8UOSTaskCreate(void(*task)(void*pd),void*p_arg,OS_STK*ptos,INT8Uprio)INT8UOSTaskCreateExt(void(*task)(void*pd),void*p_arg,OS_STK*ptos,INT8Uprio,INT16Uid,OS_STK*pbos,INT32Ustk_size,void*p

6、ext,INT16Uopt)进程函数体传递给进程的参数进程栈顶指针进程优先级进程ID号进程栈底指针进程栈大小传递给进程控制块的数据是否初始化进程栈任务状态任务控制块(TCB)任务控制块OS_TCB是一个数据结构,保存该任务的相关参数,包括任务堆栈指针,状态,优先级,任务表位置,任务链表指针等。所有的任务控制块分为两条链表,空闲链表和使用链表。任务控制块结构Structos_tcb{OS_STK*OSTCBStkPtr;structos_tcb*OSTCBNext;structos_tcb*OSTCBprev;OS_EVENT

7、*OSTCBEventPtr;void*OSTCBMsg;INT16UOSTCBDly;INT8UOSTCBStat;INT8UOSTCBPrio;INT8UOSTCBX,OSTCBY,OSTCBBitX,OSTCBBitY;}OS_TCB加速任务进入就绪态的过程事件控制块的指针任务的状态字空任务列表系统初始化时,所有任务控制块被链接成空任务控制块的单向链表任务的调度--OSSchedC/OS是占先式实时多任务内核,优先级最高的任务一旦准备就绪,则拥有CPU所有权并投入运行。C/OS中不支持时间片轮转法,每个任务的优先级

8、不一样且是唯一的,所以任务调度的工作就是:查找准备就绪的最高优先级的任务并进行上下文切换。将被挂起的任务寄存器入栈将较高优先级任务的寄存器出栈PC指针跳转到新的位置开始执行C/OS任务调度所花的时间为常数,与应用程序中建立的任务数无关。(Linux?)检查是否中断调用和允许任务调用找到优

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。