关于Linux平台设备驱动模型,并不是创建新的设备分类,是在原有的字符设备基础上使用,将设备和驱动分开,生成两个.ko文件。
Linux内核维护一个全局设备链表,对应的总线会将驱动和设备链表里的设备名进行匹配,如果匹配成功就会将设备的信息传递给驱动的probe函数,probe函数得到设备的核心结构体platform_device的信息就可以进行对应的操作。
我们只需实现平台驱动和平台设备即可,平台总线是内核实现的,常见的总线如IIC、SPI、CAN等,LED、KEY这类型的普通字符设备,linux内核就使用虚拟的平台总线struct bus_type platform_bus_type来匹配这类设备。
首先来看platform_device平台设备层结构体。
我们只需要关注name、id、num_resources、resource、dev这几个成员。
struct platform_device{
const char *name; //自定义的设备名,用于和驱动匹。
int id; //当设备和驱动一对一匹配时,所设值为-1
struct device dev; //下面列举其成员介绍。该结构体下的release函数是必须实现的
u32 num_resources; //设备的个数,即设备资源数组的元素个数
struct resource *resource; //设备所用资源数组的首地址
};