30d14fce3d1c1fc06d3366a529f8d8ba540e03b2
[openafs.git] / src / afs / LINUX / osi_vfs.h
1 /*
2  * Copyright 2000, International Business Machines Corporation and others.
3  * All Rights Reserved.
4  * 
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
8  */
9
10 /*
11  * Linux interpretations of vnode and vfs structs.
12  *
13  * The Linux "inode" has been abstracted to the fs independent part to avoid
14  * wasting 100+bytes per vnode.
15  */
16
17 #ifndef OSI_VFS_H_
18 #define OSI_VFS_H_
19
20 /* The vnode should match the current implementation of the fs independent
21  * part of the Linux inode.
22  */
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;
30 #endif
31         unsigned long           i_ino;
32         unsigned int            i_count;
33         kdev_t                  i_dev;
34         umode_t                 i_mode;
35         nlink_t                 i_nlink;
36         uid_t                   i_uid;
37         gid_t                   i_gid;
38         kdev_t                  i_rdev;
39 #if defined(AFS_LINUX24_ENV) || defined(pgoff2loff) 
40         loff_t                  i_size;
41 #else
42         off_t                   i_size;
43 #endif
44         time_t                  i_atime;
45         time_t                  i_mtime;
46         time_t                  i_ctime;
47         unsigned long           i_blksize;
48         unsigned long           i_blocks;
49         unsigned long           i_version;
50 #if !defined(AFS_LINUX24_ENV)
51         unsigned long           i_nrpages;
52 #endif
53 #ifdef STRUCT_INODE_HAS_I_BYTES
54         unsigned short          i_bytes;
55 #endif
56         struct semaphore        i_sem;
57 #if defined(AFS_LINUX24_ENV)
58         struct semaphore        i_zombie;
59 #else
60         struct semaphore        i_atomic_write;
61 #endif
62         struct inode_operations *i_op;
63 #if defined(AFS_LINUX24_ENV)
64         struct file_operations  *i_fop;
65 #endif
66         struct super_block      *i_sb;
67 #if defined(AFS_LINUX24_ENV)
68         wait_queue_head_t       i_wait;
69 #else
70         struct wait_queue       *i_wait;
71 #endif
72         struct file_lock        *i_flock;
73 #if defined(AFS_LINUX24_ENV)
74         struct address_space    *i_mapping;
75         struct address_space    i_data;
76 #else
77         struct vm_area_struct   *i_mmap;
78         struct page             *i_pages;
79 #endif
80         struct dquot            *i_dquot[MAXQUOTAS];
81 #if defined(AFS_LINUX24_ENV)
82         struct pipe_inode_info  *i_pipe;
83         struct block_device     *i_bdev;
84 #if defined(STRUCT_INODE_HAS_I_CDEV)
85         struct char_device      *i_cdev;
86 #endif
87         unsigned long           i_dnotify_mask;
88         struct dnotify_struct   *i_dnotify;
89 #endif
90
91         unsigned long           i_state;
92
93         unsigned int            i_flags;
94 #if !defined(AFS_LINUX24_ENV)
95         unsigned char           i_pipe;
96 #endif
97         unsigned char           i_sock;
98
99 #if defined(AFS_LINUX24_ENV)
100         atomic_t                i_writecount;
101 #else
102         int                     i_writecount;
103 #endif
104         unsigned int            i_attr_flags;
105 #if LINUX_VERSION_CODE >= KERNEL_VERSION(2,2,10)
106         __u32                   i_generation;
107 #endif
108 #ifdef notdef
109         union {
110                 struct pipe_inode_info          pipe_i;
111                 struct minix_inode_info         minix_i;
112                 struct ext2_inode_info          ext2_i;
113                 struct hpfs_inode_info          hpfs_i;
114                 struct ntfs_inode_info          ntfs_i;
115                 struct msdos_inode_info         msdos_i;
116                 struct umsdos_inode_info        umsdos_i;
117                 struct iso_inode_info           isofs_i;
118                 struct nfs_inode_info           nfs_i;
119                 struct sysv_inode_info          sysv_i;
120                 struct affs_inode_info          affs_i;
121                 struct ufs_inode_info           ufs_i;
122                 struct romfs_inode_info         romfs_i;
123                 struct coda_inode_info          coda_i;
124                 struct smb_inode_info           smbfs_i;
125                 struct hfs_inode_info           hfs_i;
126                 struct adfs_inode_info          adfs_i;
127                 struct qnx4_inode_info          qnx4_i;    
128                 struct socket                   socket_i;
129                 void                            *generic_ip;
130         } u;
131 #endif
132 } vnode_t;
133
134 /* Map vnode fields to inode fields. */
135 #define i_number        i_ino
136 #define v_count         i_count
137 #define v_op            i_op
138 #if defined(AFS_LINUX24_ENV)
139 #define v_fop           i_fop
140 #endif
141 #define v_type          i_mode
142 #define v_vfsp          i_sb
143 #define vfs_vnodecovered s_covered
144
145 /* v_type bits map to mode bits: */
146 #define VNON 0
147 #define VREG S_IFREG
148 #define VDIR S_IFDIR
149 #define VBLK S_IFBLK
150 #define VCHR S_IFCHR
151 #define VLNK S_IFLNK
152 #define VSOCK S_IFSOCK
153
154 /* vcexcl - used only by afs_create */
155 enum vcexcl { EXCL, NONEXCL } ;
156
157 /* afs_open and afs_close needs to distinguish these cases */
158 #define FWRITE  O_WRONLY|O_RDWR|O_APPEND
159 #define FTRUNC  O_TRUNC
160
161
162 #define IO_APPEND O_APPEND
163 #define FSYNC O_SYNC
164
165 #define VTOI(V)  ((struct inode*)V)
166 #define VN_HOLD(V) ((vnode_t*)V)->i_count++;
167 #define VN_RELE(V) osi_iput((struct inode *)V);
168 #define VFS_STATFS(V, S) ((V)->s_op->statfs)((V), (S), sizeof(*(S)))
169
170
171
172 /* Various mode bits */
173 #define VWRITE  S_IWUSR
174 #define VREAD   S_IRUSR
175 #define VEXEC   S_IXUSR
176 #define VSUID   S_ISUID
177 #define VSGID   S_ISGID
178
179
180 #define vfs super_block
181
182 typedef struct vattr {
183     int         va_type;        /* One of v_types above. */
184     size_t      va_size;
185     unsigned long va_blocks;
186     unsigned long va_blocksize;
187     int         va_mask;        /* AT_xxx operation to perform. */
188     umode_t     va_mode;        /* mode bits. */
189     uid_t       va_uid;
190     gid_t       va_gid;
191     int         va_fsid;        /* Not used? */
192     dev_t       va_rdev;
193     ino_t       va_nodeid;      /* Inode number */
194     nlink_t     va_nlink;       /* link count for file. */
195     struct timeval va_atime;
196     struct timeval va_mtime;
197     struct timeval va_ctime;
198 } vattr_t;
199
200 #define VATTR_NULL(A) memset(A, 0, sizeof(struct vattr))
201
202
203 /* va_masks - these should match their respective ATTR_xxx #defines in fs.h.
204  * afs_notify_change has to use the attr bits in both the Linux and AFS
205  * meanings. The glue layer code uses the ATTR_xxx style names.
206  */
207 #define AT_SIZE         ATTR_SIZE
208 #define AT_MODE         ATTR_MODE
209 #define AT_UID          ATTR_UID
210 #define AT_GID          ATTR_GID
211 #define AT_MTIME        ATTR_MTIME
212
213
214 #define vnodeops inode_operations
215
216 #endif /* OSI_VFS_H_ */