diff options
author | Glenn Elliott <gelliott@cs.unc.edu> | 2012-03-04 19:47:13 -0500 |
---|---|---|
committer | Glenn Elliott <gelliott@cs.unc.edu> | 2012-03-04 19:47:13 -0500 |
commit | c71c03bda1e86c9d5198c5d83f712e695c4f2a1e (patch) | |
tree | ecb166cb3e2b7e2adb3b5e292245fefd23381ac8 /fs/nilfs2/mdt.h | |
parent | ea53c912f8a86a8567697115b6a0d8152beee5c8 (diff) | |
parent | 6a00f206debf8a5c8899055726ad127dbeeed098 (diff) |
Merge branch 'mpi-master' into wip-k-fmlpwip-k-fmlp
Conflicts:
litmus/sched_cedf.c
Diffstat (limited to 'fs/nilfs2/mdt.h')
-rw-r--r-- | fs/nilfs2/mdt.h | 37 |
1 files changed, 19 insertions, 18 deletions
diff --git a/fs/nilfs2/mdt.h b/fs/nilfs2/mdt.h index 6c4bbb0470fc..ab20a4baa50f 100644 --- a/fs/nilfs2/mdt.h +++ b/fs/nilfs2/mdt.h | |||
@@ -28,26 +28,33 @@ | |||
28 | #include "nilfs.h" | 28 | #include "nilfs.h" |
29 | #include "page.h" | 29 | #include "page.h" |
30 | 30 | ||
31 | struct nilfs_shadow_map { | ||
32 | struct nilfs_bmap_store bmap_store; | ||
33 | struct address_space frozen_data; | ||
34 | struct address_space frozen_btnodes; | ||
35 | struct list_head frozen_buffers; | ||
36 | }; | ||
37 | |||
31 | /** | 38 | /** |
32 | * struct nilfs_mdt_info - on-memory private data of meta data files | 39 | * struct nilfs_mdt_info - on-memory private data of meta data files |
33 | * @mi_nilfs: back pointer to the_nilfs struct | ||
34 | * @mi_sem: reader/writer semaphore for meta data operations | 40 | * @mi_sem: reader/writer semaphore for meta data operations |
35 | * @mi_bgl: per-blockgroup locking | 41 | * @mi_bgl: per-blockgroup locking |
36 | * @mi_entry_size: size of an entry | 42 | * @mi_entry_size: size of an entry |
37 | * @mi_first_entry_offset: offset to the first entry | 43 | * @mi_first_entry_offset: offset to the first entry |
38 | * @mi_entries_per_block: number of entries in a block | 44 | * @mi_entries_per_block: number of entries in a block |
39 | * @mi_palloc_cache: persistent object allocator cache | 45 | * @mi_palloc_cache: persistent object allocator cache |
46 | * @mi_shadow: shadow of bmap and page caches | ||
40 | * @mi_blocks_per_group: number of blocks in a group | 47 | * @mi_blocks_per_group: number of blocks in a group |
41 | * @mi_blocks_per_desc_block: number of blocks per descriptor block | 48 | * @mi_blocks_per_desc_block: number of blocks per descriptor block |
42 | */ | 49 | */ |
43 | struct nilfs_mdt_info { | 50 | struct nilfs_mdt_info { |
44 | struct the_nilfs *mi_nilfs; | ||
45 | struct rw_semaphore mi_sem; | 51 | struct rw_semaphore mi_sem; |
46 | struct blockgroup_lock *mi_bgl; | 52 | struct blockgroup_lock *mi_bgl; |
47 | unsigned mi_entry_size; | 53 | unsigned mi_entry_size; |
48 | unsigned mi_first_entry_offset; | 54 | unsigned mi_first_entry_offset; |
49 | unsigned long mi_entries_per_block; | 55 | unsigned long mi_entries_per_block; |
50 | struct nilfs_palloc_cache *mi_palloc_cache; | 56 | struct nilfs_palloc_cache *mi_palloc_cache; |
57 | struct nilfs_shadow_map *mi_shadow; | ||
51 | unsigned long mi_blocks_per_group; | 58 | unsigned long mi_blocks_per_group; |
52 | unsigned long mi_blocks_per_desc_block; | 59 | unsigned long mi_blocks_per_desc_block; |
53 | }; | 60 | }; |
@@ -57,13 +64,6 @@ static inline struct nilfs_mdt_info *NILFS_MDT(const struct inode *inode) | |||
57 | return inode->i_private; | 64 | return inode->i_private; |
58 | } | 65 | } |
59 | 66 | ||
60 | static inline struct the_nilfs *NILFS_I_NILFS(struct inode *inode) | ||
61 | { | ||
62 | struct super_block *sb = inode->i_sb; | ||
63 | |||
64 | return sb ? NILFS_SB(sb)->s_nilfs : NILFS_MDT(inode)->mi_nilfs; | ||
65 | } | ||
66 | |||
67 | /* Default GFP flags using highmem */ | 67 | /* Default GFP flags using highmem */ |
68 | #define NILFS_MDT_GFP (__GFP_WAIT | __GFP_IO | __GFP_HIGHMEM) | 68 | #define NILFS_MDT_GFP (__GFP_WAIT | __GFP_IO | __GFP_HIGHMEM) |
69 | 69 | ||
@@ -76,16 +76,17 @@ int nilfs_mdt_forget_block(struct inode *, unsigned long); | |||
76 | int nilfs_mdt_mark_block_dirty(struct inode *, unsigned long); | 76 | int nilfs_mdt_mark_block_dirty(struct inode *, unsigned long); |
77 | int nilfs_mdt_fetch_dirty(struct inode *); | 77 | int nilfs_mdt_fetch_dirty(struct inode *); |
78 | 78 | ||
79 | struct inode *nilfs_mdt_new(struct the_nilfs *, struct super_block *, ino_t, | 79 | int nilfs_mdt_init(struct inode *inode, gfp_t gfp_mask, size_t objsz); |
80 | size_t); | ||
81 | struct inode *nilfs_mdt_new_common(struct the_nilfs *, struct super_block *, | ||
82 | ino_t, gfp_t, size_t); | ||
83 | void nilfs_mdt_destroy(struct inode *); | ||
84 | void nilfs_mdt_set_entry_size(struct inode *, unsigned, unsigned); | 80 | void nilfs_mdt_set_entry_size(struct inode *, unsigned, unsigned); |
85 | void nilfs_mdt_set_shadow(struct inode *, struct inode *); | ||
86 | |||
87 | 81 | ||
88 | #define nilfs_mdt_mark_buffer_dirty(bh) nilfs_mark_buffer_dirty(bh) | 82 | int nilfs_mdt_setup_shadow_map(struct inode *inode, |
83 | struct nilfs_shadow_map *shadow); | ||
84 | int nilfs_mdt_save_to_shadow_map(struct inode *inode); | ||
85 | void nilfs_mdt_restore_from_shadow_map(struct inode *inode); | ||
86 | void nilfs_mdt_clear_shadow_map(struct inode *inode); | ||
87 | int nilfs_mdt_freeze_buffer(struct inode *inode, struct buffer_head *bh); | ||
88 | struct buffer_head *nilfs_mdt_get_frozen_buffer(struct inode *inode, | ||
89 | struct buffer_head *bh); | ||
89 | 90 | ||
90 | static inline void nilfs_mdt_mark_dirty(struct inode *inode) | 91 | static inline void nilfs_mdt_mark_dirty(struct inode *inode) |
91 | { | 92 | { |
@@ -100,7 +101,7 @@ static inline void nilfs_mdt_clear_dirty(struct inode *inode) | |||
100 | 101 | ||
101 | static inline __u64 nilfs_mdt_cno(struct inode *inode) | 102 | static inline __u64 nilfs_mdt_cno(struct inode *inode) |
102 | { | 103 | { |
103 | return NILFS_MDT(inode)->mi_nilfs->ns_cno; | 104 | return ((struct the_nilfs *)inode->i_sb->s_fs_info)->ns_cno; |
104 | } | 105 | } |
105 | 106 | ||
106 | #define nilfs_mdt_bgl_lock(inode, bg) \ | 107 | #define nilfs_mdt_bgl_lock(inode, bg) \ |