一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

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)程序的數(shù)據(jù)封裝

開關(guān)電源芯片 ? 來源:Linux與SoC ? 作者:spy_os ? 2021-08-14 11:34 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

0.引言

基于 ARM 內(nèi)核的 SoC 在引入設(shè)備樹技術(shù)之后,通過設(shè)備樹文件來描述不同的設(shè)備并匹配不同的驅(qū)動(dòng)代碼,使得一個(gè) kernel 鏡像文件可以支持多種設(shè)備。這種代碼可重用的思想不僅體現(xiàn)在設(shè)備樹文件中,在驅(qū)動(dòng)代碼中同樣也有所體現(xiàn)。

其中之一就是驅(qū)動(dòng)代碼中設(shè)備描述表-of_device_id。同一個(gè) IP 集成到不同 SoC 或者根據(jù)應(yīng)用場景激活不同功能,可以通過 of_device_id 這個(gè)數(shù)據(jù)結(jié)構(gòu)來實(shí)現(xiàn)。

對(duì)于同一個(gè) IP 集成到不同 SoC 的應(yīng)用場景而言,其寄存器基地址以及時(shí)鐘等參數(shù)可能不同,但是 IP 功能基本一樣。那么可以通過 of_device_id 里的不同 data 條目獲取對(duì)應(yīng)的參數(shù)信息。例如 exynos 的 dsi IP,在不同版本的 SoC 中基地址不同,定義了 5 種 SoC 類型。在 dsi probe 時(shí)獲取其在 SoC 中的基地址。

a3718f80-fc4b-11eb-9bcf-12bb97331649.png

a3a6fc88-fc4b-11eb-9bcf-12bb97331649.png

下面驅(qū)動(dòng)代碼表示該模塊需要支持多種不同時(shí)鐘頻率的初始化,可以定義一個(gè) of_device_id 表,根據(jù)匹配到的設(shè)備信息為每一種時(shí)鐘提供獨(dú)立的初始化函數(shù)。由 of_device_id_match_data 獲取到不同的 init_fn,按照不同的 dev.of_node,執(zhí)行 return init_fn(np);

a4da811a-fc4b-11eb-9bcf-12bb97331649.png

以上應(yīng)用場景核心的數(shù)據(jù)結(jié)構(gòu)是 of_device_id,關(guān)鍵的處理函數(shù)是 of_device_get_match_data(),當(dāng)然,關(guān)于 of_device_id 的應(yīng)用場景不僅僅限于上面說的這兩種。

1.數(shù)據(jù)結(jié)構(gòu) of_device_id

of_device_id 數(shù)據(jù)結(jié)構(gòu)如下,定義在 mod_devicetable.h 中,組成也并不復(fù)雜。

1struct of_device_id {

2 char name[32];

3 char type[32];

4 char compatible[128];

5 const void *data;

6};

mod_devicetable.h 這個(gè)文件最初并沒有 of_device_id 這個(gè)數(shù)據(jù)結(jié)構(gòu),該文件的歷史暫時(shí)也只能查到 2005 年的 Linux-2.6.12-rc2

a53c80c2-fc4b-11eb-9bcf-12bb97331649.png

它的功能從最初的文件中也可以看到,主要是為 PCI 以及 USB 設(shè)備使用的,將設(shè)備的 vendor ID、subsystem ID、class 等信息提供給 scripts/table2alias.c,當(dāng)系統(tǒng)新插入一個(gè) PCI 或 USB 設(shè)備時(shí),用戶空間程序根據(jù)對(duì)應(yīng)的 vendor ID 等信息來加載對(duì)應(yīng)的驅(qū)動(dòng)程序。

2005 年 7 月 Linux-2.6.13-rc2 中提交了 of_match_id 這個(gè)數(shù)據(jù)結(jié)構(gòu)的代碼。

a551b2da-fc4b-11eb-9bcf-12bb97331649.png

2.of_device_get_match_data()

函數(shù)原型位于 drivers/of/device.c

1const void *of_device_get_match_data(

2 const struct device *dev)

3{

4 const struct of_device_id *match;

5

6 match = of_match_device(xxx);

7 if (!match)

8 return NULL;

9

10 return match-》data;

11}

12EXPORT_SYMBOL(of_device_get_match_data);

這個(gè)函數(shù)的返回值類型可強(qiáng)制轉(zhuǎn)換成任何類型,取決于驅(qū)動(dòng)程序中例化數(shù)據(jù)結(jié)構(gòu) of_device_id data。當(dāng)然,由于 of_device_get_match_data 的函數(shù)返回值類型決定了不做強(qiáng)制類型轉(zhuǎn)換,也不會(huì)有問題。

代碼中增加下面的內(nèi)容,來追蹤 of_device_get_match_data 執(zhí)行流程。

#定義 of_device_id 并完成例化

a694184a-fc4b-11eb-9bcf-12bb97331649.png

#在 probe 函數(shù)中增加獲取數(shù)據(jù)的代碼

a7176844-fc4b-11eb-9bcf-12bb97331649.png

執(zhí)行結(jié)果顯示正確的獲取到了 of_device_id 各個(gè)成員例化的 value 值

a7510c34-fc4b-11eb-9bcf-12bb97331649.png

#of_device_get_match_data() 代碼流程

a7784c04-fc4b-11eb-9bcf-12bb97331649.png

有幾種情況是無法獲取到數(shù)據(jù)的

解析 dtb 之后未創(chuàng)建設(shè)備結(jié)點(diǎn)

驅(qū)動(dòng)代碼未實(shí)現(xiàn) of_device_id 設(shè)備表

of_device_id 成員 compatible、name、type 的值和設(shè)備樹中定義的同

基于模塊加載的并且可以熱插拔的驅(qū)動(dòng)程序,可以在系統(tǒng)啟動(dòng)后查看設(shè)備表信息。以定位出未獲取到設(shè)備表信息的故障原因。

3.查看設(shè)備表信息

能夠查看到設(shè)備表信息的一個(gè)前置條件是在定義 of_device_id 的時(shí)候,要將該設(shè)備表通過 MODULE_DEVICE_TABLE 來進(jìn)行聲明注冊(cè),否則在用戶空間是看不到的。其定義在/include/linux/module.h 中。type 可以是 of、usb、pci 等,name 為設(shè)備表的名字。

a7f6127e-fc4b-11eb-9bcf-12bb97331649.png

內(nèi)核中 scripts/mod/file2alias.c,用于將設(shè)備表導(dǎo)出到用戶空間 modules.alias 中,所以可以直接查看 modules.alias 文件。

a84db114-fc4b-11eb-9bcf-12bb97331649.png

也可以通過 modinfo 來查看 ko 文件符號(hào)信息!

a8b86b3a-fc4b-11eb-9bcf-12bb97331649.png

設(shè)備表的定義如下,代碼定義了 name、type,那么設(shè)備樹里同樣也要定義:

a9455112-fc4b-11eb-9bcf-12bb97331649.png

刪除 MODULE_DEVICE_TABLE,modules.alias 里是沒有設(shè)備表信息的。

a954c796-fc4b-11eb-9bcf-12bb97331649.png

對(duì)于 of_device_id 而言,name、type、compatible 添加的方法:

a9784482-fc4b-11eb-9bcf-12bb97331649.png

#USB 設(shè)備表

1struct usb_device_id {

2 /* which fields to match against? */

3 __u16 match_flags;

4

5 /* Used for product specific matches; range is inclusive */

6 __u16 idVendor;

7 __u16 idProduct;

8 __u16 bcdDevice_lo;

9 __u16 bcdDevice_hi;

10

11 /* Used for device class matches */

12 __u8 bDeviceClass;

13 __u8 bDeviceSubClass;

14 __u8 bDeviceProtocol;

15

16 /* Used for interface class matches */

17 __u8 bInterfaceClass;

18 __u8 bInterfaceSubClass;

19 __u8 bInterfaceProtocol;

20

21 /* Used for vendor-specific interface matches */

22 __u8 bInterfaceNumber;

23

24 /* not matched against */

25 kernel_ulong_t driver_info

26 __attribute__((aligned(sizeof(kernel_ulong_t))));

27};

#PCI 設(shè)備表

1struct pci_device_id {

2 __u32 vendor, device; /* Vendor and device ID or PCI_ANY_ID*/

3 __u32 subvendor, subdevice; /* Subsystem ID‘s or PCI_ANY_ID */

4 __u32 class, class_mask; /* (class,subclass,prog-if) triplet */

5 kernel_ulong_t driver_data; /* Data private to the driver */

6};

對(duì)于這兩種類型的設(shè)備,導(dǎo)出的符號(hào)信息和普通設(shè)備也不一樣。

PCI 設(shè)備導(dǎo)出到用戶空間的設(shè)備信息:

aa0d2f3e-fc4b-11eb-9bcf-12bb97331649.png

導(dǎo)出 PCI 設(shè)備信息的代碼

aa66d8ea-fc4b-11eb-9bcf-12bb97331649.png

USB 設(shè)備導(dǎo)出到用戶空間的設(shè)備信息:

aaba9d9a-fc4b-11eb-9bcf-12bb97331649.png

導(dǎo)出 USB 設(shè)備信息的代碼

ab7ded72-fc4b-11eb-9bcf-12bb97331649.png

除了上面三種設(shè)備描述 table 之外,kernel 還提供了很多種其他的設(shè)備描述表,定義在 include/linux/mod_devicetable.h

mod_devicetable.h 的 commit log:

https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/log/include/linux/mod_devicetable.h

編輯:jq

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

    關(guān)注

    134

    文章

    9347

    瀏覽量

    377206
  • usb
    usb
    +關(guān)注

    關(guān)注

    60

    文章

    8175

    瀏覽量

    272622
  • soc
    soc
    +關(guān)注

    關(guān)注

    38

    文章

    4385

    瀏覽量

    222615
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4379

    瀏覽量

    64783

原文標(biāo)題:linux 驅(qū)動(dòng)程序的數(shù)據(jù)封裝

文章出處:【微信號(hào):gh_3980db2283cd,微信公眾號(hào):開關(guān)電源芯片】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    Linux環(huán)境再升級(jí):PLIN驅(qū)動(dòng)程序正式發(fā)布

    PLIN驅(qū)動(dòng)程序現(xiàn)已正式發(fā)布,本文將展示如何安裝PLIN驅(qū)動(dòng)程序,以及如何在Linux環(huán)境下進(jìn)行基本的PLIN通信操作,確保您能夠快速掌握并應(yīng)用這一新工具。
    的頭像 發(fā)表于 04-21 15:29 ?346次閱讀
    <b class='flag-5'>Linux</b>環(huán)境再升級(jí):PLIN<b class='flag-5'>驅(qū)動(dòng)程序</b>正式發(fā)布

    RTC芯片有Linux PCA2131驅(qū)動(dòng)程序嗎?

    RTC 芯片有 Linux PCA2131驅(qū)動(dòng)程序嗎? 1) 如果沒有,我可以使用任何兼容的驅(qū)動(dòng)程序驅(qū)動(dòng)這個(gè) RTC 芯片嗎? 2) 如果是,我在哪里可以找到它?
    發(fā)表于 03-31 06:22

    適用于Oracle的ODBC驅(qū)動(dòng)程序

    Linux 上符合 ODBC 標(biāo)準(zhǔn)的報(bào)告、分析、BI 和 ETL 工具訪問 Oracle 數(shù)據(jù)庫。我們的 ODBC 驅(qū)動(dòng)程序完全支持標(biāo)準(zhǔn) ODBC API 功能和數(shù)據(jù)類型,并支持
    的頭像 發(fā)表于 01-13 09:17 ?505次閱讀

    適用于Oracle的dbExpress驅(qū)動(dòng)程序

    (包括社區(qū)版)快速訪問 Oracle macOS(32 位和 64 位)和 Linux(64 位)平臺(tái)。對(duì)于此服務(wù)器,dbExpress 將驅(qū)動(dòng)程序作為實(shí)現(xiàn)通用 dbExpress 的獨(dú)立庫提供 用于
    的頭像 發(fā)表于 01-09 16:04 ?393次閱讀
    適用于Oracle的dbExpress<b class='flag-5'>驅(qū)動(dòng)程序</b>

    Linux驅(qū)動(dòng)程序程序員指南

    電子發(fā)燒友網(wǎng)站提供《Linux驅(qū)動(dòng)程序程序員指南.pdf》資料免費(fèi)下載
    發(fā)表于 11-22 15:53 ?0次下載
    <b class='flag-5'>Linux</b><b class='flag-5'>驅(qū)動(dòng)程序</b><b class='flag-5'>程序</b>員指南

    pcie設(shè)備驅(qū)動(dòng)程序安裝步驟

    設(shè)備能夠正常工作的重要步驟。 1. 準(zhǔn)備工作 在開始安裝PCIe設(shè)備驅(qū)動(dòng)程序之前,需要做一些準(zhǔn)備工作: 確認(rèn)設(shè)備兼容性 :確保你的PCIe設(shè)備與你的操作系統(tǒng)兼容。 備份數(shù)據(jù) :在安裝任何驅(qū)動(dòng)程序之前,備份重要
    的頭像 發(fā)表于 11-13 10:32 ?3291次閱讀

    Wilink8 Linux Wi-Fi驅(qū)動(dòng)程序R8.8版用戶指南

    電子發(fā)燒友網(wǎng)站提供《Wilink8 Linux Wi-Fi驅(qū)動(dòng)程序R8.8版用戶指南.pdf》資料免費(fèi)下載
    發(fā)表于 11-05 09:19 ?0次下載
    Wilink8 <b class='flag-5'>Linux</b> Wi-Fi<b class='flag-5'>驅(qū)動(dòng)程序</b>R8.8版用戶指南

    用于bq275xx電量計(jì)的WinCE/Linux驅(qū)動(dòng)程序

    電子發(fā)燒友網(wǎng)站提供《用于bq275xx電量計(jì)的WinCE/Linux驅(qū)動(dòng)程序.pdf》資料免費(fèi)下載
    發(fā)表于 10-17 11:17 ?0次下載
    用于bq275xx電量計(jì)的WinCE/<b class='flag-5'>Linux</b><b class='flag-5'>驅(qū)動(dòng)程序</b>

    LSP 2.10 DaVinci Linux驅(qū)動(dòng)程序

    電子發(fā)燒友網(wǎng)站提供《LSP 2.10 DaVinci Linux驅(qū)動(dòng)程序.pdf》資料免費(fèi)下載
    發(fā)表于 10-09 09:30 ?0次下載
    LSP 2.10 DaVinci <b class='flag-5'>Linux</b><b class='flag-5'>驅(qū)動(dòng)程序</b>

    Linux設(shè)備驅(qū)動(dòng)程序分類有哪些

    Linux設(shè)備驅(qū)動(dòng)程序是操作系統(tǒng)與硬件設(shè)備之間的橋梁,負(fù)責(zé)實(shí)現(xiàn)硬件設(shè)備與操作系統(tǒng)之間的通信和控制。Linux設(shè)備驅(qū)動(dòng)程序的分類繁多,可以根據(jù)不同的標(biāo)準(zhǔn)進(jìn)行分類。 按硬件類型分類
    的頭像 發(fā)表于 08-30 15:11 ?1224次閱讀

    linux驅(qū)動(dòng)程序如何加載進(jìn)內(nèi)核

    Linux系統(tǒng)中,驅(qū)動(dòng)程序是內(nèi)核與硬件設(shè)備之間的橋梁。它們?cè)试S內(nèi)核與硬件設(shè)備進(jìn)行通信,從而實(shí)現(xiàn)對(duì)硬件設(shè)備的控制和管理。 驅(qū)動(dòng)程序的編寫 驅(qū)動(dòng)程序的編寫是
    的頭像 發(fā)表于 08-30 15:02 ?1089次閱讀

    linux驅(qū)動(dòng)程序主要有哪些功能

    Linux驅(qū)動(dòng)程序是操作系統(tǒng)與硬件設(shè)備之間進(jìn)行通信的橋梁,負(fù)責(zé)實(shí)現(xiàn)硬件設(shè)備與操作系統(tǒng)之間的數(shù)據(jù)交換和控制。Linux驅(qū)動(dòng)程序的主要功能包括以
    的頭像 發(fā)表于 08-30 14:47 ?895次閱讀

    linux驅(qū)動(dòng)程序的編譯方法是什么

    Linux驅(qū)動(dòng)程序的編譯方法主要包括兩種: 與內(nèi)核一起編譯 和 編譯成獨(dú)立的內(nèi)核模塊 。以下是對(duì)這兩種方法的介紹: 一、與內(nèi)核一起編譯 與內(nèi)核一起編譯意味著將驅(qū)動(dòng)程序的源代碼直接集成到Linu
    的頭像 發(fā)表于 08-30 14:46 ?1236次閱讀

    linux驅(qū)動(dòng)程序的編譯方法有哪兩種

    Linux驅(qū)動(dòng)程序的編譯方法主要可以歸納為兩種: 手動(dòng)編譯 和 使用內(nèi)核構(gòu)建系統(tǒng)(Makefile)自動(dòng)編譯 。 1. 手動(dòng)編譯 手動(dòng)編譯驅(qū)動(dòng)程序通常涉及直接使用GCC(GNU Compiler
    的頭像 發(fā)表于 08-30 14:39 ?1521次閱讀

    linux驅(qū)動(dòng)程序運(yùn)行在什么空間

    Linux 驅(qū)動(dòng)程序是操作系統(tǒng)的一部分,負(fù)責(zé)管理硬件設(shè)備與操作系統(tǒng)之間的交互。驅(qū)動(dòng)程序運(yùn)行在內(nèi)核空間(Kernel Space),這是操作系統(tǒng)的核心部分,與用戶空間(User Space)相對(duì)。內(nèi)核
    的頭像 發(fā)表于 08-30 14:37 ?899次閱讀