以文本方式查看主题 - 曙海教育集团论坛 (http://peixun0.cn/bbs/index.asp) -- Linux技术讨论区 (http://peixun0.cn/bbs/list.asp?boardid=7) ---- 嵌入式实时Linux的技术研究 (http://peixun0.cn/bbs/dispbbs.asp?boardid=7&id=1356) |
-- 作者:wangxinxin -- 发布时间:2010-11-15 13:46:29 -- 嵌入式实时Linux的技术研究 PC硬件使用的增加是近年来高端嵌入式系统的一个最重要的发展。由于这个趋势,嵌入式系统的硬件成本大大地下降了,然而应用于嵌入式PC平台的软件系统却没有太多的选择。 目前嵌入式操作系统主要有Palm OS,WindowsCE,EPOC,LinuxCE,QNX.ECOS,LYNX等,但这些系统一般都价格昂贵、不具有良好的可移植性。由于linux具有适应于多种CPU和多种硬件平台、性能稳定、裁剪性能好,开发和使用都很容易等特点,越来越多的人倾向于将Linux嵌入到移动计算平台、信息家电、媒体手机及其它产品中去。这同时也对Linux的实时性提出了更高的要求。 我们参加开发的上海数字技术中心的电子警察系统就是这样一个基于PC平台的嵌入式系统。它的主要功能是安装在十字路口上监视闯红灯的汽车,录制这些镜头,并适时通过网络传回总监控中心。该系统原来采用Vxworks作为运作平台,然而由于Vxworks的昂贵,且只能安装一台机器,因此将Linux改制成嵌入式的、具有一定实时性的系统平台。 1 硬件需求 考虑到实际的系统功能和系统开发的难度,我们决定选择X86体系作为平台,底板采PCM-5864/L板,CPU选择Intel的P55C系列,同时它也支持PC104接口。I/O方面,PCM-5864/L支持EIDE、FDD、Keyboard、Mouse、RS-232、USB等接口,同时也集成了10Mbps/l00Mbps网卡。另外PCM-5864/L还集成了显卡,并提供36位TTL的LCD接口、LVDS接口和Video-in/TV-out接口。由于电子磁盘体积小、抗震性能也较好的特点,我们选用M-Systems公司的DiskOnChip2000作为存储设备,这样比较适合该系统户外作业的特性。Doc2000还提供了安装的工具包、Linux下的驱动程序和对不同版本Linux内核的Patch。安装时只需对Linux内核和Lilo进行相应修改即可。这样的硬件选择使系统开发的难度大大降低了。 2 嵌入Linux主要解决的几个问题 由于采用X86体系作为平台,大大降低了嵌入化Linux的难度,主要要考虑的问题可分为以下几个方面: 2.1 非虚拟内存 Linux采用虚拟内存技术,当数据溢出内存时,可以将其交换到磁盘交换空间巾去,这对程序员来说是不可见的。然而,普通的嵌入式系统不需要这种强大的功能。实际上,可能不希望它在实时的关键系统里,因为它会带来无法控制的时问因素。因此,考虑将虚拟内存的功能去掉。然而,清除Linux的虚拟内存代码非常费事,我们采用一种迂回的方法,即将交换空间的大小设置为零。这样,如果你写的程序比实际的内存大,系统就会当作你的运行用尽了交换空间来处理;这个程序将不会运行,或者malloc将会失灵。这只是一种临时的解决方案,系统中存在许多冗余未清除的代码,如果进一步改进可以缩小系统体积。 2.2 处理文件系统 许多嵌入式系统没有磁盘或者文件系统,Linux不需要它们也能运行,这样可以在系统启动时就将操作系统和预先编好的应用程序全都加载到内存中去。然而.考虑到以后的扩展,我们分析了Linux当前的文件系统,将与系统和程序运行相关的文件析取出来,移植到Doc上面.这样就能为应用程序的开发人员提供更方便的接口。 2.3 设置启动(Lilo和BIOS) 当PC系统启动时,由BIOS执行了一些低水平的CPU初始化和其它硬件的配置,然后辨认哪个磁盘里有操作系统,把操作系统复制到RAM并且转向它。在PC上运行的Linux依靠PC的BIOS来提供这些配置和OS加戟功能。由于选择了X86系列作为平台,同样可以通过设置BIOS来设定由Doc启动。我们将内核安装在Doc上。同时修改目录/etc下的lilo.config文件,使Lilo记录内核代码在存储设备上的位置,然后将Lilo安装在Doc上。这样当系统启动时.BIOS指定Doc为启动设备,这时Lilo被执行。它指出Linux内核的位置,加载内核。 2.4 设备驱动程序的编写 由于采用通用PC平台,有许多驱动程序都不需要自己再编写了。系统中,唯一需要编写驱动程序的设备是上海数字中心的数据采集卡.该卡采用的是Bt848芯片。Bt848是一块很常用的芯片.许多驱动程序都非常相近,因此编写它的驱动程序有很好的例子可以参考,相应的,编写应用程序只需调用驱动程序提供的接口即可,如同操作文件一样。 3 Linux的实时性分析 以上简要介绍了实现Linux的嵌入化过程,在嵌入化Linux的同时,还考虑提高它的实时性。于是着手分析Linux的实时性能和存在的不足。 概括来讲,影响操作系统实时性能的主要有3个方面: (1)外部中断管理 我们知道,外部中断发生时,操作系统调用中断处理程序.进入核心态。为了保证系统执行的正确性,要求内核状态不重入,也即保证这部分关键代码执行结束之前不被打断。因此,这时进入关中模式,这是外部中断管理中影响Linux性能的一个关键的地方。在这段时间内,操作系统负责将中断发送到相应的设备驱动程序去处理,系统不能进行其它任何工作,为了减少这个过程损耗的时间,Linux内核利用底半处理过程(bottom-half-handler)帮助实现中断的快速处理。在Linux设备驱动程序中,往往将最关键最迅速的部分处理完成之后,将剩余部分任务放置到队列中。当中断响应完成后.再执行剩余部分的任务。在Linux中,主要设置了以下几个数据结构来标志未完成的任务。 enum{ TIMER_BH=0,CONSOLE_BH,TQUEUE_BH,DIGI_BH,SERIAL_BH,RISCOM8_BH,SPECIALIX_BH, ESP_BH,NET_BH,SCSI_BH,IMMEDIATE_BH,KEYBOARD_BH,CYCLADES_BH,CM206_BH, JS_BH,MACSERIAL_BHISICOM_BH }; 上面每一项标识未完成任务的队列类型,不同队列的任务轻重缓急不同。 extern unsigned long bh_active; extern unsigned long bh_mask; extern void(*bh_base[32])(void); bh_base代表的指针数组中可包含32个不同的底半处理过程。bh_mask和札bh_active的数据位分别代表对应的底半处理过程是否安装和激活。如果bh_mask的第N位为1.则说明bh_base数组的第N个元素包含某个底半处理过程的地址;如果bh_active的第N位为1.则说明必须由调度程序在适当的时候调用第N个底半处理过程。这些数据结构的设置一般是在外部设备初始化和中断处理函数运行时进行的。如:在serialc中进行serial设备的初始化,它调用语句init_bh(SERIAL_BH,do_serial_bh);来设置bh_base[]数组中相应于SERIAL_BH的那一项。又如:在serial设备的处理程序中通过语句queue_task(&info->tqueue,&tq_serial);将不是很紧急的任务放入tq_serial队列中,等中断处理函数结束,由bh_base中注册的底半处理程序处理队列中的任务。 中断管理的第二个关键部分即是系统是否允许中断嵌套的能力,也就是说,当响应一个中断时,是否允许其它更高优先级的中断打断,等更高优先级的中断处理完毕,是否还能恢复原来中断处理的现场。通过这项功能,系统设计者可以指示外部中断的优先级,从而确保高优先级的任务能及时处理。Linux允许中断嵌套,它是利用外部中断管理器来设置中断的优先级的。在Linux的中断处理程序的启动过程中,它一般调用语句mask_and_ack_8259A(irq);来设置8259中的int_mask寄存器.使优先级比此中断低的中断不能发生。在中断处理程序离开时,调用enable_8259A_irq(irq)来改回8259中int_mask寄存器原来的值。因此,intr类中断的优先级由硬件8259来决定. 由此可见,Linux的中断管理部分具有高效的特点,已经可以满足许多软实时任务的要求 |