file_operations下函數(shù)詳解
struct file_operations{
struct module *owner;
// 指向擁有該結(jié)構(gòu)的模塊的指針,避免正在操作時被卸載,一般為初始化為THIS_MODULES
loff_t (*llseek) (struct file *, loff_t, int);
// llseek用來修改文件當前的讀寫位置,返回新位置
// loff_t為一個長偏移量。當此函數(shù)指針為空,seek調(diào)用將會以不可預期的方式修改file結(jié)構(gòu)中的位置計數(shù)器。
ssize_t (*read) (struct file *, char __user *, size_t, loff_t *);
// 從設備中同步讀取數(shù)據(jù)。讀取成功返回讀取的字節(jié)數(shù)。設置為NULL,調(diào)用時返回-EINVAL
ssize_t (*aio_read) (struct kiocb *, char __user *, size_t, loff_t);
// 初始化一個異步的讀取操作,為NULL時全部通過read處理
ssize_t (*write) (struct file *, const char __user *, size_t, loff_t *);
// 向設備發(fā)送數(shù)據(jù)。
ssize_t (*aio_write) (struct kiocb *, const char __user *, size_t, loff_t);
// 初始化一個異步的寫入操作。
int (*readdir) (struct file *, void *, filldir_t);
// 僅用于讀取目錄,對于設備文件,該字段為 NULL
unsigned int (*poll) (struct file *, struct poll_table_struct *);
// 返回一個位掩碼,用來指出非阻塞的讀取或?qū)懭胧欠窨赡堋?br style="padding-right: 0px; padding-left: 0px; padding-bottom: 0px; margin: 0px; padding-top: 0px; word-wrap: break-word" />
// 將pool定義為 NULL,設備會被認為即可讀也可寫。
int (*ioctl) (struct inode *, struct file *, unsigned int, unsigned long);
// 提供一種執(zhí)行設備特殊命令的方法。不設置入口點,返回-ENOTTY
long (*unlocked_ioctl) (struct file *, unsigned int, unsigned long);
// 不使用BLK的文件系統(tǒng),將使用此種函數(shù)指針代替ioctl
long (*compat_ioctl) (struct file *, unsigned int, unsigned long);
// 在64位系統(tǒng)上,32位的ioctl調(diào)用,將使用此函數(shù)指針代替
int (*mmap) (struct file *, struct vm_area_struct *);
// 用于請求將設備內(nèi)存映射到進程地址空間。如果無此方法,將訪問-ENODEV。
int (*open) (struct inode *, struct file *);
// 如果為空,設備的打開操作永遠成功,但系統(tǒng)不會通知驅(qū)動程序
// 由VFS調(diào)用,當VFS打開一個文件,即建立了一個新的struct file,之后調(diào)用open方法分配文件結(jié)構(gòu)。open屬于struct
inode_operations。
int (*flush) (struct file *);
// 發(fā)生在進程關閉設備文件描述符副本,執(zhí)行并等待,若設置為NULL,內(nèi)核將忽略用戶應用程序的請求。
int (*release) (struct inode *, struct file *);
// file結(jié)構(gòu)釋放時,將調(diào)用此指針函數(shù),release與open相同可設置為NULL
int (*fsync) (struct file *, struct dentry *, int datasync);
評論