亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 服務器 > Linux服務器 > 正文

詳解Linux驅動中,probe函數何時被調用

2024-09-05 23:03:12
字體:
來源:轉載
供稿:網友

最近看到linux的設備驅動模型,關于Kobject、Kset等還不是很清淅??吹搅藄truct device_driver這個結構時,想到一個問題:它的初始化函數到底在哪里調用呢?以前搞PCI驅動時用pci驅動注冊函數就可以調用它,搞s3c2410驅動時只要在mach-smdk2410.c中的struct platform_device *smdk2410_devices {}中加入設備也會調用。但從來就沒有想過具體的驅動注冊并調用probe的過程。

于是打開SourceInsight追蹤了一下:

從driver_register看起:

int driver_register(struct device_driver * drv){    klist_init(&drv->klist_devices, klist_devices_get, klist_devices_put);    init_completion(&drv->unloaded);    return bus_add_driver(drv);}

klist_init與init_completion沒去管它,可能是2.6的這個設備模型要做的一些工作。直覺告訴我要去bus_add_driver。

bus_add_driver中:

都是些Kobject 與 klist 、attr等。還是與設備模型有關的。但是其中有一句:

driver_attach(drv);

單聽名字就很像:

void driver_attach(struct device_driver * drv){    bus_for_each_dev(drv->bus, NULL, drv, __driver_attach);}

這個熟悉,遍歷總線上的設備并設用__driver_attach。

在__driver_attach中又主要是這樣:

driver_probe_device(drv, dev);

跑到driver_probe_device中去看看:

有一段很重要:

if (drv->bus->match && !drv->bus->match(dev, drv))        goto Done;

明顯,是調用的驅動的總線上的match函數。如果返回1,則可以繼續,否則就Done了。

繼承執行的話:

    if (drv->probe) {        ret = drv->probe(dev);        if (ret) {            dev->driver = NULL;            goto ProbeFailed;        }

只要probe存在則調用之。至此就完成了probe的調用。

這個過程鏈的關鍵還是在drv->bus->match ,因為其余的地方出錯的話就是注冊失敗,而只要注冊不失敗且match返回1,那么就鐵定會調用驅程的probe了。你可以注冊一個總線類型和總線,并在match中總是返回 1, 會發現,只要struct device_driver中的bus類型正確時,probe函數總是被調用.

PCI設備有自己的總線模型,估計在它的match中就有一個判斷的條件。

static int pci_bus_match(struct device *dev, struct device_driver *drv){    struct pci_dev *pci_dev = to_pci_dev(dev);    struct pci_driver *pci_drv = to_pci_driver(drv);    const struct pci_device_id *found_id;    found_id = pci_match_device(pci_drv, pci_dev);    if (found_id)        return 1;    return 0;}

再往下跟蹤就知道主要是根據我們熟悉的id_table來的。

-------------------------------另解-----------------------------------------------------------------------------------------------

從driver_register看起,此處我的這里是:

int driver_register(struct device_driver * drv){if ((drv->bus->probe && drv->probe) ||   (drv->bus->remove && drv->remove) ||   (drv->bus->shutdown && drv->shutdown)) {  printk(KERN_WARNING "Driver '%s' needs updating - please use bus_type methods/n", drv->name);}klist_init(&drv->klist_devices, NULL, NULL);return bus_add_driver(drv);} 

klist_init不相關,不用管他,具體再去看bus_add_driver:

int bus_add_driver(struct device_driver *drv){//1.先kobject_set_name(&drv->kobj, "%s", drv->name);//2.再kobject_register(&drv->kobj)//3.然后調用了:driver_attach(drv)}
int driver_attach(struct device_driver * drv){return bus_for_each_dev(drv->bus, NULL, drv, __driver_attach);}

真正起作用的是__driver_attach:

static int __driver_attach(struct device * dev, void * data){...if (!dev->driver)  driver_probe_device(drv, dev);...}int driver_probe_device(struct device_driver * drv, struct device * dev){...//1.先是判斷bus是否match:if (drv->bus->match && !drv->bus->match(dev, drv))  goto done;//2.再具體執行probe:ret = really_probe(dev, drv);...}

really_probe才是我們要找的函數: 

static int really_probe(struct device *dev, struct device_driver *drv){...//1.先是調用的驅動所屬總線的probe函數:if (dev->bus->probe) {  ret = dev->bus->probe(dev);  if (ret)  goto probe_failed;} else if (drv->probe) {//2.再調用你的驅動中的probe函數:  ret = drv->probe(dev);  if (ret)  goto probe_failed;}...}

其中,drv->probe(dev),才是真正調用你的驅動實現的具體的probe函數。

也就是對應此文標題所問的,probe函數此時被調用。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲欧美日韩精品久久奇米色影视| 欧美国产欧美亚洲国产日韩mv天天看完整| 98精品国产自产在线观看| 久久av红桃一区二区小说| 欧美视频免费在线| 国产精品欧美风情| 中文字幕视频在线免费欧美日韩综合在线看| 久久久久久免费精品| 久久久精品中文字幕| 国产精品成人久久久久| 91夜夜未满十八勿入爽爽影院| 欧美日韩亚洲一区二区三区| 国产免费一区视频观看免费| 国产精品一区二区三区久久| 成人午夜激情免费视频| 久久久久亚洲精品成人网小说| 情事1991在线| 欧美电影免费观看高清| 亚洲精品电影在线观看| 欧美在线视频播放| 国产热re99久久6国产精品| 精品中文视频在线| 在线看国产精品| 国产欧美日韩丝袜精品一区| 久久久久久91香蕉国产| 精品国产91乱高清在线观看| 成人免费视频xnxx.com| 国产精品91久久| 日韩精品中文字幕视频在线| 亚洲尤物视频网| 日韩一区二区av| 国产主播精品在线| 亚洲精品国产suv| 精品国产视频在线| 亚洲欧美日韩综合| 性欧美xxxx交| 成人久久一区二区| 伊人久久久久久久久久久| 色婷婷综合久久久久中文字幕1| 国产欧美日韩精品丝袜高跟鞋| 欧美美女18p| 欧洲亚洲免费在线| 久久久之久亚州精品露出| 日韩精品亚洲元码| 午夜精品理论片| 亚洲精品久久久久久久久久久| 国产一区视频在线播放| 国产视频精品久久久| 欧美人与物videos| 欧美性色视频在线| 欧美床上激情在线观看| 日韩在线播放av| 爽爽爽爽爽爽爽成人免费观看| 欧美黄色片免费观看| 欧美精品日韩三级| 久国内精品在线| 国产精品18久久久久久首页狼| 国产精品专区h在线观看| xxxxx91麻豆| 这里只有精品在线播放| 91po在线观看91精品国产性色| 欧美成人剧情片在线观看| 久久精品国产欧美激情| 国产精品一区二区三区毛片淫片| 欧美激情国产精品| 深夜福利日韩在线看| 蜜臀久久99精品久久久久久宅男| 91社影院在线观看| 亚洲专区国产精品| 欧美激情极品视频| 亚洲精品久久久久国产| 国产视频999| 精品亚洲一区二区三区| 成人在线激情视频| 亚洲国产天堂久久综合网| 亚洲性xxxx| 欧美一区二区色| 国产精品亚洲视频在线观看| 欧美成人精品在线| 最近2019年日本中文免费字幕| 久久久国产一区二区三区| 欧美成人高清视频| 日韩中文字幕视频在线观看| 欧美国产日韩中文字幕在线| 欧美性受xxx| 日本国产欧美一区二区三区| 国产精品视频自拍| 亚洲天堂日韩电影| 久久伊人精品天天| 国产精品视频一区二区高潮| 中文字幕久久久av一区| 在线成人中文字幕| 中文字幕日韩在线观看| 国产精品尤物福利片在线观看| 精品久久久久久国产91| 亚洲第一色中文字幕| 欧美整片在线观看| 亚洲第一福利网站| 午夜精品在线观看| 欧美另类高清videos| 欧美日韩国产激情| 午夜精品理论片| 国产精品ⅴa在线观看h| 亚洲第一精品福利| 97精品视频在线| 欧美另类在线播放| 欧美亚洲视频在线看网址| 深夜福利亚洲导航| 亚洲国产精久久久久久| 按摩亚洲人久久| 韩国精品美女www爽爽爽视频| 日韩三级影视基地| 日韩精品免费在线播放| 成人欧美一区二区三区黑人| 国产欧美精品一区二区三区介绍| 91欧美精品成人综合在线观看| 91久久精品一区| 日韩一级黄色av| 国产精品热视频| 亚洲精品动漫100p| 亚洲视频精品在线| 欧美日韩精品在线观看| 欧美高清视频免费观看| 欧美精品激情在线观看| 国产日韩视频在线观看| 欧美理论片在线观看| 午夜精品一区二区三区在线播放| 精品久久久久久久大神国产| 国产精品福利小视频| 精品高清一区二区三区| www.久久久久久.com| 亚洲人av在线影院| 欧美日本啪啪无遮挡网站| 国产精品啪视频| 亚洲欧美另类人妖| 欧美日韩国产丝袜另类| 国产精品久久久久99| 久久亚洲精品一区| 亚洲欧美国产日韩中文字幕| 欧美日韩福利电影| 亚洲人成在线电影| 日产精品99久久久久久| 日韩精品视频在线| 国产成人短视频| 亚洲偷欧美偷国内偷| 在线a欧美视频| 亚洲第一中文字幕在线观看| 亚洲一区二区久久久久久久| 欧美高清在线视频观看不卡| 免费97视频在线精品国自产拍| 日韩中文在线不卡| 久久久精品在线观看| 亚洲第一福利在线观看| 欧美三级xxx| 九九久久综合网站| 久久精品中文字幕电影| 国内精品久久久| 色妞一区二区三区| 亚洲精品视频二区| 欧美性69xxxx肥| 精品国产一区二区三区久久久狼| 久久久999精品视频| 一区二区三区精品99久久| 91成人在线播放|