從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.xnbt.net All Rights Reserved.
中國網絡消費網 版權所有 未經書面授權 不得復制或建立鏡像
聯系郵箱:920 891 263@qq.com
主站蜘蛛池模板: 一级看片| 又大又硬又黄又刺激的免费视频| 好妈妈5高清中字在线观看| 欧美精品寂寞影院请用uc| 男乱女| 房客(糙汉)何璐程曜坤| 挺进白嫩老师下面视频| 国产一区电影| 一二三四在线播放免费视频中国| 免费看日b视频| 五月深爱网| 毛片大全免费| aaa毛片免费观看| 天天摸天天摸色综合舒服网| 亚洲成a人片在线观看中文| 青青国产线免观| 日本理论在线| 狠狠天天| 成人毛片18女人毛片免费视频未| 久久精品精品| 久久国产精品二国产精品| 欧美激情一区二区| 蜜桃成熟时3之蜜桃仙子电影| 国产无遮挡又黄又爽高清视| 悠悠色影院| 亚洲大成色www永久网站| 久久国产成人精品国产成人亚洲| 里番库全彩本子彩色h琉璃| 李采潭一级毛片高清中文字幕| 女人和拘做受口述| 亚洲精品www久久久久久| 香蕉视频毛片| 2021国内精品久久久久影院| 亚洲va韩国va欧美va| 国产福利影院在线观看| 中国老太大bbw| 国产精品高清一区二区三区 | 娇妻之欲海泛舟白丽交换 | 国内精品久久久久久不卡影院| 免费网站看v片在线a| 太深了灬太大了灬舒服|