與一線Linux嵌入式開發(fā)工程師的對(duì)話開發(fā)者在線 Builder.com.cn 更新時(shí)間:2008-05-23作者:lupaworld 來源:本文關(guān)鍵詞: 嵌入式 GUI 嵌入式Linux 嵌入式開發(fā) 嵌入式系統(tǒng)陳工程師一直做Linux的嵌入式開發(fā),作為在開發(fā)一線的工程師,他對(duì)很多問題的看法可能更切合實(shí)際需求,于是,通過郵件,就嵌入式開發(fā)方面的問題,請(qǐng)他談了一下自己的看法: 問:關(guān)于嵌入式開發(fā),我們準(zhǔn)備給同學(xué)們講解一些入門知識(shí),從你一線開發(fā)經(jīng)驗(yàn)來說,給我們一些建議: 陳工回答: 對(duì)于嵌入式Linux入門,如果有一定基礎(chǔ),可以從驅(qū)動(dòng)開始;如果沒有基礎(chǔ),我個(gè)人建議還是從應(yīng)用程序開始。因?yàn)閺膽?yīng)用程序開始是最容易的,也是最直觀的。而驅(qū)動(dòng)程序運(yùn)行在內(nèi)核態(tài),驅(qū)動(dòng)本身的結(jié)構(gòu)就比較復(fù)雜,如果要徹底弄明白驅(qū)動(dòng)的運(yùn)行機(jī)制,必定牽涉內(nèi)核,對(duì)于高年級(jí)的學(xué)生恐怕問題會(huì)少一些,而 對(duì)于低年級(jí)的學(xué)生,問題估計(jì)較多。我曾經(jīng)遇到過一些初學(xué)者,就是一入門就栽了,失去了信心,當(dāng)然這只是少數(shù)。不過,如果在遇到問題之后,能夠得到即時(shí)、 正確的點(diǎn)化,那就是好事了。 既然您決定講驅(qū)動(dòng),那就從內(nèi)核模塊開始。在PC上就可以進(jìn)行的虛擬設(shè)備實(shí)驗(yàn),如基于內(nèi)存的內(nèi)核模塊??梢钥紤]從模塊的結(jié)構(gòu)、編譯、插入、卸載等方 面進(jìn)行闡述。 驅(qū)動(dòng)模塊無非分字符驅(qū)動(dòng)、塊設(shè)備驅(qū)動(dòng)和網(wǎng)絡(luò)驅(qū)動(dòng)三大類。但是一定要讓學(xué)生知道,任何一個(gè)系統(tǒng),特別是嵌入式系統(tǒng),并且在目前的嵌入式Linux產(chǎn)品 開發(fā)中,最簡(jiǎn)單、最重要、最多、最復(fù)雜的也是字符設(shè)備驅(qū)動(dòng),從IO驅(qū)動(dòng)到串口驅(qū)動(dòng)、到USB驅(qū)動(dòng)等等,廣義上都是字符驅(qū)動(dòng)。讓學(xué)生最好專注于字符設(shè)備驅(qū) 動(dòng),因?yàn)橐粋€(gè)嵌入式設(shè)備,網(wǎng)卡一般一塊,F(xiàn)LASH一般也是一塊(也包括幾塊組成的FLASH組),但是這兩方面,基本都有完善的驅(qū)動(dòng),如網(wǎng)卡驅(qū)動(dòng)有很 多,塊設(shè)備驅(qū)動(dòng),硬件層已經(jīng)有通用接口,不管是NOR FLASH還是NAND FLASH,文件系統(tǒng)層更是有了非常多、非常成熟的文件系統(tǒng),如 JFFS2、YAFFS、YAFFS2、EXT2、EXT3、ROMFS、CRAMFS等等,無需我們?cè)偃パ芯?,學(xué)會(huì)應(yīng)用即可。而除此之外的其它設(shè)備, 如AD、DA、CAN、RS485等等,都是需要根據(jù)應(yīng)用來進(jìn)行設(shè)計(jì)的,這才是一個(gè)產(chǎn)品區(qū)別于其它產(chǎn)品的重點(diǎn),更是市場(chǎng)價(jià)值增值點(diǎn)。 另外呢,也是前一點(diǎn)引申為而來的,學(xué)習(xí)Linux,準(zhǔn)備做產(chǎn)品的話,不要把Linux當(dāng)成了終極目標(biāo)(當(dāng)然,這是對(duì)應(yīng)用而言的),要有只是把 Linux當(dāng)成一個(gè)平臺(tái)的思想。更重要的還在各種產(chǎn)品所需求的專業(yè)技術(shù),如通信方面像CAN、RS485、GPRS等等,或者工業(yè)控制方面,IO控制、 實(shí)時(shí)特性等等。Linxu博大精深,研究起來永無止境,但是在產(chǎn)品中,只要到了一個(gè)產(chǎn)品夠用就可以了(當(dāng)然,多一些更好,要視人而定)。 問:嵌入式應(yīng)用程序的開發(fā),應(yīng)用場(chǎng)景較多的是圖形界面還是字符界面,如果是圖形界面,開發(fā)環(huán)境QT和Minigui哪一種更合適,哪種類型的應(yīng)用程序在嵌入式系統(tǒng)中應(yīng)用比較多? 陳工回答: 對(duì)于嵌入式Linux的應(yīng)用,大多數(shù)的應(yīng)用并不需要圖形界面,比如交換機(jī)、路由器、嵌入式網(wǎng)關(guān)以及服務(wù)器等等。圖形界面呢,主要應(yīng)用在多媒體、手機(jī)等手持設(shè)備和一些需要圖形界面的人機(jī)交互系統(tǒng)。 嵌入式Linux可選圖形界面很多,上網(wǎng)找找的話,可以發(fā)現(xiàn)遠(yuǎn)非我們常說的QT、MiniGUI等。包括Tiny-X,matchbox、OPIE、GPE等等。不同GUI有自己的特色,有自己的特殊應(yīng)用場(chǎng)合,對(duì)于產(chǎn)品開發(fā),根據(jù)需要選擇合適的GUI。對(duì)于學(xué)習(xí),自然是選擇容易得到、容易開發(fā)的GUI。QT是一個(gè)不錯(cuò)的選擇,由于QT有一個(gè)PC上的模擬器,可以在沒有實(shí)際液晶LCD的情況下,甚至在沒有任何硬件的情況下都可以在PC上進(jìn)行模擬開發(fā)。QT是收費(fèi)的,當(dāng)然,有免費(fèi)版可用。MiniGUI呢,純粹國產(chǎn)的,支持國貨,可以考慮選擇MiniGUI。這是一個(gè)輕量級(jí)的嵌入式GUI,可以跨平臺(tái),學(xué)習(xí)版也才100多塊。MiniGUI可以用于工業(yè)控制場(chǎng)合,QT在這方面的應(yīng)用目前還沒有遇到,主要用在手持設(shè)備。 我們?cè)陂_發(fā)中采用Tiny-X,這也是一個(gè)可以用于工業(yè)控制的GUI,基本兼容X-Window,體積小,占用資源少,速度快,穩(wěn)定。 對(duì)于Linux的應(yīng)用程序開發(fā),除了GUI程序之外,最基本的應(yīng)用程序有: ?。?)串口編程。無論是在Windows下還是Linux下,串口編程都是極為復(fù)雜的,但是非常鍛煉一個(gè)人的編程水平和能力。 ?。?)網(wǎng)絡(luò)編程以及WEB相關(guān)編程。網(wǎng)絡(luò)編程的tcp、udp、tcp/ip等。至于WEB編程,主要是在系統(tǒng)開啟一個(gè)WEB服務(wù)器,制作一些網(wǎng)頁,通過遠(yuǎn)程登錄能夠?qū)φ麄€(gè)系統(tǒng)進(jìn)行配置甚至升級(jí)等功能。比如我們的路由器配置網(wǎng)頁。這種應(yīng)用在以后會(huì)越來越廣泛。 (3)另外一個(gè)就是Shell編程了。Shell的作用我想,*NIX世界的人都很清楚。在很多應(yīng)用里面,通過一些非常富有技巧性的Shell腳本,實(shí)現(xiàn)了非常復(fù)雜的功能,包括遠(yuǎn)程系統(tǒng)升級(jí)等。 以上我提到的這3方面,非常易于實(shí)驗(yàn),在沒有硬件,只有PC的情況都可以做。 學(xué)生電腦安裝ubuntu,那以后配置嵌入式Linux開發(fā)環(huán)境可能遇到的問題會(huì)多一點(diǎn)。不過沒關(guān)系,能夠解決的。在我個(gè)人看來ubuntu適合于家用、辦公,但要用于開發(fā),配置難度稍微大一點(diǎn)。不過沒有辦法,現(xiàn)在電腦硬件太新,最適合的RedHat 9.0無法安裝。 |
|