总线程序
vbus.c
#include <linux/init.h>
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/device.h>
//
/*
当接入一个USB设备时,USB总线会立即感知到这件事,并去遍历所有注册在USB总线上的驱动(这个过程可能会自动加载一个匹配的驱动)
然后调用驱动中的一段代码来探测是否能否驱动插入的USB设备,如果可以,那么总线完成驱动和设备之间的绑定
linux设备模型为这三种对象自定义了对应的类:
struct bus_type;
struct device;
struct devcie_driver;
总线、设备和驱动都继承自同一个基类struct kobject 于是生成相应的总线、设备和驱动的目录。另外linux内核还为这些kobject和kset对象附属了很多属性,
于是也产生了对应目录下的文件
*/
static int vbus_match(struct device *dev,struct device_drvier *drv)
{
return 1;
}
static struct bus_type = {
.name = "vbus",
.match = vbus_match,
};
EXPORT_SYMBOL(vbus);
static int __init vbus_init(void)
{
return bus_register(&bus);
}
static int __exit vbus_exit(void)
{
bus_unregister(&bus);
}
module_init(vbus_init);
module_exit(vbus_exit);
MODULE_LICENSE("GPL");
vdev.c
#include <linux/init.h>
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/device.h>
//
/*
当接入一个USB设备时,USB总线会立即感知到这件事,并去遍历所有注册在USB总线上的驱动(这个过程可能会自动加载一个匹配的驱动)
然后调用驱动中的一段代码来探测是否能否驱动插入的USB设备,如果可以,那么总线完成驱动和设备之间的绑定
linux设备模型为这三种对象自定义了对应的类:
struct bus_type;
struct device;
struct devcie_driver;
总线、设备和驱动都继承自同一个基类struct kobject 于是生成相应的总线、设备和驱动的目录。另外linux内核还为这些kobject和kset对象附属了很多属性,
于是也产生了对应目录下的文件
*/
static int vbus_match(struct device *dev,struct device_drvier *drv)
{
return 1;
}
static struct bus_type = {
.name = "vbus",
.match = vbus_match,
};
EXPORT_SYMBOL(vbus);
static int __init vbus_init(void)
{
return bus_register(&bus);
}
static int __exit vbus_exit(void)
{
bus_unregister(&bus);
}
module_init(vbus_init);
module_exit(vbus_exit);
MODULE_LICENSE("GPL");
vdrv.c
#include <linux/init.h>
#include <linux/kernel>
#include <linux/module.h>
#include <linux/device.h>
static struct bus_type;
static struct device_drvier vdrv = {
.name = "vdrv",
.bus = &vbus,
};
static int __init vdrv_init(void)
{
return drvier_register(&vdrv);
}
static void __exit vdrv_exit(void)
{
drvier_unregister(&vdrv);
}
module_init(vdrv_init);
module_exit(vdrv_exit);
MODULE_LICENSE("GPL");