linux 总线-设备-驱动模型

程序设计思想:分离 - 分层 - 抽象  高内聚-低耦合

Linux   总线只负责匹配设备和驱动,驱动则以标准途径拿到 驱动信息,驱动是放之四海而皆准。设备只管设备。

Linux下的总线(bus)、驱动(driver)和设备(device)模型

但是在 SOC 中有些外设是没有总线这个概念的,但是又要使用总线、驱动和设备模型该怎么办呢?为了解决此问题, Linux 提出了 platform_bus 这个虚拟总线,相应的就有 platform_driver 和 platform_device。

 

 

platform总线实例(在文件drivers/base/platform.c 中):

这里我们重点来关注匹配函数platform_match:

我们暂且先知道其有几种匹配方法。

platform驱动结构体(在文件include/linux/platform_device.h 中):

platform_driver 结构体中的driver成员所属的结构体类型为(在文件include/linux/device.h 中):

这里体现出了C语言的面向对象的思想,其中driver相当于基类,platform_driver继承了这个基类。

struct device_driver 结构体中(在文件include/linux/device.h 中)的name成员在上面提到的匹配函数platform_match里用到,即:

platform_driver 结构体中的id_table成员所属的结构体类型为(在文件include/linux/mod_devicetable.h 中):

常用函数:

platform 驱动注册函数:

int platform_driver_register(struct platform_driver *driver);

platform 驱动卸载函数:

void platform_driver_unregister(struct platform_driver *drv);

描述设备有两种方法:一种是用用设备树来指定,另一种是直接用platform_device结构体来指定。设备树的内容不在我们本篇笔记的学习范围内。下面先来看一下platform设备结构体(在文件include/linux/platform_device.h 中):

platform_device结构体中的resource成员所属的结构体类型为(在文件include/linux/ioport.h 中):

常用函数:

platform 驱动注册函数:

int platform_device_register(struct platform_device *pdev);

platform 驱动卸载函数:

void platform_device_unregister(struct platform_device *pdev);

platform_driver与platform_device的匹配围绕着上面说的platform_match函数。上面有说描述设备有两种方法,这里暂且只分享直接用platform_device结构体来指定设备时platform_driver与platform_device的匹配过程。(参考来源:百问网)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值