专利名称:基于PowerPC处理器的车用操作系统中断管理方法
技术领域:
基于PowerPC处理器的车用操作系统中断管理方法属于嵌入式实时操作系统技术领域,尤其涉及基于PowerPC处理器结构的嵌入式实时操作系统技术领域。
背景技术:
中断管理是采用双内核结构的Linux操作系统的实时技术的重要环节之一。目前流行的实时Linux的中断管理多采用中断模拟技术,来提高通用Linux的实时性能。即当Linux禁止/开启中断时,不再直接对硬件中断控制器操作,只是通过设置中断模拟器上对应的全局标志位加以记录,而实际上,在非实时进程和Linux内核运行过程中,中断总是开启的。当硬件中断发生时,实时中断控制器截获该中断,然后判断该中断是否有实时性要求,以决定是立即处理还是挂起该中断。如果该中断发生时实时内核中有就绪态实时进程,而且中断没有实时要求,则立即将CPU控制权返回给操作系统,而略过了查找Linux中断向量表和执行Linux中断服务程序的过程。
在中断处理过程中,堆栈管理关系到操作系统的稳定性、运行效率和存储空间的利用率。其主要任务当中断发生时保存现场、中断处理完成后恢复中断发生时保存的现场、为中断服务程序运行确定合理的堆栈空间,并且如果有高优先级的实时任务在中断处理程序中进入就绪态,则需要在中断服务程序退出时进行任务切换。
目前,采用双内核结构的实时Linux最典型的是RTLinux和RTAI。为了保证通用性,它们在中断处理过程中堆栈切换采用较简单的实现框架,以减少系统移植的代码量。但是,目前各种处理器在堆栈操作、寻址操作等方面的指令系统特征差别很大,如果针对特定的处理器结构设计任务切换机制,将更有利于充分利用特定处理器的功能,提高在该处理器平台上的运行效率。
在RTLinux的中断管理中,不论中断发生时系统运行在哪种状态下,只要实时中断处理程序的运行导致有高优先级的实时任务进入就绪态,系统都要在中断处理开始时保存一次处理器现场,而发生任务切换时需要再保存一次处理器现场。当高优先级任务运行完之后,系统首先恢复进程切换时保存的现场,然后根据函数调用出入栈规则出栈,最后恢复中断发生时保存的现场。然而在实时任务运行时发生中断的情况下,第二次保存的现场是实时中断服务程序运行结束时的处理器现场,而这个现场已经没有意义,保存它不仅降低了实时内核的中断响应速度而且浪费了实时任务的堆栈空间。
发明内容
针对现有采用双内核结构的实时操作系统的中断管理过程中堆栈管理与处理器特性结合不够紧密、现场保存有多余操作、堆栈使用不够经济的问题,本发明针对PowerPC结构提出了一个灵活高效的堆栈管理方法,主要包括下列内容1.在同一中断处理流程中,对中断发生在不同的情况进行区别处理;针对中断发生在实时任务运行过程中的情况,中断处理流程对实时任务运行现场采用一次保存一次恢复的策略。
2.在实时内核运行态采用中断堆栈管理,降低实时任务的堆栈使用需求。
本发明的特征在于它是采用双内核机制的实时操作系统,所述的双内核机制是把标准非实时Linux进行硬实时化的方法,即通过在标准非实时Linux内核与底层硬件之间插入一个小的实时内核,由实时内核提供实时任务的管理,所述Linux内核作为实时内核的优先级最低的实时任务,只有当没有实时任务处于就绪态时才能得到运行;针对中断发生在实时任务运行过程中的情况,中断处理流程对实时任务运行现场采用一次保存一次恢复的策略;相应地所述方法依次含有以下步骤步骤1.设定所述实时操作系统在逻辑上分成下述四个级别非实时进程级别运行用户编写的非实时程序,运行进程采用动态优先级策略,由Linux调度程序调度运行,它的处理级别最低;实时进程级别用户编写的实时应用程序和Linux内核运行于实时进程级别,所述Linux内核作为一个由实时内核管理的特殊进程其优先级最低,为“0”;它支持动态对象创建,动态内存分配;它实行模拟中断管理;实时核心级别实时内核受非实时进程和Linux内核驱动,运行于实时核心级别;实时中断级别它运行实时中断服务程序,以及驱动中断模拟器管理Linux中断处理程序;所述的操作系统设有以下三种堆栈类型用户堆栈,它为用户态程序运行做准备;为实时进程分配的实时进程堆栈,其中的Linux实时进程堆栈对应于Linux内核中当前进程的核心堆栈;实时中断堆栈运行实时中断处理程序;步骤2.在PowerPC处理器上构建以下模块进程创建与堆栈分配模块,它包含非实时任务的创建与堆栈分配子模块它在所述Linux内核上为每个非实时任务分配以下各空间进程控制块,表示进程的状态和拥有的资源;
一定空间的内核堆栈,它是为运行系统服务和中断服务分配的内存空间;任务运行空间,设有用户堆栈用于运行任务代码;实时任务创建和堆栈分配子模块它运行于实时内核之上,所述系统为每个实时任务分配一个实时任务堆栈并固定在系统内核生成时预留的内存空间内;系统双内核操作模块,包括供系统启动代码、用户任务代码、中断处理程序调用的激活任务和按照规定策略从就绪任务列表中选取一个用户任务再跳转到该任务执行的这样一种调度器操作;系统双内核操作代码支持抢占式调度,即当用户任务代码或者中断处理程序调用系统实时内核操作激活一个高优先级的用户任务时,激活任务操作就调用调度器选择新激活的任务,强制打断正在运行的优先级较低的用户任务,而转到激活的任务去执行。
中断处理程序操作模块,它含有中断处理程序入口其中,外部中断处理程序放在MPC555微控制器的入口地址0x500处,计数器中断处理程序放在入口地址0x900处;实时中断服务程序设定实时中断处理程序的优先级高于实时任务优先级;非实时中断处理程序设定非实时内核中的任务作为实时内核的优先级最低的实时任务,在非实时内核中,非实时中断处理程序和内核系统服务运行于内核态,其优先级高于用户态的任务;中断处理程序结束由用户中断服务程序激活了的新任务,只能等中断处理程序结束后再通过调度器来执行。
步骤3.所述的中断处理程序依次含有以下各个步骤步骤3.1保存现场在产生中断后,只要所述系统处于实时或非实时用户态,便把堆栈指针从用户堆栈切换到中断堆栈,进入内核态,再保存现场;否则,系统已经处于内核态,可以直接保留现场;步骤3.2判断发生中断时的状态若为用户态,依次执行保存进程地址、保存进程栈指针和获取中断通道号的操作;若为内核态首先判断中断发生时内核是否忙,若内核不忙,则保存进程地址,再保存进程栈指针和获取中断通道号;若内核忙,则先判断实时内核中断是否嵌套,若已嵌套,则保存进程栈指针,再获取中断通道号;若未嵌套,则先从实时进程堆栈切换到实时中断堆栈,清除实时内核需要调度的变量,再接着去获取中断通道号;步骤3.3判断是否为实时中断若是实时中断则执行实时中断处理程序、设置中断模拟器;否则,便直接设置中断模拟器;步骤3.4判断所述系统是否同时满足以下条件实时内核不忙、中断模拟器处于开通中断状态、中断响应通道畅通,若同时满足以上三个条件,则直接进入中断模拟器调用中断服务程序,然后作中断结束处理;若实时内核不忙,而其他条件不满足,则直接作中断结束处理;若以上三个条件都不满足,则判断实时内核堆栈是否嵌套;步骤3.5若实时内核堆栈已经嵌套,则直接作中断结束处理;若实时内核中断未嵌套,便从实时中断堆栈切换到实时进程堆栈,接着判断是否需要实时调度,若需要实时调度,便执行实时调度操作,否则,作中断结束处理。
经过在MPC555平台上测试得出,用本发明所述的方法从产生中断到进入用户中断处理程序所需时间为14微秒,比采用通用方法时的25微秒要少,提高了中断响应速度。
图1.MPC555寄存器分类示意图;图2.MPC555微控制器CPU现场的内存映射示意图;图3.OSEKLinux堆栈类型示意图;图4.非实时任务存储结构示意图;图5.实时任务存储结构示意图;图6.中断管理方法流程图。
具体实施例方式
本发明提出的方法是嵌入式实时操作系统内核的一部分,以操作系统代码的形式实现。下面以清华大学自主开发的OSEKLinux操作系统、基于MPC555微控制器的硬件平台环境为例,说明中断管理方法的具体实施方式
。
双内核机制是将标准非实时Linux进行硬实时化的一种方法,通过在标准Linux内核与硬件之间插入一个小的实时内核,实时内核提供实时任务的管理,Linux内核作为实时内核的优先级最低的实时任务,只有当没有实时任务处于就绪态时才能得到运行。
OSEKLinux采用双内核实时架构的系统模型设计方案通用操作系统Linux内核与一个实时的符合OSEK标准的实时内核共存于系统中,OSEK实时内核嵌入在Linux内核与底层硬件之间,实时内核为实时任务提供运行环境,而Linux内核用来运行非实时任务。
OSEKLinux操作系统从逻辑上可划分为四个处理级别非实时进程级别用户编写的非实时程序运行于非实时进程级别,这些进程采用动态优先级策略,由Linux调度程序调度运行。在四个处理级别中,非实时进程级别是最低的处理级别,只有当其它级别没有处理要求时,它才会处理。
实时进程级别用户编写的实时应用程序和Linux内核运行于实时进程级别,Linux内核作为一个由实时内核管理的特殊进程,其优先级最低,它独占实时进程优先级“0”。Linux内核除了把原有的开关中断管理由模拟中断管理取代,不再直接控制硬件来开关中断之外,其他机制和编程接口基本相同;在OSEKLinux的双内核中Linux内核支持动态对象的创建,动态内存分配,非实时进程和Linux内核除了启动实时内核外,不能调用实时内核提供的所有系统服务。其他实时进程由用户编写,由于这些进程运行于传统Linux意义的内核态下,所以用户需要确保其正确性,否则会影响到整个系统的安全。实时进程根据用户分配的静态优先级进行调度。
实时核心级别实时内核运行于实时核心级别,它为用户编写的实时应用程序提供系统服务,实时内核管理的系统对象均为静态分配的,在系统生成时由用户静态配置,实时内核不支持内存的动态分配机制。
实时中断级别中断级别运行实时中断服务程序(ISR),包括实时内核的两类中断处理服务程序,驱动中断模拟器管理以及Linux中断处理程序。
根据实时性的不同,OSEKLinux把进程分为两大类,即在Linux内核上运行的普通进程和在实时内核上运行的实时进程。没有实时要求而且比较复杂的任务以Linux进程的方式运行;而实时任务则以实时进程的形式运行。
在OSEKLinux车用嵌入式实时操作系统中,当处理器或设备产生一个中断时,操作系统会对该中断作出响应,并运行响应中断的处理程序。由于该过程在实时系统运行过程中发生非常频繁,该处理程序的好坏直接影响着整个系统的运行效率,本发明针对中断处理过程中的进程堆栈管理提出了一种管理框架,以提高OSEKLinux实时中断处理过程的处理效率。
堆栈类型OSEKLinux车用嵌入式实时操作系统中有三种堆栈。如图3所示,一种是为用户态程序运行准备的用户堆栈;一种是为实时进程分配的实时进程堆栈,其中Linux实时进程的堆栈是一个抽象的堆栈管理,实际对应的是Linux内核中当前进程的核心堆栈;还有一种是实时中断堆栈,专门运行实时中断处理程序。
中断处理过程如图4所示,该中断管理方法的处理流程如下①当中断发生时,首先通过判断SPRG2寄存器的值是否为0,该寄存器被Linux内核用来保存核心堆栈中为保存中断现场而预留堆栈空间的基址,如果该值为0,说明中断发生时堆栈指针已经在核心堆栈内,也可以说系统一定不会运行非实时任务,此时可以直接将现场压入堆栈;如果SPRG2寄存器的值不为0,则将现场保存到以该值为基址的栈内,并将当前栈指针调整为该值,将实现用户栈到核心栈的切换。
②现场保留完毕后,实时内核的中断模拟处理器接管处理权,首先判断发生中断时系统的运行状态,如果是源自实时内核,则系统需要处理OSEK实时内核中断处理的预备工作。中断源自实时内核有两种情况,一种是未发生中断嵌套,这种情况下将堆栈指针从进程堆栈转换到中断堆栈内,并将一个表示中断退出时是否需要调度的全局变量清零,然后进入下一步处理;另一种情况是中断发生时,实时内核正在处理实时中断处理程序,即发生中断嵌套,此时需要增加嵌套级数,但由于此时系统已经运行在中断堆栈中,并且表示是否需要调度的变量已经被清零,所以可以直接进入下一步处理。
③系统通过调用专门的函数来获得中断通道号,并通过osek_global结构上rtirq域上相应的位,判断该通道是否是实时中断,如果是,则跳到osek_global_Handlers[]的相应处理函数,执行实时中断服务程序,如果不是则直接将该通道记录在osek_global结构上的pending域上以备Linux内核使用。
④下一步要决定是否要进行Linux内核中断处理,进行Linux内核中断处理要同时满足三个条件才行,即实时内核不忙(通过osek_local结构的flags域上的l_busy位判断)、Linux内核处于开通中断状态并且该中断通道未被屏蔽。如果是这种情况,则系统进入Linux的标准处理流程。如果是后两个条件不满足,则系统直接恢复CPU现场,返回到中断发生时的程序,其继续运行;如果实时内核忙,则需要处理实时内核中断处理的善后工作,如果在中断嵌套中,则恢复上一级中断处理程序的现场,继续进行实时中断处理,直到最后一层中断处理完毕,在退出实时中断处理流程之前,需将堆栈指针从实时中断堆栈切换到中断前的实时进程堆栈中,判断系统是否需要调度,如果实时中断处理程序调用了一些系统服务导致比当前进程更高优先级的实时进程进入就绪态,则设置表示中断退出时是否需要调度的全局变量,如果该变量不为零,进行调度,否则返回到中断前实时进程继续运行。
权利要求
1.基于PowerPC处理器结构的车用操作系统中断管理方法,其特征在于它是采用双内核机制的实时操作系统,所述的双内核机制是把标准非实时Linux进行硬实时化的方法,即通过在标准非实时Linux内核与底层硬件之间插入一个小的实时内核,由实时内核提供实时任务的管理,所述Linux内核作为实时内核的优先级最低的实时任务,只有当没有实时任务处于就绪态时才能得到运行;针对中断发生在实时任务运行过程中的情况,中断处理流程对实时任务运行现场采用一次保存一次恢复的策略;相应地所述方法依次含有以下步骤步骤1.设定所述实时操作系统在逻辑上分成下述四个级别非实时进程级别运行用户编写的非实时程序,运行进程采用动态优先级策略,由Linux调度程序调度运行,它的处理级别最低;实时进程级别用户编写的实时应用程序和Linux内核运行于实时进程级别,所述Linux内核作为一个由实时内核管理的特殊进程其优先级最低,为“0”;它支持动态对象创建,动态内存分配;它实行模拟中断管理;实时核心级别实时内核受非实时进程和Linux内核驱动,运行于实时核心级别;实时中断级别它运行实时中断服务程序,以及驱动中断模拟器管理Linux中断处理程序;所述的操作系统设有以下三种堆栈类型用户堆栈,它为用户态程序运行做准备;为实时进程分配的实时进程堆栈,其中的Linux实时进程堆栈对应于Linux内核中当前进程的核心堆栈;实时中断堆栈运行实时中断处理程序;步骤2.在PowerPC处理器上构建以下模块进程创建与堆栈分配模块,它包含非实时任务的创建与堆栈分配子模块它在所述Linux内核上为每个非实时任务分配以下各空间进程控制块,表示进程的状态和拥有的资源;一定空间的内核堆栈,它是为运行系统服务和中断服务分配的内存空间;任务运行空间,设有用户堆栈用于运行任务代码;实时任务创建和堆栈分配子模块它运行于实时内核之上,所述系统为每个实时任务分配一个实时任务堆栈并固定在系统内核生成时预留的内存空间内;系统双内核操作模块,包括供系统启动代码、用户任务代码、中断处理程序调用的激活任务和按照规定策略从就绪任务列表中选取一个用户任务再跳转到该任务执行的这样一种调度器操作;系统双内核操作代码支持抢占式调度,即当用户任务代码或者中断处理程序调用系统实时内核操作激活一个高优先级的用户任务时,激活任务操作就调用调度器选择新激活的任务,强制打断正在运行的优先级较低的用户任务,而转到激活的任务去执行。中断处理程序操作模块,它含有中断处理程序入口其中,外部中断处理程序放在MPC555微控制器的入口地址0x500处,计数器中断处理程序放在入口地址0x900处;实时中断服务程序设定实时中断处理程序的优先级高于实时任务优先级;非实时中断处理程序设定非实时内核中的任务作为实时内核的优先级最低的实时任务,在非实时内核中,非实时中断处理程序和内核系统服务运行于内核态,其优先级高于用户态的任务;中断处理程序结束由用户中断服务程序激活了的新任务,只能等中断处理程序结束后再通过调度器来执行。步骤3.所述的中断处理程序依次含有以下各个步骤步骤3.1保存现场在产生中断后,只要所述系统处于实时或非实时用户态,便把堆栈指针从用户堆栈切换到中断堆栈,进入内核态,再保存现场;否则,系统已经处于内核态,可以直接保留现场;步骤3.2判断发生中断时的状态若为用户态,依次执行保存进程地址、保存进程栈指针和获取中断通道号的操作;若为内核态首先判断中断发生时内核是否忙,若内核不忙,则保存进程地址,再保存进程栈指针和获取中断通道号;若内核忙,则先判断实时内核中断是否嵌套,若已嵌套,则保存进程栈指针,再获取中断通道号;若未嵌套,则先从实时进程堆栈切换到实时中断堆栈,清除实时内核需要调度的变量,再接着去获取中断通道号;步骤3.3判断是否为实时中断若是实时中断则执行实时中断处理程序、设置中断模拟器;否则,便直接设置中断模拟器;步骤3.4判断所述系统是否同时满足以下条件实时内核不忙、中断模拟器处于开通中断状态、中断响应通道畅通,若同时满足以上三个条件,则直接进入中断模拟器调用中断服务程序,然后作中断结束处理;若实时内核不忙,而其他条件不满足,则直接作中断结束处理;若以上三个条件都不满足,则判断实时内核堆栈是否嵌套;步骤3.5若实时内核堆栈已经嵌套,则直接作中断结束处理;若实时内核中断未嵌套,便从实时中断堆栈切换到实时进程堆栈,接着判断是否需要实时调度,若需要实时调度,便执行实时调度操作,否则,作中断结束处理。
全文摘要
基于PowerPC处理器的车用操作系统中断管理方法属于嵌入式实时操作系统技术领域,其特征在于针对基于PowerPC处理器实现的采用双内核结构的嵌入式实时操作系统,根据中断发生时系统的运行状态,采用不同的处理器现场保存,在实时内核运行态下,采用一次保存、一次恢复,从而减少了不必要的堆栈操作。作为清华大学汽车电子开放式系统的一部分,在MPC555平台上实施。测试表明,该方法提高了双内核系统中实时内核的中断响应速度和系统运行效率。
文档编号G06F9/46GK1655124SQ200510011379
公开日2005年8月17日 申请日期2005年3月4日 优先权日2005年3月4日
发明者孙晓民, 周书平 申请人:清华大学