欧美色综合网_狠狠色狠色综合曰曰_麻豆精品一区二区av白丝在线_久久精品综合一区
網絡消費網 >  5G > > 正文
Linux內核中的platform機制
時間:2021-12-08 22:22:05

Linux2.6起引入了一套新的驅動管理和注冊機制platform_device和platform_driver。Linux中大部分的設備驅動,都可以使用這套機制,設備用platform_device表示,驅動用platform_driver進行注冊。

本文引用地址:http://www.eepw.com.cn/article/148691.htm

Linuxplatform. driver機制和傳統的device driver 機制(通過driver_register函數進行注冊)相比,一個十分明顯的優勢在于platform機制將設備本身的資源注冊進內核,由內核統一管理,在驅動程序中使用這些資源時通過platform. device提供的標準接口進行申請并使用。這樣提高了驅動和資源管理的獨立性,并且擁有較好的可移植性和安全性(這些標準接口是安全的)。platform機制的本身使用并不復雜,由兩部分組成:platform_device和platfrom_driver。通過platform機制開發底層設備驅動的大致流程如圖所示。

圖 platform機制開發驅動流程

platform_device結構體用來描述設備的名稱、資源信息等。該結構被定義在include/linux/platform_device.h中,定義原型如下:

struct platform_device {

const char * name; //定義平臺設備的名稱

int id;

struct device dev;

u32 num_resources;

struct resource * resource; //定義平臺設備的資源。

};

下面來看一下platform_device結構體中最重要的一個成員struct resource * resource。struct resource被定義在include/linux/ioport.h中,定義原型如下:

struct resource {

resource_size_t start; //定義資源的起始地址

resource_size_t end; //定義資源的結束地址

const char *nAME; //定義資源的名稱

unsigned long flags; //定義資源的類型,比如MEM,IO,IRQ,DMA類型

struct resource *parent, *sibling, *child; //資源鏈表指針

};

通過調用函數platform_add_devices()向系統中添加該設備了,該函數內部調用platform_device_register( )進行設備注冊。要注意的是,這里的platform_device設備的注冊過程必須在相應設備驅動加載之前被調用,即執行platform_driver_register()之前,原因是驅動注冊時需要匹配內核中所有已注冊的設備名。

接下來來看platform_driver結構體的原型定義,在include/linux/platform_device.h中,代碼如下:

struct platform_driver {

int (*probe)(struct platform_device *);

int (*remove)(struct platform_device *);

void (*shutdown)(struct platform_device *);

int (*suspend)(struct platform_device *, pm_message_t state);

int (*suspend_late)(struct platform_device *, pm_message_t state);

int (*resume_early)(struct platform_device *);

int (*resume)(struct platform_device *);

struct device_driver driver;

};

內核提供的platform_driver結構體的注冊函數為platform_driver_register(),其原型定義在driver/base/platform.c文件中,具體實現代碼如下:

int platform_driver_register(struct platform_driver *drv)

{

drv->driver.bus = platform_bus_type;

if (drv->probe)

drv->driver.probe = platform_drv_probe;

if (drv->remove)

drv->driver.remove = platform_drv_remove;

if (drv->shutdown)

drv->driver.shutdown = platform_drv_shutdown;

if (drv->suspend)

drv->driver.suspend = platform_drv_suspend;

if (drv->resume)

drv->driver.resume = platform_drv_resume;

return driver_register(drv->driver);

}

總結,通常情況下只要和內核本身運行依賴性不大的外圍設備,相對獨立的,擁有各自獨自的資源(地址總線和IRQs),都可以用platform_driver實現。如:LCD,網卡、USB、UART等,都可以用platfrom_driver寫,而timer,irq等小系統之內的設備則最好不用platfrom_driver機制。

關鍵詞: 機制 platform 內核 Linux

版權聲明:
    凡注明來網絡消費網的作品,版權均屬網絡消費網所有,未經授權不得轉載、摘編或利用其它方式使用上述作品。已經本網授權使用作品的,應在授權范圍內使用,并注明"來源:網絡消費網"。違反上述聲明者,本網將追究其相關法律責任。
    除來源署名為網絡消費網稿件外,其他所轉載內容之原創性、真實性、完整性、及時性本站不作任何保證或承諾,請讀者僅作參考并自行核實。
熱文

網站首頁 |網站簡介 | 關于我們 | 廣告業務 | 投稿信箱
 

Copyright © 2000-2020 www.yjkq2010.com All Rights Reserved.
 

中國網絡消費網 版權所有 未經書面授權 不得復制或建立鏡像
 

聯系郵箱:920 891 263@qq.com

備案號:京ICP備2022016840號-15

營業執照公示信息

欧美色综合网_狠狠色狠色综合曰曰_麻豆精品一区二区av白丝在线_久久精品综合一区
主站蜘蛛池模板: 久久久久久久久一区二区| 在线不卡中文字幕播放| 久久久综合网| 欧美三级午夜理伦三级中视频| 国内偷自视频区视频综合| 午夜国产精品视频| 国产精品播放| 在线一区二区三区四区| 欧美粗暴jizz性欧美20| 欧美国产成人精品| 亚洲欧洲日韩在线| 欧美不卡三区| 亚洲老板91色精品久久| 欧美jizz19性欧美| 亚洲精品永久免费| 欧美激情视频在线播放| 夜夜爽av福利精品导航| 欧美三级在线播放| 午夜精品久久久久久| 韩国视频理论视频久久| 久热这里只精品99re8久| 亚洲狠狠婷婷| 欧美日韩在线一区| 欧美在线视频免费播放| 永久555www成人免费| 欧美激情一区二区三区成人| 99ri日韩精品视频| 国产精品精品视频| 久久久久久久一区二区三区| 亚洲精品麻豆| 国产伦精品一区二区三区在线观看 | 日韩一二三区视频| 久久久另类综合| 欧美激情导航| 亚洲网址在线| 国产日韩亚洲欧美精品| 免费一区二区三区| 小辣椒精品导航| 亚洲人精品午夜| 国产精品一区亚洲| 欧美精品国产一区|