⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 fs.h

📁 GNU Mach 微内核源代码, 基于美国卡内基美隆大学的 Mach 研究项目
💻 H
📖 第 1 页 / 共 2 页
字号:
#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 + -