前段時間有個剛開始學習 Arm Linux 的同學問我:對于還處于入門階段的新手,有什么建議。并讓我推薦一些好的書籍。嵌入式 Linux 是一個龐大的系統(tǒng),涉及到硬件和計算機科學,是橫跨電子和計算機的綜合學科。很多從電子相關專業(yè)切入的學生對計算機原理和操作系統(tǒng)不了解,而從計算機相關專業(yè)切入的同學對硬件、電路也很迷惑,所以入門確實是有一定的難度的。 然后我告訴這位同學:首先得有興趣,興趣是克服一切困難的源動力。然后要善于利用網絡和身邊的資源,多嘗試、多搜索、多討論。 我本人也是電子相關專業(yè)(自動化)畢業(yè)的,大四找工作之前在實驗室一直玩 51 單片機 和 Cortex-M3,可是機緣巧合卻面試進了一家做 Android 的公司——面試之前,我看招聘要求上只寫了要熟悉 Arm 體系結構,Cortex-M3 也是 Arm 啊,所以我就去面試了,最后竟然拿到了 offer。簽三方的時候 HR 說:你回去后要開始學 Linux,這是你進來后工作的重點技術。我點頭說:好的、好的…… 出來后我就蒙了——Linux!WTF!我要是看到招聘要求上有寫 Linux,再給我個膽子我也不敢去面試?。?/p> 回來后去實驗室,老師知道我簽了這家公司,還是很高興的!說你先學會怎么在 Linux 系統(tǒng)下工作吧,不然你連門的入不了。 于是老師給我找了一臺臺式機,裝了 Ubuntu,然后又從實驗室倉庫的最里面翻出來了一塊 S3C2410 的開發(fā)板—— 沒錯,我沒寫錯,就是 2410。因為我們是自動化院系,大部分老師的項目都是和各種廠礦、車間的控制相關,這里面大部分都是用 PLC、單片機、MCU 來做控制,跑 Linux,那是不存在的!老師說,一個控制不當,機毀人亡,那是要去坐牢的。所以院系里也沒人玩 Linux、這塊開發(fā)板還是好幾年前一家公司來做推廣的時候送的。我會玩玩 Ubuntu 已經是比較潮流的了。 于是后面的幾個月我就在這塊 S3C2410 的板子上開始了 Arm Linux 的入門學習:不停的重復實驗、不停的上網搜索…… 后面就畢業(yè),順利入職。工作后蠻順利,在各種芯片上折騰 Android、Linux,樂此不疲。 得益于入門時期的特殊經歷,我對業(yè)內的相關書籍一直比較關注,看到哪位大牛出版了好書,就忍不住要買回來,看到網上有對應的 PDF 版本,也一定會想辦法下下來。 所以剛好這幾天有空,我就把這些我看過的書單整理了出來,希望對大家有所幫助: 這些書籍我按照 Arm Linux 系統(tǒng)所需要的知識結構,做了分類:
前三類是基礎,無論從事哪個方向的開發(fā),這些都是必須要熟練掌握的基本功。后面五類是相輔相成的,理論基礎相當于內功心法,開發(fā)實踐相當于招式,要相互結合相互印證。招式好上手,使起來也漂亮,可以讓你快速在江湖上闖出一定的小名頭,但是要想走的更遠、飛的更高、躋身真正的高手行列,還是離不開深厚的內功心法。 1、Linux 系統(tǒng)環(huán)境熟悉 Linux 系統(tǒng)環(huán)境是一切的前提 —— Linux 系統(tǒng)環(huán)境中,最強大的開發(fā)武器是命令行和 Shell 腳本。 為什么?因為大量(幾乎所有)的開源項目的編譯、配置、都是通過命令行實現(xiàn);在涉及海量源碼的工程下,命令行的 find、grep 命令可以提供強大、高效的搜索功能,能幫忙快速的定位、理解源碼;通過 Shell 腳本能夠讓大量重復的工作自動化,節(jié)省時間和生命。我曾經向 U-Boot 和 Linux Kernel mainline 提交過兩個補丁,涉及到大幾十個文件中雷同代碼的修改,如果一步步手工修改,可能要幾天時間,我花了大半天的時間寫了個腳本利用 我聽到過很多還處在入門階段的同學說:以后的趨勢是桌面化、圖形化、所以我不需要命令行。其實這種看法是不對的,至少在可以看到的將來,命令行沒有被取代的趨勢。至少我現(xiàn)在還經??吹接型瑢W問:我照著教程敲的這個命令,為什么報錯了?我問他:你明白這個命令是什么意思嗎?你看懂它報錯的提示信息了嗎?他說不知道。所以你要熟悉命令行,至少你要知道你敲下去的每個命令是什么意思,能看懂它的錯誤提示信息。能會用 所以這部分我推薦了四本書(資料):
2、Git 版本管理我把 Git 版本管理放在了第二位、是想凸顯它的重要性,在現(xiàn)在這種團隊化、快速迭代的開發(fā)模式中,用不好版本管理,開發(fā)工作也很難做的干凈高效。我現(xiàn)在寫文檔都是用 Git + Markdown + Github 做版本管理,發(fā)現(xiàn)錯誤隨時迭代修改。 據傳說,中國的第一代的程序員——求伯君、王江民,他們晚上下班之前會把主機上存儲自己寫的程序的軟件盤拆下來,帶回家——怕發(fā)生意外,自己寫的程序丟了?,F(xiàn)在依托 Git 這種版本管理工具,似乎再也沒有人有這種憂慮了。 其實版本管理工具很多,推薦 Git 是因為它用的廣泛,Android 項目用的是 Git做版本管理,Linux 內核、U-Boot 這些知名的開源項目都是用 Git 做版本管理,還有 Github、Gitlab、Gitee 這種代碼托管網站都是以 Git 作為基石,可見在版本管理上,Git 以及形成了一種生態(tài)級別的存在。所以你應該毫不猶豫的擁抱它。 對了,Git 的原型是 Linus 大神(就是寫出 Linux kernel 的那位)在一個星期內寫出來的。 我推薦了兩本書,對,兩本:
3、C 語言和匯編做嵌入式開發(fā)、C 語言的重要性就不用多說了,從 U-Boot 到 Linux kernel,已經各種基礎組件,基本都是用 C 語言寫的,所以要做一個好的嵌入式 Hacker,C 語言是必須會的。 不像 C 這種跨平臺的語言,匯編是和 CPU 體系結構強相關的一門語言,不同的架構 匯編都不一樣,比如 32 位的 Armv7 和 64 位的 Armv8 匯編就不一樣,比較難以掌握。 對于入門者來說,剛開始不會匯編也沒關系,對你的工作影響不大,因為絕大部分場景都用不到。 但是當你的技能提高的一定層次,掌握了匯編就會讓你更能深入系統(tǒng)內部,看清程序運行的內部機理。 U-Boot 和 Linux Kernel 中的第一段啟動代碼,基本都是匯編寫的,Cache、MMU 相關的控制,也只能通過匯編實現(xiàn)。 有時候一段 C 代碼運行異常,或者效率低下,或者你的 Linux 系統(tǒng)跑崩潰了,這時候把對應的代碼反匯編,從匯編級別的去分析,更容易發(fā)現(xiàn)問題之所在。我平時經常的一部分工作就是通過匯編去發(fā)現(xiàn)或者分析前線部門或者客戶報過來的各種疑難雜癥。 當然了,匯編不用把每一句都搞懂,只要能大概看懂常用的指令就行,具體遇到問題的時候再去查對應的匯編手冊,然后就是熟能生巧的問題了。 這里我推薦了三本 C 語言的書和 三份 Arm64 的匯編指令簡介:
4、Arm 體系結構要想把 Arm 嵌入式 玩的溜,尤其是想了解整個系統(tǒng)的,對 Arm 體系結構還是要有一定的學習。如果深入到一定的層次,Arm 體系結構相關的,也是必須要熟悉的,因為很多優(yōu)化做到極致都是和體系結構緊密相關的。 上面是《奔跑吧 Linux Kernel》的作者笨叔叔前兩天在朋友圈幫國內手機大廠打的招聘信息,里面有對 Arm 體系結構的要求,大家可以自行感受下。 現(xiàn)階段的 Arm 處理器,應用最廣泛的大概分為三類:定位于 MCU 的 Cortex-M 系列,定位于應用處理器的 Cortex-A 系列:Armv7-A 和 Armv8-A,Armv7-A 是 32 位的 CPU,包括 Cortex-A7/A9/A15/A17 這些,比如大家常見的 i.MX6ULL 芯片就屬于 Arm Cortex-A7,Armv8-A 是 32 位的 CPU,包括 Cortex-A35/A53/A57/A72/A73 市面上在售 的 i.MX8,RK3399、以及現(xiàn)在的主流手機 CPU,都屬于 Armv8-A。 這部分我推薦了兩本書,剩下的都是 Arm 官方發(fā)布的文檔:
除了第一本是中國人寫的,剩下的四本都是老外寫的,而且部頭都比較大,所以選一本你自己喜歡的認真去實踐即可。 6、Linux 內核基礎原理很多學習嵌入式 Linux 開發(fā)的同學一上來就呆住一個驅動就開始較勁,然后發(fā)現(xiàn)看著像天書一樣,各種奇怪的 API 完全不知道為什么需要這樣寫,這時候你需要了解一些 Linux 內核的基礎原理。 這種書一般不是上來就給你分析某個驅動時怎么寫的,它側重于描述 Linux 內核的基礎框架,基礎數(shù)據結構,基本驅動模型,CPU 調度、內存管理這些機制。 我推薦了五本書:
當然,你不用希望一上來就能熟讀他們,第一遍你可能只能看個大概,而且看的很容易犯困。沒關系,瞌睡了就去睡覺,或者去找個簡單的驅動寫一寫,過幾天遇到疑問了再返回來看一看。這樣周而復始,總會有看明白的一天。 這里面的前兩本我從大四就開始看,最開始看著就犯迷糊,到后來工作了,結合平時寫的一些驅動,再返回去看,總算不再會打瞌睡。現(xiàn)在偶爾還會拿起來翻一翻。 我知道有的同學會說 《Linux 設備驅動程序》這本書太老了,它是針對 2.6 內核的,連設備樹都沒有。其實在技術里面,也有一個道和術的問題,這本書講的是驅動的基礎原理,雖然 Linux kernel 一直在發(fā)展,現(xiàn)在 5.4 都快發(fā)布了,但是那些基本的內在邏輯還是一致的,驅動最底層的結構和原理都還沒有變化。Linux Kernel 開發(fā)的哲學就是這樣的,不允許你上來就直接推到之前的設計重新搞一套,你必須在原有的基礎上做持續(xù)性的改進,對于一個擁有龐大用戶群體的系統(tǒng),前向兼容性比什么都重要。至于設備樹(dts)這些東西,只是技術實現(xiàn)上的細枝末節(jié),找到規(guī)律很快就能掌握。 《深入 Linux 內核架構》這本書是一個德國人寫的,其實我沒看過,但是我知道這本書很出名,講的很深入,在我的閱讀計劃之內。 《深入 Linux 設備驅動程序內核機制》這本書是一個中國人寫的,基于 Linux 2.6.39,也是講 Linux 設備驅動的基本原理和組件,對于做驅動開發(fā)來說,還是值得一讀,而且中國人寫的書在思維也和大家更接近。 《Mastering Linux Kernel Development》這本書比較新,基于 Linux 4.9 ,所以這本書也只有英文版本。 7、Linux 內核開發(fā)與實戰(zhàn)第六部分給大家推薦的書都比較偏理論,這部分推薦到是比較偏實踐的,基本就是告訴你開發(fā)環(huán)境怎么搭建,內核怎么編譯,文件系統(tǒng)怎么構建,驅動怎么編寫,所以建議六、七兩部分要結合起來看。 還是五本書:
8、操作系統(tǒng)理論與基礎Linux Kernel 是一個綜合性的工程,是大量科學理論的具體實現(xiàn)。對這些基礎理論有個基礎的認識,會讓我們學的更好。當然,短時間內不了解這些知識,也不會影響到你去調試一個驅動,Bringup 一塊板子,但是要想讓更深入的去研究一些問題,這些知識還是要補充的。尤其是對于電子相關專業(yè)的學生,可能連計算機基本原理,進程、線程、虛擬內存、Cache這些概念都沒有,那下邊這兩本書可以很好的幫到你。
寫在最后這份書單非常的長,53 份! 幾乎不可能全部讀完! 其實你也用不著把他們詳細的讀完! 如果從這篇介紹文章中,你能區(qū)分出哪些是要精讀的,哪些是當作工具書來需要的時候查閱的,它們就會對你有一定的幫助了。 我也會感到很高興。 另外,寫作不宜,這里面提到的大部分書,都已出版,如果可能,去買一本,支持下作者,也算是對知識的一種尊重。 我每年都會買很多書,有些書買來都沒來得及看,但是看著就感覺是好書,買回來,擺在案頭,看著就開心。 |
|
|
來自: 西北望msm66g9f > 《編程》