David Woodhouse | c00c310 | 2007-04-25 14:16:47 +0100 | [diff] [blame^] | 1 | /* |
| 2 | * JFFS2 -- Journalling Flash File System, Version 2. |
| 3 | * |
| 4 | * Copyright © 2001-2007 Red Hat, Inc. |
| 5 | * |
| 6 | * Created by David Woodhouse <dwmw2@infradead.org> |
| 7 | * |
| 8 | * For licensing information, see the file 'LICENCE' in this directory. |
| 9 | * |
| 10 | */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 11 | |
| 12 | #ifndef _JFFS2_FS_I |
| 13 | #define _JFFS2_FS_I |
| 14 | |
| 15 | #include <linux/version.h> |
| 16 | #include <linux/rbtree.h> |
KaiGai Kohei | aa98d7c | 2006-05-13 15:09:47 +0900 | [diff] [blame] | 17 | #include <linux/posix_acl.h> |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 18 | #include <asm/semaphore.h> |
| 19 | |
| 20 | struct jffs2_inode_info { |
Jes Sorensen | 1b1dcc1 | 2006-01-09 15:59:24 -0800 | [diff] [blame] | 21 | /* We need an internal mutex similar to inode->i_mutex. |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 22 | Unfortunately, we can't used the existing one, because |
| 23 | either the GC would deadlock, or we'd have to release it |
| 24 | before letting GC proceed. Or we'd have to put ugliness |
Jes Sorensen | 1b1dcc1 | 2006-01-09 15:59:24 -0800 | [diff] [blame] | 25 | into the GC code so it didn't attempt to obtain the i_mutex |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 26 | for the inode(s) which are already locked */ |
| 27 | struct semaphore sem; |
| 28 | |
| 29 | /* The highest (datanode) version number used for this ino */ |
| 30 | uint32_t highest_version; |
| 31 | |
| 32 | /* List of data fragments which make up the file */ |
| 33 | struct rb_root fragtree; |
| 34 | |
| 35 | /* There may be one datanode which isn't referenced by any of the |
| 36 | above fragments, if it contains a metadata update but no actual |
| 37 | data - or if this is a directory inode */ |
Thomas Gleixner | 182ec4e | 2005-11-07 11:16:07 +0000 | [diff] [blame] | 38 | /* This also holds the _only_ dnode for symlinks/device nodes, |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 39 | etc. */ |
| 40 | struct jffs2_full_dnode *metadata; |
| 41 | |
| 42 | /* Directory entries */ |
| 43 | struct jffs2_full_dirent *dents; |
| 44 | |
Artem B. Bityutskiy | 2b79adc | 2005-07-17 12:13:51 +0100 | [diff] [blame] | 45 | /* The target path if this is the inode of a symlink */ |
| 46 | unsigned char *target; |
| 47 | |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 48 | /* Some stuff we just have to keep in-core at all times, for each inode. */ |
| 49 | struct jffs2_inode_cache *inocache; |
| 50 | |
| 51 | uint16_t flags; |
| 52 | uint8_t usercompr; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 53 | struct inode vfs_inode; |
KaiGai Kohei | aa98d7c | 2006-05-13 15:09:47 +0900 | [diff] [blame] | 54 | #ifdef CONFIG_JFFS2_FS_POSIX_ACL |
| 55 | struct posix_acl *i_acl_access; |
| 56 | struct posix_acl *i_acl_default; |
| 57 | #endif |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 58 | }; |
| 59 | |
| 60 | #endif /* _JFFS2_FS_I */ |