Greg Kroah-Hartman | b244131 | 2017-11-01 15:07:57 +0100 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0 */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 2 | /* |
| 3 | * coda_fs_i.h |
| 4 | * |
| 5 | * Copyright (C) 1998 Carnegie Mellon University |
| 6 | * |
| 7 | */ |
| 8 | |
| 9 | #ifndef _LINUX_CODA_FS_I |
| 10 | #define _LINUX_CODA_FS_I |
| 11 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 12 | #include <linux/types.h> |
| 13 | #include <linux/list.h> |
Yoshihisa Abe | b5ce1d8 | 2010-10-25 02:03:44 -0400 | [diff] [blame] | 14 | #include <linux/spinlock.h> |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 15 | #include <linux/coda.h> |
| 16 | |
| 17 | /* |
| 18 | * coda fs inode data |
Yoshihisa Abe | b5ce1d8 | 2010-10-25 02:03:44 -0400 | [diff] [blame] | 19 | * c_lock protects accesses to c_flags, c_mapcount, c_cached_epoch, c_uid and |
| 20 | * c_cached_perm. |
| 21 | * vfs_inode is set only when the inode is created and never changes. |
| 22 | * c_fid is set when the inode is created and should be considered immutable. |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 23 | */ |
| 24 | struct coda_inode_info { |
Yoshihisa Abe | b5ce1d8 | 2010-10-25 02:03:44 -0400 | [diff] [blame] | 25 | struct CodaFid c_fid; /* Coda identifier */ |
| 26 | u_short c_flags; /* flags (see below) */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 27 | unsigned int c_mapcount; /* nr of times this inode is mapped */ |
| 28 | unsigned int c_cached_epoch; /* epoch for cached permissions */ |
Eric W. Biederman | 17499e3 | 2013-01-30 19:36:06 -0800 | [diff] [blame] | 29 | kuid_t c_uid; /* fsuid for cached permissions */ |
Yoshihisa Abe | b5ce1d8 | 2010-10-25 02:03:44 -0400 | [diff] [blame] | 30 | unsigned int c_cached_perm; /* cached access permissions */ |
| 31 | spinlock_t c_lock; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 32 | struct inode vfs_inode; |
| 33 | }; |
| 34 | |
| 35 | /* |
| 36 | * coda fs file private data |
| 37 | */ |
| 38 | #define CODA_MAGIC 0xC0DAC0DA |
| 39 | struct coda_file_info { |
| 40 | int cfi_magic; /* magic number */ |
| 41 | struct file *cfi_container; /* container file for this cnode */ |
| 42 | unsigned int cfi_mapcount; /* nr of times this file is mapped */ |
Pedro Cuadra | a9fba24 | 2019-07-16 16:29:13 -0700 | [diff] [blame] | 43 | bool cfi_access_intent; /* is access intent supported */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 44 | }; |
| 45 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 46 | /* flags */ |
| 47 | #define C_VATTR 0x1 /* Validity of vattr in inode */ |
| 48 | #define C_FLUSH 0x2 /* used after a flush */ |
| 49 | #define C_DYING 0x4 /* from venus (which died) */ |
| 50 | #define C_PURGE 0x8 |
| 51 | |
Al Viro | f4947fb | 2012-01-10 11:11:49 -0500 | [diff] [blame] | 52 | struct inode *coda_cnode_make(struct CodaFid *, struct super_block *); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 53 | struct inode *coda_iget(struct super_block *sb, struct CodaFid *fid, struct coda_vattr *attr); |
Al Viro | 0b2c4e3 | 2012-01-10 10:46:03 -0500 | [diff] [blame] | 54 | struct inode *coda_cnode_makectl(struct super_block *sb); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 55 | struct inode *coda_fid_to_inode(struct CodaFid *fid, struct super_block *sb); |
Fabian Frederick | 5bb4481 | 2019-07-16 16:29:09 -0700 | [diff] [blame] | 56 | struct coda_file_info *coda_ftoc(struct file *file); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 57 | void coda_replace_fid(struct inode *, struct CodaFid *, struct CodaFid *); |
| 58 | |
| 59 | #endif |