查看: 6098|回复: 0

如何选择嵌入式操作系统

[复制链接]

该用户从未签到

发表于 2007-8-2 18:01:56 | 显示全部楼层 |阅读模式
分享到:
        嵌入式操作系统是ARM CPU的软件基础从8位/16位单片机发展到以ARM CPU核为代表的32位嵌入式处理器嵌入式操作系统将替代传统的由手工编制的监控程序或调度程序成为重要的基础组件。更重要的是嵌入式操作系统对应用程序可以起到屏蔽的作用使应用程序员面向操作系统级开发应用软件并易于在不同的ARM核的嵌入式处理器上移植。 嵌入式操作系统都具有一定的实时性易于裁剪和伸缩可以适合于从ARM7到Xscale各种ARM CPU和各种档次的应用嵌入式操作系统可以使用广泛流行的ARM开发工具如ARM公司的SDT/ADS和RealView等也可以使用开发软件如GCC/GDB、KDE或Eclipe开发环境市场上还有专用的开发工具如Tornado、μC/View、μC/KA、CODE/Lab、Metroworks等。
        本文就目前国内在ARM CPU上广泛采用的三种嵌入式操作系统(μC/OS-II、μCLinux和嵌入式Linux)作分析。 μC/OS-II嵌入式实时内核 全世界数百种设备已经在使用μC/OS-II包括手机、路由器、不间断电源、飞行器、医疗设备和工业控制设备。μC/OS-II已经有ARM7TDMI、ARM9和Strong ARM等各种ARM CPU的移植支持包含Atmel、Hynix、Intel、Motorola、Philips、Samsung、Sharp等公司的ARM核的CPU。μC/OS-II的移植也相当容易与CPU相关的代码包装在三个文件中它们是os_cpu.h、os_cpu_a.asm和os_cpu_c.c。 μC/OS-II有60多个系统调用覆盖任务、定时器、信号量、事件标志、邮箱、队列和内存管理已经包含了传统嵌入式操作系统内核(如PSOSVRTX)的功能还支持互斥型信号量这是90年代的嵌入式操作系统内核如VxWorks和VRTXsa才有的技术。 μC/OS-II因为是可抢占的实时内核所以μC/OS-II与商业嵌入式实时内核在性能上没有什么差异μC/OS-II没有用户态和内核态任务(线程)或中断和任务切换的响应可以很快主要是和ARM CPU相关的。最新的2.7x版本还增加了算法以避免在移植中修改堆栈指针这样可以保证μC/OS-II在不同的CPU上运行更稳定移植更便。               
        μC/OS-II目前除了内核外还有商业化文件系统μC/FS图形系统μC/GUI以及任务调试工具μC/KA和μC/View但是μC/OS-II自己目前还没有TCP/IP协议系统。 总的来说μC/OS-II是一个非常容易学习结构简单功能完备和实时性很强的嵌入式操作系统内核适合于各种嵌入式应用以及大专院校教学和科研。最后需要说明μC/OS-II不是免费软件任何人学习使用μC/OS-II需要购买《嵌入式实时操作系统μC/OS-II》一书使用μC/OS-II的产品需要购买产品生产授权购买了此授权的还可以得到开发期间的技术支持和升级服务。 μCLinux操作系统 μCLinux是Linux小型化后适合于没有MMU(内存管理单元)的微处理器芯片而裁剪成的操作系统如果ARM CPU系列中的ARM7 TDMI、ARM940T等产品希望使用Linux操作系统只能用μCLinux当然μCLinux也支持Motorola Dragonball、Coldfire等其它中低端嵌入式处理器。 μCLinux保持了传统Linux操作系统的主要特性包括稳定、强大的网络和文件系统的支持μCLinux裁剪了大量的Linux内核以缩小尺寸适合象512k/b RAM、1M/b Flash这样小容量、低成本的嵌入式系统。μCLinux系统小型化的另一简化是采用了μCLib库替代Linux的Glib库使用μCLib可以大大减少应用程序的代码尺寸对于中小型嵌入式应用μCLib功能可以满足需要所以目前即使是某些采用Linux 2.4。 嵌入式Linux操作系统 这里要讨论的是可以嵌入在ARM CPU上的具有MMU功能的Linux操作系统也可以称是嵌入式Linux操作系统。与微软公司的软件不一样Linux不是由一家公司所拥有、维护开发的Linux在市场有多种发行版本所有发行版本都包含一样的Linux内核、基本工具和应用不同的发行版本主要是在附加的工具链、应用、配置以及各种内核补丁上有所不同。嵌入式Linux主要是在实时性增强、内核精简和裁减、支持多种CPU结构(如ARM CPU)等方面做了改进和提高。
        使用嵌入式Linux系统有两种途径: 第一是用户自己装配(称为DIY内核)你可以在www.kernel.org找到全部Linux代码或直接到ARM CPU的源代码树下www.armlinux.org.uk找到所需要的Linux版本的移植或者某些半导体公司如三星、Motorola在自己的网站或在自己的ARM评估板含有一个最小Linux内核系统。如果这个最小内核没有包含GCC/GDB工具链可能还要到GNU的网站下载全部的源代码然后再编译生成所需要版本的ARM工具链和应用程序库这个过程是相当耗时和困难的。还需要指出这种DIY内核的配置添加应用和驱动程序也是不标准的和复杂的这是嵌入式系统的特殊性所在。 第二是选择一个商业化的嵌入式Linux操作系统平台。商业化的嵌入式Linux版本是针对嵌入式处理器如ARM所优化设计的支持各种半导体厂家的评估板和主要的设备驱动商业化的嵌入式Linux包含了文件系统、应用、实时性扩展和技术支持培训服务现今国外著名的商业化嵌入式Linux产品有:MontaVista Linux、Bluecat Linux、Timesys Linux、Metrowork Linux、Vlinux和Redhat Linux等国内也有红旗、中软、新华嵌入式Linux。 MontaVista Linux是MontaVista软件公司于1999年推出的它是目前全球优秀的嵌入式Linux操作系统和工具供应商MontaVista在嵌入式Linux的实时性、交叉开发工具、高可用性、动态电源管理等Linux技术要点方面具有领先地位。MontaVista Linux最版本是3.1采用Linux 2.4.20针对8种CPU系列(包含ARM和Xscale)优化定制的商业化版本。 选择象MontaVista Linux这样商业化嵌入式Linux可以让用户把时间和资金放在应用软件和特定的硬件接口和设备驱动程序使用商业化嵌入式Linux可以得到一定时间(一般是1年)的技术支持升级和培训(这很重要因为Linux是每天都在变化的)。
        商业化嵌入式Linux目前除国内的产品外价格还是很昂贵的根据配置和服务时间大约从几千到几万美元多数国内用户从资金和心理上还很难承受商业化嵌入式Linux开发工具相对于Microsoft和象Tornado/VxWork的开发工具在易于使用和丰富性方面还待于提高和改进。 同样作为Linux操作系统笔者推荐使用带有MMU的嵌入式Linux而不是mCLinux因为绝大多数新的ARM CPU都是AMR9核它们都带有MMU了无论是开放源码的Linux社区还是商业化的嵌入式Linux公司的支持和维护都比mCLinux要好要快和丰富得多。 结语 前面我们对三种在ARM CPU上较为流行的嵌入式操作系统作了详细的分析在进入一个总结之前笔者还想提到几个在国际上很有名气的嵌入式操作系统它们是WindRiver公司的VxWorks、ATI的Nucleus、iTron和WinCE但它们在ARM CPU的应用不多见介绍从略。
        最后归纳一下选择一个合适的ARM CPU的嵌入式操作系统的几个重要因素: 第一是应用。如果你想开发的嵌入式设备是一个和网络应用密切相关或者就是一个网络设备那么你应该选择用嵌入式Linux或者mCLinux而不是mC/OS-II。 第二是实时性。没有一个绝对的数字可以告诉你什么是硬实时什么是软实时它们之间的界限也是十分模糊的这与你选择什么样的ARM CPU它的主频、内存等参数有一定的关系。如果你使用加入实时补丁等技术的嵌入式Linux如MontaVista Linux(2.4.17版本)最坏的情况只有436微秒而99.9%的情况是195微秒。考虑到最新的Linux在实时性方面的改进。它可以适合于90~95%的各种嵌入式系统应用。当然你如果希望更快的实时响应如高速的A/D转换需要几个微秒以内的中断延时可能采用mC/OS-II是合适的。当然你采用象Vxworks这样传统的嵌入式操作系统也可以满足这样的强实时性要求。 第三是开发工具。显然目前mC/OS-II、mCLinux和嵌入式Linux的开发工具与商业嵌入式操作系统工具还有一些差距目前在ARM CPU上广泛流行和使用的是ARM公司SDT/ADS工具链产品无论在功能、稳定性和众多的第三方厂商支持方面都很好唯一不足的是缺少对嵌入式Linux操作系统的支持SDT/ADS的升级产品RealView计划支持GCC和嵌入式Linux但目前还没有看到mC/OS-II可以使用ARM SDT/ADS但没有操作系统调试功能。 第四是所选择的ARM CPU和参考板象ARM7TDMI和ARM940T(如S3C2500/2510)核是不能使用嵌入式Linux的如果想用Linux只能用mCLinux如果想用VxWorks需要了解一下提供评估板的公司是否有BSP(板支持包)VxWorks自己只有少数ARM公司评估板的支持。 最后是价格和技术服务。在考虑购买商业嵌入式操作系统时会遇到是买还是自己做的问题这是很正常的尤其是在采用开放源代码技术时这个问题就更加突出。有一点需要注意的是有些产品如VxWorks是既按用户数收取开发费也按用户产品售出的实际数量收取每个VxWorks软件运行的版税。mC/OS-II只是收取每种产品一次性版税(不限数量)。Linux无论是mCLinux还是嵌入式Linux(即使是商业版本象MontaVista Linux)是不收版税的商用嵌入式Linux是以服务费或订阅方式收取开发时的费用。很明显国外产品价格是贵一些但不能不承认他们在嵌入式操作系统的技术已经远远走在前方。
回复

使用道具 举报

您需要登录后才可以回帖 注册/登录

本版积分规则

关闭

站长推荐上一条 /4 下一条



手机版|小黑屋|与非网

GMT+8, 2024-11-22 08:45 , Processed in 0.114379 second(s), 15 queries , MemCache On.

ICP经营许可证 苏B2-20140176  苏ICP备14012660号-2   苏州灵动帧格网络科技有限公司 版权所有.

苏公网安备 32059002001037号

Powered by Discuz! X3.4

Copyright © 2001-2024, Tencent Cloud.