嵌入式Linux内核开发教程之深入分析Linux内核源码-进程调度.ppt
《嵌入式Linux内核开发教程之深入分析Linux内核源码-进程调度.ppt》由会员分享,可在线阅读,更多相关《嵌入式Linux内核开发教程之深入分析Linux内核源码-进程调度.ppt(22页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、嵌入式Linux内核开发教程之深入分析Linux内核源码进程调度 Still waters run deep.流静水深流静水深,人静心深人静心深 Where there is life,there is hope。有生命必有希望。有生命必有希望千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org3.1基本原理调度的实质就是资源的分配。系统通过不同的调度算法(Scheduling Algorithm)来实现这种资源的分配。通常来说,选择什么样的调度算法取决于的资源分配的策略(Schedulin
2、g Policy),在这里只说明与Linux调度相关的几种算法及这些算法的原理。一个好的调度算法应当考虑以下几个方面:(1)公平:保证每个进程得到合理的CPU时间。(2)高效:使CPU保持忙碌状态,即总是有进程在CPU上运行嵌入式嵌入式LinuxLinux内核开发教程内核开发教程之之LinuxLinux的的调度程序调度程序Schedule()Schedule()千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org(3)响应时间:使交互用户的响应时间尽可能短。(4)周转时间:使批处理用户等待输
3、出的时间尽可能短。(5)吞吐量:使单位时间内处理的进程数量尽可能多。很显然,这5个目标不可能同时达到,所以,不同的操作系统会在这几个方面中作出相应的取舍,从而确定自己的调度算法,例如UNIX采用动态优先数调度、BSD采用多级反馈队列调度、Windows采用抢先多任务调度等等。嵌入式嵌入式LinuxLinux内核开发教程内核开发教程千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org下面来了解一下主要的调度算法及其基本原理:1时间片轮转调度算法时间片(Time Slice)就是分配给进程运行的
4、一段时间。在通常的轮转法中,系统将所有的可运行(即就绪)进程按先来先服务的原则,排成一个队列,每次调度时把CPU分配给队首进程,并令其执行一个时间片。当执行的时间片用完时,系统发出信号,通知调度程序,调度程序便据此信号来停止该进程的执行,并将它送到运行队列的末尾,等待下一次执行;然后,把处理机分配给就绪队列中新的队首进程,同时也让它执行一个时间片。这样就可以保证运行队列中的所有进程,在一个给定的时间内,均能获得一时间片的处理机执行时间。嵌入式嵌入式LinuxLinux内核开发教程内核开发教程之之1 1时间时间片轮转调度算法片轮转调度算法千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动
5、互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org为了照顾到紧迫型进程在进入系统后便能获得优先处理,引入了最高优先权调度算法。当将该算法用于进程调度时,系统将把处理机分配给运行队列中优先权最高的进程,这时,又可进一步把该算法分成两种方式:(1)非抢占式优先权算法(又称不可剥夺调度:Nonpreemptive Scheduling)在这种方式下,系统一旦将处理机(CPU)分配给运行队列中优先权最高的进程后,该进程便一直执行下去,直至完成;或因发生某事件使该进程放弃处理机时,系统方可将处理机分配给另一个优先权高的进程。这种调度算法主要用于批处理系统中
6、,也可用于某些对实时性要求不严的实时系统中。嵌入式嵌入式LinuxLinux内核开发教程内核开发教程之之2 2优先优先权调度算法权调度算法千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org(2)抢占式优先权调度算法(又称可剥夺调度:Preemptive Scheduling)该算法的本质就是系统中当前运行的进程永远是可运行进程中优先权最高的那个。在采用这种调度算法时,每当出现一新的可运行进程,就将它和当前运行进程进行优先权比较,如果高于当前进程,将触发进程调度。这种方式的优先权调度算法,能
7、更好的满足紧迫进程的要求,故而常用于要求比较严格的实时系统中,以及对性能要求较高的批处理和分时系统中。Linux也采用这种调度算法。嵌入式嵌入式LinuxLinux内核开发教程内核开发教程千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org这是时下最时髦的一种调度算法。其本质是:综合了时间片轮转调度和抢占式优先权调度的优点,即:优先权高的进程先运行给定的时间片,相同优先权的进程轮流运行给定的时间片。嵌入式嵌入式LinuxLinux内核开发教程内核开发教程之之3 3多级多级反馈队列调度反馈队列
8、调度千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org最后我们来看一下实时系统中的调度。什么叫实时系统,就是系统对外部事件有求必应、尽快响应。在实时系统中,广泛采用抢占调度方式,特别是对于那些要求严格的实时系统。因为这种调度方式既具有较大的灵活性,又能获得很小的调度延迟;但是这种调度方式也比较复杂。嵌入式嵌入式LinuxLinux内核开发教程内核开发教程之之4 4实时实时调度调度千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.o
9、rg www.mobiletrain.orgLinux的调度程序是一个叫Schedule()的函数,这个函数被调用的频率很高,由它来决定是否要进行进程的切换,如果要切换的话,切换到哪个进程等等。我们先来看在什么情况下要执行调度程序,我们把这种情况叫做调度时机。Linux调度时机主要有:1、进程状态转换的时刻:进程终止、进程睡眠;2、当前进程的时间片用完时(current-counter=0);3、设备驱动程序主动调用schedule;嵌入式嵌入式LinuxLinux内核开发教程内核开发教程之之3.2 3.2 LinuxLinux进程调度时机进程调度时机千锋千锋3G3G嵌入式移动互联网技术研发培
10、训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org4、进程从中断、异常及系统调用返回到用户态时;时机1,进程要调用sleep()或exit()等函数进行状态转换,这些函数会主动调用调度程序进行进程调度;时机2,由于进程的时间片是由时钟中断来更新的,因此,这种情况和时机4是一样的。时机3,当设备驱动程序执行长而重复的任务时,直接调用调度程序。在每次反复循环中,驱动程序都检查need_resched的值,如果必要,则调用调度程序schedule()主动放弃CPU。嵌入式嵌入式LinuxLinux内核开发教程内核开发教程千锋千锋3G3G
11、嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.org时机4,如前所述,不管是从中断、异常还是系统调用返回,最终都调用ret_from_sys_call(),由这个函数进行调度标志的检测,如果必要,则调用调度程序。那么,为什么从系统调用返回时要调用调度程序呢?这当然是从效率考虑。从系统调用返回意味着要离开内核态而返回到用户态,而状态的转换要花费一定的时间,因此,在返回到用户态前,系统把在内核态该处理的事全部做完。每个时钟中断(timer interrupt)发生时,由三个函数协同工作,共同完成进程的选择和切换
12、,它们是:schedule()、do_timer()及ret_form_sys_call()。我们先来解释一下这三个函数:嵌入式嵌入式LinuxLinux内核开发教程内核开发教程千锋千锋3G3G嵌入式移动互联网技术研发培训中心嵌入式移动互联网技术研发培训中心www.embedtrain.org www.mobiletrain.orgschedule():进程调度函数,由它来完成进程的选择(调度);do_timer():暂且称之为时钟函数,该函数在时钟中断服务程序中被调用,被调用的频率就是时钟中断的频率即每秒钟100次(简称100赫兹或100Hz);ret_from_sys_call():系统调
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 嵌入式 Linux 内核 开发 教程 深入 分析 源码 进程 调度
限制150内