fs.h
来自「Linux Kernel 2.6.9 for OMAP1710」· C头文件 代码 · 共 1,645 行 · 第 1/4 页
H
1,645 行
#ifndef _LINUX_FS_H#define _LINUX_FS_H/* * This file has definitions for some important file table * structures etc. */#include <linux/config.h>#include <linux/linkage.h>#include <linux/limits.h>#include <linux/wait.h>#include <linux/types.h>#include <linux/kdev_t.h>#include <linux/ioctl.h>#include <linux/dcache.h>#include <linux/stat.h>#include <linux/cache.h>#include <linux/prio_tree.h>#include <linux/kobject.h>#include <asm/atomic.h>struct iovec;struct nameidata;struct pipe_inode_info;struct poll_table_struct;struct kstatfs;struct vm_area_struct;struct vfsmount;/* * It's silly to have NR_OPEN bigger than NR_FILE, but you can change * the file limit at runtime and only root can increase the per-process * nr_file rlimit, so it's safe to set up a ridiculously high absolute * upper limit on files-per-process. * * Some programs (notably those using select()) may have to be * recompiled to take full advantage of the new limits.. *//* Fixed constants first: */#undef NR_OPEN#define NR_OPEN (1024*1024) /* Absolute upper limit on fd num */#define INR_OPEN 1024 /* Initial setting for nfile rlimits */#define BLOCK_SIZE_BITS 10#define BLOCK_SIZE (1<<BLOCK_SIZE_BITS)/* And dynamically-tunable limits and defaults: */struct files_stat_struct { int nr_files; /* read only */ int nr_free_files; /* read only */ int max_files; /* tunable */};extern struct files_stat_struct files_stat;struct inodes_stat_t { int nr_inodes; int nr_unused; int dummy[5];};extern struct inodes_stat_t inodes_stat;extern int leases_enable, dir_notify_enable, lease_break_time;#define NR_FILE 8192 /* this can well be larger on a larger system */#define NR_RESERVED_FILES 10 /* reserved for root */#define NR_SUPER 256#define MAY_EXEC 1#define MAY_WRITE 2#define MAY_READ 4#define MAY_APPEND 8#define FMODE_READ 1#define FMODE_WRITE 2/* Internal kernel extensions */#define FMODE_LSEEK 4#define FMODE_PREAD 8#define FMODE_PWRITE FMODE_PREAD /* These go hand in hand */#define RW_MASK 1#define RWA_MASK 2#define READ 0#define WRITE 1#define READA 2 /* read-ahead - don't block if no resources */#define SPECIAL 4 /* For non-blockdevice requests in request queue */#define READ_SYNC (READ | (1 << BIO_RW_SYNC))#define WRITE_SYNC (WRITE | (1 << BIO_RW_SYNC))#define WRITE_BARRIER ((1 << BIO_RW) | (1 << BIO_RW_BARRIER))#define SEL_IN 1#define SEL_OUT 2#define SEL_EX 4/* public flags for file_system_type */#define FS_REQUIRES_DEV 1 #define FS_BINARY_MOUNTDATA 2#define FS_REVAL_DOT 16384 /* Check the paths ".", ".." for staleness */#define FS_ODD_RENAME 32768 /* Temporary stuff; will go away as soon * as nfs_rename() will be cleaned up *//* * These are the fs-independent mount-flags: up to 32 flags are supported */#define MS_RDONLY 1 /* Mount read-only */#define MS_NOSUID 2 /* Ignore suid and sgid bits */#define MS_NODEV 4 /* Disallow access to device special files */#define MS_NOEXEC 8 /* Disallow program execution */#define MS_SYNCHRONOUS 16 /* Writes are synced at once */#define MS_REMOUNT 32 /* Alter flags of a mounted FS */#define MS_MANDLOCK 64 /* Allow mandatory locks on an FS */#define MS_DIRSYNC 128 /* Directory modifications are synchronous */#define MS_NOATIME 1024 /* Do not update access times. */#define MS_NODIRATIME 2048 /* Do not update directory access times */#define MS_BIND 4096#define MS_MOVE 8192#define MS_REC 16384#define MS_VERBOSE 32768#define MS_POSIXACL (1<<16) /* VFS does not apply the umask */#define MS_ONE_SECOND (1<<17) /* fs has 1 sec a/m/ctime resolution */#define MS_ACTIVE (1<<30)#define MS_NOUSER (1<<31)/* * Superblock flags that can be altered by MS_REMOUNT */#define MS_RMT_MASK (MS_RDONLY|MS_SYNCHRONOUS|MS_MANDLOCK|MS_NOATIME|\ MS_NODIRATIME)/* * Old magic mount flag and mask */#define MS_MGC_VAL 0xC0ED0000#define MS_MGC_MSK 0xffff0000/* Inode flags - they have nothing to superblock flags now */#define S_SYNC 1 /* Writes are synced at once */#define S_NOATIME 2 /* Do not update access times */#define S_APPEND 4 /* Append-only file */#define S_IMMUTABLE 8 /* Immutable file */#define S_DEAD 16 /* removed, but still open directory */#define S_NOQUOTA 32 /* Inode is not counted to quota */#define S_DIRSYNC 64 /* Directory modifications are synchronous */#define S_NOCMTIME 128 /* Do not update file c/mtime */#define S_SWAPFILE 256 /* Do not truncate: swapon got its bmaps *//* * Note that nosuid etc flags are inode-specific: setting some file-system * flags just means all the inodes inherit those flags by default. It might be * possible to override it selectively if you really wanted to with some * ioctl() that is not currently implemented. * * Exception: MS_RDONLY is always applied to the entire file system. * * Unfortunately, it is possible to change a filesystems flags with it mounted * with files in use. This means that all of the inodes will not have their * i_flags updated. Hence, i_flags no longer inherit the superblock mount * flags, so these have to be checked separately. -- rmk@arm.uk.linux.org */#define __IS_FLG(inode,flg) ((inode)->i_sb->s_flags & (flg))#define IS_RDONLY(inode) ((inode)->i_sb->s_flags & MS_RDONLY)#define IS_SYNC(inode) (__IS_FLG(inode, MS_SYNCHRONOUS) || \ ((inode)->i_flags & S_SYNC))#define IS_DIRSYNC(inode) (__IS_FLG(inode, MS_SYNCHRONOUS|MS_DIRSYNC) || \ ((inode)->i_flags & (S_SYNC|S_DIRSYNC)))#define IS_MANDLOCK(inode) __IS_FLG(inode, MS_MANDLOCK)#define IS_NOQUOTA(inode) ((inode)->i_flags & S_NOQUOTA)#define IS_APPEND(inode) ((inode)->i_flags & S_APPEND)#define IS_IMMUTABLE(inode) ((inode)->i_flags & S_IMMUTABLE)#define IS_NOATIME(inode) (__IS_FLG(inode, MS_NOATIME) || ((inode)->i_flags & S_NOATIME))#define IS_NODIRATIME(inode) __IS_FLG(inode, MS_NODIRATIME)#define IS_POSIXACL(inode) __IS_FLG(inode, MS_POSIXACL)#define IS_ONE_SECOND(inode) __IS_FLG(inode, MS_ONE_SECOND)#define IS_DEADDIR(inode) ((inode)->i_flags & S_DEAD)#define IS_NOCMTIME(inode) ((inode)->i_flags & S_NOCMTIME)#define IS_SWAPFILE(inode) ((inode)->i_flags & S_SWAPFILE)/* the read-only stuff doesn't really belong here, but any other place is probably as bad and I don't want to create yet another include file. */#define BLKROSET _IO(0x12,93) /* set device read-only (0 = read-write) */#define BLKROGET _IO(0x12,94) /* get read-only status (0 = read_write) */#define BLKRRPART _IO(0x12,95) /* re-read partition table */#define BLKGETSIZE _IO(0x12,96) /* return device size /512 (long *arg) */#define BLKFLSBUF _IO(0x12,97) /* flush buffer cache */#define BLKRASET _IO(0x12,98) /* set read ahead for block device */#define BLKRAGET _IO(0x12,99) /* get current read ahead setting */#define BLKFRASET _IO(0x12,100)/* set filesystem (mm/filemap.c) read-ahead */#define BLKFRAGET _IO(0x12,101)/* get filesystem (mm/filemap.c) read-ahead */#define BLKSECTSET _IO(0x12,102)/* set max sectors per request (ll_rw_blk.c) */#define BLKSECTGET _IO(0x12,103)/* get max sectors per request (ll_rw_blk.c) */#define BLKSSZGET _IO(0x12,104)/* get block device sector size */#if 0#define BLKPG _IO(0x12,105)/* See blkpg.h *//* Some people are morons. Do not use sizeof! */#define BLKELVGET _IOR(0x12,106,size_t)/* elevator get */#define BLKELVSET _IOW(0x12,107,size_t)/* elevator set *//* This was here just to show that the number is taken - probably all these _IO(0x12,*) ioctls should be moved to blkpg.h. */#endif/* A jump here: 108-111 have been used for various private purposes. */#define BLKBSZGET _IOR(0x12,112,size_t)#define BLKBSZSET _IOW(0x12,113,size_t)#define BLKGETSIZE64 _IOR(0x12,114,size_t) /* return device size in bytes (u64 *arg) */#define BMAP_IOCTL 1 /* obsolete - kept for compatibility */#define FIBMAP _IO(0x00,1) /* bmap access */#define FIGETBSZ _IO(0x00,2) /* get the block size used for bmap */#ifdef __KERNEL__#include <linux/list.h>#include <linux/radix-tree.h>#include <linux/audit.h>#include <linux/init.h>#include <asm/semaphore.h>#include <asm/byteorder.h>/* Used to be a macro which just called the function, now just a function */extern void update_atime (struct inode *);extern void __init inode_init(unsigned long);extern void __init inode_init_early(void);extern void __init mnt_init(unsigned long);extern void __init files_init(unsigned long);struct buffer_head;typedef int (get_block_t)(struct inode *inode, sector_t iblock, struct buffer_head *bh_result, int create);typedef int (get_blocks_t)(struct inode *inode, sector_t iblock, unsigned long max_blocks, struct buffer_head *bh_result, int create);typedef void (dio_iodone_t)(struct inode *inode, loff_t offset, ssize_t bytes, void *private);/* * Attribute flags. These should be or-ed together to figure out what * has been changed! */#define ATTR_MODE 1#define ATTR_UID 2#define ATTR_GID 4#define ATTR_SIZE 8#define ATTR_ATIME 16#define ATTR_MTIME 32#define ATTR_CTIME 64#define ATTR_ATIME_SET 128#define ATTR_MTIME_SET 256#define ATTR_FORCE 512 /* Not a change, but a change it */#define ATTR_ATTR_FLAG 1024#define ATTR_KILL_SUID 2048#define ATTR_KILL_SGID 4096/* * This is the Inode Attributes structure, used for notify_change(). It * uses the above definitions as flags, to know which values have changed. * Also, in this manner, a Filesystem can look at only the values it cares * about. Basically, these are the attributes that the VFS layer can * request to change from the FS layer. * * Derek Atkins <warlord@MIT.EDU> 94-10-20 */struct iattr { unsigned int ia_valid; umode_t ia_mode; uid_t ia_uid; gid_t ia_gid; loff_t ia_size; struct timespec ia_atime; struct timespec ia_mtime; struct timespec ia_ctime; unsigned int ia_attr_flags;};/* * This is the inode attributes flag definitions */#define ATTR_FLAG_SYNCRONOUS 1 /* Syncronous write */#define ATTR_FLAG_NOATIME 2 /* Don't update atime */#define ATTR_FLAG_APPEND 4 /* Append-only file */#define ATTR_FLAG_IMMUTABLE 8 /* Immutable file */#define ATTR_FLAG_NODIRATIME 16 /* Don't update atime for directory *//* * Includes for diskquotas. */#include <linux/quota.h>/* * oh the beauties of C type declarations. */struct page;struct address_space;struct writeback_control;struct kiocb;struct address_space_operations { int (*writepage)(struct page *page, struct writeback_control *wbc); int (*readpage)(struct file *, struct page *); int (*sync_page)(struct page *); /* Write back some dirty pages from this mapping. */ int (*writepages)(struct address_space *, struct writeback_control *); /* Set a page dirty */ int (*set_page_dirty)(struct page *page); int (*readpages)(struct file *filp, struct address_space *mapping, struct list_head *pages, unsigned nr_pages); /* * ext3 requires that a successful prepare_write() call be followed * by a commit_write() call - they must be balanced */ int (*prepare_write)(struct file *, struct page *, unsigned, unsigned); int (*commit_write)(struct file *, struct page *, unsigned, unsigned); /* Unfortunately this kludge is needed for FIBMAP. Don't use it */ sector_t (*bmap)(struct address_space *, sector_t); int (*invalidatepage) (struct page *, unsigned long); int (*releasepage) (struct page *, int); ssize_t (*direct_IO)(int, struct kiocb *, const struct iovec *iov, loff_t offset, unsigned long nr_segs);};struct backing_dev_info;struct address_space { struct inode *host; /* owner: inode, block_device */ struct radix_tree_root page_tree; /* radix tree of all pages */ spinlock_t tree_lock; /* and spinlock protecting it */ unsigned int i_mmap_writable;/* count VM_SHARED mappings */ struct prio_tree_root i_mmap; /* tree of private and shared mappings */ struct list_head i_mmap_nonlinear;/*list VM_NONLINEAR mappings */ spinlock_t i_mmap_lock; /* protect tree, count, list */ atomic_t truncate_count; /* Cover race condition with truncate */ unsigned long nrpages; /* number of total pages */ pgoff_t writeback_index;/* writeback starts here */ struct address_space_operations *a_ops; /* methods */ unsigned long flags; /* error bits/gfp mask */ struct backing_dev_info *backing_dev_info; /* device readahead, etc */ spinlock_t private_lock; /* for use by the address_space */ struct list_head private_list; /* ditto */ struct address_space *assoc_mapping; /* ditto */};struct block_device { dev_t bd_dev; /* not a kdev_t - it's a search key */ struct inode * bd_inode; /* will die */ int bd_openers; struct semaphore bd_sem; /* open/close mutex */ struct semaphore bd_mount_sem; /* mount mutex */ struct list_head bd_inodes; void * bd_holder; int bd_holders; struct block_device * bd_contains; unsigned bd_block_size; struct hd_struct * bd_part; /* number of times partitions within this device have been opened. */ unsigned bd_part_count; int bd_invalidated; struct gendisk * bd_disk; struct list_head bd_list; struct backing_dev_info *bd_inode_backing_dev_info; /* * Private data. You must have bd_claim'ed the block_device * to use this. NOTE: bd_claim allows an owner to claim * the same device multiple times, the owner must take special * care to not mess up bd_private for that case. */ unsigned long bd_private;};/* * Radix-tree tags, for tagging dirty and writeback pages within the pagecache * radix trees */#define PAGECACHE_TAG_DIRTY 0#define PAGECACHE_TAG_WRITEBACK 1int mapping_tagged(struct address_space *mapping, int tag);/* * Might pages of this file be mapped into userspace? */static inline int mapping_mapped(struct address_space *mapping){ return !prio_tree_empty(&mapping->i_mmap) || !list_empty(&mapping->i_mmap_nonlinear);}/* * Might pages of this file have been modified in userspace? * Note that i_mmap_writable counts all VM_SHARED vmas: do_mmap_pgoff * marks vma as VM_SHARED if it is shared, and the file was opened for * writing i.e. vma may be mprotected writable even if now readonly. */static inline int mapping_writably_mapped(struct address_space *mapping){ return mapping->i_mmap_writable != 0;}/* * Use sequence counter to get consistent i_size on 32-bit processors. */#if BITS_PER_LONG==32 && defined(CONFIG_SMP)
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?