打印本文 打印本文  关闭窗口 关闭窗口  
一种时间触发的多任务调度器设计来源于瑞达科技网
作者:佚名  文章来源:不详  点击数  更新时间:2011/12/29   文章录入:瑞达  责任编辑:瑞达科技

引言目前,嵌入式系统的硬件核心大致有两大类:一类是功能强大的嵌入式微处理器,使用这类产品的系统一般功能强大,多数使用嵌入式操作系统,往往与无线通信、互联网访问以及多媒体处理等复杂而强大的功能联系在一起;另一类是微控制器,它通常以某一种微控制器内核为核心,芯片内部集成ROM、RAM、定时器、串行口等各种必要功能和外设。出于成本和技术上的考虑,这类系统的软件开发还是基于处理器直接编写,没有配备多任务操作系统

引 言

目前,嵌入式系统的硬件核心大致有两大类:一类是功能强大的嵌入式微处理器,使用这类产品的系统一般功能强大,多数使用嵌入式操作系统,往往与无线通信、互联网访问以及多媒体处理等复杂而强大的功能联系在一起;另一类是微控制器,它通常以某一种微控制器内核为核心,芯片内部集成ROM、RAM、定时器、串行口等各种必要功能和外设。出于成本和技术上的考虑,这类系统的软件开发还是基于处理器直接编写,没有配备多任务操作系统作为开发平台,也不需要将系统软件和应用软件完全分开处理。但在实际的应用中,很多时候也会面临同时应付多种外设、处理多个任务的要求,这就需要安排一个调度器来完成多任务的处理。

本文设计并实现了一种基于时间触发的多任务调度器。该调度器使用传递消息(message)的方式使得控制器在多个任务之间进行切换。因为消息和任务一一对应,一个消息触发一个任务,所以本文对两者不做详细区分。

1 嵌入式软件的两种触发方式

嵌入式系统中,通常采用两种本质上不同的调度方式:事件触发和时间触发。事件触发方式往往使用多级中断实现,其发生时间具有随机性;而时间触发方式则不同,它是通过一个全局时钟进行驱动的,系统的行为不仅在功能上确定,而且在时间上也是确定的。

1.1 事件触发方式存在的问题

如果多个中断源在随机的时间间隔内产生中断,则需要处理同时发生的多个事件。这样不但增加了系统复杂性,而且降低了对事件触发系统在所有情况下行为的预计能力。实际上,在同时有几个有效中断源的情况下,几乎不可能创建代码来正确处理所有可能的中断组合。中断事件不会丢失是存在于绝大多数嵌入式系统开发人员头脑中的一种错误观念,这往往给所开发的产品带来灾难性的后果。事件触发系统的开销是人们经常忽略的另一个问题。Alexander Metzner专门讨论了这种问题并得出结论:一个包含27个任务、采用RM调度算法的事件触发系统,CPU的实际利用率仅为18%。

1.2 时间触发方式的优点

Kopetz首先提出:使用基于时间触发的合作式调度器会使得系统有非常好的可预测性。因此,在某些与安全相关的应用系统中选用时间触发方式,设计人员能预先安排可控的顺序,保证一次只处理一个事件,提高系统的可靠性并减轻CPU的负荷。

2 时间触发调度器的设计

调度器的设计主要包括3个方面:消息队列、定时器和周期性任务调度。在调度器的实现中,将定时器的设置分离出来,并且定义不依赖于编译器的数据类型,通过修改这一部分可以轻松地将该调度器移植到多种硬件平台上使用。

2.1 消息队列的设计

图1中,消息队列MsgQue[]和定时队列TmrQue[]是调度器的核心数据结构。为了减少时钟中断中对它们的处理时间,还设置了2个队列——就绪索引队列RdIdx[]和定时索引队列TmrIdx[]。这4个队列都由静态数组实现。

打印本文 打印本文  关闭窗口 关闭窗口