從Linux2.6起引入了一套新的驅動管理和注冊機制:platform_device和platform_driver。Linux中大部分的設備驅動,都可以使用這套機制,設備用platform_device表示,驅動用platform_driver進行注冊。
本文引用地址:http://www.eepw.com.cn/article/148691.htmLinuxplatform. 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機制。
網站首頁 |網站簡介 | 關于我們 | 廣告業務 | 投稿信箱
Copyright © 2000-2020 www.yjkq2010.com All Rights Reserved.
中國網絡消費網 版權所有 未經書面授權 不得復制或建立鏡像
聯系郵箱:920 891 263@qq.com
欧美色综合网_狠狠色狠色综合曰曰_麻豆精品一区二区av白丝在线_久久精品综合一区 主站蜘蛛池模板: 久久久久久久久一区二区| 在线不卡中文字幕播放| 久久久综合网| 欧美三级午夜理伦三级中视频| 国内偷自视频区视频综合| 午夜国产精品视频| 国产精品播放| 在线一区二区三区四区| 欧美粗暴jizz性欧美20| 欧美国产成人精品| 亚洲欧洲日韩在线| 欧美不卡三区| 亚洲老板91色精品久久| 欧美jizz19性欧美| 亚洲精品永久免费| 欧美激情视频在线播放| 夜夜爽av福利精品导航| 欧美三级在线播放| 午夜精品久久久久久| 韩国视频理论视频久久| 久热这里只精品99re8久| 亚洲狠狠婷婷| 欧美日韩在线一区| 欧美在线视频免费播放| 永久555www成人免费| 欧美激情一区二区三区成人| 99ri日韩精品视频| 国产精品精品视频| 久久久久久久一区二区三区| 亚洲精品麻豆| 国产伦精品一区二区三区在线观看 | 日韩一二三区视频| 久久久另类综合| 欧美激情导航| 亚洲网址在线| 国产日韩亚洲欧美精品| 免费一区二区三区| 小辣椒精品导航| 亚洲人精品午夜| 国产精品一区亚洲| 欧美精品国产一区|