1 Linux 體系結(jié)構(gòu)
如下圖所示,Linux 體系結(jié)構(gòu),從大的方面可以分為用戶空間(User Space)和內(nèi)核空間(Kernel Space)。
用戶空間中包含了 C 庫,用戶的應(yīng)用程序。在某些體系結(jié)構(gòu)圖中還包含了 shell,當(dāng)然 shell 腳本也是Linux 體系中不可缺少的一部分。
內(nèi)核空間包括硬件平臺、平臺依賴代碼、內(nèi)核、系統(tǒng)調(diào)用接口。
在任何一個現(xiàn)代操作系統(tǒng)中,都是分層的。為什么需要分層呢?
從程序員的角度分析,將 linux 底層和和應(yīng)用分開,將 linux 底層和應(yīng)用分開,做應(yīng)用的做應(yīng)用,做底層的做底層,各干各的。經(jīng)濟(jì)學(xué)的基本原理是,分工產(chǎn)生效率。
從安全性的角度分析,是為了保護(hù)內(nèi)核。現(xiàn)代 CPU 通常都實(shí)現(xiàn)了不同的工作模式。
以 ARM 為例:ARM 實(shí)現(xiàn)了 7 種工作模式,不同模式下 CPU 可以執(zhí)行的指令或者訪問的寄存器不同:
(1) 用戶模式 usr
(2) 系統(tǒng)模式 sys
(3) 管理模式 svc
(4) 快速中斷 fiq
(5) 外部中斷 irq
(6) 數(shù)據(jù)訪問終止 abt
(7) 未定義指令異常。
如果任何一個上層應(yīng)用都可以調(diào)用都可以調(diào)用寄存器,那樣肯定是無法穩(wěn)定執(zhí)行的。而且因?yàn)槌霈F(xiàn)了這個問題,出現(xiàn)了一個新的學(xué)科“現(xiàn)代操作系統(tǒng)”,如果大家感興趣可以看一下“現(xiàn)代操作系統(tǒng)”相關(guān)文章或者書籍。
以 X86 為例:X86 實(shí)現(xiàn)了 4 個不同級別的權(quán)限,Ring0—Ring3 ;Ring0 下可以執(zhí)行特權(quán)指令,可以訪問
IO 設(shè)備;Ring3 則有很多的限制
如果分析一下 Android 的,這方面做的更加“喪心病狂”,Android 所有的 APK 應(yīng)用程序,都是在 Java虛擬機(jī)上面運(yùn)行,應(yīng)用程序更加遠(yuǎn)離底層。
另外,用戶空間和內(nèi)核空間是程序執(zhí)行的兩種不同狀態(tài),可以通過“系統(tǒng)調(diào)用”和“硬件中斷”來完成用戶空間到內(nèi)核空間的轉(zhuǎn)移。
2 Linux 內(nèi)核結(jié)構(gòu)
這一節(jié),分析一下內(nèi)核結(jié)構(gòu)。如下圖所示,是 Linux 內(nèi)核結(jié)構(gòu)圖。
SCI 層(System Call Interface),這一層是給應(yīng)用用戶空間提供一套標(biāo)準(zhǔn)的系統(tǒng)調(diào)用函數(shù)來訪問 Linux。前面分析 Linux 體系結(jié)構(gòu)的時候,介紹過任何一類現(xiàn)代操作系統(tǒng)都不會允許上層應(yīng)用直接訪問底層,在Linux 中,內(nèi)核提供了一套標(biāo)準(zhǔn)接口,上層應(yīng)用就可以通過這一套標(biāo)準(zhǔn)接口來訪問底層。
PM(Procees Management),這一部分包括具體創(chuàng)建創(chuàng)建進(jìn)程(fork、exec),停止進(jìn)程(kill、exit), 并控制他們之間的通信(signal 等)。還包括進(jìn)程度,控制活動進(jìn)程如何共享 CPU。這一部分是 Linux 已經(jīng)做好的,在寫驅(qū)動的時候,只需要調(diào)用對應(yīng)的函數(shù)即可實(shí)現(xiàn)這些功能,例如創(chuàng)建進(jìn)程、進(jìn)程通信等等。
MM(Memory Management),內(nèi)存管理的主要作用是控制多個進(jìn)程安全的共享內(nèi)存區(qū)域。
VFS(Virtual File Systems),虛擬文件系統(tǒng),隱藏各種文件系統(tǒng)的具體細(xì)節(jié),為文件操作提供統(tǒng)一的接口。在 Linux 中“一切皆文件”,這些文件就是通過 VFS 來實(shí)現(xiàn)的。Linux 提供了一個大的通用模型,使這個模型包含了所有文件系統(tǒng)功能的集合。如下圖所示,是一個虛擬文件系統(tǒng)的結(jié)構(gòu)圖。
Device Drivers 設(shè)備驅(qū)動,這一部分就是需要學(xué)習(xí)和掌握的。Linux 內(nèi)核中有大量的代碼在設(shè)備驅(qū)動程序部分,用于控制特定的硬件設(shè)備。
Linux 驅(qū)動一般分為網(wǎng)絡(luò)設(shè)備、塊設(shè)備、字符設(shè)備、雜項設(shè)備,需要編寫的只有字符設(shè)備,雜項設(shè)備是不容易歸類的一種驅(qū)動,雜項設(shè)備和字符設(shè)備有很多重合的地方。
網(wǎng)絡(luò)協(xié)議棧,Linux 內(nèi)核中提供了豐富的網(wǎng)絡(luò)協(xié)議實(shí)現(xiàn)。
3 Linux 內(nèi)核源碼目錄結(jié)構(gòu)
Linux 內(nèi)核源碼采用樹形結(jié)構(gòu)。功能相關(guān)的文件放到不同的子目錄下面,使程序更具有可讀行。使用Source Insight 打開源碼,如下圖所示,可以看到源碼是樹形結(jié)構(gòu)。
下面來介紹每一個目錄的作用。
arch 目錄是平臺目錄。處理器原廠提供一套 Linux 內(nèi)核的源碼,那么在這個目錄下都有一套針對具體處理器 CPU 的子目錄。每個 CPU 的子目錄,又進(jìn)一步分解為 boot,mm, kernel 等子目錄,分別控制系統(tǒng)引導(dǎo),內(nèi)存管理,系統(tǒng)調(diào)用,動態(tài)調(diào)頻,主頻率設(shè)置部分等。
在 arch 目錄中有關(guān)鍵的平臺文件。任何一款支持 Linux 的處理器,都有一部分內(nèi)核代碼是針對特定的處理器來提供的,具體的實(shí)現(xiàn)就是通過平臺文件。
迅為 iTOP-4412 的平臺文件,是 arch→arm→mach-exynos→mach-itop4412.c。
arch→arm→boot 目錄,默認(rèn)編譯生成的內(nèi)核鏡像是在這個目錄下。
在 arch→arm→kernel 目錄中,有針對具體 CPU 處理器的代碼,有相關(guān)內(nèi)核特性實(shí)現(xiàn)方式,如信號處理等。這一部分當(dāng)然是芯片廠商做好了,4412 的這部分就是三星已經(jīng)做好的部分。
在 arch→arm→lib 目錄 中,有 一些和 硬件相 關(guān)庫函 數(shù),后 面學(xué)習(xí) 驅(qū)動的 時候會 使用到 。在
arch→arm→tools 目錄中,包含了生成鏡像的工具。
如下圖所示。
在 binary 目錄中,有一些無源碼的驅(qū)動以二進(jìn)制放到該文件夾,例如一些測試版本或者不愿意公布源碼,都可以將二進(jìn)制文件放到這個目錄中。
在 drivers 目錄中,就是需要重點(diǎn)學(xué)習(xí)的部分,后面的實(shí)驗(yàn)都是圍繞這一步進(jìn)行的。
在 include 目錄中,通用的 Linux 頭文件都在該文件下。
如下圖所示,部分目錄如下。下面的這些目錄,幾乎不需要去動其中任何一個文件。
如下圖所示,有內(nèi)核編程的范例,實(shí)現(xiàn)安全性的代碼,聲卡設(shè)備驅(qū)動等還有內(nèi)核裁減配置工具目錄 tools,這一部分實(shí)現(xiàn)的功能是將.c 編譯成目標(biāo)文件,連接合并成可運(yùn)行的內(nèi)核鏡像文件等。提供給大家的內(nèi)核源碼一百多 M,最后編譯成的 zImage 只有不到 5M,這都是依靠這個工具來實(shí)現(xiàn)的,后面會有針對性的實(shí)驗(yàn)來教大家如何使用編譯工具。
上一篇:每天學(xué)習(xí)一點(diǎn)丨借助U盤或TF卡拷貝程序到迅為IMX6ULL開發(fā)板上(二)
下一篇:迅為-IMX6Q開發(fā)板Buildroot文件系統(tǒng)nfs測試
推薦閱讀最新更新時間:2025-06-14 17:15






設(shè)計資源 培訓(xùn) 開發(fā)板 精華推薦
- Microchip 升級數(shù)字信號控制器(DSC)產(chǎn)品線 推出PWM 分辨率和 ADC 速度業(yè)界領(lǐng)先的新器件
- 意法半導(dǎo)體STM32MP23x:突破成本限制的工業(yè)AI應(yīng)用核心
- 意法半導(dǎo)體推出用于匹配遠(yuǎn)距離無線微控制器STM32WL33的集成的匹配濾波芯片
- ESP32開發(fā)板連接TFT顯示屏ST7789跳坑記
- 如何讓ESP32支持analogWrite函數(shù)
- LGVL配合FreeType為可變字體設(shè)置字重-ESP32篇
- 使用樹莓派進(jìn)行 ESP32 Jtag 調(diào)試
- ESP32怎么在SPIFFS里面存儲html,css,js文件,以及網(wǎng)頁和arduino的通訊
- ESP32 freeRTOS使用測試
- 對講機(jī)dtmf解碼
- TND315-D、160 W CRT-TV 電源文檔包
- NSV45020JZ 大電流 LED 燈串的典型應(yīng)用
- MIC8114的典型應(yīng)用:微處理器復(fù)位電路
- 用于消費(fèi)電子產(chǎn)品的 PIC33 MCU 開發(fā)系統(tǒng)
- L7818C 0.5 至 10 V 輸出穩(wěn)壓器的典型應(yīng)用
- AD5313 雙軌至軌電壓輸出、10 位 DAC 的典型應(yīng)用
- 使用 Analog Devices 的 LT1021DIN8-10 的參考設(shè)計
- MIKROE-3274,磁性線性點(diǎn)擊板 HMC1501 磁阻傳感器
- LT3990EDD 1.8V 降壓轉(zhuǎn)換器的典型應(yīng)用
- 南芯科技推出高集成度多口移動電源解決方案,助力充電寶市場穩(wěn)健發(fā)展
- 英飛凌推出具有超低導(dǎo)通電阻的CoolSiC? MOSFET 750 V G2,適用于汽車和工業(yè)功率電子應(yīng)用
- DigiKey 慶祝 B 站賬號粉絲突破 10 萬,贈送驚喜禮包
- 碳化硅企業(yè) Wolfspeed 啟動破產(chǎn)重組,預(yù)計 2025 年三季度末完成司法重整
- 蘋果被曝考慮放棄自研模型 轉(zhuǎn)而與Anthropic或OpenAI合作
- ?百度文心4.5來襲!英特爾Day0即支持端側(cè)部署
- 【廣瀨電機(jī)】關(guān)于中國發(fā)明專利侵權(quán)訴訟達(dá)成和解的公告
- 英飛凌BMS解決方案推動電動汽車創(chuàng)新
- 地平線的L3判斷與實(shí)踐路徑
- 汽車網(wǎng)絡(luò)升級攻略:CAN-CAN FD-車載以太網(wǎng)
- 海克斯康大數(shù)據(jù)分析軟件助力汽車制造質(zhì)量管理
- 感受工業(yè)4.0精益生產(chǎn) 全面展示十大工藝
- CHAdeMO與中國共同制定新標(biāo)準(zhǔn)即將落地
- 央視:汽車產(chǎn)業(yè)迎來變革,日本或率先普及氫燃料電池汽車
- 歐洲電池逆襲日韓和中國,勝算幾何?
- 【STM32電機(jī)矢量控制】記錄7——六扇區(qū)輸出值的設(shè)定
- 【STM32電機(jī)矢量控制】記錄8——ADC三電阻采樣
- 【STM32電機(jī)矢量控制】記錄9——狀態(tài)觀測器與鎖相環(huán)
- 【STM32電機(jī)矢量控制】記錄11——DMA傳輸
- 【STM32電機(jī)矢量控制】記錄12——IWDG看門狗