選擇ARM CPU的嵌入式操作系統(tǒng)的技巧
從8位/16位單片機發(fā)展到以ARM CPU核為代表的32位嵌入式處理器,嵌入式操作系統(tǒng)將替代傳統(tǒng)的由手工編制的監(jiān)控程序或調(diào)度程序,成為重要的基礎組件。更重要的是嵌入式操作系統(tǒng)對應用程序可以起到屏蔽的作用,使應用程序員面向操作系統(tǒng)級開發(fā)應用軟件,并易于在不同的ARM核的嵌入式處理器上移植。 嵌入式操作系統(tǒng)都具有一定的實時性,易于裁剪和伸縮,可以適合于從ARM7到Xscale各種ARM CPU和各種檔次的應用,嵌入式操作系統(tǒng)可以使用廣泛流行的ARM開發(fā)工具,如ARM公司的SDT/ADS和RealView等,也可以使用開發(fā)軟件,如GCC/GDB、KDE或Eclipe開發(fā)環(huán)境,市場上還有專用的開發(fā)工具,如Tornado、mC/View、mC/KA、CODE/Lab、Metroworks等。
本文就目前國內(nèi)在ARM CPU上廣泛采用的三種嵌入式操作系統(tǒng)(uCOS-II、uCLinux和嵌入式Linux)作分析。
uCOS-II嵌入式實時內(nèi)核
全世界數(shù)百種設備已經(jīng)在使用uCOS-II,包括手機、路由器、不間斷電源、飛行器、醫(yī)療設備和工業(yè)控制設備。uCOS-II已經(jīng)有ARM7TDMI、ARM9和Strong ARM等各種ARM CPU的移植,支持包含Atmel、Hynix、Intel、Motorola、Philips、Samsung、Sharp等公司的ARM核的CPU。uCOS-II的移植也相當容易,與CPU相關的代碼包裝在三個文件中,它們是os_cpu.h、os_cpu_a.asm和os_cpu_c.c。
uCOS-II有60多個系統(tǒng)調(diào)用,覆蓋任務、定時器、信號量、事件標志、郵箱、隊列和內(nèi)存管理,已經(jīng)包含了傳統(tǒng)嵌入式操作系統(tǒng)內(nèi)核(如PSOS,VRTX)的功能,還支持互斥型信號量,這是90年代的嵌入式操作系統(tǒng)內(nèi)核,如VxWorks和VRTXsa才有的技術(shù)。 字串5
uCOS-II因為是可搶占的實時內(nèi)核,所以uCOS-II與商業(yè)嵌入式實時內(nèi)核在性能上沒有什么差異,uCOS-II沒有用戶態(tài)和內(nèi)核態(tài),任務(線程)或中斷和任務切換的響應可以很快,主要是和ARM CPU相關的。最新的2.7x版本還增加了算法以避免在移植中修改堆棧指針,這樣可以保證uCOS-II在不同的CPU上運行更穩(wěn)定,移植更方便。uCOS-II目前除了內(nèi)核外還有商業(yè)化文件系統(tǒng)mC/FS,圖形系統(tǒng)uC/GUI以及任務調(diào)試工具uC/KA和uC/View,但是uC/OS-II自己目前還沒有TCP/IP協(xié)議系統(tǒng)。
總的來說,uCOS-II是一個非常容易學習,結(jié)構(gòu)簡單,功能完備和實時性很強的嵌入式操作系統(tǒng)內(nèi)核,適合于各種嵌入式應用以及大專院校教學和科研。最后需要說明,uCOS-II不是免費軟件,任何人學習使用uCOS-II需要購買《嵌入式實時操作系統(tǒng)uCOS-II》一書,使用uCOS-II的產(chǎn)品需要購買產(chǎn)品生產(chǎn)授權(quán),購買了此授權(quán)的還可以得到開發(fā)期間的技術(shù)支持和升級服務。
uCLinux操作系統(tǒng) ARM
uCLinux是Linux小型化后,適合于沒有MMU(內(nèi)存管理單元)的微處理器芯片而裁剪成的操作系統(tǒng),如果ARM CPU系列中的ARM7 TDMI、ARM940T等產(chǎn)品希望使用Linux操作系統(tǒng),只能用uCLinux,當然,uCLinux也支持Motorola Dragonball、Coldfire等其它中低端嵌入式處理器。
uCLinux保持了傳統(tǒng)Linux操作系統(tǒng)的主要特性,包括穩(wěn)定、強大的網(wǎng)絡和文件系統(tǒng)的支持,uCLinux裁剪了大量的Linux內(nèi)核以縮小尺寸,適合象512k/b RAM、1M/b Flash這樣小容量、低成本的嵌入式系統(tǒng)。uCLinux系統(tǒng)小型化的另一簡化是采用了uCLib庫替代Linux的Glib庫,使用uCLib可以大大減少應用程序的代碼尺寸,對于中小型嵌入式應用,uCLib功能可以滿足需要,所以目前即使是某些采用Linux 2.4內(nèi)核的嵌入式Linux系統(tǒng)也采用uCLib庫的做法。uCLinux中,由于沒有內(nèi)存保護機制,應用代碼一般采用靜態(tài)連接的方式,而且在uCLinux中采用Flat文件執(zhí)行格式(Linux是Coff或Elf格式), uCLinux和應用代碼都可以支持固化,存儲在Flash存儲介質(zhì)中,不需象Linux需要經(jīng)過一次Flash到RAM的拷貝。所有這些,使得uCLinux更象傳統(tǒng)意義上的嵌入式操作系統(tǒng)。
uCLinux是由Linux 2.0.38內(nèi)核開始移植的,目前已經(jīng)有2.4 Linux支持的一些移植的版本,如S3C2500、44B0等ARM芯片,可以在uCLinux的官方網(wǎng)站www.uclinux.org上找到這些版本,uCLinux近期主要是在發(fā)展各種2.4.x版本的移植,以期跟上Linux社會主流的發(fā)展趨勢(因為今后Linux 2.6將開始成為主流的內(nèi)核)。 字串8
uCLinux主要是針對沒有MMU的嵌入式處理器開發(fā)設計,那么它也失去了有MMU所帶來的Linux操作系統(tǒng)的特色,比如,上面已經(jīng)提到的靜態(tài)加載(Linux支持動態(tài)應用的加載),uCLinux對內(nèi)存操作是直接的物理內(nèi)存,這樣,任何程序的異常都可能導致內(nèi)核崩潰,uCLinux支持多線程,但需要父子線程協(xié)調(diào)同步,uCLinux的文件系統(tǒng)相對比較陳舊,支持的CPU和參考設計還比較少,社區(qū)的發(fā)展和維護也相對緩慢。目前uCLinux官方網(wǎng)站還很少看見象IBM、Intel這樣的大型公司身影,只有2~3家小型的硬件或方案提供商,這對于商業(yè)化的產(chǎn)品開發(fā)中采用是有一定的風險。
嵌入式Linux操作系統(tǒng)
這里要討論的是可以嵌入在ARM CPU上的,具有MMU功能的Linux操作系統(tǒng),也可以稱是嵌入式Linux操作系統(tǒng)。與微軟公司的軟件不一樣,Linux不是由一家公司所擁有、維護開發(fā)的, Linux在市場有多種發(fā)行版本,所有發(fā)行版本都包含一樣的Linux內(nèi)核、基本工具和應用,不同的發(fā)行版本主要是在附加的工具鏈、應用、配置以及各種內(nèi)核補丁上有所不同。嵌入式Linux主要是在實時性增強、內(nèi)核精簡和裁減、支持多種CPU結(jié)構(gòu)(如ARM CPU)等方面做了改進和提高。
http://www.armforum.cn
使用嵌入式Linux系統(tǒng)有兩種途徑: http://www.armforum.cn
第一是用戶自己裝配(稱為DIY內(nèi)核),你可以在www.kernel.org找到全部Linux代碼,或直接到ARM CPU的源代碼樹下www.armlinux.org.uk找到所需要的Linux版本的移植,或者某些半導體公司,如三星、Motorola在自己的網(wǎng)站或在自己的ARM評估板含有一個最小Linux內(nèi)核系統(tǒng)。如果這個最小內(nèi)核沒有包含GCC/GDB工具鏈,可能還要到GNU的網(wǎng)站下載全部的源代碼,然后再編譯生成所需要版本的ARM工具鏈和應用程序庫,這個過程是相當耗時和困難的。還需要指出,這種DIY內(nèi)核的配置,添加應用和驅(qū)動程序也是不標準的和復雜的,這是嵌入式系統(tǒng)的特殊性所在。
第二是選擇一個商業(yè)化的嵌入式Linux操作系統(tǒng)平臺。商業(yè)化的嵌入式Linux版本是針對嵌入式處理器,如ARM所優(yōu)化設計的,支持各種半導體廠家的評估板和主要的設備驅(qū)動,商業(yè)化的嵌入式Linux包含了文件系統(tǒng)、應用、實時性擴展和技術(shù)支持培訓服務,現(xiàn)今國外著名的商業(yè)化嵌入式Linux產(chǎn)品有:MontaVista Linux、Bluecat Linux、Timesys Linux、 Metrowork Linux、Vlinux和Redhat Linux等,國內(nèi)也有紅旗、中軟、新華嵌入式Linux。
MontaVista Linux是MontaVista軟件公司于1999年推出的,它是目前全球優(yōu)秀的嵌入式Linux操作系統(tǒng)和工具供應商,MontaVista在嵌入式Linux的實時==叉開發(fā)工具、高可用性、動態(tài)電源管理等Linux技術(shù)要點方面具有領先地位。MontaVista Linux最版本是3.1,采用Linux 2.4.20,針對8種CPU系列(包含ARM和Xscale)優(yōu)化定制的商業(yè)化版本。
選擇象MontaVista Linux這樣商業(yè)化嵌入式Linux,可以讓用戶把時間和資金放在應用軟件和特定的硬件接口和設備驅(qū)動程序,使用商業(yè)化嵌入式Linux可以得到一定時間(一般是1年)的技術(shù)支持,升級和培訓(這很重要,因為Linux是每天都在變化的)。
商業(yè)化嵌入式Linux目前除國內(nèi)的產(chǎn)品外,價格還是很昂貴的,根據(jù)配置和服務時間,大約從幾千到幾萬美元,多數(shù)國內(nèi)用戶從資金和心理上還很難承受,商業(yè)化嵌入式Linux開發(fā)工具相對于Microsoft和象Tornado/VxWork的開發(fā)工具,在易于使用和豐富性方面還待于提高和改進。 同樣作為Linux操作系統(tǒng),筆者推薦使用帶有MMU的嵌入式Linux,而不是mCLinux,因為絕大多數(shù)新的ARM CPU都是AMR9核,它們都帶有MMU了,無論是開放源碼的Linux社區(qū)還是商業(yè)化的嵌入式Linux公司的支持和維護都比mCLinux要好要快和豐富得多。
結(jié)語
前面我們對三種在ARM CPU上較為流行的嵌入式操作系統(tǒng)作了詳細的分析,在進入一個總結(jié)之前,筆者還想提到幾個在國際上很有名氣的嵌入式操作系統(tǒng),它們是WindRiver公司的VxWorks、ATI的Nucleus、iTron和WinCE,但它們在ARM CPU的應用不多見,介紹從略。 最后歸納一下選擇一個合適的ARM CPU的嵌入式操作系統(tǒng)的幾個重要因素:
第一是應用。如果你想開發(fā)的嵌入式設備是一個和網(wǎng)絡應用密切相關或者就是一個網(wǎng)絡設備,那么你應該選擇用嵌入式Linux或者uCLinux,而不是uC/OS-II。
第二是處理器。它可以適合于90~95%的各種嵌入式系統(tǒng)應用。當然,你如果希望更快的實時響應,如高速的A/D轉(zhuǎn)換需要幾個微秒以內(nèi)的中斷延時,可能采用uC/OS-II是合適的。當然,你采用象Vxworks這樣傳統(tǒng)的嵌入式操作系統(tǒng)也可以滿足這樣的強實時性要求。 ARM
第三是開發(fā)工具。顯然,目前uC/OS-II、uCLinux和嵌入式Linux的開發(fā)工具與商業(yè)嵌入式操作系統(tǒng)工具還有一些差距,目前在ARM CPU上廣泛流行和使用的是ARM公司SDT/ADS工具鏈,產(chǎn)品無論在功能、穩(wěn)定性和眾多的第三方廠商支持方面都很好,唯一不足的是缺少對嵌入式Linux操作系統(tǒng)的支持,SDT/ADS的升級產(chǎn)品RealView計劃支持GCC和嵌入式Linux,但目前還沒有看到,uC/OS-II可以使用ARM SDT/ADS,但沒有操作系統(tǒng)調(diào)試功能。
第四是所選擇的ARM CPU和參考板,象ARM7TDMI和ARM940T(如S3C2500/2510)核是不能使用嵌入式Linux的,如果想用Linux,只能用uCLinux,如果想用VxWorks,需要了解一下提供評估板的公司是否有BSP(板支持包),VxWorks自己只有少數(shù)ARM公司評估板的支持。
最后是價格和技術(shù)服務。在考慮購買商業(yè)嵌入式操作系統(tǒng)時,會遇到是買還是自己做的問題,這是很正常的,尤其是在采用開放源代碼技術(shù)時,這個問題就更加突出。有一點需要注意的是,有些產(chǎn)品如VxWorks是既按用戶數(shù)收取開發(fā)費,也按用戶產(chǎn)品售出的實際數(shù)量收取每個VxWorks軟件運行的版稅。 uC/OS-II只是收取每種產(chǎn)品一次性版稅(不限數(shù)量)。Linux無論是uCLinux還是嵌入式Linux(即使是商業(yè)版本象 MontaVista Linux)是不收版稅的,商用嵌入式Linux是以服務費或訂閱方式收取開發(fā)時的費用。很明顯,國外產(chǎn)品價格是貴一些,但不能不承認他們在嵌入式操作系統(tǒng)的技術(shù)已經(jīng)遠遠走在前方。
tcp/ip相關文章:tcp/ip是什么
評論