嵌入式OS入门笔记-以RTX为案例:六.RTX的任务调度

上一篇笔记介绍了一些绕开排程器(或调度程序,scheduler)来进行时间管理的一些小方法。这一篇详细介绍RTX的任务调度原理。

RTX主要有三种调度方式:

  • Pre-emptive: 抢断式
  • Round robin: 轮转式
  • Co-operative: 合作式

在正式介绍这些方式之前。先看一下RTX的进程优先等级设置。

1.RTX的优先度

每个task在创建之初都会有一个优先级(os_tsk_create(task_name,priority);)。优先级是一个从0到255的整形数据,该数据越高的task。优先级越高。每个优先级都有一个先入先出的队列结构。

详细说来:

首先,RTX并不能处理高速中断(FIQ。ARM处理器中最高优先级的中断),相反地,当高速中断发生时。RTX内核可能会被打断。

然后到普通中断,普通中断并非一个进程,所以不须要设定优先度,但普通中断一定会打断进程。

然后就到优先度为2-255的进程,这些进程会依照先入先出的顺序执行。低优先度的进程不能打断高优先度的进程,但高优先度的进程会打断低优先度的进程。假设当前最高优先度是x。但全部优先度为x的进程都处于等待状态,那么排程器就会考虑下一优先度(x-1)的进程。但一旦任一x进程进入就绪状态。排程器会打断低优先度进程。

优先度为1的进程时轮转进程,以下介绍到轮转排程时会记录它与优先度为2-255进程的差别。

优先度为0的进程为空暇进程。

当没有进程运行时,RTX会运行它,并提升其优先度到1.

几个特殊进程的优先度:os_idle_demon(void) 的优先度永远为0, RTX实在没进程可跑才会执行这个进程。os_error (U32 err_code)的优先度永远为255。用于处理错误的。这两个进程原型都在RTX_CONFIG.C文件里。

另外,除了创建时给进程分配优先级。优先级也是能够通过调用下面服务改变:

os_tsk_prio(taskID,priority);用于改变其它进程的优先度。

os_tsk_prio_self(priority); 用于改变当前进程的优先度。

2.RTX的调度

搞清楚RTX的优先级后,事实上RTX的调度不难理解。

1. pre-emptive

每个进程都有不同的优先级。最高优先级的进程会执行,排程器不会终止它。所以它会执行直到它自行中止挂起(blocked),或者被更高优先级的进程打断。

自行挂起的办法事实上我们上一节介绍过,就三个:os_tsk_pass();, os_dly_wait(delay_time);os_itv_wait(void);.假设其被中止挂起。其余优先级最高的进程会执行。这个配置的办法就是除能在RTX_CONFIG.C中的Round-Robin Task
Switching项。

2. Round robin

每个进程的优先级都是1。每个进程都会被分配到一个时间片,在执行完这个时间片后,该进程就会增加优先级为1的队列的末端,然后队列最前端的进程继续执行。

时间片由RTX_CONFIG.C中的Round_Robin Timeout[ticks]决定。准确时间是Round_Robin Timeout[ticks]×Time tick value[us] (μs). 如上图所看到的。那么时间片就是10000×5=50000μs.配置该排程须要使能Round-Robin Task switching项。

3. Co-operative

这个是全部进程都是同样的优先度(比如1,)且除能了轮转式排程。

在这样的合作模式下,进程不会被排程器挂起,仅仅能自己中止。

3.小结

事实上RTX的任务调度非常灵活,最经常使用的就是轮转和抢断式调度混用: 一部分进程的优先度是大于2的。其它进程的优先度是1(轮转式排程)。也就是说假设优先度大于2的进程就绪了,优先执行,假设没有就绪的大于2的进程,那么就先执行轮转式的进程。并且加上不同的进程间能够相互调节进程的优先度,所以调度的自由度非常大的。

另一些具体的细节问题,比如优先度反转等问题,在记录到进程间通讯后。再具体记录一下吧。

嵌入式OS入门笔记-以RTX为案例:六.RTX的任务调度的更多相关文章

  1. 嵌入式OS入门注意事项-同RTX案件:九.关于优先-翻转,继承和天花板

    嵌入式OS入门注意事项-同RTX案件:九.关于优先-翻转,继承和天花板 涉及当调度优先级,会有很多问题,本文中,优先调度和一些战略的主要问题,以应付. 有几个概念如下:(priority invers ...

  2. HTML入门笔记案例展示(1)

    一: html标签&html书写规则 Html 的标签 分为如下 这两种 : 单标签: 单标签一般 用于特殊的含义,  例如 :  <br/> 表示换行,  <hr/> ...

  3. MySQL入门笔记

    MySQL入门笔记 版本选择: 5.x.20 以上版本比较稳定 一.MySQL的三种安装方式: 安装MySQL的方式常见的有三种: ·          rpm包形式 ·          通用二进制 ...

  4. React.js入门笔记

    # React.js入门笔记 核心提示 这是本人学习react.js的第一篇入门笔记,估计也会是该系列涵盖内容最多的笔记,主要内容来自英文官方文档的快速上手部分和阮一峰博客教程.当然,还有我自己尝试的 ...

  5. redis入门笔记(2)

    redis入门笔记(2) 上篇文章介绍了redis的基本情况和支持的数据类型,本篇文章将介绍redis持久化.主从复制.简单的事务支持及发布订阅功能. 持久化 •redis是一个支持持久化的内存数据库 ...

  6. redis入门笔记

    redis入门笔记 参考redis实战手册 1. Redis在windows下安装 下载地址:https://github.com/MSOpenTech/redis/tags 安装Redis 1.1. ...

  7. C++ 快速入门笔记:进阶编程

    C++入门笔记:高级编程 文件和流 打开文件 void open (const char *filename, ios::openmode mode); ios::app 追加模式.所有写入都追加到文 ...

  8. golang微服务框架go-micro 入门笔记2.4 go-micro service解读

    本章节阐述go-micro 服务发现原理 go-micro架构 下图来自go-micro官方 阅读本文前你可能需要进行如下知识储备 golang分布式微服务框架go-micro 入门笔记1:搭建go- ...

  9. Centos7——docker入门(笔记)

    docker 入门(笔记) 一.Docker是什么? 官方原话: Docker provides a way to run applications securely isolated in a co ...

随机推荐

  1. C与C++动态分配二维数组

    C: C中使用函数malloc和free两个函数. //动态分配M*N维 int **a=(int **)malloc(sizeof(int*)*M); ;i<M;i++) a[i]=(int ...

  2. hdu 1078 FatMouse and Cheese_记忆搜索

    做这类型的搜索比较少,看懂题意花了半天 题意:给你个n*n的图,老鼠一次最远走k步,老鼠起初在(0,0),每次偷吃的东西必须比之前偷吃的要大. #include<iostream> #in ...

  3. Tengine笔记2:通过IP、域名、端口实现虚拟主机

    一.通过端口创建虚拟主机 案例:通过端口访问两个不同的页面 将/usr/local/tengine-2.1.0/html/index.html内的内容改为 Welcom to port1 然后在/op ...

  4. Linux下命令行显示当前全路径方法

    /etc/profile 和 ~/.bashrc 或者直接在用户的.bash_profile中添加 export PS1='[\u@\h \W]\$' 然后执行source命令

  5. 如何以非 root 用户将应用绑定到 80 端口-ssh 篇

    有时想以普通用户身份让应用跑在80端口?? linux下1024以下端口只有root用户才能bind,那怎样才能以普通用户身份绑定到80端口呢? 参考: http://stackoverflow.co ...

  6. Http权威指南笔记(一) URI URL URN 关系

    定义 URI:统一资源标识符(Uniform Resource Indentifier)用来标识服务器上的资源. URL:统一资源定位符(Uniform Resouce Locator)是资源标识符最 ...

  7. PL/SQL块loop..各种循环练习

    --利用loop输出1到100的值并求和 ---loop exit end loop set serveroutput on; declare v_i ; v_sum ; begin loop )th ...

  8. 利用java生成带有干扰线的网页验证码图片

    package imageCreate; import java.awt.Color; import java.awt.Font; import java.awt.Graphics; import j ...

  9. css样式规则的简要总结

    css与文档关联起来发挥作用. css文件中是各种样式规则,由选择器和声名块构成.声明块由多条声明组成.选择器是声明要作用的对象,声明是对具体规则的描述. 声明由属性和值组成,值或是属性的错误都会使该 ...

  10. 一个Socket连接管理池(心跳机制)

    一个Socket连接管理池(心跳机制) http://cuisuqiang.iteye.com/blog/1489661