• 注册驱动时如何调用probe函数 ?


    platform_driver_register
          driver_register
                bus_add_driver    //把驱动放入总线的驱动链表里
                        driver_attach
                                   bus_for_each_dev(drv->bus, NULL, drv, __driver_attach);//遍历该总线上所有的device,执行一次__driver_attach(),看能不能将驱动关联(attach)到某个设备上去。
                                           __driver_attach
                                                     driver_probe_device(drv, dev)
                                                             if (drv->bus->match && !drv->bus->match(dev, drv)) //调用驱动的总线上的match函数,查看驱动与设备是否匹配
                                                                     goto done;
                                                             really_probe(dev, drv);
                                                                     if (dev->bus->probe) {
                                                                                 ret = dev->bus->probe(dev); //(如果bus->probe非空,则调用bus->probe)
                                                                                if (ret)
                                                                                       goto probe_failed;
                                                                       } 
                                                                       else  if (drv->probe) 
                                                                        {
                                                                                        ret = drv->probe(dev);  //调用驱动的probe函数
                                                                                       if (ret)
                                                                                               goto probe_failed;
                                                                         }


    总结,注册一个某个bus的驱动就是先把驱动自己链入到bus驱动链表中去,
    在从bus的设备链表中一一寻找,看有没有自己可以关联上的设备。找到就probe,
    再把二者bind起来。反之,添加设备道理也是一样的。




    选中代码后,按tab键,整体后移;按shift + tab键,整体前移
  • 相关阅读:
    python 通过*.cer *..pfx 获取公钥私钥
    python 交集 并集 差集
    python3 RSA加密、解密、签名
    Go 入门
    ansible入门篇一
    ACM/ICPC 之 两道dijkstra练习题(ZOJ1053(POJ1122)-ZOJ1053)
    数学软件 之 基于MATLAB的DFP算法
    ACM/ICPC 之 最短路径-dijkstra范例(ZOJ2750-POJ1135(ZOJ1298))
    ACM/ICPC 之 判别MST唯一性-Kruskal解法(POJ1679)
    ACM/ICPC 之 四道MST-Prim解法(POJ1258-POJ1751-POJ2349-POJ3026)
  • 原文地址:https://www.cnblogs.com/alan666/p/8312432.html
Copyright © 2020-2023  润新知