kernel探索driver与of的match过程1

kernel探索driver与of的match过程1

回顾:前面的文章我们做了of读取过程的追踪,目的是消除疑惑,理清里面的逻辑。

现在我们可以确定of的读取和MTK定制化没有关系,MTK也是按照kernel的行事规则在添加“mtkfb”节点,然后将mtkfb注册成为了一个platform_driver驱动。
那么针对kernel3.18“mtkfb”这个driver又是在哪里match的呢?(回到系列文章开头的第一个问题)


正文:通过对of读取的探索,我们看到过of的"init"在"driver_match"之前,目的是将of的信息写到bus里面,所以bus里面的节点信息都是在"driver_match"之前就填充完毕了,所以在“driver_match”的时候主要是将mtkfb_driver的代码与已经读取的bus信息进行匹配

进入目录:project/kernel-3.18/drivers/misc/mediatek/video/mt6755/mtkfb.c
我们首先发现mtkfb是一个platform_driver如下图

mtkfb_driver结构

既然是platform_driver,那么需要与platform_device进行区别;这两者肯定是有区别的,具体区别需要单独看

通过搜索我们可以发现platform_driver_register只出现在了int __init mtkfb_init(void)函数里面,并且有module_init(mtkfb_init);这样的注册函数,所以我们基本确定platform_driver_register函数会在mtkfb_init中被调用。

mtkfb_init函数如下:

/* Register both the driver and the device */
int __init mtkfb_init(void)
{
    int r = 0;

    MSG_FUNC_ENTER();
    DISPMSG("mtkfb_init Enter\n");
    //printk("fuhua->checkcode->when mtkfb_driver begin\n");
    //dump_stack();
    //printk("fuhua->checkcode->when mtkfb_driver begin2\n");
    if (platform_driver_register(&mtkfb_driver)) {
        PRNERR("failed to register mtkfb driver\n");
        r = -ENODEV;
        goto exit;
    }
#if 0
#ifdef CONFIG_HAS_EARLYSUSPEND
    register_early_suspend(&mtkfb_early_suspend_handler);
#endif
#endif
    PanelMaster_Init();
    DBG_Init();
    mtkfb_ipo_init();
exit:
    MSG_FUNC_LEAVE();
    DISPMSG("mtkfb_init LEAVE\n");
    return r;
}

我们通过添加的printkdump_stack()可以发现该init函数调用的上级,log如下:

dump_stack打印出来的函数

可以看出调用mtkfb_init的上级函数是do_one_initcall函数,该函数有本人有看过,调用的时候都是传入的指针,而且是在一个for循环里面调用的,所以没必要继续追踪(可通过查找资料补充)

接下来往platform_driver_register函数进行追踪
由于之前已经追过这部分代码,所以从log可看到追踪的痕迹,并且追踪这部分代码还是需要一些技巧,比如printk的时候避免空指针
总之我们开始进一步的追溯,首先我们可以看到platform_driver_register进入了project/kernel-3.18/drivers/base/bus.c里面的bus_add_driver函数,而该函数调用了driver_attach(drv)

继续跟踪,我们可以看到在kernel-3.18/drivers/base/dd.c文件的__driver_attach函数里已经将of_node信息填写好了,此对比过程暂时不详细描述,也是比较麻烦的这是一个inline函数,并且在driver_match_device(drv, dev)函数里进行的对比,主要是对drv->bus->match(dev, drv)进行了调用,而此函数早已填写好了。通过查找资料和打印log,我们可以确定后面是调用了kernel-3.18/drivers/base/dd.c里面的driver_attach函数(可以查证到match=driver_attach这样的语句),然后进入bus_for_each_dev,里面有调用到__driver_attach,此函数(__driver_attach)是被循环调用的,如果匹配了就调用里面的driver_probe_device``函数里面就会调用really_probe()```

另外需要注意一点就是driver结构体里面即有drv也有dev,如果没有记错传入match函数的参数只有一个drv,所以通过drv->name可以打印出'mtkfb',通过dev->of_node->properties->value可以打印出设备树里面的compatible信息。

经过这一系列的对比,返回到bus_add_driver

返回到driver_attach

然后执行module_add_driver(drv->owner,drv);等函数。
通过函数名称,基本上可以确定是在这个时候创建了文件了
至此match函数

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容