Linux驱动编写的基本流程主要包括以下几个步骤:
module_init
和module_exit
宏定义模块的初始化和退出函数。register_chrdev
或class_create
)注册设备驱动。ioremap
函数将物理地址映射到内核虚拟地址空间。ioread32
/iowrite32
等宏实现。以下是一个简单的字符设备驱动示例,展示了如何注册和注销设备:
#include <linux/init.h>
#include <linux/module.h>
#include <linux/fs.h>
#include <linux/cdev.h>
#define DEVICE_NAME "mydevice"
#define CLASS_NAME "myclass"
static int major_number;
static struct class* mydevice_class = NULL;
static struct cdev mydevice_cdev;
static int __init mydevice_init(void) {
major_number = register_chrdev(0, DEVICE_NAME, &mydevice_fops);
if (major_number < 0) {
printk(KERN_ALERT "Failed to register a major number\n");
return major_number;
}
mydevice_class = class_create(THIS_MODULE, CLASS_NAME);
if (IS_ERR(mydevice_class)) {
unregister_chrdev(major_number, DEVICE_NAME);
printk(KERN_ALERT "Failed to register device class\n");
return PTR_ERR(mydevice_class);
}
device_create(mydevice_class, NULL, MKDEV(major_number, 0), NULL, DEVICE_NAME);
cdev_init(&mydevice_cdev, &mydevice_fops);
cdev_add(&mydevice_cdev, MKDEV(major_number, 0), 1);
printk(KERN_INFO "%s: successfully loaded\n", DEVICE_NAME);
return 0;
}
static void __exit mydevice_exit(void) {
cdev_del(&mydevice_cdev);
device_destroy(mydevice_class, MKDEV(major_number, 0));
class_unregister(mydevice_class);
class_destroy(mydevice_class);
unregister_chrdev(major_number, DEVICE_NAME);
printk(KERN_INFO "%s: successfully unloaded\n", DEVICE_NAME);
}
static struct file_operations mydevice_fops = {
.owner = THIS_MODULE,
.open = mydevice_open,
.read = mydevice_read,
.write = mydevice_write,
.release = mydevice_release,
};
static int mydevice_open(struct inode *inodep, struct file *filep) {
printk(KERN_INFO "Device opened\n");
return 0;
}
static ssize_t mydevice_read(struct file *filep, char *buffer, size_t len, loff_t *offset) {
// Implement read logic here
return len;
}
static ssize_t mydevice_write(struct file *filep, const char *buffer, size_t len, loff_t *offset) {
// Implement write logic here
return len;
}
static int mydevice_release(struct inode *inodep, struct file *filep) {
printk(KERN_INFO "Device closed\n");
return 0;
}
module_init(mydevice_init);
module_exit(mydevice_exit);
MODULE_LICENSE("GPL");
MODULE_AUTHOR("Your Name");
MODULE_DESCRIPTION("A simple Linux character device driver");
MODULE_VERSION("0.1");
通过以上步骤和示例代码,你可以初步了解并开始编写自己的Linux驱动程序。