file_operations下函數(shù)詳解
struct file_operations{
struct module *owner;
// 指向擁有該結構的模塊的指針,避免正在操作時被卸載,一般為初始化為THIS_MODULES
loff_t (*llseek) (struct file *, loff_t, int);
// llseek用來修改文件當前的讀寫位置,返回新位置
// loff_t為一個"長偏移量"。當此函數(shù)指針為空,seek調用將會以不可預期的方式修改file結構中的位置計數(shù)器。
ssize_t (*read) (struct file *, char __user *, size_t, loff_t *);
// 從設備中同步讀取數(shù)據(jù)。讀取成功返回讀取的字節(jié)數(shù)。設置為NULL,調用時返回-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 *);
// 返回一個位掩碼,用來指出非阻塞的讀取或寫入是否可能。
// 將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調用,將使用此函數(shù)指針代替
int (*mmap) (struct file *, struct vm_area_struct *);
// 用于請求將設備內(nèi)存映射到進程地址空間。如果無此方法,將訪問-ENODEV。
int (*open) (struct inode *, struct file *);
// 如果為空,設備的打開操作永遠成功,但系統(tǒng)不會通知驅動程序
// 由VFS調用,當VFS打開一個文件,即建立了一個新的"struct file",之后調用open方法分配文件結構。open屬于struct
inode_operations。
int (*flush) (struct file *);
// 發(fā)生在進程關閉設備文件描述符副本,執(zhí)行并等待,若設置為NULL,內(nèi)核將忽略用戶應用程序的請求。
int (*release) (struct inode *, struct file *);
// file結構釋放時,將調用此指針函數(shù),release與open相同可設置為NULL
int (*fsync) (struct file *, struct dentry *, int datasync);[!--empirenews.page--]
// 刷新待處理的數(shù)據(jù),如果驅動程序沒有實現(xiàn),fsync調用將返回-EINVAL
int (*aio_fsync) (struct kiocb *, int datasync);
// 異步fsync
int (*fasync) (int, struct file *, int);
// 通知設備FASYNC標志發(fā)生變化,如果設備不支持異步通知,該字段可以為NULL
int (*lock) (struct file *, int, struct file_lock *);
// 實現(xiàn)文件鎖,設備驅動常不去實現(xiàn)此lock
ssize_t (*readv) (struct file *, const struct iovec *, unsigned long, loff_t *);
ssize_t (*writev) (struct file *, const struct iovec *, unsigned long, loff_t *);
// readv和writev 分散/聚集型的讀寫操作,實現(xiàn)進行涉及多個內(nèi)存區(qū)域的單次讀或寫操作。
ssize_t (*sendfile) (struct file *, loff_t *, size_t, read_actor_t, void *);
// 實現(xiàn)sendfile調用的讀取部分,將數(shù)據(jù)從一個文件描述符移到另一個,設備驅動通常將其設置為 NULL
ssize_t (*sendpage) (struct file *, struct page *, int, size_t, loff_t *, int);
// 實現(xiàn)sendfile調用的另一部分,內(nèi)核調用將其數(shù)據(jù)發(fā)送到對應文件,每次一個數(shù)據(jù)頁,設備驅動通常將其設置為NULL
unsigned long (*get_unmapped_area)(struct file *, unsigned long, unsigned long, unsigned long, unsigned
long);
// 在進程地址空間找到一個合適的位置,以便將底層設備中的內(nèi)存段映射到該位置。大部分驅動可將其設置為NULL
int (*check_flags)(int);
// 允許模塊檢查傳遞給fcntl(F_SETEL…)調用的標志
int (*dir_notify)(struct file *filp, unsigned long arg);
// 應用程序使用fcntl來請求目錄改變通知時,調用該方法。僅對文件系統(tǒng)有效,驅動程序不必實現(xiàn)。
int (*flock) (struct file *, int, struct file_lock *);
// 實現(xiàn)文件鎖
};