路径查看linux 向内核注册总线例子

首先声明,我是一个菜鸟。一下文章中出现技术误导情况盖不负责

    mail:bookworepeng@Hotmail.com

    qq:196568501

    author:Driver Monkey

    phone:13410905075

    每日一道理
那蝴蝶花依然花开花落,而我心中的蝴蝶早已化作雄鹰飞向了广阔的蓝天。
#include <linux/init.h>
#include <linux/module.h>
#include <linux/cdev.h>
#include <linux/fs.h>
#include <linux/device.h>


MODULE_LICENSE("Dual BSD/GPL");
MODULE_AUTHOR("Driver Monkey");

static int monkey_match(struct device *dev, 
								struct device_driver *driver)
{
	printk(KERN_INFO"monkey_match()++\n");

	printk(KERN_INFO"monkey_match()--\n");

	return 0;
}

static int monkey_uevent(struct device *dev, struct kobj_uevent_env *env)
{
	printk(KERN_INFO"monkey_hotplug()++\n");
	
	printk(KERN_INFO"monkey_hotplug()++\n");	

	return 0;
}

struct bus_type monkey_bus_type = 
{
	.name = "monkey_bus",
	.match = monkey_match,
	.uevent = monkey_uevent,
};


static int monkey_init(void)
{
	int err = 0;

	printk("monkey_init()++\n");
	
	err = bus_register(&monkey_bus_type);
	if(err < 0)
		return err;
		
	printk("monkey_init()--\n");
	
	return 0;
}

static void monkey_exit(void)
{
	printk(KERN_INFO"monkey_exit()++\n");
	
	bus_unregister(&monkey_bus_type);
	
	printk(KERN_INFO"monkey_exit()--\n");
}

module_init(monkey_init);
module_exit(monkey_exit);

    查看路径注册胜利:

    /sys/bus # ls
i2c         monkey_bus  scsi        spi
mdio_bus    platform    serio       usb

文章结束给大家分享下程序员的一些笑话语录: 开发时间
  项目经理: 如果我再给你一个人,那可以什么时候可以完工?程序员: 3个月吧!项目经理: 那给两个呢?程序员: 1个月吧!
项目经理: 那100呢?程序员: 1年吧!
项目经理: 那10000呢?程序员: 那我将永远无法完成任务.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要向Linux内核注册设备驱动程序,必须按照以下步骤进行操作: 1. 定义一个 struct bus_type 结构体,用于描述设备驱动程序所支持的总线类型。 2. 定义一个 struct device_driver 结构体,用于描述设备驱动程序的属性和操作函数。 3. 在驱动程序初始化函数中调用函数 bus_register() 注册总线类型。 4. 在驱动程序初始化函数中调用函数 driver_register() 注册设备驱动程序。 下面是一个示例代码,演示如何向Linux内核注册设备驱动程序: ```c #include <linux/module.h> #include <linux/kernel.h> #include <linux/init.h> #include <linux/device.h> static int my_driver_probe(struct device *dev) { /* 处理设备插入事件 */ return 0; } static int my_driver_remove(struct device *dev) { /* 处理设备移除事件 */ return 0; } static struct device_driver my_driver = { .name = "my_driver", .bus = &my_bus_type, .probe = my_driver_probe, .remove = my_driver_remove, }; static struct bus_type my_bus_type = { .name = "my_bus", }; static int __init my_driver_init(void) { int ret; ret = bus_register(&my_bus_type); if (ret) { printk(KERN_ERR "Unable to register my bus type\n"); return ret; } ret = driver_register(&my_driver); if (ret) { printk(KERN_ERR "Unable to register my driver\n"); bus_unregister(&my_bus_type); return ret; } return 0; } static void __exit my_driver_exit(void) { driver_unregister(&my_driver); bus_unregister(&my_bus_type); } module_init(my_driver_init); module_exit(my_driver_exit); MODULE_LICENSE("GPL"); ``` 在这个示例中,我们定义了一个名为 my_driver 的 struct device_driver 结构体,其中包含了驱动程序的名称、支持的总线类型、设备插入和移除事件的处理函数等。我们还定义了一个名为 my_bus_type 的 struct bus_type 结构体,用于描述设备驱动程序所支持的总线类型。 在驱动程序初始化函数 my_driver_init() 中,我们首先调用函数 bus_register() 注册总线类型,然后调用函数 driver_register() 注册设备驱动程序。如果注册失败,我们需要通过 bus_unregister() 和 driver_unregister() 函数注销已注册总线类型和设备驱动程序。 需要注意的是,设备驱动程序的初始化函数和退出函数需要通过宏 module_init() 和 module_exit() 分别进行注册。同时,还需要在模块头部添加 MODULE_LICENSE() 宏,指定模块的许可证。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值