书签 分享 收藏 举报 版权申诉 / 50
上传文档赚钱

类型嵌入式操作系统uCOS课件.ppt

  • 上传人(卖家):晟晟文业
  • 文档编号:4652606
  • 上传时间:2022-12-29
  • 格式:PPT
  • 页数:50
  • 大小:434.50KB
  • 【下载声明】
    1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
    2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
    3. 本页资料《嵌入式操作系统uCOS课件.ppt》由用户(晟晟文业)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
    4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
    5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
    配套讲稿:

    如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。

    特殊限制:

    部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。

    关 键  词:
    嵌入式 操作系统 uCOS 课件
    资源描述:

    1、嵌入式操作系统uC/OS1What is uC/OS?u:Micro C:controluC/OS:适合于小的、控制器的操作系统n小巧n公开源代码,详细的注解n可剥夺实时内核n可移植性强n多任务多任务 n确定性嵌入式操作系统uC/OS2The Story of uC/OS n美国人Jean Labrosse 1992年编写的n商业软件的昂贵n应用面覆盖了诸多领域,如照相机、医疗器械、音响设备、发动机控制、高速公路电话系统、自动提款机等 nwww.uCOS-II.com嵌入式操作系统uC/OSnCOS不但提供了一个完整的嵌入式实时内核的源代码,而且对这些代不但提供了一个完整的嵌入式实时内核的源代

    2、码,而且对这些代码的细节作了详尽的解释,它不仅告诉读者这个实时内核是怎么写的,码的细节作了详尽的解释,它不仅告诉读者这个实时内核是怎么写的,还解释了为什么要这样写。而商业上的实时操作系统软件不但价格昂贵还解释了为什么要这样写。而商业上的实时操作系统软件不但价格昂贵(一般都在(一般都在5千到千到2万美元的价位上),而且其中很多都是所谓黑盒子,万美元的价位上),而且其中很多都是所谓黑盒子,即不提供源代码。即不提供源代码。nl 源代码的绝大部分是用源代码的绝大部分是用C语言写的,经过简单的编译,读者就能在语言写的,经过简单的编译,读者就能在PC机上运行,边读书、边实践。由于用汇编语言写的部分只有机上

    3、运行,边读书、边实践。由于用汇编语言写的部分只有200行左右,行左右,该实时内核可以方便地移植到几乎所有的嵌入式应用类该实时内核可以方便地移植到几乎所有的嵌入式应用类CPU上。移植范上。移植范例的源代码可以从因特网上下载。例的源代码可以从因特网上下载。nl 从最老版本的实时内核从最老版本的实时内核COS,以及后来的,以及后来的C/OS,到新版本的,到新版本的C/OS-II,已经有多年的历史。许多行业上都有成功应用该实时源代码,已经有多年的历史。许多行业上都有成功应用该实时源代码.实时内实时内核移植核移植.内核实时内核的实例,这些应用的实践是该内核实用性、无误性内核实时内核的实例,这些应用的实践

    4、是该内核实用性、无误性的最好证据。的最好证据。3嵌入式操作系统uC/OS4嵌入式操作系统uC/OS5概要n内核结构-任务以及调度机制n任务间通信nuC/OS的移植n在PC机上运行uC/OS嵌入式操作系统uC/OS6任务taskn典型的一个无限循环。void mytask(void*pdata)for(;)do something;waiting;do something;n支持64个任务,每个任务一个特定的优先级。优先级越高,数字越小n系统占用了两个任务,空闲任务和统计任务。嵌入式操作系统uC/OS任务优先级n每个任务按其重要性被赋予一定的优先级。C/OS-可以管理多达64个任务,但目前版本的

    5、C/OS-有两个任务已经被系统占用了。作者保留了优先级为0、1、2、3、OS_LOWEST_PRIO-3、OS_LOWEST_PRI0-2,OS_LOWEST_PRI0-1以及OS_LOWEST_PRI0这8个任务以被将来使用。OS_LOWEST_PRI0是作为定义的常数在OS_CFG.H文件中用定义常数语句#define constant定义的。因此用户可以有多达56个应用任务。必须给每个任务赋以不同的优先级,优先级可以从0到OS_LOWEST_PR10-2。优先级号越低,任务的优先级越高。C/OS-总是运行进入就绪态的优先级最高的任务。目前版本的C/OS-中,任务的优先级号就是任务编号(I

    6、D)。优先级号(或任务的ID号)也被一些内核服务函数调用,如改变优先级函数OSTaskChangePrio(),以及任务删除函数OSTaskDel()。7嵌入式操作系统uC/OS任务状态任务状态n休眠态休眠态(dormant):指任务驻留在程序空间中,还没有交给内核管:指任务驻留在程序空间中,还没有交给内核管理。把任务交给内核是通过调用理。把任务交给内核是通过调用OSTaskCreate()或或OSTaskCreatExt()实现的。实现的。n就绪就绪(Ready):当任务一旦建立,这个任务就处于就绪态准备运行。:当任务一旦建立,这个任务就处于就绪态准备运行。任务可以动态的被另一个程序建立,也

    7、可以在系统运行开始之前任务可以动态的被另一个程序建立,也可以在系统运行开始之前建立。如果一个任务是被另一个任务建立的,而这个任务的优先建立。如果一个任务是被另一个任务建立的,而这个任务的优先级高于建立它的那个任务,则这个刚刚建立的任务将立即得到级高于建立它的那个任务,则这个刚刚建立的任务将立即得到CPU的控制权。通过调用的控制权。通过调用OSTaskDel()使任务返回到休眠态。就使任务返回到休眠态。就绪态的任务都放在就绪列表中。在任务调度时,指针绪态的任务都放在就绪列表中。在任务调度时,指针OSTCBHighRdy指向优先级最高的就绪任务,也就是立刻就要运指向优先级最高的就绪任务,也就是立刻

    8、就要运行的任务。行的任务。8嵌入式操作系统uC/OSn运行运行(Running):准备就绪的最高优先级的任务获得:准备就绪的最高优先级的任务获得CPU的控制的控制权,从而处于运行态。指针权,从而处于运行态。指针OSTCBCur指向正在运行的任务。指向正在运行的任务。n等待或挂起等待或挂起(Pending):正在运行的任务由于调用延时函数:正在运行的任务由于调用延时函数OSTimeDly()或等待事件信号量的来临而将自身挂起,因而处于或等待事件信号量的来临而将自身挂起,因而处于等待或挂起态。因为等待某事件而被挂起的任务注册在该事件的等待或挂起态。因为等待某事件而被挂起的任务注册在该事件的等待列表

    9、中。等待列表中。n中断态中断态(Interrupt):正在运行的任务可以被中断,除非是该任务:正在运行的任务可以被中断,除非是该任务将中断关闭。被中断的任务进入中断服务程序将中断关闭。被中断的任务进入中断服务程序(ISR)。如果中断服。如果中断服务程序使一个更高优先级的任务准备就绪,则中断服务程序结束务程序使一个更高优先级的任务准备就绪,则中断服务程序结束后,更高优先级的任务开始运行程序。后,更高优先级的任务开始运行程序。9嵌入式操作系统uC/OS10R RU U N N N N I IN N G GR RE EA A D D Y YO OS ST Ta as sk kC Cr re ea a

    10、t te e()O OS ST Ta as sk kC Cr re ea at te eE Ex xt t()T Ta as sk k i is s P Pr re ee em m p pt te ed dO OS SM M B Bo ox xP Pe en nd d()O OS SQ QP Pe en nd d()O OS SS Se em m P Pe en nd d()O OS ST Ta as sk kS Su us sp pe en nd d()O OS ST Ti im m e eD Dl l y y()O OS ST Ti im m e eD Dl l y yH HM M S S

    11、M M()O OS SM M B Bo ox xP Po os st t()O OS SQ QP Po os st t()O OS SQ QP Po os st tF Fr ro on nt t()O OS SS Se em m P Po os st t()O OS ST Ta as sk kR Re es su um m e e()O OS ST Ti im m e eD Dl l y yR Re es su um m e e()O OS ST Ti im m e eT Ti i c ck k()O OS ST Ta as sk kD De el l()D D O O R RM M A A

    12、N N T TW W A A I IT TI IN N G GO OS SS St ta ar rt t()O OS SI In nt tE Ex xi it t()O OS S_ _T TA AS SK K_ _S SW W()O OS ST Ta as sk kD De el l()O OS ST Ta as sk kD De el l()I In nt te er rr ru up pt tO OS SI In nt tE Ex xi it t()I IS SR R嵌入式操作系统uC/OS任务堆栈任务堆栈n在C/OS-中,每个任务都有自己的堆栈空间。为方便使用,在C/OS-中专门定义了一

    13、个OS_STK类型的数据,这样在应用程序中定义任务的堆栈就非常方便。例如:n程序 8 5n#define TASK_STK_SIZE 200nOS_STK TaskStartStkTASK_STK_SIZE;11嵌入式操作系统uC/OS12任务的数据结构任务控制块n任务控制块 OS_tcb,包括 任务堆栈指针,状态,优先级,任务表位置,任务链表指针等。n所有的任务控制块分为两条链表,空闲链表和使用链表。OSTCBFreeListTCB0TCB1TCBn新任务TCB(1)空(2)(3)prenext图 4.3 TCB的双向链表结构嵌入式操作系统uC/OS13任务控制块结构nStruct os_t

    14、cb OS_STK *OSTCBStkPtr;struct os_tcb*OSTCBNext;struct os_tcb*OSTCBprev;OS_EVENT *OSTCBEventPtr;void *OSTCBMsg;INT16U OSTCBDly;INT8U OSTCBStat;INT8U OSTCBPrio;INT8U OSTCBX,OSTCBY,OSTCBBitX,OSTCBBitY;OS_TCB嵌入式操作系统uC/OSnOSTCBStkPtr是指向当前任务栈顶的指针。C/OS-允许每个任务有自己的栈,尤为重要的是,每个任务的栈的容量可以是任意的。有些商业内核要求所有任务栈的容量都一样

    15、,除非用户写一个复杂的接口函数来改变之。这种限制浪费了RAM,当各任务需要的栈空间不同时,也得按任务中预期栈容量需求最多的来分配栈空间。OSTCBStkPtr是OS_TCB数据结构中唯一的一个能用汇编语言来处置的变量(在任务切换段的代码Context-switching code之中),把OSTCBStkPtr放在数据结构的最前面,使得从汇编语言中处理这个变量时较为容易。14嵌入式操作系统uC/OSn.OSTCBNext和.OSTCBPrev用于任务控制块OS_TCBs的双重链接,该链表在时钟节拍函数OSTimeTick()中使用,用于刷新各个任务的任务延迟变量.OSTCBDly,每个任务的任

    16、务控制块OS_TCB在任务建立的时候被链接到链表中,在任务删除的时候从链表中被删除。双重连接的链表使得任一成员都能被快速插入或删除。15嵌入式操作系统uC/OSnOSTCBEventPtr是指向事件控制块的指针,后面的章节中会有所描述(见8.9 任务的同步和通信)。n.OSTCBMsg是指向传给任务的消息的指针。用法将在后面的章节中提到(见8.9 任务的同步和通信)。n.OSTCBDly当需要把任务延时若干时钟节拍时要用到这个变量,或者需要把任务挂起一段时间以等待某事件的发生,这种等待是有超时限制的。在这种情况下,这个变量保存的是任务允许等待事件发生的最多时钟节拍数。如果这个变量为0,表示任务

    17、不延时,或者表示等待事件发生的时间没有限制16嵌入式操作系统uC/OSnOSTCBStat是任务的状态字。当.OSTCBStat为0,任务进入就绪态。可以给.OSTCBStat赋其它的值,在文件uCOS_II.H中有关于这个值的描述。n.OSTCBPrio是任务优先级。高优先级任务的.OSTCBPrio值小。也就是说,这个值越小,任务的优先级越高。n.OSTCBX,.OSTCBY,.OSTCBBitX和和.OSTCBBitY用于加速任务进入就绪态的过程或进入等待事件发生状态的过程(避免在运行中去计算这些值)。这些值是在任务建立时算好的,或者是在改变任务优先级时算出的。n.OSTCBDelReq

    18、是一个布尔量,用于表示该任务是否需要删除。17嵌入式操作系统uC/OS18任务的调度-OSSchednuC/OS是占先式实时多任务内核,优先级最高的任务一旦准备就绪,则拥有CPU的所有权开始投入运行。nuC/OS中不支持时间片轮转法,每个任务的优先级要求不一样且是唯一的,所以任务调度的工作就是:查找准备就绪的最高优先级的任务并进行上下文切换。嵌入式操作系统uC/OS19任务的调度n就绪任务表:用于存贮每个任务的就绪状态标志。由两个变量组成:nOSRdyGrp:8位,每位表示一组(8个)任务中是否有就绪的任务。nOSRdyTbl:位图方式表示某个任务是否就绪。嵌入式操作系统uC/OS20就绪状态

    19、标志Bit 0 in OSRdyGrp is 1 when any bit in OSRdyTbl0 is 1.Bit 1 in OSRdyGrp is 1 when any bit in OSRdyTbl1 is 1.Bit 2 in OSRdyGrp is 1 when any bit in OSRdyTbl2 is 1.Bit 3 in OSRdyGrp is 1 when any bit in OSRdyTbl3 is 1.Bit 4 in OSRdyGrp is 1 when any bit in OSRdyTbl4 is 1.Bit 5 in OSRdyGrp is 1 when

    20、any bit in OSRdyTbl5 is 1.Bit 6 in OSRdyGrp is 1 when any bit in OSRdyTbl6 is 1.Bit 7 in OSRdyGrp is 1 when any bit in OSRdyTbl7 is 1.嵌入式操作系统uC/OS21根据优先级找到任务在就绪任务表中的位置OSRdyGrp1207 6 5 4 300XXXYY Y任务优先级20176543108915 14 13 12 1118161723 22 21 20 1926242531 30 29 28 2734323339 38 37 36 3542404147 46 4

    21、5 44 4350484955 54 53 52 5158565763 62 61 60 5901234567OSRdyTbl7XY优先级最低任务(空闲任务)优先级最高任务任务优先级号嵌入式操作系统uC/OS22根据优先级确定就绪表n假设优先级为12的任务进入就绪状态,12=1 100b,则OSRdyTbl1的第4位置1,且OSRdyGrp的第1位置1,相应的数学表达式为:OSRdyGrp|=0 x02;OSRdyTbl1|=0 x10;n而优先级为21的任务就绪21=10 101b,则OSRdyTbl2的第5位置1,且OSRdyGrp的第2位置1,相应的数学表达式为:OSRdyGrp|=0

    22、x04;OSRdyTbl2|=0 x20;嵌入式操作系统uC/OS23根据优先级确定就绪表n从上面的计算我们可以得到:若第n位置1,则应该与2n 相或。uC/OS中,把2n的n=0-7的8个值 先计算好存在数组OSMapTbl7中,也就是:OSMapTbl0=20=0 x1;OSMapTbl1=21=0 x2;OSMapTbl7=27=0 x80;嵌入式操作系统uC/OS24根据优先级确定就绪表n利用OSMapTbl,通过任务的识别号-优先级prio来设置任务在就绪组和就绪表数组中相应位置的数学式为:OSRdyGrp|=OSMapTblprio3;OSRdyTblprio3|=OSMapTbl

    23、prio&0 x07;假设优先级为12,1 100bOSRdyGrp|=0 x02;OSRdyTbl1|=0 x10;嵌入式操作系统uC/OS25根据就绪表确定最高优先级(1)两个关键:n优先级数分解为高三位和低三位分别确定;n高优先级有着小的优先级号着小的优先级号;嵌入式操作系统uC/OS26根据就绪表确定最高优先级(2)n通过OSRdyGrp值确定高3位,假设为0 x24=100 100b,-OSRdyTbl2 和OSRdyTbl5,高优先级为2n通过OSRdyTbl2的值来确定低3位,假设为0 x12=010 010b,-第2个和第5个任务,取高优先级第2个-17嵌入式操作系统uC/OS

    24、27源代码中使用了查表法查表法具有确定的时间,增加了系统的可预测性,uC/OS中所有的系统调用时间都是确定的nHigh3=OSUnMapTblOSRdyGrp;nLow3 =OSUnMapTblOSRdyTblHigh3;nPrio =(Hign33)+Low3;?为什么频繁的使用查表法?请问OSUnMapTbl的来历;嵌入式操作系统uC/OS28INT8U const OSUnMapTbl=0,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,5,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,4,0,1,

    25、0,2,0,1,0,3,0,1,0,2,0,1,0,6,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,5,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,7,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,5,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,6,0,1,0,2,0,1,0,3,

    26、0,1,0,2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,5,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0,4,0,1,0,2,0,1,0,3,0,1,0,2,0,1,0;嵌入式操作系统uC/OS任务调度核心之任务切换宏任务调度核心之任务切换宏OS_TASK_SW()n任务切换很简单,简单说就是终止正在运行的任务,然后去运行另外一个任务,这由以下两步完成,将被挂起任务的微处理器寄存器推入堆栈,然后将较高优先级的任务的寄存器值从栈中恢复到寄存器中。在C/OS-中,就绪任务的栈结构总是看起来跟刚刚发生过中断一样,所有微处理器的寄存器都保存在栈中。换句

    27、话说,C/OS-运行就绪态的任务所要做的一切,只是恢复所有的CPU寄存器并运行中断返回指令。为了做任务切换,运行OS_TASK_SW(),人为模仿了一次中断。多数微处理器有软中断指令SWI或者陷阱指令TRAP来实现上述操作。中断服务子程序或陷阱处理(Trap hardler),也称作事故处理(exception handler),必须提供中断向量给汇编语言函数OSCtxSw()。OSCtxSw()除了需要OS_TCBHighRdy指向即将被挂起的任务,还需要让当前任务控制块OSTCBCur指向即将被挂起的任务29嵌入式操作系统uC/OS30任务间通信手段n提供OS_ENTER_CRITICAL

    28、和OS_EXIT_CRITICAL来对临界资源进行保护nOSSchedLock()禁止调度保护任务级的共享资源。n提供了经典操作系统任务间通信方法:信号量、邮箱、消息队列,事件标志。嵌入式操作系统uC/OS31信号量semaphorenuC/OS中信号量由两部分组成:信号量的计数值和等待该信号任务的等待任务表。信号量的计数值可以为二进制,也可以是其他整数。n系统通过OSSemPend()和OSSemPost()来支持信号量的两种原子操作P()和V()。P()操作减少信号量的值,如果新的信号量的值不大于0,则操作阻塞;V()操作增加信号量的值。嵌入式操作系统uC/OS32中断与时钟节拍n我们知道

    29、:当发生中断时,首先应保护现场,将CPU寄存器入栈,再处理中断函数,然后恢复现场,将CPU寄存器出栈,最后执行中断返回iret(x86)指令实现中断返回。nuC/OS中提供了OSIntEnter()和OSIntExit()告诉内核进入了中断状态。OSIntNesting n时钟节拍是一种特殊的中断,操作系统的心脏。首先32位的整数OSTime加一。对任务列表进行扫描,判断是否有延时任务应该处于准备就绪状态,最后进行上下文切换。嵌入式操作系统uC/OS33多任务的启动n首先创建任务n最后调用OSStart开始多任务调度void main()OSInit();.OSTaskcreat().OSSt

    30、art();嵌入式操作系统uC/OS34任务的格式n每个任务不能占用全部CPU的资源n需要有等待,或延时等系统调用n典型的一个无限循环。void mytask(void*pdata)for(;)do something;waiting;do something;嵌入式操作系统uC/OS35揭开神秘的面纱任务调度全程追踪nFor example1 创建2个任务,每个任务仅仅是进行延时,延时不同的时间片,不同优先级void Task1(void)void Task2(void)while(1)while(1)blinkled1();blinkled2();Task1Data+;Task2Data+

    31、;OSTimeDly(25);OSTimeDly(50);嵌入式操作系统uC/OS36void main()sysinit();OSInit();OSTaskCreate(Task1,(void*)&Task1Data,(void*)&Task1StkTASK_STK_SIZE,Task1prio);OSTaskCreate (Task2,(void*)&Task2Data,(void*)&Task2StkTASK_STK_SIZE,Task2prio);ticker_start(OS_TICKS_PER_SEC);OSStart();嵌入式操作系统uC/OS37void OSStart(vo

    32、id)INT8U y,x;if(OSRunning=FALSE)判断是否没有启动内核 y =OSUnMapTblOSRdyGrp;x =OSUnMapTblOSRdyTbly;OSPrioHighRdy=(INT8U)(y 0)确保tick大于0 OS_ENTER_CRITICAL();进入临界段代码 if(OSRdyTblOSTCBCur-OSTCBY&=OSTCBCur-OSTCBBitX)=0)/*Delay current task */OSRdyGrp&=OSTCBCur-OSTCBBitY;设置任务为非就绪状态 OSTCBCur-OSTCBDly=ticks;在TCB中装载延时数

    33、OS_EXIT_CRITICAL();退出临界段代码 OSSched();调度下一个任务开始运行 嵌入式操作系统uC/OS40void OSSched(void)INT8U y;OS_ENTER_CRITICAL();if(OSLockNesting|OSIntNesting)=0)调度锁,或者处于中断状态禁止调度 y =OSUnMapTblOSRdyGrp;OSPrioHighRdy=(INT8U)(y OSTCBPrio!=OS_IDLE_PRIO)看是不是空闲任务,空闲任务是最后的任务 if(ptcb-OSTCBDly!=0)是否延时 if(-ptcb-OSTCBDly=0)延时减一,看

    34、是否延时结束 if(!(ptcb-OSTCBStat&OS_STAT_SUSPEND)OSRdyGrp|=ptcb-OSTCBBitY;是的话将其列入准备就绪表 OSRdyTblptcb-OSTCBY|=ptcb-OSTCBBitX;else ptcb-OSTCBDly=1;ptcb=ptcb-OSTCBNext;指针指向下一个TCB结构 OSTime+;变量加一,记录系统启动以来的时钟滴答数 嵌入式操作系统uC/OS44OSTimeTick(void)令指针指向第一个任务是否是空闲任务?任务是否存在延时?延时数减一延时数是否为0?如果条件合适,将该任务放入就绪列表 令指针指向下一个任务 OS

    35、Time+返回是否是否是否空闲任务总是最后一个任务对 任 务 表 进行扫描预定的延时到了,就应该在使任务处于就绪条件是:任务没有处于挂起态任务没有延时的话忽略即可嵌入式操作系统uC/OS45时间任务一任务二OSStartTime Tick Time Tick 12550Time Tick 空闲任务嵌入式操作系统uC/OS46总结n不存在一个内核任务/实体,内核的管理是通过调用系统函数来实现的。n每个任务有自己的堆栈空间。内核对任务的占先式调度不会干扰每个任务的总的运行结果。嵌入式操作系统uC/OS47uC/OS的移植n代码分为三部分:n与CPU无关的内核代码,包括os_core.c,os_mb

    36、ox.c,os_mem.c,os_q.c,os_sem.c,os_task.c,os_time.c,ucos_ii.c,ucos_ii.h;n与应用相关的设置头文件,包括:os_cfg.h,include.h;n处 理 器 相 关 的 代 码,包 括:o s _ c p u.h,os_cpu_a.asm,os_cpu.c.c。嵌入式操作系统uC/OS48移植要点n定义函数OS_ENTER_CRITICAL和OS_ENTER_CRITICAL。n定义函数OS_TASK_SW执行任务切换。n定义函数OSCtxSw实现用户级上下文切换,用纯汇编实现。n定义函数OSIntCtxSw实现中断级任务切换,

    37、用纯汇编实现。n定义函数OSTickISR。n定义OSTaskStkInit来初始化任务的堆栈。嵌入式操作系统uC/OS49uC/OS的改进n固定的基于优先级的调度,不支持时间片,使用起来不方便。一个任务的基础上增加一个基于时间片的微型调度核n在对临界资源的访问上使用关闭中断实现,没有使用CPU提供的硬件指令,例如测试并置位。n系统时钟中断,没有提供用户使用定时器,可以借鉴linux的定时器加以修改n可以加上文件系统和TCP/IP协议栈嵌入式操作系统uC/OS50学习uC/OS的步骤n学习与研究uC/OS的起点:在PC上执行uC/OS,环境:VC编译环境,新建一个工程n源代码阅读n移植:DSP,单片机

    展开阅读全文
    提示  163文库所有资源均是用户自行上传分享,仅供网友学习交流,未经上传用户书面授权,请勿作他用。
    关于本文
    本文标题:嵌入式操作系统uCOS课件.ppt
    链接地址:https://www.163wenku.com/p-4652606.html

    Copyright@ 2017-2037 Www.163WenKu.Com  网站版权所有  |  资源地图   
    IPC备案号:蜀ICP备2021032737号  | 川公网安备 51099002000191号


    侵权投诉QQ:3464097650  资料上传QQ:3464097650
       


    【声明】本站为“文档C2C交易模式”,即用户上传的文档直接卖给(下载)用户,本站只是网络空间服务平台,本站所有原创文档下载所得归上传人所有,如您发现上传作品侵犯了您的版权,请立刻联系我们并提供证据,我们将在3个工作日内予以改正。

    163文库