12.0-uC/OS-III任务调度
调度器,决定了任务的运行顺序。 uC/OS-III是一个可抢占的, 基
于优先级的内核。根据其重要性每个任务都被分配了一个优先级。
uC/OS-III支持多个任务拥有相同的优先级。
1.抢占式调度
uC/OS-III通过两种方法处理中断提交的事件:直接提交或延迟提交。
从调度的角度看, 这两种方法产生的结果是一样的;
最高优先级的就绪任务会占用CPU 。
直接提交:
( 1)一个低优先级任务正在执行,这时中断发生了。
( 2)如果中断使能,指令指针IP会跳转到中断服务程序。
( 3)中断服务程序处理相关的程序,发送信号量或消息给一个
高优先级任务。高优先级任务被就绪。
( 4)中断服务程序完成操作后,它将CPU的控制权还给uC/OS-III。
( 5) uC/OS-III执行相应的操作。
( 6) 因为就绪队列中有一个更重要的任务, uC/OS-III将不会返
回中断前那个低优先级的任务。而是执行高优先级任务。
( 7)开始执行高优先级任务
( 8)高优先级任务处理完成后,将CPU的控制权交给uC/OS-III。
( 9) uC/OS-III执行相应的操作。
( 10) uC/OS-III转向执行原先那个低优先级任务。
( 11)低优先级任务从被中断处继续执行。
延迟提交:
当选择延迟提交中断产生的事件的方式时的一些额外步
骤。最后的结果是一样的:高优先级任务抢占了低优先级任务。
( 1)中断服务程序中,不是直接发送信号量或消息给任务。而
是先将信号量或消息放人外部消息队列,并就绪中断处理任务。
( 2)当ISR处理完它的工作时,就把CPU的使用权交给uC/OS-III。
( 3) uC/OS-III处理一些操作。
( 4)因为中断处理任务被就绪, uC/OS-III将CPU的使用权交给它。
( 5) uC/OS-III处理一些操作。
( 6) 中断处理任务将外部消息队列中的消息移除并重新提交给
相应的任务。这样,就将这个过程消息提交从中断级变成了任务级。
使用这种方法的目的是为了减小关中断时间(详见第9章)。当消息
队列为空时, uC/OS-III将中断处理任务从就绪队列中移除,然后执
行就绪队列中的最高优先级任务。
2.调度点
当出现以下情况时会发生调度:
(1).任务被标记或发送消息给另一个任务
(2).任务调用OSTimeDly()或OSTimeDlyHMSM():
(3).任务所等待的事件发生或超时
(4).任务取消挂起
(5).新任务被创建
(6).任务被删除
(7).内核对象被删除
(8).任务改变自身的优先级或其它任务的优先级
(9).当任务通过调用OSTaskSuspend()停止自身
(10).任务调用OSTaskResume()恢复其它停止了的任务
(11).退出中断服务程序
(12).通过调用OSSchedUnlock()调度器被解锁
(13).调用OSSchedRoundRobinYield()任务放弃了分配给它的时间片
(14).用户调用OSSched()
3.循环轮转调度
当多个任务有相同的优先级时, uC/OS-III允许每个任务运行规定
的时间片。 当任务没有用完分配给它的时间片时, 它可以自愿地放弃
CPU。 uC/OS-III允许任务在运行时开启或者关闭循环轮转调度。
如图, 有三个优先级都为X的任务。为了说明,时间片的长度为4:
( 1)任务3正在被运行。在这段时间内,时基中断发生,但任
务3还没有到期。
( 2)任务3主动放弃剩下的时间片。
( 3) uC/OS-III恢复任务1,因为它是队列中任务3的下一个任
务。
( 4)任务1被执行直到分配给它的时间片到期。
( 5)任务3正在被运行。在这段时间内,时基中断发生,但任
务3还没有到期。
( 6)任务3主动放弃剩下的时间片。
( 7) 有趣的事情发生了, uC/OS-III会重新设置任务1的时间片
长度为4个时基。 但剩余时间片的计数是每个时基中断递减, 即在第
4个时基中断发生时时间片到期。 而任务1是在时基即将发生时接手
的,所以事实上它的时间片会少一个时基。
( 8) 任务1执行, uC/OS-III允许用户在任务运行时修改时间片
的长度( 通过OSSchedRoundRobinCfg())。 这个函数也
可以用于开启或关闭循环轮转调度。
uC/OS-III允许用户为每个任务设置不同的时间片。 不同的任务可
以有不同的时间片。 当任务被创建时, 其时间片长度被设置。 也可以
在运行时调用OSTaskTimeQuantaSet()修改。
12.0-uC/OS-III任务调度的更多相关文章
- uC/OS 的任务调度解析 (转)
uC/OS 的任务调度解析 1.任务调度器启动之后(初始化,主要是TCB的初始化),就可以创建任务,开始任务调度了,实际上第一个任务准确的说不是进行任务切换,而是进行启动当前最高优先级任务.uC/OS ...
- uc/os iii移植到STM32F4---IAR开发环境
也许是先入为主的原因,时钟用不惯Keil环境,大多数的教程都是拿keil写的,尝试将官方的uc/os iii 移植到IAR环境. 1.首先尝试从官网上下载的官方移植的代码,编译通过,但是执行会报堆栈溢 ...
- uC/OS - III 移植 IAR平台
关于移植uC/OS-III 网上已经有很多教程了此处只是做个记录 首先下载源码然后解压得到下面的文件: 然后在模版工程里新建各种文件夹: 最后全部都添加进工程: OK了,编译一下,惊呆了,竟然 0错误 ...
- 【原创】uC/OS II 任务切换原理
今天学习了uC/OS II的任务切换,知道要实现任务的切换,要将原先任务的寄存器压入任务堆栈,再将新任务中任务堆栈的寄存器内容弹出到CPU的寄存器,其中的CS.IP寄存器没有出栈和入栈指令,所以只能引 ...
- uC/OS II原理分析及源码阅读(一)
uC/OS II(Micro Control Operation System Two)是一个可以基于ROM运行的.可裁减的.抢占式.实时多任务内核,具有高度可移植性,特别适合于微处理器和控制器,是和 ...
- uc/os任务创建
问题描述: uc/os中任务创建 问题解决: 创建一个任务,任务从无到有.任务创建函数分两种, 一种是基本的创建函数OSTaskCreate, 另一种是扩展的任务创建函数OSTaskCrea ...
- VMware 12安装Mac OS X 10.11&解决上网的问题
近日想在Win10上安装Mac OS 玩玩,于是上网搜了相关资源,查看了相关经验分享,开始着手安装.系统很快成功安装,但最大问题是虚拟机中的Mac OS无法上网.费了很长时间,最终看到Ping通结果, ...
- kubernetes之Kubeadm快速安装v1.12.0版
通过Kubeadm只需几条命令即起一个单机版kubernetes集群系统,而后快速上手k8s.在kubeadm中,需手动安装Docker和kubeket服务,Docker运行容器引擎,kubelet是 ...
- 【原创】uC/OS 中LES BX,DWORD PTR DS:_OSTCBCur的作用及原理
LES BX, DWORD PTR DS:_OSTCBCur ;OSTCBCur->OSTCBStkPtr = SS:SP!!! ], SS ;将当前SS(栈的基地址)寄存器值存放至当前任务控制 ...
- 基于μC/OS—III的CC1120驱动程序设计
基于μC/OS—III的CC1120驱动程序设计 时间:2014-01-21 来源:电子设计工程 作者:张绍游,张贻雄,石江宏 关键字:CC1120 嵌入式操作系统 STM32F103ZE ...
随机推荐
- elastic search query & filter & query_string
一.基本概念 1.query时,如何指定返回哪些字段 希望返回name和date字段 希望返回以location.*为前缀的字段以及date字段:不希望返回location.geolocation字段 ...
- 【转】Mac OS X 上修改主机名
修改主机名称 sudo scutil --set HostName MacBookPro 修改共享名称 sudo scutil --set ComputerName MacBookPro [转自]:h ...
- 8款基于Jquery的WEB前端动画特效
1.超炫酷的30个jQuery按钮悬停动画 按钮插件是最常见的jQuery插件之一,因为它用途广泛,而且配置起来最为方便.今天我们要分享的是30个超炫酷的jQuery悬停按钮动画,当我们将鼠标滑过按钮 ...
- Cobalt Strike DNS通讯实例
一.域名设置 如果没有域名,可以参考另一篇博客,申请Freenom免费域名,并使用DNSPod解析 链接:https://www.cnblogs.com/ssooking/p/6364639.html ...
- 【iCore1S 双核心板_FPGA】例程十七:基于双口RAM的ARM+FPGA数据存取实验
实验现象: 核心代码: module DUAL_PORT_RAM( input CLK_12M, inout WR, input RD, input CS0, :]A, :]DB, output FP ...
- Hibernate获取数据java.lang.StackOverflowError
原因:因为在重写toString()方法时,把关联的属性也放入到toString方法中了,去掉就可以了. 如:重写的toString方法中不能有关联关系IDCard属性idCard public cl ...
- 类似于c语言读取文件进行解析
$log_file_name = 'D:/static/develop/kuai_zhi/acagrid.com/public/Logs/'.date('Ym').'/'.date('d').'_er ...
- C语言 · FBI树
算法训练 FBI树 时间限制:1.0s 内存限制:256.0MB 锦囊1 二叉树. 问题描述 我们可以把由“0”和“1”组成的字符串分为三类:全“0”串称为B串,全“1”串称为I ...
- Scratch 可能能帮你找到学习编程的初心
Scratch 是MIT 出品的一款少儿编程软件,基于Adobe Air开发,这个运行环境在如今已经显得有些过时,但只要这个软件有用,软件本身就不会过时. 编程的本质大致是调用计算机的指令编写一系列任 ...
- Golang查缺补漏(一)
Go语言高级编程(Advanced Go Programming) Go语言高级编程(Advanced Go Programming) golang都是传值,与其他语言不同的是数组作为参数时,也是传值 ...