1、module_platform_driver:这是一个宏,位于kernel根目录下include/linux/platform_device.h,其展开如下:
#define module_platform_driver(__platform_driver) \
module_driver(__platform_driver, platform_driver_register, \
platform_driver_unregister)
//module_driver 宏位于kernel根目录下include/linux/device.h,展开后是
#define module_driver(__driver, __register, __unregister, ...) \
static int __init __driver##_init(void) \
{ \
return __register(&(__driver) , ##__VA_ARGS__); \
} \
module_init(__driver##_init); \
static void __exit __driver##_exit(void) \
{ \
__unregister(&(__driver) , ##__VA_ARGS__); \
} \
module_exit(__driver##_exit);
由以上展开可以看出,module_platform_driver是由module_driver封装而来,并填充了platform_driver_register、
platform_driver_unregister
两个函数作为宏的参数传递给了 module_driver的宏,这样做的目的是统一了接口函数,使得所有驱动的注册、
注销函数都能统一的管理。
因此,展开 module_platform_driver(xilinx_vdma_driver),第一步展开,调用宏module_driver(xilinx_vdma_driver,
platform_driver_register,
platform_driver_unregister);第二步展开,展开宏module_driver,展开的结果是:ps: 在宏定义里,## 的作用是将连个参数连在一起, # 的作用是加上双引号
eg:__driver##_init 即为 xilinx_vdma_driver_init , #define TEST(a) (#a),那么 TEST(123) 展开是 “123”
static int _init xilinx_vdma_driver_init(void)
{
return platform_driver_register(&xilinx_vdma_driver);
}
module_init(xilinx_vdma_driver_init);
static int _exit xilinx_vdma_driver_exit(void)
{
return platform_driver_unregister(&xilinx_vdma_driver);
}
module_exit(xilinx_vdma_driver_init);
从而间接调用了 platform_driver_register 和 platform_driver_unregister实现了 驱动函数的注册和注销
今天的文章module_platform_driver分析分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/26090.html