首先dts编译成dtb传给内核,内核会解析dtb文件得到很多个device_node结构体,每个device_node会变为platform_device结构体,包含资源。
platform_driver会与platform_device匹配,一旦匹配成功便会调起platform_driver里的probe函数,会去分配、设置、注册file_operation结构体,还会从platform_device结构体中获取资源。之前资源是写在c文件里的,现在写在dts里面。
设备树是对平台设备的一种改进,仍然属于总线设备驱动模型的一种。
从上篇pdev->dev.bus = &platform_bus_type;开始分析:
.match = platform_match, //绑定平台设备到平台驱动程序。
if (of_driver_match_device(dev, drv))
return of_match_device(drv->of_match_table, dev) != NULL;
平台driver:
struct device_driver {
const char *name;
...
const struct of_device_id *of_match_table;
...
};
struct of_device_id {
char name[32];
char type[32];
char compatible[128];
const void *data;
};
从dts得到的platform_device里有“compatible”属性,两者比较,一样的话就匹配成功。
驱动里构造出.of_match_table=of_match即可。表示能够支持哪些来自dts的平台设备