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

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

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

想要駕馭Linux驅(qū)動(dòng)開發(fā),必須深刻理解Linux總線設(shè)備驅(qū)動(dòng)框架

Q4MP_gh_c472c21 ? 來源:未知 ? 作者:李倩 ? 2018-03-22 11:08 ? 次閱讀

Linux驅(qū)動(dòng)程序的開發(fā)與應(yīng)用程序的開發(fā)有很大的區(qū)別,這些差別導(dǎo)致了編寫Linux設(shè)備驅(qū)動(dòng)程序與編寫應(yīng)用程序的本質(zhì)區(qū)別。

一、用戶態(tài)和內(nèi)核態(tài)

Linux操作系統(tǒng)分為用戶態(tài)和內(nèi)核態(tài)。內(nèi)核態(tài)完成與硬件的交互,比如讀寫內(nèi)存、將硬盤上的數(shù)據(jù)讀取到內(nèi)存等。驅(qū)動(dòng)程序在底層與硬件交互,因此工作在內(nèi)核態(tài)。用戶態(tài)可以理解為上層的應(yīng)用程序,可以是Java應(yīng)用程序、Qt應(yīng)用程序、Python應(yīng)用程序等。Linux操作系統(tǒng)分成兩種狀態(tài)的原因是,即使用戶態(tài)的應(yīng)用程序出現(xiàn)異常,也不會(huì)導(dǎo)致操作系統(tǒng)崩潰,而這一切都?xì)w功于內(nèi)核態(tài)對(duì)操作系統(tǒng)有很強(qiáng)大的保護(hù)能力。

另一方面,Linux操作系統(tǒng)分為兩個(gè)狀態(tài)的原因主要是為應(yīng)用程序提供一個(gè)統(tǒng)一的計(jì)算機(jī)硬件抽象。工作在用戶態(tài)的應(yīng)用程序完全可以不考慮底層的硬件操作,這些操作由內(nèi)核態(tài)程序來完成。而這些內(nèi)核態(tài)程序大部分是設(shè)備驅(qū)動(dòng)程序。應(yīng)用程序可以在不了解硬件工作原理的情況下,很好地操作硬件設(shè)備,同時(shí)不會(huì)使硬件設(shè)備進(jìn)入非法狀態(tài)。值得注意的是,用戶態(tài)和內(nèi)核態(tài)是可以互相轉(zhuǎn)換的。每當(dāng)應(yīng)用程序執(zhí)行系統(tǒng)調(diào)用或者被硬件中斷掛起時(shí),Linux操作系統(tǒng)都會(huì)從用戶態(tài)切換到內(nèi)核態(tài);當(dāng)系統(tǒng)調(diào)用完成或者中斷處理完成后,操作系統(tǒng)會(huì)從內(nèi)核態(tài)返回到用戶態(tài),繼續(xù)執(zhí)行應(yīng)用程序。

二、模塊機(jī)制

模塊是可以在運(yùn)行時(shí)加入內(nèi)核的代碼,這是Linux一個(gè)很好地特性,這個(gè)特性可以使內(nèi)核很容易得擴(kuò)大或縮小,擴(kuò)大內(nèi)核可以增加內(nèi)核的功能,縮小內(nèi)核可以減少內(nèi)核的大小。Linux內(nèi)核支持多種模塊,驅(qū)動(dòng)程序就是其中最重要的一種,每一個(gè)模塊由編譯好的目標(biāo)代碼組成,使用insmod命令將模塊加入正在運(yùn)行的內(nèi)核,使用rmmod命令將一個(gè)未使用的模塊從內(nèi)核刪除。模塊在在內(nèi)核啟動(dòng)時(shí)裝載稱為靜態(tài)裝載,在內(nèi)核已經(jīng)運(yùn)行時(shí)裝載稱為動(dòng)態(tài)裝載。模塊可以擴(kuò)充內(nèi)核所期望的任何功能,但通常用于實(shí)現(xiàn)設(shè)備驅(qū)動(dòng)程序。一個(gè)模塊的最基本框架代碼如下:

三、總線,設(shè)備,驅(qū)動(dòng)

想要駕馭Linux驅(qū)動(dòng)開發(fā),必須深刻理解Linux總線設(shè)備驅(qū)動(dòng)框架。之所以會(huì)形成這樣的框架,主要是為了代碼的可重用性,因?yàn)轵?qū)動(dòng)和設(shè)備的關(guān)系是一對(duì)多的。正如主設(shè)備號(hào)和次設(shè)備號(hào)之分,主設(shè)備號(hào)表示驅(qū)動(dòng)程序,次設(shè)備號(hào)表示具體的設(shè)備。另外是為了提高驅(qū)動(dòng)的可移植性,Linux把驅(qū)動(dòng)要用到的資源(如GPIO和中斷等)剝離給設(shè)備去管理。即在設(shè)備里面包含其自己的設(shè)備屬性,還包括了其連接到SOC所用到的資源。而驅(qū)動(dòng)重點(diǎn)關(guān)注操作的流程和方法??偩€的作用則是在軟件層面對(duì)設(shè)備和驅(qū)動(dòng)進(jìn)行管理。設(shè)備要讓系統(tǒng)感知自己的存在,設(shè)備需要向總線注冊(cè)自己;同樣地,驅(qū)動(dòng)要讓系統(tǒng)感知自己的存在,也需要向總線注冊(cè)自己。設(shè)備和總線在初始化時(shí)必須要明確自己是哪種總線的。因此,為了達(dá)到操作一致性,Linux發(fā)明了一種虛擬的總線,稱為Platform總線。多個(gè)設(shè)備和多個(gè)驅(qū)動(dòng)都注冊(cè)到同一個(gè)總線上,那設(shè)備怎么找到最適合自己的驅(qū)動(dòng)呢,或者說驅(qū)動(dòng)怎么找到其所支持的設(shè)備呢?這個(gè)也是由總線負(fù)責(zé),總線就像是一個(gè)紅娘,負(fù)責(zé)在設(shè)備和驅(qū)動(dòng)中牽線。設(shè)備會(huì)向總線提出自己對(duì)驅(qū)動(dòng)的條件(最簡單的也是最精確的就是指定對(duì)方的名字了),而驅(qū)動(dòng)也會(huì)向總線告知自己能夠支持的設(shè)備的條件(一般是型號(hào)ID等,最簡單的也可以是設(shè)備的名字)。那設(shè)備在注冊(cè)的時(shí)候,總線就會(huì)遍歷注冊(cè)在它上面的驅(qū)動(dòng),找到最適合這個(gè)設(shè)備的驅(qū)動(dòng),然后填入設(shè)備的結(jié)構(gòu)成員中;驅(qū)動(dòng)注冊(cè)的時(shí)候,總線也會(huì)遍歷注冊(cè)在其之上的設(shè)備,找到其支持的設(shè)備(可以是多個(gè),驅(qū)動(dòng)和設(shè)備的關(guān)系是1:N),并將設(shè)備填入驅(qū)動(dòng)的支持列表中。我們稱總線這個(gè)牽線的行為是match。牽好線之后,設(shè)備和驅(qū)動(dòng)之間的交互紅娘可不管了。

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

    關(guān)注

    12

    文章

    1908

    瀏覽量

    86644
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11479

    瀏覽量

    213070
  • 總線
    +關(guān)注

    關(guān)注

    10

    文章

    2956

    瀏覽量

    89477

原文標(biāo)題:想要駕馭Linux驅(qū)動(dòng)開發(fā),必須深刻理解Linux總線設(shè)備驅(qū)動(dòng)框架!Linux驅(qū)動(dòng)開發(fā)要點(diǎn)總結(jié)

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

收藏 人收藏
  • 不方咦1

評(píng)論

相關(guān)推薦
熱點(diǎn)推薦

從需求的角度去理解Linux系列:總線、設(shè)備驅(qū)動(dòng)

%的開發(fā)工作量,而你只需要完成20%的開發(fā)工作量。Linux平臺(tái)上的各個(gè)子系統(tǒng),如設(shè)備驅(qū)動(dòng)模型、input子系統(tǒng)、I2C
發(fā)表于 03-11 14:45

從需求的角度去理解嵌入式Linux總線、設(shè)備驅(qū)動(dòng)

系統(tǒng)學(xué)習(xí)資料和內(nèi)容以及方法加意義氣嗚嗚吧久零就易,總線設(shè)備驅(qū)動(dòng)管理就是我們今天要談的主題。Linux平臺(tái)有各種子系統(tǒng)、各種總線、各種
發(fā)表于 12-11 16:34

字符設(shè)備驅(qū)動(dòng)、設(shè)備驅(qū)動(dòng)模型、sysfs、平臺(tái)設(shè)備驅(qū)動(dòng)的關(guān)系 -----從需求的角度去理解Linux之三

相關(guān)技術(shù)也相對(duì)不錯(cuò)了。要深刻理解其中的原理需要非常熟悉設(shè)備驅(qū)動(dòng)相關(guān)的框架和模型代碼。網(wǎng)絡(luò)上有關(guān)這些技術(shù)的文章不少,但多是對(duì)其中的某一點(diǎn)進(jìn)行闡述,很難找到對(duì)這些技術(shù)進(jìn)行比較和關(guān)聯(lián)的分析。
發(fā)表于 12-17 16:16

嵌入式Linux設(shè)備驅(qū)動(dòng)開發(fā)

嵌入式Linux設(shè)備驅(qū)動(dòng)開發(fā) Linux 設(shè)備驅(qū)動(dòng)
發(fā)表于 09-10 13:10 ?82次下載
嵌入式<b class='flag-5'>Linux</b><b class='flag-5'>設(shè)備</b><b class='flag-5'>驅(qū)動(dòng)</b><b class='flag-5'>開發(fā)</b>

Linux設(shè)備驅(qū)動(dòng)開發(fā)詳解》第16章、Linux網(wǎng)絡(luò)設(shè)備驅(qū)動(dòng)

Linux設(shè)備驅(qū)動(dòng)開發(fā)詳解》第16章、Linux網(wǎng)絡(luò)設(shè)備驅(qū)
發(fā)表于 10-27 11:17 ?5次下載
《<b class='flag-5'>Linux</b><b class='flag-5'>設(shè)備</b><b class='flag-5'>驅(qū)動(dòng)</b><b class='flag-5'>開發(fā)</b>詳解》第16章、<b class='flag-5'>Linux</b>網(wǎng)絡(luò)<b class='flag-5'>設(shè)備</b><b class='flag-5'>驅(qū)動(dòng)</b>

Linux設(shè)備驅(qū)動(dòng)開發(fā)詳解》第15章、Linux的I2C核心、總線設(shè)備驅(qū)動(dòng)

Linux設(shè)備驅(qū)動(dòng)開發(fā)詳解》第15章、Linux的I2C核心、總線
發(fā)表于 10-27 11:19 ?8次下載
《<b class='flag-5'>Linux</b><b class='flag-5'>設(shè)備</b><b class='flag-5'>驅(qū)動(dòng)</b><b class='flag-5'>開發(fā)</b>詳解》第15章、<b class='flag-5'>Linux</b>的I2C核心、<b class='flag-5'>總線</b>與<b class='flag-5'>設(shè)備</b><b class='flag-5'>驅(qū)動(dòng)</b>

Linux設(shè)備驅(qū)動(dòng)開發(fā)詳解》第14章、Linux終端設(shè)備驅(qū)動(dòng)

Linux設(shè)備驅(qū)動(dòng)開發(fā)詳解》第14章、Linux終端設(shè)備驅(qū)
發(fā)表于 10-27 11:22 ?8次下載
《<b class='flag-5'>Linux</b><b class='flag-5'>設(shè)備</b><b class='flag-5'>驅(qū)動(dòng)</b><b class='flag-5'>開發(fā)</b>詳解》第14章、<b class='flag-5'>Linux</b>終端<b class='flag-5'>設(shè)備</b><b class='flag-5'>驅(qū)動(dòng)</b>

Linux設(shè)備驅(qū)動(dòng)開發(fā)詳解》第13章、Linux設(shè)備驅(qū)動(dòng)

Linux設(shè)備驅(qū)動(dòng)開發(fā)詳解》第13章、Linux設(shè)備驅(qū)動(dòng)
發(fā)表于 10-27 11:24 ?18次下載
《<b class='flag-5'>Linux</b><b class='flag-5'>設(shè)備</b><b class='flag-5'>驅(qū)動(dòng)</b><b class='flag-5'>開發(fā)</b>詳解》第13章、<b class='flag-5'>Linux</b>塊<b class='flag-5'>設(shè)備</b><b class='flag-5'>驅(qū)動(dòng)</b>

Linux設(shè)備驅(qū)動(dòng)開發(fā)詳解》第8章、Linux設(shè)備驅(qū)動(dòng)中的阻塞與非阻塞IO

Linux設(shè)備驅(qū)動(dòng)開發(fā)詳解》第8章、Linux設(shè)備驅(qū)動(dòng)
發(fā)表于 10-27 11:35 ?9次下載
《<b class='flag-5'>Linux</b><b class='flag-5'>設(shè)備</b><b class='flag-5'>驅(qū)動(dòng)</b><b class='flag-5'>開發(fā)</b>詳解》第8章、<b class='flag-5'>Linux</b><b class='flag-5'>設(shè)備</b><b class='flag-5'>驅(qū)動(dòng)</b>中的阻塞與非阻塞IO

Linux總線、設(shè)備驅(qū)動(dòng)是如何關(guān)聯(lián)的?

對(duì)于 Linux 驅(qū)動(dòng)開發(fā)來說,設(shè)備模型的理解是根本,顧名思義設(shè)備模型是關(guān)于
發(fā)表于 11-27 01:21 ?3437次閱讀

基于嵌入式Linux下的I2C設(shè)備驅(qū)動(dòng)的總體思路與框架設(shè)計(jì)

數(shù)據(jù)結(jié)構(gòu),對(duì)I2C總線協(xié)議進(jìn)行了更抽象更通用的定義,極大的增加了設(shè)備驅(qū)動(dòng)的可移植性。要編寫出自己的I2C 設(shè)備驅(qū)動(dòng)程序,
發(fā)表于 08-20 09:04 ?3909次閱讀
基于嵌入式<b class='flag-5'>Linux</b>下的I2C<b class='flag-5'>設(shè)備</b><b class='flag-5'>驅(qū)動(dòng)</b>的總體思路與<b class='flag-5'>框架</b>設(shè)計(jì)

你對(duì)Linux總線設(shè)備驅(qū)動(dòng)框架是否了解

Linux設(shè)備驅(qū)動(dòng)模型,或者說,Linux設(shè)備驅(qū)動(dòng)框架
發(fā)表于 05-05 15:13 ?860次閱讀

如何使用Linux內(nèi)核實(shí)現(xiàn)USB驅(qū)動(dòng)程序框架

Linux內(nèi)核提供了完整的USB驅(qū)動(dòng)程序框架。USB總線采用樹形結(jié)構(gòu),在一條總線上只能有唯一的主機(jī)設(shè)備
發(fā)表于 11-06 17:59 ?20次下載
如何使用<b class='flag-5'>Linux</b>內(nèi)核實(shí)現(xiàn)USB<b class='flag-5'>驅(qū)動(dòng)</b>程序<b class='flag-5'>框架</b>

Linux總線設(shè)備、驅(qū)動(dòng)模型的探究

Linux總線、設(shè)備、驅(qū)動(dòng)模型的探究
發(fā)表于 02-14 12:01 ?7次下載

Linux設(shè)備驅(qū)動(dòng)開發(fā)詳解

Linux設(shè)備驅(qū)動(dòng)開發(fā)詳解
發(fā)表于 10-28 11:03 ?54次下載

電子發(fā)燒友

中國電子工程師最喜歡的網(wǎng)站

  • 2931785位工程師會(huì)員交流學(xué)習(xí)
  • 獲取您個(gè)性化的科技前沿技術(shù)信息
  • 參加活動(dòng)獲取豐厚的禮品