Linux設備樹語法詳解

来源:http://www.cnblogs.com/xiaojiang1025/archive/2016/12/06/6131381.html
-Advertisement-
Play Games

概念 Linux內核從3.x開始引入設備樹的概念,用於實現 驅動代碼與設備信息相分離 。在設備樹出現以前,所有關於設備的具體信息都要寫在驅動里,一旦外圍設備變化,驅動代碼就要重寫。引入了設備樹之後,驅動代碼只負責處理驅動的邏輯,而關於設備的具體信息存放到設備樹文件中,這樣,如果只是硬體介面信息的變化 ...


概念

Linux內核從3.x開始引入設備樹的概念,用於實現驅動代碼與設備信息相分離。在設備樹出現以前,所有關於設備的具體信息都要寫在驅動里,一旦外圍設備變化,驅動代碼就要重寫。引入了設備樹之後,驅動代碼只負責處理驅動的邏輯,而關於設備的具體信息存放到設備樹文件中,這樣,如果只是硬體介面信息的變化而沒有驅動邏輯的變化,驅動開發者只需要修改設備樹文件信息,不需要改寫驅動代碼。比如在ARM Linux內,一個.dts(device tree source)文件對應一個ARM的machine,一般放置在內核的"arch/arm/boot/dts/"目錄內,比如exynos4412參考板的板級設備樹文件就是"arch/arm/boot/dts/exynos4412-origen.dts"。這個文件可以通過$make dtbs命令編譯成二進位的.dtb文件供內核驅動使用。

基於同樣的軟體分層設計的思想,由於一個SoC可能對應多個machine,如果每個machine的設備樹都寫成一個完全獨立的.dts文件,那麼勢必相當一些.dts文件有重覆的部分,為瞭解決這個問題,Linux設備樹目錄把一個SoC公用的部分或者多個machine共同的部分提煉為相應的.dtsi文件。這樣每個.dts就只有自己差異的部分,公有的部分只需要"include"相應的.dtsi文件, 這樣就是整個設備樹的管理更加有序。我這裡用`Linux4.8.5源碼自帶的dm9000網卡為例來分析設備樹的使用和移植。這個網卡的設備樹節點信息在"Documentation/devicetree/bindings/net/davicom-dm9000.txt"有詳細說明,其網卡驅動源碼是"drivers/net/ethernet/davicom/dm9000.c"

設備樹框架

設備樹用樹狀結構描述設備信息,它有以下幾種特性

  1. 每個設備樹文件都有一個根節點,每個設備都是一個節點。
  2. 節點間可以嵌套,形成父子關係,這樣就可以方便的描述設備間的關係。
  3. 每個設備的屬性都用一組key-value對(鍵值對)來描述。
  4. 每個屬性的描述用;結束

所以,一個設備樹的基本框架可以寫成下麵這個樣子

/{                                  //根節點
    node1{                          //node1是節點名,是/的子節點
        key=value;                  //node1的屬性
        ...
        node2{                      //node2是node1的子節點
            key=value;              //node2的屬性
            ...
        }
    }                               //node1的描述到此為止
    node3{
        key=value;
        ...
    }
}

節點名

理論個節點名只要是長度不超過31個字元的ASCII字元串即可,此外
Linux內核還約定設備名應寫成形如<name>[@<unit_address>]的形式,其中name就是設備名,unit_address就是設備地址,如果有應該寫上,下麵就是典型節點名的寫法

Linux中的設備樹還包括幾個特殊的節點,比如chosen,chosen節點不描述一個真實設備,而是用於firmware傳遞一些數據給OS,比如bootloader傳遞內核啟動參數給內核

引用

當我們找一個節點的時候,我們必須書寫完整的節點路徑,這樣當一個節點嵌套比較深的時候就不是很方便,所以,設備樹允許我們用下麵的形式為節點標註引用(起別名),藉以省去冗長的路徑。這樣就可以實現類似函數調用的效果。編譯設備樹的時候,相同的節點的不同屬性信息都會被合併到設備節點中,而相同的屬性會被覆蓋,使用引用可以避免移植者四處找節點,直接在板級.dts增改即可。

下麵的例子中就是直接引用了dtsi中的一個節點,並向其中添加/修改新的屬性信息

KEY

在設備樹中,鍵值對是描述屬性的方式,比如,Linux驅動中可以通過設備節點中的"compatible"這個屬性查找設備節點。
Linux設備樹語法中定義了一些具有規範意義的屬性,包括:compatible, address, interrupt等,這些信息能夠在內核初始化找到節點的時候,自動解析生成相應的設備信息。此外,還有一些Linux內核定義好的,一類設備通用的有預設意義的屬性,這些屬性一般不能被內核自動解析生成相應的設備信息,但是內核已經編寫的相應的解析提取函數,常見的有 "mac_addr""gpio""clock""power""regulator" 等等。

compatible

設備節點中對應的節點信息已經被內核構造成struct platform_device。驅動可以通過相應的函數從中提取信息。compatible屬性是用來查找節點的方法之一,另外還可以通過節點名或節點路徑查找指定節點。dm9000驅動中就是使用下麵這個函數通過設備節點中的"compatible"屬性提取相應的信息,所以二者的字元串需要嚴格匹配。

address

(幾乎)所有的設備都需要與CPU的IO口相連,所以其IO埠信息就需要在設備節點節點中說明。常用的屬性有

  • #address-cells,用來描述子節點"reg"屬性的地址表中用來描述首地址的cell的數量
  • #size-cells,用來描述子節點"reg"屬性的地址表中用來描述地址長度的cell的數量

有了這兩個屬性,子節點中的"reg"就可以描述一塊連續的地址區域。下例中,父節點中指定了"#address-cells = <2>" "#size-cells = <1>",則子節點dev-bootscs0中的reg中的前兩個數表示一個地址,最後的0x4表示地址跨度是0x4

interrupts

一個電腦系統中大量設備都是通過中斷請求CPU服務的,所以設備節點中就需要在指定中斷號。常用的屬性有

  • interrupt-controller 一個空屬性用來聲明這個node接收中斷信號
  • #interrupt-cells,是中斷控制器節點的屬性,用來標識這個控制器需要幾個單位做中斷描述符,用來描述子節點中"interrupts"屬性使用了父節點中的interrupts屬性的具體的哪個值。一般,如果父節點的該屬性的值是3,則子節點的interrupts一個cell的三個32bits整數值分別為:<中斷域 中斷 觸發方式>,如果父節點的該屬性是2,則是<中斷 觸發方式>
  • interrupt-parent,標識此設備節點屬於哪一個中斷控制器,如果沒有設置這個屬性,會自動依附父節點的
  • interrupts,一個中斷標識符列表,表示每一個中斷輸出信號

這裡,在我板子上的dm9000的的設備節點中,"interrupt-parent"使用了exynos4x12-pinctrl.dtsi(被板級設備樹的exynos4412.dtsi包含)中的gpx0節點的引用,而在gpx0節點中,指定了"#interrupt-cells = <2>;",所以在dm9000中的屬性"interrupts = <6 4>;"表示指定gpx0中的屬性"interrupts"中的"<0 22 0>",通過查閱exynos4412的手冊知道,對應的中斷號是EINT[6]。

gpio

gpio也是最常見的IO口,常用的屬性有

  • "gpio-controller",用來說明該節點描述的是一個gpio控制器
  • "#gpio-cells",用來描述gpio使用節點的屬性一個cell的內容,即 屬性 = <&引用GPIO節點別名 GPIO標號 工作模式>

驅動自定義key

針對具體的設備,有部分屬性很難做到通用,需要驅動自己定義好,通過內核的屬性提取解析函數進行值的獲取,比如dm9000節點中的下麵這句就是自定義的節點屬性,用以表示配置EEPROM不可用。

VALUE

dts描述一個鍵的值有多種方式,當然,一個鍵也可以沒有值

字元串信息

32bit無符號整型數組信息

二進位數數組

字元串哈希表

混合形式

上述幾種的混合形式

設備樹/驅動移植

設備樹就是為驅動服務的,配置好設備樹之後還需要配置相應的驅動才能檢測配置是否正確。比如dm9000網卡,就需要首先將示例信息掛接到我們的板級設備樹上,並根據晶元手冊和電路原理圖將相應的屬性進行配置,再配置相應的驅動。需要註意的是,dm9000的地址線一般是接在片選線上的,我這裡用的exynos4412,接在了bank1,所以是"<0x50000000 0x2 0x50000004 0x2>"
最終的配置結果是:

勾選相應的選項將dm9000的驅動編譯進內核。

make menuconfig
[*] Networking support  --->
    Networking options  --->
        <*> Packet socket
        <*>Unix domain sockets 
        [*] TCP/IP networking
        [*]   IP: kernel level autoconfiguration
Device Drivers  --->
    [*] Network device support  --->
        [*]   Ethernet driver support (NEW)  --->
            <*>   DM9000 support
File systems  --->
    [*] Network File Systems (NEW)  --->
        <*>   NFS client support
        [*]     NFS client support for NFS version 3
        [*]       NFS client support for the NFSv3 ACL protocol extension
        [*]   Root file system on NFS

執行make uImage;make dtbs,tftp下載,成功載入nfs根文件系統併進入系統,表示網卡移植成功




您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • SDRAM(Synchronous Dynamic Random Access Memory,同步動態隨機存儲器)也就是通常所說的記憶體。同步是指其時鐘頻率與CPU前端匯流排的系統時鐘頻率相同;動態是指存儲陣列需要不斷的刷新來保證數據不丟失;隨機是指數據不是線性依次存儲的。 ...
  • CentOS 6.5 x86_64系統下安裝MySQL-5.6.10,並且根據生產環境需要做了一定的安全配置。 ...
  • ARM彙編語言(Assembly Language)是ARM CPU所能接受的最底層唯一語言(所有的高級語言最終都要轉換成彙編語言然後彙編成processor instruction codes)。ARM彙編的核心是ARM指令集。理解ARM彙編有助於理解底層processor內部的工作原理,有助於對... ...
  • ARM(Advanced RISC Machine)採用的是RISC精簡指令集,Load/Store架構,所有指令必須載入到寄存器才能進行運算。7種工作模式。31個通用寄存器,6個狀態寄存器。大小端可配置。 ...
  • 由於操作不當,導致git版本庫出了大問題,如下所示: 即提示xx文件是空的。在使用git log、git commit、git status等命令都會出此錯誤(文件名可能不一樣)。如果把.git刪掉,重新init,那會很輕鬆地暴力地解決了這個問題。但是,這樣的話之前的版本信息就全部丟失了,這並不是想 ...
  • 1、Linux,繼承魚Unix 2、Unix檔案系統的兩個重要概念 3、幾個主要的 Linux distributions 發行者網址: • Red Hat: http://www.redhat.com• Fedora: http://fedora.redhat.com• Mandriva: htt... ...
  • 黃山松發表於博客園:http://www.cnblogs.com/tomview/p/6137179.html #ifndef lxx_hss_auto_clipboard_hss#define lxx_hss_auto_clipboard_hss /************************... ...
  • 這是博主第一次寫博客,本人雖然目前就讀的專業屬電腦,但目前也是屬於新手上路的那一類人。正好不久前解決了一個困擾了我很久的問題 ,現在拿出來給大家分享一下。 上個學期學校的工作室給大家集中普及linux操作系統,最後大家集中安裝了Ubuntu16.04,畢竟是一個圖形化界面的linux系統,新手上手 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...