完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
1.传统方法
使用的引脚,操作引脚,全都写死在代码里。如果需要修改引脚时,那需要重新修改代码,并重新编译。 2.总线设备驱动模型 使用platform_device / platform_driver,将“资源”和“驱动”分离开来。 优点:易于扩展,更换引脚时drv基本不用改,只需要修改dev 缺点:代码稍微复杂,重复和冗余还是比较多,修改引脚时设备端的代码需要重新编译。 3.设备树 因为linux的device非常多,导致linux内核代码非常臃肿。 于是有了DTS文件指定硬件资源的指定,编译后生成dtb文件,传给内核。设备树在内核之外,这样就避免了内核的臃肿。 优点:易于扩展,无冗余代码,修改引脚时只需要修改dts文件,并编译dtb文件,把它传给内核。无需重新编译内核/驱动。 缺点:代码比较复杂,难以理解。 总线设备驱动模型 platform_device内包含资源结构体resource,并且通过name,来匹配platform_device和platform_driver。 platform_device和platform_driver如何联系起来 platform_bus_type结构体 首先linux里有一个platform_bus_type,虚拟总线。他有两个链表,一个是device链表一个是driver链表。 macht函数是用来匹配device和driver的,当device注册进总线或者driver注册进总线。都会调用match来查看是否匹配。 platform_device结构体 dev指的是硬件资源,platform_device有name属性,表示device的名字。还有driver_override表示需要匹配的driver名字。 platform_driver drv指的是驱动程序,platform_driver的device_driver里面有一个name属性,表示了driver的名字。 同时它还有id_table表示了能支持的设备。 如何匹配
函数匹配的调用关系 platform_device_register platform_device_add device_add bus_add_device // 放入链表 bus_probe_device // probe 枚举设备,即找到匹配的(dev, drv) device_initial_probe __device_attach bus_for_each_drv(...,__device_attach_driver,...) __device_attach_driver driver_match_device(drv, dev) // 是否匹配 driver_probe_device // 调用 drv 的 probe platform_driver_register __platform_driver_register driver_register bus_add_driver // 放入链表 driver_attach(drv) bus_for_each_dev(drv->bus, NULL, drv, __driver_attach); __driver_attach driver_match_device(drv, dev) // 是否匹配 driver_probe_device // 调用 drv 的 probe |
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
基于米尔瑞芯微RK3576核心板/开发板的人脸疲劳检测应用方案
2649 浏览 0 评论
2869 浏览 1 评论
2354 浏览 1 评论
3694 浏览 1 评论
4439 浏览 1 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2025-1-26 06:09 , Processed in 0.460752 second(s), Total 70, Slave 54 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号