當(dāng)前位置:首頁 > 公眾號精選 > 嵌入式微處理器
[導(dǎo)讀][導(dǎo)讀] 前文分析了Linux設(shè)備驅(qū)動(dòng)的驅(qū)動(dòng)模型,本文來聊聊Platform_driver/Platform_device這個(gè)類。做嵌入式Linux的驅(qū)動(dòng),這個(gè)也是繞不開的,所以來學(xué)習(xí)分析總結(jié)一下。 閱讀本文,建議先讀:學(xué)Linux驅(qū)動(dòng):應(yīng)先了解總線驅(qū)動(dòng)模型 上文點(diǎn)擊即可閱讀。注:代碼分析

ich_media_content " id="js_content">
ce.com" style="font-size: 16px;color: black;padding-right: 10px;padding-left: 10px;line-height: 1.6;letter-spacing: 0px;word-break: break-word;overflow-wrap: break-word;text-align: left;font-family: Optima-Regular, Optima, PingFangSC-light, PingFangTC-light, "PingFang SC", Cambria, Cochin, Georgia, Times, "Times New Roman", serif;margin-top: -10px;">
[導(dǎo)讀] 前文分析了Linux設(shè)備驅(qū)動(dòng)的驅(qū)動(dòng)模型,本文來聊聊Platform_driver/Platform_device這個(gè)類。做嵌入式Linux的驅(qū)動(dòng),這個(gè)也是繞不開的,所以來學(xué)習(xí)分析總結(jié)一下。

閱讀本文,建議先讀:學(xué)Linux驅(qū)動(dòng):應(yīng)先了解總線驅(qū)動(dòng)模型

上文點(diǎn)擊即可閱讀。注:代碼分析基于linux-5.4.31

為什么有Platform_driver

前文談到的總線驅(qū)動(dòng)模型(注這個(gè)圖是照著bootlin的文檔繪制的):

同時(shí),根據(jù)代碼分析其基礎(chǔ)數(shù)據(jù)結(jié)構(gòu)框架關(guān)系如下(UML關(guān)系并不嚴(yán)謹(jǐn),僅為理解方便):

可見驅(qū)動(dòng)程序的模型分層有一層總線基礎(chǔ)層,那么對于嵌入式開發(fā)領(lǐng)域而言,有很多SOC芯片內(nèi)置了各種外設(shè),并比如LCD,UART、audio、攝像頭口等等,并沒有總線。為了統(tǒng)一驅(qū)動(dòng)架構(gòu)抽象,所以引入了platform bus這個(gè)虛擬的總線模型。做過嵌入式開發(fā)的人應(yīng)該都有體會,這類設(shè)備在嵌入式系統(tǒng)中非常多,所以在研究具體某類設(shè)備的驅(qū)動(dòng)開發(fā)之前,有必要研究platform 設(shè)備的驅(qū)動(dòng)模型。在強(qiáng)調(diào)一下這個(gè)是統(tǒng)一在總線驅(qū)動(dòng)模型這個(gè)體系內(nèi)的。

驅(qū)動(dòng)模型的實(shí)現(xiàn)

定義在./include/linux/platform_device.h中,來梳理一下這些數(shù)據(jù)結(jié)構(gòu)間的關(guān)系:

  • platform_device 用于抽象平臺設(shè)備
  • platform_driver 用于抽象匹配平臺設(shè)備對應(yīng)的驅(qū)動(dòng)程序
  • 通過繼承演化關(guān)系分析,platform_device/platform_driver 仍然統(tǒng)一于總線驅(qū)動(dòng)模型,只是虛擬出來了一條platform bus這樣一條虛擬總線。
  • platform_bus在哪里實(shí)現(xiàn)的呢?該模塊的實(shí)現(xiàn)位于./driver/base/platform.c中
struct device platform_bus = {
 .init_name = "platform",
};
  • platform.c導(dǎo)出了一系列內(nèi)核全局操作接口集:
EXPORT_SYMBOL_GPL(platform_bus);
EXPORT_SYMBOL_GPL(__platform_driver_register);
EXPORT_SYMBOL_GPL(__platform_driver_probe);
EXPORT_SYMBOL_GPL(platform_get_resource_byname);
EXPORT_SYMBOL_GPL(platform_get_irq_byname);
....
  • 那么既然這條總線并不存在,往往并不能實(shí)現(xiàn)設(shè)備枚舉、熱插拔等功能。

  • 既然不能利用總線自動(dòng)枚舉,那么底層又是怎么玩的呢?實(shí)際上可選的有這樣幾種方式

    • 通過內(nèi)核代碼靜態(tài)描述實(shí)現(xiàn)
    • 通過設(shè)備樹進(jìn)行匹配加載
    • BIOS ACPI表(X86/PC體系)
  • 平臺設(shè)備是通常在系統(tǒng)中顯示為自治實(shí)體的設(shè)備。這包括基于舊端口的設(shè)備和到外圍總線的主機(jī)橋接,以及集成到片上系統(tǒng)平臺中的大多數(shù)控制器。它們通常的共同點(diǎn)是從CPU總線直接尋址。很少有platform_device通過某種其他類型的總線的一部分連接的。但其寄存器仍將直接可尋址。

設(shè)備探測

  • probe()通常應(yīng)該驗(yàn)證指定的設(shè)備硬件確實(shí)存在;有時(shí)平臺設(shè)置代碼不能確定。該函數(shù)用于檢測可以使用設(shè)備資源,包括時(shí)鐘和設(shè)備platform_data。
  • 設(shè)備的注冊則是通過下面函數(shù)實(shí)現(xiàn)
int platform_driver_register(struct platform_driver *drv);

設(shè)備命令以及綁定

  • platform_device.dev.bus_id 設(shè)備名由兩個(gè)部分組成
    • platform_device.name 用于驅(qū)動(dòng)匹配
    • platform_device.id 設(shè)備實(shí)例號,或者用“-1”表示只有一個(gè)實(shí)例
    • 如"serial/0“ 表示 bus_id "serial.0","serial/3“ 表示 bus_id "serial.3"
  • 驅(qū)動(dòng)程序綁定由驅(qū)動(dòng)程序核心自動(dòng)執(zhí)行,在發(fā)現(xiàn)設(shè)備和驅(qū)動(dòng)程序之間的匹配之后調(diào)用驅(qū)動(dòng)程序probe()。如果probe()成功,驅(qū)動(dòng)程序和設(shè)備將像往常一樣綁定。有三種不同的方法來找到這樣的匹配:
    • 每當(dāng)注冊一個(gè)設(shè)備時(shí),就會檢查該總線的驅(qū)動(dòng)程序是否匹配。平臺設(shè)備應(yīng)該在系統(tǒng)啟動(dòng)時(shí)盡早注冊.
    • 當(dāng)使用platform_driver_register()注冊一個(gè)驅(qū)動(dòng)程序時(shí),將檢查總線上所有未綁定的設(shè)備是否匹配。驅(qū)動(dòng)程序通常在引導(dǎo)期間稍后注冊,或者通過模塊加載注冊。
    • 使用platform_driver_probe()注冊驅(qū)動(dòng)程序與使用platform_driver_register()一樣,不同的是,如果以后有其他設(shè)備注冊,驅(qū)動(dòng)程序不會被探測。

資源機(jī)制

  • 每個(gè)由特定驅(qū)動(dòng)程序管理的設(shè)備通常使用不同的硬件資源:I/O寄存器地址、DMA通道、IRQ線路等。
  • struct resource就是用于抽象描述驅(qū)動(dòng)程序需要用到的硬件資源,struct resource 被包進(jìn)platform_device,實(shí)現(xiàn)與 struct platform_device關(guān)聯(lián)。
  • 允許驅(qū)動(dòng)程序被實(shí)例化為多個(gè)功能類似的設(shè)備,但具有不同的地址、irq等。
  • 硬件資源如時(shí)針、IO口等的分配現(xiàn)在基本基于設(shè)備樹,對于設(shè)備樹這里不展開,后面有機(jī)會總結(jié)分享,這里舉個(gè)栗子:
uart0: serial@44e09000 {
    compatible = "ti,omap3-uart";
    ti,hwmods = "uart1";
    clock-frequency = <48000000>;
    reg = <0x44e09000 0x2000>;
    interrupts = <72>;
    status = "disabled";
};

platform_driver實(shí)例

以samsung.c 串口驅(qū)動(dòng)程序?yàn)槔?/p>

/*兼容匹配表*/
static const struct platform_device_id s3c24xx_serial_driver_ids[] = {
 {
  .name  = "s3c2410-uart",
  .driver_data = S3C2410_SERIAL_DRV_DATA,
 }, {
  .name  = "s3c2412-uart",
  .driver_data = S3C2412_SERIAL_DRV_DATA,
 }, {
  .name  = "s3c2440-uart",
  .driver_data = S3C2440_SERIAL_DRV_DATA,
 }, {
  .name  = "s3c6400-uart",
  .driver_data = S3C6400_SERIAL_DRV_DATA,
 }, {
  .name  = "s5pv210-uart",
  .driver_data = S5PV210_SERIAL_DRV_DATA,
 }, {
  .name  = "exynos4210-uart",
  .driver_data = EXYNOS4210_SERIAL_DRV_DATA,
 }, {
  .name  = "exynos5433-uart",
  .driver_data = EXYNOS5433_SERIAL_DRV_DATA,
 },
 { },
};
MODULE_DEVICE_TABLE(platform, s3c24xx_serial_driver_ids);

#ifdef CONFIG_OF
/*設(shè)備樹對應(yīng)解析匹配表*/
static const struct of_device_id s3c24xx_uart_dt_match[] = {
 { .compatible = "samsung,s3c2410-uart",
  .data = (void *)S3C2410_SERIAL_DRV_DATA },
 { .compatible = "samsung,s3c2412-uart",
  .data = (void *)S3C2412_SERIAL_DRV_DATA },
 { .compatible = "samsung,s3c2440-uart",
  .data = (void *)S3C2440_SERIAL_DRV_DATA },
 { .compatible = "samsung,s3c6400-uart",
  .data = (void *)S3C6400_SERIAL_DRV_DATA },
 { .compatible = "samsung,s5pv210-uart",
  .data = (void *)S5PV210_SERIAL_DRV_DATA },
 { .compatible = "samsung,exynos4210-uart",
  .data = (void *)EXYNOS4210_SERIAL_DRV_DATA },
 { .compatible = "samsung,exynos5433-uart",
  .data = (void *)EXYNOS5433_SERIAL_DRV_DATA },
 {},
};
MODULE_DEVICE_TABLE(of, s3c24xx_uart_dt_match);
#endif
/*串口設(shè)備驅(qū)動(dòng)實(shí)體*/
static struct platform_driver samsung_serial_driver = {
 .probe  = s3c24xx_serial_probe,
 .remove  = s3c24xx_serial_remove,
 .id_table = s3c24xx_serial_driver_ids,
 .driver  = {
  .name = "samsung-uart",
  .pm = SERIAL_SAMSUNG_PM_OPS,
  .of_match_table = of_match_ptr(s3c24xx_uart_dt_match),
 },
};

總結(jié)一下

對于做嵌入式Linux驅(qū)動(dòng)開發(fā),個(gè)人體會是先對總線驅(qū)動(dòng)模型有一個(gè)相對清晰的概念認(rèn)識會比較好,而平臺設(shè)備以及平臺設(shè)備驅(qū)動(dòng)模型同樣是衍生于總線驅(qū)動(dòng)模型,這樣從體系結(jié)構(gòu)上就變得相對統(tǒng)一了。平臺設(shè)備及驅(qū)動(dòng)在嵌入式系統(tǒng)里大量應(yīng)用,很多SOC內(nèi)置了大量豐富的各類設(shè)備接口,這些接口往往都是通過處理器內(nèi)部總線進(jìn)行直接尋址的,這類型的設(shè)備幾乎都是通過平臺設(shè)備及驅(qū)動(dòng)模型進(jìn)行抽象實(shí)施的,所以深入理解平臺設(shè)備/平臺設(shè)備驅(qū)動(dòng)模型,無疑對開發(fā)此類設(shè)備驅(qū)動(dòng)程序大有助益。


本文授權(quán)轉(zhuǎn)載自公眾號“嵌入式客棧”,作者逸珺


-END-




推薦閱讀



【01】學(xué)Linux驅(qū)動(dòng):應(yīng)先了解總線驅(qū)動(dòng)模型
【02】對工作幫助極大!Linux 內(nèi)存相關(guān)問題匯總
【03】最全Linux面試題(2020最新版)
【04】國內(nèi)最良心的Linux!深度操作系統(tǒng) 20 BETA 發(fā)布
【05】十個(gè)你可能不曾用過的 Linux 命令


免責(zé)聲明:整理文章為傳播相關(guān)技術(shù),版權(quán)歸原作者所有,如有侵權(quán),請聯(lián)系刪除
cene=21#wechat_redirect" target="_blank" rel="nofollow">

免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

嵌入式ARM

掃描二維碼,關(guān)注更多精彩內(nèi)容

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運(yùn)營商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動(dòng)現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡稱"軟通動(dòng)力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉