uCOS-II移植课件.pptVIP

  1. 1、本文档共32页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
8/17/2010 * (2)OSCtxSw():任务优先级切换函数 该函数由OS_TASK_SW()宏调用,OS_TASK_SW()由OSSched()函数调用,OSSched()函数负责任务之间的调度。OSCtxSw()函数的工作是,先将当前任务的CPU现场保存到该任务的堆栈中,然后获得最高优先级任务的堆栈指针,并从该堆栈中恢复此任务的CPU现场,使之继续执行,该函数就完了一次任切换。 OSCtxSw PUSH {R4, R5} LDR R4, =NVIC_INT_CTRL ; 触发软件中断 LDR R5, =NVIC_PENDSVSET STR R5, [R4] POP {R4, R5} BX LR 产生PendSV异常 PendSV并没有马上执行,因为OS_TASK_SW()(实际是OSCtxSw())被调用前中断是关闭的。PednSV只能在中断使能后才能执行。OS_TASK_SW()总是被OS_Sched()调用(见OS_CORE.C文件) 8/17/2010 * 8/17/2010 * 触发PendSV异常 当PendSV使能,执行此后将进入中断服务程序 8/17/2010 * (3)OSInitCtxSw():中断级的任务切换函数 该函数由OSIntExit()调用。由于中断可能会使更高优先级的任务进入就绪态,因此,为了让更高优先级的任务能立即运行,在中断服务子程序的最后,OSInitExit()函数会调用OSInitCtxSw()做任务切换。这样做的目的主要是能够尽快地让高优先级的任务得到响应,保证系统的实时性能。 OSInitCtxSw()与OSCtxSw()都是用于任务切换函数,其区别在于,在OSIntCtxSw()中无需再保存CPU寄存器,因为在调用OSIntCtxSw()之前已发生了中断,OSIntCtxSw()已将默认的CPU寄存器保存到被中断的任务堆栈中。 OSIntCtxSw PUSH {R4, R5} LDR R4, =NVIC_INT_CTRL; 触发软件中断 LDR R5, =NVIC_PENDSVSET STR R5, [R4] POP {R4, R5} BX LR NOP OSCtxSw() OSIntCtxSw()这两个函最终都会触发PendSV异常 8/17/2010 * OSPendSV()函数 OSPendSV()是PendSV(可挂起中断服务)的中断处理函数,它负责μC/OS-II的全部上下文切换。这是ARM Cortex-M3提倡的上下文切换方法。使用这种方法的好处理当发生任何的异常时,Cortex-m3自动保存CPU的一半通用寄存器到预先指定的堆栈中,并且在退出异常前按顺序恢复寄存器。OSPendSV()只需保存剩下的R4-R11寄存器并且调整好堆栈指针。这种方法速度快,充分体现了ARM Cortex-M3的优势,而且无论是任务还是异常均可触发此函数切换上下文。注意使用前应在Startup.S中申明。 8/17/2010 * 8/17/2010 * ARM Cortex-M3任务切换示意图 8/17/2010 * (4)OSTickISR():时钟节拍中断服务函数 时钟节拍是特定的周期性中断,是由硬件定时器产生的。时钟节拍式中断使得内核可将任务延时若干个整数时钟节拍,以及当任务等待事件发生时,提供等待超时的依据。时钟节拍频率越高,系统的额外开销越大。中断间的时间间隔取决于不同的应用。 OSTickISR()首先将CPU寄存器的值保存在被中断任务的堆栈中,之后调用OSIntEnter()。随后,OSTickISR()调用OSTimeTick,检查所有处于延时等待状态的任务,判断是否有延时结束就绪的任务。OSTickISR()最后调用OSIntExit()。如果在中断中(或其他嵌套的中断)有更高优先级的任务就绪,并且当前中断为中断嵌套的最后一层,那么OSIntExit()将进行任务调度。 8/17/2010 * ** Function name: tickInit ** Descriptions: 初始化uC/OS-II的时钟源(系统定时器) static void tickInit (void) { SysTickPeriodSet((INT32U)(SysCtlCl

文档评论(0)

mwk365 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档