#include <linux/init.h>
#include <linux/module.h>
#include <linux/cdev.h>
#include <linux/fs.h>
#include <linux/device.h>
#include <linux/slab.h>
#include <linux/uaccess.h>
#include <linux/poll.h>
#define CNAME "mycdev"
struct cdev cdev;
int major = 0;
int minor = 0;
const int count = 3;
struct class *cls;
struct device *dev;
char kbuf[128] = {0};
//1.定义等待队列头(加condition变量)
wait_queue_head_t wq;
//condition代表数据是否准备好,1=准备好
int condition = 0;
int mycdev_open(struct inode *inode, struct file *file){
printk("%s:%s(%d)\n",__FILE__,__func__,__LINE__);
return 0;
}
ssize_t mycdev_read(struct file *file, char __user *ubuf, size_t size, loff_t *offs){
int ret = 0;
printk("%s:%s(%d)\n",__FILE__,__func__,__LINE__);
//阻塞由VFS中sys_select来实现,驱动不再实现阻塞
/*//4.判断用户是否以阻塞方式打开
if(file->f_flags & O_NONBLOCK)
字符设备驱动 I/O模型(实现select多路复用 驱动部分)示例
于 2023-05-12 17:39:16 首次发布
本文展示了如何在Linux内核中使用cdev(字符设备)结构来实现一个简单的设备驱动程序,包括打开、读取、写入和轮询操作。驱动程序使用了一个等待队列头wq和条件变量condition来处理阻塞I/O,当数据准备好时唤醒等待的进程。同时,文章还包含了一个用户空间程序示例,演示了如何通过select系统调用来监听设备事件。
摘要由CSDN通过智能技术生成