📄 fs.h
字号:
#define FL_FLOCK 2#define FL_BROKEN 4 /* broken flock() emulation */#define FL_ACCESS 8 /* for processes suspended by mandatory locking */struct file_lock { struct file_lock *fl_next; /* singly linked list for this inode */ struct file_lock *fl_nextlink; /* doubly linked list of all locks */ struct file_lock *fl_prevlink; /* used to simplify lock removal */ struct file_lock *fl_nextblock; /* circular list of blocked processes */ struct file_lock *fl_prevblock; struct task_struct *fl_owner; struct wait_queue *fl_wait; struct file *fl_file; unsigned char fl_flags; unsigned char fl_type; off_t fl_start; off_t fl_end;};#include <linux/fcntl.h>extern int fcntl_getlk(unsigned int fd, struct flock *l);extern int fcntl_setlk(unsigned int fd, unsigned int cmd, struct flock *l);extern void locks_remove_locks(struct task_struct *task, struct file *filp);#include <linux/stat.h>#define FLOCK_VERIFY_READ 1#define FLOCK_VERIFY_WRITE 2extern int locks_mandatory_locked(struct inode *inode);extern int locks_mandatory_area(int read_write, struct inode *inode, struct file *filp, unsigned int offset, unsigned int count);extern inline int locks_verify_locked(struct inode *inode){ /* Candidates for mandatory locking have the setgid bit set * but no group execute bit - an otherwise meaningless combination. */ if (IS_MANDLOCK(inode) && (inode->i_mode & (S_ISGID | S_IXGRP)) == S_ISGID) return (locks_mandatory_locked(inode)); return (0);}extern inline int locks_verify_area(int read_write, struct inode *inode, struct file *filp, unsigned int offset, unsigned int count){ /* Candidates for mandatory locking have the setgid bit set * but no group execute bit - an otherwise meaningless combination. */ if (IS_MANDLOCK(inode) && (inode->i_mode & (S_ISGID | S_IXGRP)) == S_ISGID) return (locks_mandatory_area(read_write, inode, filp, offset, count)); return (0);}struct fasync_struct { int magic; struct fasync_struct *fa_next; /* singly linked list */ struct file *fa_file;};#define FASYNC_MAGIC 0x4601extern int fasync_helper(struct inode *, struct file *, int, struct fasync_struct **);#include <linux/minix_fs_sb.h>#include <linux/ext_fs_sb.h>#include <linux/ext2_fs_sb.h>#include <linux/hpfs_fs_sb.h>#include <linux/msdos_fs_sb.h>#include <linux/iso_fs_sb.h>#include <linux/nfs_fs_sb.h>#include <linux/xia_fs_sb.h>#include <linux/sysv_fs_sb.h>#include <linux/affs_fs_sb.h>#include <linux/ufs_fs_sb.h>struct super_block { kdev_t s_dev; unsigned long s_blocksize; unsigned char s_blocksize_bits; unsigned char s_lock; unsigned char s_rd_only; unsigned char s_dirt; struct file_system_type *s_type; struct super_operations *s_op; struct dquot_operations *dq_op; unsigned long s_flags; unsigned long s_magic; unsigned long s_time; struct inode * s_covered; struct inode * s_mounted; struct wait_queue * s_wait; union { struct minix_sb_info minix_sb; struct ext_sb_info ext_sb; struct ext2_sb_info ext2_sb; struct hpfs_sb_info hpfs_sb; struct msdos_sb_info msdos_sb; struct isofs_sb_info isofs_sb; struct nfs_sb_info nfs_sb; struct xiafs_sb_info xiafs_sb; struct sysv_sb_info sysv_sb; struct affs_sb_info affs_sb; struct ufs_sb_info ufs_sb; void *generic_sbp; } u;};/* * This is the "filldir" function type, used by readdir() to let * the kernel specify what kind of dirent layout it wants to have. * This allows the kernel to read directories into kernel space or * to have different dirent layouts depending on the binary type. */typedef int (*filldir_t)(void *, const char *, int, off_t, ino_t); struct file_operations { int (*lseek) (struct inode *, struct file *, off_t, int); int (*read) (struct inode *, struct file *, char *, int); int (*write) (struct inode *, struct file *, const char *, int); int (*readdir) (struct inode *, struct file *, void *, filldir_t); int (*select) (struct inode *, struct file *, int, select_table *); int (*ioctl) (struct inode *, struct file *, unsigned int, unsigned long); int (*mmap) (struct inode *, struct file *, struct vm_area_struct *); int (*open) (struct inode *, struct file *); void (*release) (struct inode *, struct file *); int (*fsync) (struct inode *, struct file *); int (*fasync) (struct inode *, struct file *, int); int (*check_media_change) (kdev_t dev); int (*revalidate) (kdev_t dev);};struct inode_operations { struct file_operations * default_file_ops; int (*create) (struct inode *,const char *,int,int,struct inode **); int (*lookup) (struct inode *,const char *,int,struct inode **); int (*link) (struct inode *,struct inode *,const char *,int); int (*unlink) (struct inode *,const char *,int); int (*symlink) (struct inode *,const char *,int,const char *); int (*mkdir) (struct inode *,const char *,int,int); int (*rmdir) (struct inode *,const char *,int); int (*mknod) (struct inode *,const char *,int,int,int); int (*rename) (struct inode *,const char *,int,struct inode *,const char *,int, int); int (*readlink) (struct inode *,char *,int); int (*follow_link) (struct inode *,struct inode *,int,int,struct inode **); int (*readpage) (struct inode *, struct page *); int (*writepage) (struct inode *, struct page *); int (*bmap) (struct inode *,int); void (*truncate) (struct inode *); int (*permission) (struct inode *, int); int (*smap) (struct inode *,int);};struct super_operations { void (*read_inode) (struct inode *); int (*notify_change) (struct inode *, struct iattr *); void (*write_inode) (struct inode *); void (*put_inode) (struct inode *); void (*put_super) (struct super_block *); void (*write_super) (struct super_block *); void (*statfs) (struct super_block *, struct statfs *, int); int (*remount_fs) (struct super_block *, int *, char *);};struct dquot_operations { void (*initialize) (struct inode *, short); void (*drop) (struct inode *); int (*alloc_block) (const struct inode *, unsigned long); int (*alloc_inode) (const struct inode *, unsigned long); void (*free_block) (const struct inode *, unsigned long); void (*free_inode) (const struct inode *, unsigned long); int (*transfer) (struct inode *, struct iattr *, char);};struct file_system_type { struct super_block *(*read_super) (struct super_block *, void *, int); const char *name; int requires_dev; struct file_system_type * next;};extern int register_filesystem(struct file_system_type *);extern int unregister_filesystem(struct file_system_type *);asmlinkage int sys_open(const char *, int, int);asmlinkage int sys_close(unsigned int); /* yes, it's really unsigned */asmlinkage int sys_read(unsigned int, char *, int);extern void kill_fasync(struct fasync_struct *fa, int sig);extern int getname(const char * filename, char **result);extern void putname(char * name);extern int do_truncate(struct inode *, unsigned long);extern int register_blkdev(unsigned int, const char *, struct file_operations *);extern int unregister_blkdev(unsigned int major, const char * name);extern int blkdev_open(struct inode * inode, struct file * filp);extern void blkdev_release (struct inode * inode);extern struct file_operations def_blk_fops;extern struct inode_operations blkdev_inode_operations;extern int register_chrdev(unsigned int, const char *, struct file_operations *);extern int unregister_chrdev(unsigned int major, const char * name);extern int chrdev_open(struct inode * inode, struct file * filp);extern struct file_operations def_chr_fops;extern struct inode_operations chrdev_inode_operations;extern void init_fifo(struct inode * inode);extern struct inode_operations fifo_inode_operations;extern struct file_operations connecting_fifo_fops;extern struct file_operations read_fifo_fops;extern struct file_operations write_fifo_fops;extern struct file_operations rdwr_fifo_fops;extern struct file_operations read_pipe_fops;extern struct file_operations write_pipe_fops;extern struct file_operations rdwr_pipe_fops;extern struct file_system_type *get_fs_type(const char *name);extern int fs_may_mount(kdev_t dev);extern int fs_may_umount(kdev_t dev, struct inode * mount_root);extern int fs_may_remount_ro(kdev_t dev);extern struct file *first_file;extern struct super_block super_blocks[NR_SUPER];extern void refile_buffer(struct buffer_head * buf);extern void set_writetime(struct buffer_head * buf, int flag);extern int try_to_free_buffer(struct buffer_head*, struct buffer_head**, int);extern int nr_buffers;extern int buffermem;extern int nr_buffer_heads;#define BUF_CLEAN 0#define BUF_LOCKED 1 /* Buffers scheduled for write */#define BUF_LOCKED1 2 /* Supers, inodes */#define BUF_DIRTY 3 /* Dirty buffers, not yet scheduled for write */#define NR_LIST 4void mark_buffer_uptodate(struct buffer_head * bh, int on);extern inline void mark_buffer_clean(struct buffer_head * bh){ if (clear_bit(BH_Dirty, &bh->b_state)) { if (bh->b_list == BUF_DIRTY) refile_buffer(bh); }}extern inline void mark_buffer_dirty(struct buffer_head * bh, int flag){ if (!set_bit(BH_Dirty, &bh->b_state)) { set_writetime(bh, flag); if (bh->b_list != BUF_DIRTY) refile_buffer(bh); }}extern int check_disk_change(kdev_t dev);extern void invalidate_inodes(kdev_t dev);extern void invalidate_inode_pages(struct inode *);extern void invalidate_buffers(kdev_t dev);extern int floppy_is_wp(int minor);extern void sync_inodes(kdev_t dev);extern void sync_dev(kdev_t dev);extern int fsync_dev(kdev_t dev);extern void sync_supers(kdev_t dev);extern int bmap(struct inode * inode,int block);extern int notify_change(struct inode *, struct iattr *);extern int namei(const char * pathname, struct inode ** res_inode);extern int lnamei(const char * pathname, struct inode ** res_inode);extern int permission(struct inode * inode,int mask);extern int get_write_access(struct inode *inode);extern void put_write_access(struct inode *inode);extern int open_namei(const char * pathname, int flag, int mode, struct inode ** res_inode, struct inode * base);extern int do_mknod(const char * filename, int mode, dev_t dev);extern int do_pipe(int *);extern void iput(struct inode * inode);extern struct inode * __iget(struct super_block * sb,int nr,int crsmnt);extern struct inode * get_empty_inode(void);extern void insert_inode_hash(struct inode *);extern void clear_inode(struct inode *);extern struct inode * get_pipe_inode(void);extern void make_bad_inode(struct inode *);extern int get_unused_fd(void);extern void put_unused_fd(int);extern struct file * get_empty_filp(void);extern int close_fp(struct file *filp);extern struct buffer_head * get_hash_table(kdev_t dev, int block, int size);extern struct buffer_head * getblk(kdev_t dev, int block, int size);extern void ll_rw_block(int rw, int nr, struct buffer_head * bh[]);extern void ll_rw_page(int rw, kdev_t dev, unsigned long nr, char * buffer);extern void ll_rw_swap_file(int rw, kdev_t dev, unsigned int *b, int nb, char *buffer);extern int is_read_only(kdev_t dev);extern void __brelse(struct buffer_head *buf);extern inline void brelse(struct buffer_head *buf){ if (buf) __brelse(buf);}extern void __bforget(struct buffer_head *buf);extern inline void bforget(struct buffer_head *buf){ if (buf) __bforget(buf);}extern void set_blocksize(kdev_t dev, int size);extern struct buffer_head * bread(kdev_t dev, int block, int size);extern struct buffer_head * breada(kdev_t dev,int block, int size, unsigned int pos, unsigned int filesize);extern int generic_readpage(struct inode *, struct page *);extern int generic_file_read(struct inode *, struct file *, char *, int);extern int generic_file_mmap(struct inode *, struct file *, struct vm_area_struct *);extern int brw_page(int, struct page *, kdev_t, int [], int, int);extern void put_super(kdev_t dev);unsigned long generate_cluster(kdev_t dev, int b[], int size);extern kdev_t ROOT_DEV;extern void show_buffers(void);extern void mount_root(void);#ifdef CONFIG_BLK_DEV_INITRDextern kdev_t real_root_dev;extern int change_root(kdev_t new_root_dev,const char *put_old);#endifextern int char_read(struct inode *, struct file *, char *, int);extern int block_read(struct inode *, struct file *, char *, int);extern int read_ahead[];extern int char_write(struct inode *, struct file *, const char *, int);extern int block_write(struct inode *, struct file *, const char *, int);extern int block_fsync(struct inode *, struct file *);extern int file_fsync(struct inode *, struct file *);extern void dcache_add(struct inode *, const char *, int, unsigned long);extern int dcache_lookup(struct inode *, const char *, int, unsigned long *);extern int inode_change_ok(struct inode *, struct iattr *);extern void inode_setattr(struct inode *, struct iattr *);extern inline struct inode * iget(struct super_block * sb,int nr){ return __iget(sb, nr, 1);}/* kludge to get SCSI modules working */#include <linux/minix_fs.h>#include <linux/minix_fs_sb.h>#endif /* __KERNEL__ */#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -