2 * Copyright 2000, International Business Machines Corporation and others.
5 * This software has been released under the terms of the IBM Public
6 * License. For details, see the LICENSE file in the top-level source
7 * directory or online at http://www.openafs.org/dl/license10.html
11 * Linux interpretations of vnode and vfs structs.
13 * The Linux "inode" has been abstracted to the fs independent part to avoid
14 * wasting 100+bytes per vnode.
20 /* The vnode should match the current implementation of the fs independent
21 * part of the Linux inode.
23 /* The first cut is to continue to use a separate vnode pool. */
24 typedef struct vnode {
25 struct list_head i_hash;
26 struct list_head i_list;
27 struct list_head i_dentry;
28 #if defined(AFS_LINUX24_ENV)
29 struct list_head i_dirty_buffers;
31 #if defined(STRUCT_INODE_HAS_I_DIRTY_DATA_BUFFERS)
32 struct list_head i_dirty_data_buffers;
42 #if defined(AFS_LINUX24_ENV) || defined(pgoff2loff)
50 unsigned long i_blksize;
51 unsigned long i_blocks;
52 unsigned long i_version;
53 #if !defined(AFS_LINUX24_ENV)
54 unsigned long i_nrpages;
56 #ifdef STRUCT_INODE_HAS_I_BYTES
57 unsigned short i_bytes;
59 struct semaphore i_sem;
60 #ifdef STRUCT_INODE_HAS_I_TRUNCATE_SEM
61 struct rw_semaphore i_truncate_sem;
63 #if defined(AFS_LINUX24_ENV)
64 struct semaphore i_zombie;
66 struct semaphore i_atomic_write;
68 struct inode_operations *i_op;
69 #if defined(AFS_LINUX24_ENV)
70 struct file_operations *i_fop;
72 struct super_block *i_sb;
73 #if defined(AFS_LINUX24_ENV)
74 wait_queue_head_t i_wait;
76 struct wait_queue *i_wait;
78 struct file_lock *i_flock;
79 #if defined(AFS_LINUX24_ENV)
80 struct address_space *i_mapping;
81 struct address_space i_data;
83 struct vm_area_struct *i_mmap;
86 #if defined(STRUCT_INODE_HAS_I_MAPPING_OVERLOAD)
87 int i_mapping_overload;
89 struct dquot *i_dquot[MAXQUOTAS];
90 #if defined(AFS_LINUX24_ENV)
91 struct pipe_inode_info *i_pipe;
92 struct block_device *i_bdev;
93 #if defined(STRUCT_INODE_HAS_I_CDEV)
94 struct char_device *i_cdev;
96 unsigned long i_dnotify_mask;
97 struct dnotify_struct *i_dnotify;
100 unsigned long i_state;
102 unsigned int i_flags;
103 #if !defined(AFS_LINUX24_ENV)
104 unsigned char i_pipe;
106 unsigned char i_sock;
108 #if defined(AFS_LINUX24_ENV)
109 atomic_t i_writecount;
113 unsigned int i_attr_flags;
114 #if LINUX_VERSION_CODE >= KERNEL_VERSION(2,2,10)
119 struct pipe_inode_info pipe_i;
120 struct minix_inode_info minix_i;
121 struct ext2_inode_info ext2_i;
122 struct hpfs_inode_info hpfs_i;
123 struct ntfs_inode_info ntfs_i;
124 struct msdos_inode_info msdos_i;
125 struct umsdos_inode_info umsdos_i;
126 struct iso_inode_info isofs_i;
127 struct nfs_inode_info nfs_i;
128 struct sysv_inode_info sysv_i;
129 struct affs_inode_info affs_i;
130 struct ufs_inode_info ufs_i;
131 struct romfs_inode_info romfs_i;
132 struct coda_inode_info coda_i;
133 struct smb_inode_info smbfs_i;
134 struct hfs_inode_info hfs_i;
135 struct adfs_inode_info adfs_i;
136 struct qnx4_inode_info qnx4_i;
137 struct socket socket_i;
143 /* Map vnode fields to inode fields. */
144 #define i_number i_ino
145 #define v_count i_count
147 #if defined(AFS_LINUX24_ENV)
150 #define v_type i_mode
152 #define vfs_vnodecovered s_covered
154 /* v_type bits map to mode bits: */
161 #define VSOCK S_IFSOCK
163 /* vcexcl - used only by afs_create */
164 enum vcexcl { EXCL, NONEXCL } ;
166 /* afs_open and afs_close needs to distinguish these cases */
167 #define FWRITE O_WRONLY|O_RDWR|O_APPEND
168 #define FTRUNC O_TRUNC
171 #define IO_APPEND O_APPEND
174 #define VTOI(V) ((struct inode*)V)
175 #define VN_HOLD(V) ((vnode_t*)V)->i_count++;
176 #define VN_RELE(V) osi_iput((struct inode *)V);
177 #define VFS_STATFS(V, S) ((V)->s_op->statfs)((V), (S), sizeof(*(S)))
181 /* Various mode bits */
182 #define VWRITE S_IWUSR
183 #define VREAD S_IRUSR
184 #define VEXEC S_IXUSR
185 #define VSUID S_ISUID
186 #define VSGID S_ISGID
189 #define vfs super_block
191 typedef struct vattr {
192 int va_type; /* One of v_types above. */
194 unsigned long va_blocks;
195 unsigned long va_blocksize;
196 int va_mask; /* AT_xxx operation to perform. */
197 umode_t va_mode; /* mode bits. */
200 int va_fsid; /* Not used? */
202 ino_t va_nodeid; /* Inode number */
203 nlink_t va_nlink; /* link count for file. */
204 struct timeval va_atime;
205 struct timeval va_mtime;
206 struct timeval va_ctime;
209 #define VATTR_NULL(A) memset(A, 0, sizeof(struct vattr))
212 /* va_masks - these should match their respective ATTR_xxx #defines in fs.h.
213 * afs_notify_change has to use the attr bits in both the Linux and AFS
214 * meanings. The glue layer code uses the ATTR_xxx style names.
216 #define AT_SIZE ATTR_SIZE
217 #define AT_MODE ATTR_MODE
218 #define AT_UID ATTR_UID
219 #define AT_GID ATTR_GID
220 #define AT_MTIME ATTR_MTIME
223 #define vnodeops inode_operations
225 #endif /* OSI_VFS_H_ */