计算机应用 | 古代文学 | 市场营销 | 生命科学 | 交通物流 | 财务管理 | 历史学 | 毕业 | 哲学 | 政治 | 财税 | 经济 | 金融 | 审计 | 法学 | 护理学 | 国际经济与贸易
计算机软件 | 新闻传播 | 电子商务 | 土木工程 | 临床医学 | 旅游管理 | 建筑学 | 文学 | 化学 | 数学 | 物理 | 地理 | 理工 | 生命 | 文化 | 企业管理 | 电子信息工程
计算机网络 | 语言文学 | 信息安全 | 工程力学 | 工商管理 | 经济管理 | 计算机 | 机电 | 材料 | 医学 | 药学 | 会计 | 硕士 | 法律 | MBA
现当代文学 | 英美文学 | 通讯工程 | 网络工程 | 行政管理 | 公共管理 | 自动化 | 艺术 | 音乐 | 舞蹈 | 美术 | 本科 | 教育 | 英语 |

实时嵌入式系统中的一种互斥方法(1)

2015-05-13 01:41
导读:计算机应用论文论文,实时嵌入式系统中的一种互斥方法(1)应该怎么写,有什么格式要求,科教论文网提供的这篇文章是一个很好的范例: 摘要:本文分析了实时嵌入式操作系统中几种常用的互斥方法,
摘要:本文分析了实时嵌入式操作系统中几种常用的互斥方法,提出了一种基于任务优先级的禁止抢占法,并分析了该方法的安全性和高效性。
关键词:多任务 任务优先级 抢占 调度时机 调度器
A EXCLUSIVE METHOD OF THE REAL-TIME EMBED OPERATING SYSTEM
Abstract Some common-used exclusive methods are analyzed in this paper.It advances a no preemptive method which based on task priority and analyzes the security and high-efficiency.
Keywords Multitask Task priority Preemptive Scheduling chance Scheduler 1 引言多任务系统中当一个共享地址空间简单地用于数据交换时,为避免竞争,需要对内存的访问上锁,以保证访问互斥进行。实现资源互斥访问的方法很多,不同之处仅在于互斥的范围和程度。这些方法包括禁止中断,禁止抢占和使用信号量等对资源上锁。
互斥机制最强有力的方法是禁止中断,这种上锁保证了对CPU的独占访问。在互斥期间,即使外部事件产生而引发相应的中断,系统也不会切换到相应的中断服务程序(ISR),也能保证任务之间的互斥。因此在上锁期间,它可能造成系统对外部事件反应迟钝。这对于大多数实时系统而言,系统的实时性也就得不到保证,因而不适合作为一种通用的互斥方法。然而当涉及到任务和中断服务程序共享数据时,中断上锁又是唯一的方法。但是在任何情况下,应该使中断上锁时间尽量短,这也是所有实时系统的基本要求。
从本质上讲,信号量机制比禁止中断或禁止抢占提供更精确的互斥粒度,但是在使用时需要注意优先级继承,删除安全性和递归使用等问题,并且当一个任务需要同时获取多个信号量时更要注意避免系统的死锁问题。因此,一般实时嵌入式操作系统都会为用户提供多种互斥手段,以适应不同的使用场合。但对于禁止抢占(禁止调度)这种方法而言,有些系统支持,如UC/OS--II,VxWorks等,而有些系统未必支持,如PSOS等,为了达到禁止抢占这种效果,并且不受具体系统的约束,本文提出了一种新的禁止抢占方法——最高优先级法。2禁止抢占的基本原理如果任务不与中断服务子程序共享变量或数据结构,可以使用先禁止然后允许任务切换的手段。此时虽然任务切换禁止了,但中断还是开着的。如果这时中断来了,中断服务子程序会在这一临界区内立即执行。中断服务子程序结束时,即使有更高优先级的任务已经进入就绪态,内核还是返回到原先被中断了的任务,直到执行完给任务切换开锁函数,内核再看看有没有优先级更高的任务被中断服务子程序激活而进入就绪态,如果有则做任务切换。此种机制比中断上锁要弱一些。3最高优先级法3.1最高优先级法的基本原理 (转载自中国科教评价网http://www.nseac.com
在实时嵌入式系统中,各个应用任务依据实时性.重要性被赋予了不同的优先级,内核严格按照优先级的高低来调度任务,高优先级的任务能抢占低优先级的任务以满足实时性的要求。另外,实时嵌入式操作系统一般都提供了动态更改任务优先级的系统调用。我们可以将系统中的最高优先级(HiPriority)预留下来,当某任务需要禁止抢占时,将该任务的优先级提升到最高优先级(PriorityProtect),在该任务将其自身的优先级设回原优先级(UnPriorityProtect)之前,系统中的其它任务不会抢占该任务,该任务可以放心地完成临界区的操作。使用这种方法也可以选择基于优先级的时间片轮转调度。轮转调度可以使优先级相同处于就绪态的任务公平地分享使用CPU。按照优先级调度的原理,考察我们的最高优先级法:当任务处于最高优先级时即使时间片到期任务也不会切换出去,因为就绪队列里优先级最高(为HiPriority)的任务只有一个,不管它是否用完时间片,其它低优先级的任务都无法抢占它。
3.2最高优先级法的普通实现
我们先来分析下面的一种在实际开发工作中会遇到的情况,任务A中有一段临界区代码,并且假设该临界区代码不包含因等待资源而不得不让出CPU的可能:
上一篇:巧用数组实现长整数的精确计算(1) 下一篇:没有了