Linux kernel Linux设备驱动程序中的open方法是否应返回文件描述符?
我正在学习Linux设备驱动程序编程第3版,我对开放方法有一些疑问,这是那本书中使用的“scull_开放”方法:Linux kernel Linux设备驱动程序中的open方法是否应返回文件描述符?,linux-kernel,linux-device-driver,system-calls,Linux Kernel,Linux Device Driver,System Calls,我正在学习Linux设备驱动程序编程第3版,我对开放方法有一些疑问,这是那本书中使用的“scull_开放”方法: int scull_open(struct inode *inode, struct file *filp){ struct scull_dev *dev; /* device information */ dev = container_of(inode->i_cdev, struct scull_dev, cdev); filp->priva
int scull_open(struct inode *inode, struct file *filp){
struct scull_dev *dev; /* device information */
dev = container_of(inode->i_cdev, struct scull_dev, cdev);
filp->private_data = dev; /* for other methods */
/* now trim to 0 the length of the device if open was write-only */
if ( (filp->f_flags & O_ACCMODE) == O_WRONLY) {
if (down_interruptible(&dev->sem))
return -ERESTARTSYS;
scull_trim(dev); /* ignore errors */
up(&dev->sem);
}
return 0; /* success */
}
我的问题是:
- 这个函数不应该向刚刚打开的设备返回一个文件描述符吗
- 这个函数的“*filp”不是本地的吗?那么为什么我们要将dev的内容复制到它呢
- 我们以后如何使用读写方法
- 有人能给我写一个开放方法的典型“非脂肪”实现吗 ssize\u t scull\u read(结构文件*filp,字符用户*buf,大小计数,loff\u t*f\u pos){ struct scul_dev*dev=filp->private_data; …}
我当然知道开放的用户空间。当用户空间打开调用内核时,您是否有任何资源或链接可以确切地了解发生了什么?。我猜你提到的那本书只涉及开放的用户空间。