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

📄 fs.h

📁 GNU Hurd 源代码
💻 H
📖 第 1 页 / 共 2 页
字号:
#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/vfs.h>#include <linux/net.h>#include <linux/kdev_t.h>#include <linux/ioctl.h>#include <linux/list.h>#include <linux/dcache.h>#include <linux/stat.h>#include <asm/atomic.h>#include <linux/bitops.h>#include <asm/cache.h>#include <linux/stddef.h>	/* just in case the #define NULL previously in here was needed */struct poll_table_struct;/* * 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: */extern int max_inodes;extern int max_files, nr_files, nr_free_files;extern int max_super_blocks, nr_super_blocks;#define NR_FILE  4096	/* 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 FMODE_READ 1#define FMODE_WRITE 2#define READ 0#define WRITE 1#define READA 2		/* read-ahead  - don't block if no resources */#define WRITEA 3	/* write-ahead - don't block if no resources */#define NIL_FILP	((struct file *)0)#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_NO_DCACHE    2 /* Only dcache the necessary things. */#define FS_NO_PRELIM    4 /* prevent preloading of dentries, even if			   * FS_NO_DCACHE is not set.			   */#define FS_IBASKET      8 /* FS does callback to free_ibasket() if space gets low. *//* * These are the fs-independent mount-flags: up to 16 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 S_QUOTA		128	/* Quota initialized for file/directory/symlink */#define S_APPEND	256	/* Append-only file */#define S_IMMUTABLE	512	/* Immutable file */#define MS_NOATIME	1024	/* Do not update access times. */#define MS_NODIRATIME   2048    /* Do not update directory access times */#define MS_ODD_RENAME   32768    /* Temporary stuff; will go away as soon				  * as nfs_rename() will be cleaned up				  *//* * Flags that can be altered by MS_REMOUNT */#define MS_RMT_MASK (MS_RDONLY|MS_NOSUID|MS_NODEV|MS_NOEXEC|MS_SYNCHRONOUS|MS_MANDLOCK|MS_NOATIME|MS_NODIRATIME)/* * Magic mount flag number. Has to be or-ed to the flag values. */#define MS_MGC_VAL 0xC0ED0000	/* magic flag number to indicate "new" flags */#define MS_MGC_MSK 0xffff0000	/* magic flag number mask *//* * Note that read-only 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 && (inode)->i_sb->s_flags & (flg)) \				|| (inode)->i_flags & (flg))#define IS_RDONLY(inode) (((inode)->i_sb) && ((inode)->i_sb->s_flags & MS_RDONLY))#define IS_NOSUID(inode)	__IS_FLG(inode, MS_NOSUID)#define IS_NODEV(inode)		__IS_FLG(inode, MS_NODEV)#define IS_NOEXEC(inode)	__IS_FLG(inode, MS_NOEXEC)#define IS_SYNC(inode)		__IS_FLG(inode, MS_SYNCHRONOUS)#define IS_MANDLOCK(inode)	__IS_FLG(inode, MS_MANDLOCK)#define IS_QUOTAINIT(inode)	((inode)->i_flags & S_QUOTA)#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)#define IS_NODIRATIME(inode)	__IS_FLG(inode, MS_NODIRATIME)/* 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 */#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 */#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 <asm/semaphore.h>#include <asm/byteorder.h>#include <asm/bitops.h>extern void update_atime (struct inode *inode);#define UPDATE_ATIME(inode) update_atime (inode)extern void buffer_init(unsigned long);extern void inode_init(void);extern void file_table_init(void);extern void dcache_init(void);typedef char buffer_block[BLOCK_SIZE];/* bh state bits */#define BH_Uptodate	0	/* 1 if the buffer contains valid data */#define BH_Dirty	1	/* 1 if the buffer is dirty */#define BH_Lock		2	/* 1 if the buffer is locked */#define BH_Req		3	/* 0 if the buffer has been invalidated */#define BH_Protected	6	/* 1 if the buffer is protected *//* * Try to keep the most commonly used fields in single cache lines (16 * bytes) to improve performance.  This ordering should be * particularly beneficial on 32-bit processors. *  * We use the first 16 bytes for the data which is used in searches * over the block hash lists (ie. getblk(), find_buffer() and * friends). *  * The second 16 bytes we use for lru buffer scans, as used by * sync_buffers() and refill_freelist().  -- sct */struct buffer_head {	/* First cache line: */	struct buffer_head * b_next;	/* Hash queue list */	unsigned long b_blocknr;	/* block number */	unsigned long b_size;		/* block size */	kdev_t b_dev;			/* device (B_FREE = free) */	kdev_t b_rdev;			/* Real device */	unsigned long b_rsector;	/* Real buffer location on disk */	struct buffer_head * b_this_page;	/* circular list of buffers in one page */	unsigned long b_state;		/* buffer state bitmap (see above) */	struct buffer_head * b_next_free;	unsigned int b_count;		/* users using this block */	/* Non-performance-critical data follows. */	char * b_data;			/* pointer to data block (1024 bytes) */	unsigned int b_list;		/* List that this buffer appears */	unsigned long b_flushtime;      /* Time when this (dirty) buffer					 * should be written */	struct wait_queue * b_wait;	struct buffer_head ** b_pprev;		/* doubly linked list of hash-queue */	struct buffer_head * b_prev_free;	/* doubly linked list of buffers */	struct buffer_head * b_reqnext;		/* request queue */	/*	 * I/O completion	 */	void (*b_end_io)(struct buffer_head *bh, int uptodate);	void *b_dev_id;};typedef void (bh_end_io_t)(struct buffer_head *bh, int uptodate);void init_buffer(struct buffer_head *bh, kdev_t dev, int block,		 bh_end_io_t *handler, void *dev_id);static inline int buffer_uptodate(struct buffer_head * bh){	return test_bit(BH_Uptodate, &bh->b_state);}	static inline int buffer_dirty(struct buffer_head * bh){	return test_bit(BH_Dirty, &bh->b_state);}static inline int buffer_locked(struct buffer_head * bh){	return test_bit(BH_Lock, &bh->b_state);}static inline int buffer_req(struct buffer_head * bh){	return test_bit(BH_Req, &bh->b_state);}static inline int buffer_protected(struct buffer_head * bh){	return test_bit(BH_Protected, &bh->b_state);}#define buffer_page(bh)		(mem_map + MAP_NR((bh)->b_data))#define touch_buffer(bh)	set_bit(PG_referenced, &buffer_page(bh)->flags)#include <linux/pipe_fs_i.h>#include <linux/minix_fs_i.h>#include <linux/ext2_fs_i.h>#include <linux/hpfs_fs_i.h>#include <linux/ntfs_fs_i.h>#include <linux/msdos_fs_i.h>#include <linux/umsdos_fs_i.h>#include <linux/iso_fs_i.h>#include <linux/nfs_fs_i.h>#include <linux/sysv_fs_i.h>#include <linux/affs_fs_i.h>#include <linux/ufs_fs_i.h>#include <linux/efs_fs_i.h>#include <linux/coda_fs_i.h>#include <linux/romfs_fs_i.h>#include <linux/smb_fs_i.h>#include <linux/hfs_fs_i.h>#include <linux/adfs_fs_i.h>#include <linux/qnx4_fs_i.h>/* * 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/* * 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;	off_t		ia_size;	time_t		ia_atime;	time_t		ia_mtime;	time_t		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 and mount structures. */#include <linux/quota.h>#include <linux/mount.h>struct inode {	struct list_head	i_hash;	struct list_head	i_list;	struct list_head	i_dentry;	unsigned long		i_ino;	unsigned int		i_count;	kdev_t			i_dev;	umode_t			i_mode;	nlink_t			i_nlink;	uid_t			i_uid;	gid_t			i_gid;	kdev_t			i_rdev;	off_t			i_size;	time_t			i_atime;	time_t			i_mtime;	time_t			i_ctime;	unsigned long		i_blksize;	unsigned long		i_blocks;	unsigned long		i_version;	unsigned long		i_nrpages;	struct semaphore	i_sem;	struct semaphore	i_atomic_write;	struct inode_operations	*i_op;	struct super_block	*i_sb;	struct wait_queue	*i_wait;	struct file_lock	*i_flock;	struct vm_area_struct	*i_mmap;	struct page		*i_pages;	struct dquot		*i_dquot[MAXQUOTAS];	unsigned long		i_state;	unsigned int		i_flags;	unsigned char		i_pipe;	unsigned char		i_sock;	int			i_writecount;	unsigned int		i_attr_flags;	__u32			i_generation;	union {		struct pipe_inode_info		pipe_i;		struct minix_inode_info		minix_i;		struct ext2_inode_info		ext2_i;		struct hpfs_inode_info		hpfs_i;		struct ntfs_inode_info          ntfs_i;		struct msdos_inode_info		msdos_i;		struct umsdos_inode_info	umsdos_i;		struct iso_inode_info		isofs_i;		struct nfs_inode_info		nfs_i;		struct sysv_inode_info		sysv_i;		struct affs_inode_info		affs_i;		struct ufs_inode_info		ufs_i;		struct efs_inode_info		efs_i;		struct romfs_inode_info		romfs_i;		struct coda_inode_info		coda_i;		struct smb_inode_info		smbfs_i;		struct hfs_inode_info		hfs_i;		struct adfs_inode_info		adfs_i;		struct qnx4_inode_info		qnx4_i;		struct socket			socket_i;		void				*generic_ip;	} u;};/* Inode state bits.. */#define I_DIRTY		1#define I_LOCK		2#define I_FREEING	4extern void __mark_inode_dirty(struct inode *);static inline void mark_inode_dirty(struct inode *inode){	if (!(inode->i_state & I_DIRTY))		__mark_inode_dirty(inode);}struct fown_struct {	int pid;		/* pid or -pgrp where SIGIO should be sent */	uid_t uid, euid;	/* uid/euid of process setting the owner */	int signum;		/* posix.1b rt signal to be delivered on IO */};struct file {	struct file		*f_next, **f_pprev;	struct dentry		*f_dentry;	struct file_operations	*f_op;	mode_t			f_mode;	loff_t			f_pos;	unsigned int 		f_count, f_flags;	unsigned long 		f_reada, f_ramax, f_raend, f_ralen, f_rawin;	struct fown_struct	f_owner;	unsigned int		f_uid, f_gid;	int			f_error;	unsigned long		f_version;	/* needed for tty driver, and maybe others */	void			*private_data;};extern int init_private_file(struct file *, struct dentry *, int);#define FL_POSIX	1#define FL_FLOCK	2#define FL_BROKEN	4	/* broken flock() emulation */#define FL_ACCESS	8	/* for processes suspended by mandatory locking */#define FL_LOCKD	16	/* lock held by rpc.lockd *//* * The POSIX file lock owner is determined by * the "struct files_struct" in the thread group * (or NULL for no owner - BSD locks). * * Lockd stuffs a "host" pointer into this. */typedef struct files_struct *fl_owner_t;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;	fl_owner_t fl_owner;	unsigned int fl_pid;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -