0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

初學(xué)者如何學(xué)習(xí)嵌入式Linux底層系統(tǒng)

Q4MP_gh_c472c21 ? 來源:cc ? 2019-02-21 14:12 ? 次閱讀

很多初學(xué)者會問,嵌入式Linux怎么學(xué)?下面就來討論討論這個問題。

嵌入式Linux可以分為兩部分:底層系統(tǒng)、應(yīng)用開發(fā)。

對于應(yīng)用開發(fā) : C語言、數(shù)據(jù)結(jié)構(gòu)、JAVA什么的需學(xué)好。嵌入式應(yīng)用開發(fā)和PC上的應(yīng)用開發(fā)并沒有什么特別要注意的。也許你說在嵌入式上要做些優(yōu)化,是的,要優(yōu)化,但是未經(jīng)優(yōu)化的程序和PC上的程序開發(fā)沒什么差別。另外,當(dāng)你有能力去優(yōu)化時,你已經(jīng)不用來問這個問題了。具體到某個例子,比如說開發(fā)界面,在PC上我們用VC;在嵌入式Linux里也許我們用QT也用Android,這個時候你應(yīng)該去學(xué)學(xué)QT、Android的編程。但是基礎(chǔ)還是C或JAVA,在此基礎(chǔ)上去熟悉它們的接口。你學(xué)過VC的話,也是要花時間去了解那些類、控件的。

如果你想學(xué)習(xí)底層系統(tǒng),這是我的專長,倒是可以說一點(diǎn)。

在回答這個問題之前,我先回答:不少人問我,到底是學(xué)驅(qū)動還是學(xué)應(yīng)用? 我只能說憑興趣,并且驅(qū)動和應(yīng)用并不是截然分開的。

1. 我們說的驅(qū)動,其實(shí)并不局限于硬件的操作,還有操作系統(tǒng)的原理、進(jìn)程的休眠喚醒調(diào)度等概念。想寫出一個好的應(yīng)用,想比較好的解決應(yīng)用碰到的問題,這些知識你應(yīng)該懂

2. 做應(yīng)用門檻低,特別是現(xiàn)在的ANDROID,純JAVA。做應(yīng)用的發(fā)展路徑個人認(rèn)為就是業(yè)務(wù)純熟。比如在通信行業(yè)、IPTV行業(yè)、手機(jī)行業(yè),你了解行業(yè)的需求。所以,當(dāng)領(lǐng)導(dǎo)的人,多是做應(yīng)用的。

3. 做驅(qū)動,其實(shí)我不想稱為“做驅(qū)動”,而是想稱為“做底層系統(tǒng)”,做好了這是通殺各行業(yè)。我工作幾年,做過手機(jī)、IPTV、會議電視,但是這些產(chǎn)品對我毫無差別,因?yàn)槲抑蛔龅讓印K麄兊臉I(yè)務(wù)跟我沒關(guān)系。當(dāng)應(yīng)用出現(xiàn)問題,他們解決不了時,我就會從內(nèi)核角度給他們出主意,給他們提供工具。做底層的發(fā)展方向,個人認(rèn)為是技術(shù)專家。

4. 其實(shí),做底層還是做應(yīng)用,之間并沒有一個界線,有底層經(jīng)驗(yàn),再去做應(yīng)用,你會感覺很踏實(shí)。有了業(yè)務(wù)經(jīng)驗(yàn),你再了解一下底層,很快就可以組成一個團(tuán)隊(duì)。

回到怎么學(xué)的問題上。嵌入式Linux底層系統(tǒng)包含哪些東西?不要急,舉一個例子你就知道了。

1. 電腦一開機(jī),那些界面是誰顯示的?是BIOS,它做什么?一些自檢,然后從硬盤上讀入windows,并啟動它。類似的,這個BIOS對應(yīng)于嵌入式Linux里的bootloader。這個bootloader要去Flash上讀入Linux內(nèi)核,并啟動它。

2. 啟動windows的目的是什么?當(dāng)然是上網(wǎng)聊天什么的了。這些上網(wǎng)、聊天工具在哪?在C盤、D盤上。所以, windows要先識別出C盤、D盤。在Linux下我們稱為根文件系統(tǒng)。

3. windows能識別出C盤、D盤,那么肯定能讀寫硬盤才行。這涉及的東西稱為驅(qū)動程序。當(dāng)然不僅僅是硬盤,還有網(wǎng)卡、USB等等。嵌入式Linux能從Flash上讀出并執(zhí)行應(yīng)用程序,肯定也得有Flash的驅(qū)動程序啊,當(dāng)然也不僅僅是Flash。

先說到這里吧,嵌入式LINUX里含有bootloader, 內(nèi)核, 驅(qū)動程序、根文件系統(tǒng)這4大塊。

一、bootloader

它就是一個稍微復(fù)雜的裸板程序。但是要把這裸板程序看懂寫好一點(diǎn)都不容易。Windows下好用的工具弱化了我們的編程能力。

很多人一玩嵌入式就用ADS、KEIL。你能回答這幾個問題嗎?

1. 一上電,CPU從哪里取指令執(zhí)行?

答:一般從Flash上指令。

2. 但是Flash一般是只能讀不能直接寫的,如果我用到全局變量,這些全局變量在哪里?

答:全局變量應(yīng)該在內(nèi)存里

3. 那么誰把全局變量放到內(nèi)存里去?

答:長期用ADS、KEIL的朋友,你能回答嗎?這需要"重定位"。在ADS或KEIL里,重定位的代碼是制作這些工具的公司幫你寫好了。 你可曾去閱讀過?

4. 內(nèi)存那么大,我怎么知道把"原來存在Flash上的內(nèi)容"讀到內(nèi)存的"哪個地址去"?

答:這個地址用"鏈接腳本"決定,在ADS里有scatter文件,KEIL里也有類似的文件。但是,你去研究過嗎?

5. 你說重定位是把程序從Flash復(fù)制到內(nèi)存,那么這個程序可以讀Flash??? 答:是的,要能操作Flash。當(dāng)然不僅僅是這些,還有設(shè)置時鐘讓系統(tǒng)運(yùn)行得更快等等。 先自問自答到這里吧,bootloader這一個裸板程序,其實(shí)有3部分要點(diǎn):

1. 對硬件的操作

2. 對ARM體系處理器的了解

3. 程序的基本概念:重定位、棧、代碼段數(shù)據(jù)段BSS段什么的。

對硬件的操作,需要看原理圖、芯片手冊。這需要一定的硬件知識,不求你能設(shè)計(jì)硬件,但是至少能看懂; 不求能看懂模擬電路, 但是要能看懂數(shù)字電路。這方面的能力我是在學(xué)校里學(xué)到的,微機(jī)原理、數(shù)字電路這2本書(書名忘了)就足夠了。但是我懷疑你有無耐心把這2本書看完。我不知道現(xiàn)在有沒有更快捷的書。想速成的話,就先放掉這塊吧,不懂就問GOOGLE、發(fā)貼。

另外,芯片手冊是肯定要讀的,別去找中文的,就看英文的。開始是非常痛苦,以后就會發(fā)現(xiàn)那些語法、詞匯一旦熟悉后, 讀任何芯片手冊都很容易。

對ARM體系處理器的了解, 看杜春蕾的吧,里面講有匯編指令,有異常模式、MMU等。也就這3塊內(nèi)容需要你了解。

程序的基本概念,王道當(dāng)然是去看編譯原理了??上?,這類書絕對是天書級別的。勸你若非超級天才還是別去看了。就看我寫的<嵌入式Linux應(yīng)用開發(fā)完全手冊>和第1期視頻吧,別擔(dān)心,不用花錢。照著視頻把硬件相關(guān)的實(shí)驗(yàn)做了,這些概念就清楚了。我還沒有發(fā)現(xiàn)第2套講這些概念的書或視頻,允許我盲目吹噓一回。 對于bootloader,我學(xué)習(xí)時是先看了,然后自己寫程序把各個硬件的實(shí)驗(yàn)都做了一遍,比如GPIO、時鐘、 SDRAMUART、NAND。把它們都弄清楚了,組臺在一起就很容易看懂u-boot了 ??偨Y(jié)一下,看懂硬件原理圖、看芯片手冊,這需要你自己去找資料。剩下的,就按<嵌入式Linux應(yīng)用開發(fā)完全手冊>和第1期視頻的章 節(jié)目錄去學(xué)習(xí)吧。

二、內(nèi)核

想速成的人,先跨過內(nèi)核的學(xué)習(xí),直接學(xué)習(xí)怎么寫驅(qū)動。

想成為高手,內(nèi)核必須深刻了解。注意,我說的是了解,我沒奢望去寫出一個內(nèi)核。

要對里面的調(diào)度機(jī)制、內(nèi)存管理機(jī)制、文件管理機(jī)制等等有所了解。

推薦兩本書:

1. 通讀,請看薄的那本(浮燥的社會講求速度)

2. 選讀, 想了解哪一塊就讀哪一節(jié)

三、驅(qū)動

驅(qū)動包含兩部分:硬件本身的操作、驅(qū)動程序的框架。

又是硬件,還是要看得懂原理圖、讀得懂芯片手冊,多練吧。 說到驅(qū)動框架,有一些書介紹一下。LDD3,即,老外寫的那本,里面介紹了不少概念,值得一讀。但是,它的作用 也就限于介紹概念了。我基本上是入門之前用它來熟悉一下概念,入門后就扔掉了。

驅(qū)動方面比較全的介紹,應(yīng)該是宋寶華的了,老實(shí)說我只看過目錄,有不少人說好,這里推薦一下。

要想深入了解某一塊,絕對是超5星級推薦。你別指望把它讀完,1800多頁,上下兩冊呢。我是某一塊不清楚 時,就去翻一下它。任何一部分,這書都可以講上2、3百頁,非常詳細(xì)。并且是以某個目標(biāo)來帶你分析內(nèi)核源碼。它以linux 2.4為例,但是原理相通,同樣適用于其它版本的linux。 還有沒有其他介紹?當(dāng)然有了,韋東山Linux視頻第2期。<嵌入式Linux應(yīng)用開發(fā)完全手冊>里對驅(qū)動講得不多,不夠深入。

把你手上的開發(fā)板所涉及的硬件,都去嘗試寫一個驅(qū)動吧。有問題就先"痛苦地思考",思考的過程中你會把很多不相關(guān)的知識串聯(lián)起來,最終貫通。

四、根文件系統(tǒng)

大家有沒有想過這2個問題:

1. 對于Linux做出來的產(chǎn)品,有些用作監(jiān)控、有些做手機(jī)、有些做平板。那么內(nèi)核啟動后,掛載根文件系統(tǒng)后,應(yīng)該啟動哪一個應(yīng)用程序呢?

答:內(nèi)核不知道也不管應(yīng)該啟動哪一個用戶程序。它只啟動init這一個應(yīng)用程序,它對應(yīng)/sbin/init。

顯然,這個應(yīng)用程序就要讀取配置文件,根據(jù)配置文件去啟動用戶程序(監(jiān)控、手冊界面、平板界面等等,這個問題提示我們,文件系統(tǒng)的內(nèi)容是有一些約定的,比如要有/sbin/init,要有配置文件 。

2. 你寫的hello,world程序,有沒有想過里面用到的printf是誰實(shí)現(xiàn)的?

答:這個函數(shù)不是你實(shí)現(xiàn)的,是庫函數(shù)實(shí)現(xiàn)的。它運(yùn)行時,得找到庫。

這個問題提示我們,文件系統(tǒng)里還要有庫。 簡單的自問自答到這里,要想深入了解,可以看一下busybox的init.c,就可以知道init進(jìn)程做的事情了。 當(dāng)然,也可以看<嵌入式Linux應(yīng)用開發(fā)完全手冊>里構(gòu)建根文件系統(tǒng)那章。

我的學(xué)習(xí)經(jīng)歷

1. 我在學(xué)校時讀的是物理電子專業(yè),其實(shí)課程里沒有教怎么設(shè)計(jì)電路,只是教了些電子電路方面的知識。PCB的設(shè)計(jì)是在實(shí)驗(yàn)室里自學(xué)的,只設(shè)計(jì)過2層板,現(xiàn)在忘記得差不多了。但是保留了看原理圖、看芯片手冊的能力。

2. 選修了軟件學(xué)位,對軟件設(shè)計(jì)挺感興趣,但是也只是學(xué)了C語言、數(shù)據(jù)庫而已。憑著興趣做了不少競賽題。沒能力去參加競賽,但是把C語言練得很扎實(shí)。

3. 在實(shí)驗(yàn)室、在第1家公司,就是設(shè)計(jì)些簡單的PCI卡,寫一下windows的驅(qū)動程序

4. 在第2家公司,用51單片機(jī)做車載電話,開始走上純軟件的道路。

5. 開始感到單片機(jī)的不足,辭職半年閉門學(xué)Linux,從red hat怎么操作開始。步驟就是先看,再自己寫裸板程序操作硬件,接著到分析u-boot。同時看,對LINUX框架有所了解。

在寫裸板時,建議各位加強(qiáng)對中斷的理解,內(nèi)核就是用中斷來完成各種功能的。

6. 分析完u-boot,就開始進(jìn)行簡單的驅(qū)動編程了,這時候,能力還很弱。

7. 開始去中興上班,工作2年,編寫各類驅(qū)動、解決各類問題(驅(qū)動問題、幫助定位應(yīng)用問題),能力得到煅煉。

總結(jié)

1. 硬件方面的書: 微機(jī)原理、數(shù)字電路,高校里的教材。

2. Linux方面的書:

<嵌入式Linux應(yīng)用開發(fā)完全手冊> ,老外寫的那本

3. 視頻:

韋東山Linux視頻第1期(基于S3C2440錄制): ARM實(shí)驗(yàn),u-boot,文件系統(tǒng),初級驅(qū)動 韋東山Linux視頻第1期(基于S3C6410錄制): 裸板程序 韋東山Linux視頻第2期: 高級驅(qū)動

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 嵌入式
    +關(guān)注

    關(guān)注

    5053

    文章

    18920

    瀏覽量

    300889
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11178

    瀏覽量

    208500

原文標(biāo)題:嵌入式Linux底層系統(tǒng)怎么學(xué)?

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    嵌入式學(xué)習(xí)建議

    的平衡,要在理解軟件工程基本原理基礎(chǔ)上理解硬件構(gòu)件與軟件構(gòu)件等基本概念。 以上建議,僅供初學(xué)者參考。當(dāng)然,以上只是基礎(chǔ)階段的學(xué)習(xí)建議。要成為良好的嵌入式系統(tǒng)設(shè)計(jì)師,還需要在實(shí)際項(xiàng)目中
    發(fā)表于 10-22 11:41

    【免費(fèi)分享】嵌入式Linux開發(fā)板【入門+項(xiàng)目,應(yīng)用+底層】資料包一網(wǎng)打盡,附教程/視頻/源碼...

    ?想要深入學(xué)習(xí)嵌入式Linux開發(fā)嗎?現(xiàn)在機(jī)會來了!我們?yōu)?b class='flag-5'>初學(xué)者們準(zhǔn)備了一份全面的資料包,包括原理圖、教程、課件、視頻、項(xiàng)目、源碼等,所有資料全部免費(fèi)領(lǐng)取,課程視頻可試看(購買后看完整
    的頭像 發(fā)表于 09-05 10:45 ?218次閱讀
    【免費(fèi)分享】<b class='flag-5'>嵌入式</b><b class='flag-5'>Linux</b>開發(fā)板【入門+項(xiàng)目,應(yīng)用+<b class='flag-5'>底層</b>】資料包一網(wǎng)打盡,附教程/視頻/源碼...

    嵌入式linux開發(fā)的基本步驟有哪些?

    嵌入式Linux開發(fā)是一個復(fù)雜的過程,涉及到硬件選擇、操作系統(tǒng)移植、驅(qū)動開發(fā)、應(yīng)用程序開發(fā)等多個方面。以下是嵌入式Linux開發(fā)的基本步驟,
    的頭像 發(fā)表于 09-02 09:11 ?280次閱讀

    嵌入式linux開發(fā)板芯片的工作原理

    了處理器、存儲器、輸入/輸出接口等硬件資源的嵌入式系統(tǒng)開發(fā)平臺。它通常采用Linux操作系統(tǒng)作為底層軟件平臺,提供了豐富的開發(fā)工具和庫函數(shù),
    的頭像 發(fā)表于 09-02 09:07 ?251次閱讀

    嵌入式機(jī)電一體化系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn)》讀后感

    理解不僅拓寬了我的知識視野,更為后續(xù)章節(jié)的學(xué)習(xí)打下了堅(jiān)實(shí)的基礎(chǔ)。 書中第二章重點(diǎn)討論了基于Linux嵌入式系統(tǒng)設(shè)計(jì),這一章節(jié)對我而言尤為關(guān)鍵。Li
    發(fā)表于 08-21 08:45

    專家力薦|《嵌入式系統(tǒng)原理與開發(fā)——基于RISC-V和Linux系統(tǒng)》新書發(fā)售

    當(dāng)前,嵌入式系統(tǒng)已成為智能設(shè)備的核心之一,RISC-V+Linux的開源力量為嵌入式系統(tǒng)注入強(qiáng)大的創(chuàng)新動力。作為中國RISC-V軟硬件生態(tài)領(lǐng)
    的頭像 發(fā)表于 07-24 08:20 ?399次閱讀
    專家力薦|《<b class='flag-5'>嵌入式</b><b class='flag-5'>系統(tǒng)</b>原理與開發(fā)——基于RISC-V和<b class='flag-5'>Linux</b><b class='flag-5'>系統(tǒng)</b>》新書發(fā)售

    從菜鳥到大牛!嵌入式完整學(xué)習(xí)路線:STM32單片機(jī)-RTOS-Linux

    ?嵌入式系統(tǒng)是許多現(xiàn)代電子設(shè)備和智能系統(tǒng)的核心,掌握嵌入式系統(tǒng),意味著能夠設(shè)計(jì)和開發(fā)更加智能化的產(chǎn)品。本文為所有想進(jìn)入
    的頭像 發(fā)表于 07-23 16:11 ?2987次閱讀
    從菜鳥到大牛!<b class='flag-5'>嵌入式</b>完整<b class='flag-5'>學(xué)習(xí)</b>路線:STM32單片機(jī)-RTOS-<b class='flag-5'>Linux</b>

    手把手教你!STM32單片機(jī)入門指南:從初級到中級工程師的學(xué)習(xí)路線

    首選的跳板。為了幫助初學(xué)者系統(tǒng)學(xué)習(xí)STM32,我們提供了一條從初級到中級的學(xué)習(xí)路線,涵蓋了從基礎(chǔ)知識到進(jìn)階應(yīng)用的全方位技能提升,最終助力初學(xué)者
    的頭像 發(fā)表于 07-22 14:38 ?2664次閱讀
    手把手教你!STM32單片機(jī)入門指南:從初級到中級工程師的<b class='flag-5'>學(xué)習(xí)</b>路線

    適合初學(xué)者嵌入式項(xiàng)目有哪些?

    適合初學(xué)者嵌入式項(xiàng)目有哪些? 嵌入式學(xué)習(xí)是一個實(shí)踐性很強(qiáng)的領(lǐng)域,通過實(shí)際項(xiàng)目可以幫助你鞏固理論知識并提升技能。以下是幾個適合初學(xué)者練手的
    發(fā)表于 07-11 10:23

    國內(nèi)哪家的FPGA適合初學(xué)者

    如題,想著手學(xué)習(xí)FPGA的話,國內(nèi)哪家的比較好,更適合初學(xué)者學(xué)習(xí)?這方面的經(jīng)驗(yàn),是一點(diǎn)都沒。
    發(fā)表于 04-14 19:17

    盤點(diǎn)那些硬件+項(xiàng)目學(xué)習(xí)套件:STM32MP157 Linux開發(fā)板及入門常見問題解答

    Linux+Qt綜合項(xiàng)目,我們提供了非常完善的精講視頻課程,覆蓋了入門+項(xiàng)目進(jìn)階的一整套學(xué)習(xí)內(nèi)容,非常適合初學(xué)者。我們也是比較建議初學(xué)者,從Lin
    發(fā)表于 02-01 14:25

    嵌入式物聯(lián)網(wǎng)開源項(xiàng)目分享

    很多初學(xué)者或者互聯(lián)網(wǎng)轉(zhuǎn)行從業(yè)者,在學(xué)習(xí)嵌入式技術(shù)的基本理論概念之后,可能會感覺到迷茫,感覺自己雖然學(xué)了不少,但卻不知道怎么用到項(xiàng)目上。
    的頭像 發(fā)表于 01-24 10:36 ?1329次閱讀
    <b class='flag-5'>嵌入式</b>物聯(lián)網(wǎng)開源項(xiàng)目分享

    分享給嵌入式初學(xué)者

    電子發(fā)燒友網(wǎng)站提供《分享給嵌入式初學(xué)者.doc》資料免費(fèi)下載
    發(fā)表于 11-08 10:46 ?0次下載
    分享給<b class='flag-5'>嵌入式</b><b class='flag-5'>初學(xué)者</b>

    嵌入式軟件不需要架構(gòu)嗎?為什么沒有嵌入式軟件架構(gòu)師?

    我的看法:目前國內(nèi)的嵌入式開發(fā)主要分為嵌入式底層開發(fā)和嵌入式應(yīng)用開發(fā),嵌入式底層開發(fā)一般叫做驅(qū)
    發(fā)表于 10-27 14:45 ?528次閱讀
    <b class='flag-5'>嵌入式</b>軟件不需要架構(gòu)嗎?為什么沒有<b class='flag-5'>嵌入式</b>軟件架構(gòu)師?

    基于嵌入式Linux的無線多媒體傳輸系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn)

    電子發(fā)燒友網(wǎng)站提供《基于嵌入式Linux的無線多媒體傳輸系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn).pdf》資料免費(fèi)下載
    發(fā)表于 10-26 14:37 ?0次下載
    基于<b class='flag-5'>嵌入式</b><b class='flag-5'>Linux</b>的無線多媒體傳輸<b class='flag-5'>系統(tǒng)</b>設(shè)計(jì)與實(shí)現(xiàn)