浅谈Windows C E的中断处理及中断流驱动的应用
引 言
近年来,随着硬件复杂性、多样性和应用复杂性的增加,软件开发工作量急剧增长,传统的开发模式已经不能适应系统z杂性的增长。而嵌入式操作系统是嵌入式软件的运行平台和开发平台,它的引入极大地提高了软件的开发效率,方便了软件的维护。WindowsCE是微软公司嵌入式、移动计算平台的基础,它是一个开放的、可升级的32位嵌入式操作系统,是基于掌上型电脑类的电子设备操作系统,它是精简的Windows 95,Windows CE的图形用户界面相当出色。Windows CE作业系统是Windows家族中最新的成员,专门设计给掌上型电脑(HPCs)所使用的电脑环境。这样的作业系统可使完整的可携式技术与现有的Windows桌面技术整合工作。 Windows CE 被设计成针对小型设备(它是典型的拥有有限内存的无磁盘系统)的通用操作系统,Windows CE 可以通过设计一层位于内核和硬件之间代码来用设定硬件平台,各种处理器都有丰富的外部中断源,中断源和操作系统之间通常采用中断机制来控制数据的交互。硬件厂商没有为一些外部中断源提供Windows CE下的驱动,所以有时驱动成为项目开发关键的一环。
1 Windows CE中断处理
1.1 中断产生
在Windows CE中,系统的中断分为两种:软中断和硬中断。软中断是一种信号机制,而不是由软件产生的中断信号。硬中断通常是外部设备对CPU发出中断信弓。一般来说,软中断是由操作系统内核机制的事件产生的,例如定时器超叫,但是有的软中断由和硬件有关的中断引起。例如,当外部产生一个硬中断时,会产生和硬件相关的一个软中断,软中断是利用硬件中断的概念,用软件方式进行模拟,实现宏观上的异步执行效果。很多情况下,软中断和信号有些类似,同时,软中断又是和硬中断相对应的,硬中断是外部设备对CPU的中断,软中断通常是硬中断服务程序对内核的中断,信号则是由内核(或其他进程)对某个进程的中断般来说,软中断是由内核机制的触发事件引起的(例如进程运行超时),但是不可忽视有大量的软中断也是由于和硬件有关的中断引起的,例如当打印机端口产生一个硬件中断时,会通知和硬件相关的硬中断,硬中断就会产生一个软中断并送到操作系统内核里,这样内核就会根据这个软中断唤醒睡眠在打印机任务队列中的处理进程。 这样内核就会在适当的时机处理这个软中断,唤醒睡眠在相应任务队列中的处理例程。
1.2 中断处理模型
Windows CE提供了一个有效的中断处理机制,它把对中断的处理分为两部分:中断服务例程(ISR)和中断服务线程(IST)。ISR通常要求短小精悍,效率要求很严格。它只决定该怎样处理这个中断,一般情况下不应该做太多的工作。大部分工作依靠IST处理,IST和CST(commON SPANning tree,公共生成树)共同构成整个交换机网络的生成树CIST(common and internal SPANning tree,公共和内部生成树)。IST是CIST在MST域内的片段,是一个特殊的多生成树实例。根据IEEE802.1s规范的规定,MST实例能够支持802.1Q和802.1s之间的互操作性。IST实例接收并且向CST发送BPDU.IST实例能够将整个MST区域表示为到达外部世界的CST虚拟网桥。如将数据移到缓存或处理用户某些特殊要求的工作。Windows CE中断处理模型如图1所示。
1.3 中断处理过程
Windows CE支持两种ISR:静态ISR和可安装ISR.静态ISR只能静态地编译进内核,运行时不能改变。与IST通信时,它也只能是单向的,即由ISR到IST.静态ISR支持嵌套中断,并且使用内核堆栈。可安装ISR由内核管理程序从动态链接库中加载。和静态ISR不同,它和IST的通信是双向的,多个ISR可以与同一个中断请求相关联,系统按照加载驱动的顺序依次调度。图2为中断处理过程。
对图2的中断处理过程作以下几点解释:
①当内核的异常处理代码接收到一个来自硬件的中断时,内核会侦测到一个异常情况发生,并会提交这个硬件中断。
②内核的中断支持处理器通知ISR去禁止该中断的重复提交,直到相关的中断处理全部完成后,才再度使能该中断。在这个过程中,允许高优先级中断触发。为使系统能及时响应并处理发生的所有中断,系统根据引起中断事件的重要性和紧迫程度,硬件将中断源分为若干个级别,称作中断优先级。引入多级中断是因为:为使系统能及时的响应和处理所发生的紧迫中断,同时又不至于发生中断信号丢失,计算机发展早期在设计中断系统硬件时根据各种中断的轻重在线路上作出安排,从而使中断响应能有一个优先次序。多级中断的处理原则:当多级中断同时发生时,CPU按照由高到低的顺序响应。高级中断可以打断低级中断处理程序的运行,转而执行高级中断
- LPC2292的伪中断与伪中断处理(03-25)
- Linux 2.4.x内核软中断机制(04-06)
- 嵌入式系统开发之中断控制的实现(04-18)
- uC/OS-II的任务切换机理及中断调度优化(05-11)
- μC/OSII的时钟中断技术研究(06-30)
- 微内核RTOS的核外中断管理(07-27)