#include <linux/init.h>
#include <linux/module.h>
#include <linux/fs.h>
#include <linux/slab.h>
#include <linux/cdev.h>
#define LED_DEVICE_MAJOR 230
#define LED_DEVICE_MINOR 0
struct led_device{
dev_t devid;
struct cdev led_cdev;
};
struct led_device* pled;
static int led_device_open(struct inode *inode, struct file *file)
{
printk("led device_open\n");
return 0;
}
static int led_device_close(struct inode *inode, struct file *file)
{
printk("led device_close\n");
return 0;
}
//led_device_ops提供操作硬件接口
static const struct file_operations led_device_ops = {
.open = led_device_open,
.release = led_device_close,
.owner = THIS_MODULE,
};
MODULE_LICENSE("GPL v2");
static int led_driver_init(void)
{
int err;
printk("led driver init\n");
pled = kmalloc(sizeof(*pled), GFP_KERNEL);
if(!pled){
printk("fail to create dev\n");
return -ENOMEM;
}
//pled->led_cdev.ops = &led_device_ops;
//设备结构体初始化
cdev_init(&pled->led_cdev,&led_device_ops);
//注册设备号,MKDEV只是一个宏为了组合设备号
pled->devid = MKDEV(LED_DEVICE_MAJOR,LED_DEVICE_MINOR);
err = register_chrdev_region(pled->devid, 1, "led-device");
if(err){
printk("Fail to register_chrdev_region\n");
kfree(pled);
return err;
}
//字符设备添加(是为了将设备和设备号绑定在一起)
err = cdev_add(&pled->led_cdev, pled->devid, 1);
if(err){
printk("Fail to cdev_add\n");
unregister_chrdev_region(pled->devid, 1);
kfree(pled);
}
return 0;
}
void led_driver_exit(void)
{
printk("led driver exit\n");
cdev_del(&pled->led_cdev);
unregister_chrdev_region(pled->devid, 1);
kfree(pled);
return;
}
module_init(led_driver_init);
module_exit(led_driver_exit);
驱动开发基本框架
最新推荐文章于 2024-04-14 00:23:43 发布
该代码示例展示了如何创建一个Linux内核驱动程序,用于管理LED设备。它定义了LED设备结构,实现了打开和关闭设备的函数,并使用cdev结构体进行字符设备的操作。驱动程序通过register_chrdev_region注册设备号,并在系统启动和退出时进行相应的初始化和清理工作。
摘要由CSDN通过智能技术生成