diff options
-rw-r--r-- | fs/ocfs2/inode.c | 6 | ||||
-rw-r--r-- | fs/ocfs2/inode.h | 7 | ||||
-rw-r--r-- | fs/ocfs2/journal.c | 43 | ||||
-rw-r--r-- | fs/ocfs2/journal.h | 9 | ||||
-rw-r--r-- | fs/ocfs2/super.c | 2 |
5 files changed, 0 insertions, 67 deletions
diff --git a/fs/ocfs2/inode.c b/fs/ocfs2/inode.c index 16e8e74dc966..20e60e4b1f10 100644 --- a/fs/ocfs2/inode.c +++ b/fs/ocfs2/inode.c | |||
@@ -1067,12 +1067,6 @@ void ocfs2_clear_inode(struct inode *inode) | |||
1067 | mlog_bug_on_msg(oi->ip_open_count, | 1067 | mlog_bug_on_msg(oi->ip_open_count, |
1068 | "Clear inode of %llu has open count %d\n", | 1068 | "Clear inode of %llu has open count %d\n", |
1069 | (unsigned long long)oi->ip_blkno, oi->ip_open_count); | 1069 | (unsigned long long)oi->ip_blkno, oi->ip_open_count); |
1070 | mlog_bug_on_msg(!list_empty(&oi->ip_handle_list), | ||
1071 | "Clear inode of %llu has non empty handle list\n", | ||
1072 | (unsigned long long)oi->ip_blkno); | ||
1073 | mlog_bug_on_msg(oi->ip_handle, | ||
1074 | "Clear inode of %llu has non empty handle pointer\n", | ||
1075 | (unsigned long long)oi->ip_blkno); | ||
1076 | 1070 | ||
1077 | /* Clear all other flags. */ | 1071 | /* Clear all other flags. */ |
1078 | oi->ip_flags = OCFS2_INODE_CACHE_INLINE; | 1072 | oi->ip_flags = OCFS2_INODE_CACHE_INLINE; |
diff --git a/fs/ocfs2/inode.h b/fs/ocfs2/inode.h index 9957810fdf85..9b7354545cb4 100644 --- a/fs/ocfs2/inode.h +++ b/fs/ocfs2/inode.h | |||
@@ -48,13 +48,6 @@ struct ocfs2_inode_info | |||
48 | 48 | ||
49 | struct mutex ip_io_mutex; | 49 | struct mutex ip_io_mutex; |
50 | 50 | ||
51 | /* Used by the journalling code to attach an inode to a | ||
52 | * handle. These are protected by ip_io_mutex in order to lock | ||
53 | * out other I/O to the inode until we either commit or | ||
54 | * abort. */ | ||
55 | struct list_head ip_handle_list; | ||
56 | struct ocfs2_journal_handle *ip_handle; | ||
57 | |||
58 | u32 ip_flags; /* see below */ | 51 | u32 ip_flags; /* see below */ |
59 | u32 ip_attr; /* inode attributes */ | 52 | u32 ip_attr; /* inode attributes */ |
60 | 53 | ||
diff --git a/fs/ocfs2/journal.c b/fs/ocfs2/journal.c index ca6f2094b006..f02af63e5fae 100644 --- a/fs/ocfs2/journal.c +++ b/fs/ocfs2/journal.c | |||
@@ -128,7 +128,6 @@ struct ocfs2_journal_handle *ocfs2_alloc_handle(struct ocfs2_super *osb) | |||
128 | retval->k_handle = NULL; | 128 | retval->k_handle = NULL; |
129 | 129 | ||
130 | INIT_LIST_HEAD(&retval->locks); | 130 | INIT_LIST_HEAD(&retval->locks); |
131 | INIT_LIST_HEAD(&retval->inode_list); | ||
132 | retval->journal = osb->journal; | 131 | retval->journal = osb->journal; |
133 | 132 | ||
134 | return retval; | 133 | return retval; |
@@ -202,51 +201,12 @@ done_free: | |||
202 | return ERR_PTR(ret); | 201 | return ERR_PTR(ret); |
203 | } | 202 | } |
204 | 203 | ||
205 | void ocfs2_handle_add_inode(struct ocfs2_journal_handle *handle, | ||
206 | struct inode *inode) | ||
207 | { | ||
208 | BUG_ON(!handle); | ||
209 | BUG_ON(!inode); | ||
210 | |||
211 | atomic_inc(&inode->i_count); | ||
212 | |||
213 | /* we're obviously changing it... */ | ||
214 | mutex_lock(&inode->i_mutex); | ||
215 | |||
216 | /* sanity check */ | ||
217 | BUG_ON(OCFS2_I(inode)->ip_handle); | ||
218 | BUG_ON(!list_empty(&OCFS2_I(inode)->ip_handle_list)); | ||
219 | |||
220 | OCFS2_I(inode)->ip_handle = handle; | ||
221 | list_move_tail(&(OCFS2_I(inode)->ip_handle_list), &(handle->inode_list)); | ||
222 | } | ||
223 | |||
224 | static void ocfs2_handle_unlock_inodes(struct ocfs2_journal_handle *handle) | ||
225 | { | ||
226 | struct list_head *p, *n; | ||
227 | struct inode *inode; | ||
228 | struct ocfs2_inode_info *oi; | ||
229 | |||
230 | list_for_each_safe(p, n, &handle->inode_list) { | ||
231 | oi = list_entry(p, struct ocfs2_inode_info, | ||
232 | ip_handle_list); | ||
233 | inode = &oi->vfs_inode; | ||
234 | |||
235 | OCFS2_I(inode)->ip_handle = NULL; | ||
236 | list_del_init(&OCFS2_I(inode)->ip_handle_list); | ||
237 | |||
238 | mutex_unlock(&inode->i_mutex); | ||
239 | iput(inode); | ||
240 | } | ||
241 | } | ||
242 | |||
243 | /* This is trivial so we do it out of the main commit | 204 | /* This is trivial so we do it out of the main commit |
244 | * paths. Beware, it can be called from start_trans too! */ | 205 | * paths. Beware, it can be called from start_trans too! */ |
245 | static void ocfs2_commit_unstarted_handle(struct ocfs2_journal_handle *handle) | 206 | static void ocfs2_commit_unstarted_handle(struct ocfs2_journal_handle *handle) |
246 | { | 207 | { |
247 | mlog_entry_void(); | 208 | mlog_entry_void(); |
248 | 209 | ||
249 | ocfs2_handle_unlock_inodes(handle); | ||
250 | /* You are allowed to add journal locks before the transaction | 210 | /* You are allowed to add journal locks before the transaction |
251 | * has started. */ | 211 | * has started. */ |
252 | ocfs2_handle_cleanup_locks(handle->journal, handle); | 212 | ocfs2_handle_cleanup_locks(handle->journal, handle); |
@@ -272,9 +232,6 @@ void ocfs2_commit_trans(struct ocfs2_journal_handle *handle) | |||
272 | return; | 232 | return; |
273 | } | 233 | } |
274 | 234 | ||
275 | /* release inode semaphores we took during this transaction */ | ||
276 | ocfs2_handle_unlock_inodes(handle); | ||
277 | |||
278 | /* ocfs2_extend_trans may have had to call journal_restart | 235 | /* ocfs2_extend_trans may have had to call journal_restart |
279 | * which will always commit the transaction, but may return | 236 | * which will always commit the transaction, but may return |
280 | * error for any number of reasons. If this is the case, we | 237 | * error for any number of reasons. If this is the case, we |
diff --git a/fs/ocfs2/journal.h b/fs/ocfs2/journal.h index 6b5d548ca117..3a16d7d88e1c 100644 --- a/fs/ocfs2/journal.h +++ b/fs/ocfs2/journal.h | |||
@@ -149,8 +149,6 @@ struct ocfs2_journal_handle { | |||
149 | struct list_head locks; /* A bunch of locks to | 149 | struct list_head locks; /* A bunch of locks to |
150 | * release on commit. This | 150 | * release on commit. This |
151 | * should be a list_head */ | 151 | * should be a list_head */ |
152 | |||
153 | struct list_head inode_list; | ||
154 | }; | 152 | }; |
155 | 153 | ||
156 | /* Exported only for the journal struct init code in super.c. Do not call. */ | 154 | /* Exported only for the journal struct init code in super.c. Do not call. */ |
@@ -236,7 +234,6 @@ static inline void ocfs2_checkpoint_inode(struct inode *inode) | |||
236 | * ocfs2_handle_add_lock to indicate that a lock needs | 234 | * ocfs2_handle_add_lock to indicate that a lock needs |
237 | * to be released at the end of that handle. Locks | 235 | * to be released at the end of that handle. Locks |
238 | * will be released in the order that they are added. | 236 | * will be released in the order that they are added. |
239 | * ocfs2_handle_add_inode - Add a locked inode to a transaction. | ||
240 | */ | 237 | */ |
241 | 238 | ||
242 | /* You must always start_trans with a number of buffs > 0, but it's | 239 | /* You must always start_trans with a number of buffs > 0, but it's |
@@ -293,12 +290,6 @@ int ocfs2_journal_dirty_data(handle_t *handle, | |||
293 | struct buffer_head *bh); | 290 | struct buffer_head *bh); |
294 | int ocfs2_handle_add_lock(struct ocfs2_journal_handle *handle, | 291 | int ocfs2_handle_add_lock(struct ocfs2_journal_handle *handle, |
295 | struct inode *inode); | 292 | struct inode *inode); |
296 | /* | ||
297 | * Use this to protect from other processes reading buffer state while | ||
298 | * it's in flight. | ||
299 | */ | ||
300 | void ocfs2_handle_add_inode(struct ocfs2_journal_handle *handle, | ||
301 | struct inode *inode); | ||
302 | 293 | ||
303 | /* | 294 | /* |
304 | * Credit Macros: | 295 | * Credit Macros: |
diff --git a/fs/ocfs2/super.c b/fs/ocfs2/super.c index 76b46ebbb10c..f3027c2fe2b6 100644 --- a/fs/ocfs2/super.c +++ b/fs/ocfs2/super.c | |||
@@ -914,9 +914,7 @@ static void ocfs2_inode_init_once(void *data, | |||
914 | oi->ip_open_count = 0; | 914 | oi->ip_open_count = 0; |
915 | spin_lock_init(&oi->ip_lock); | 915 | spin_lock_init(&oi->ip_lock); |
916 | ocfs2_extent_map_init(&oi->vfs_inode); | 916 | ocfs2_extent_map_init(&oi->vfs_inode); |
917 | INIT_LIST_HEAD(&oi->ip_handle_list); | ||
918 | INIT_LIST_HEAD(&oi->ip_io_markers); | 917 | INIT_LIST_HEAD(&oi->ip_io_markers); |
919 | oi->ip_handle = NULL; | ||
920 | oi->ip_created_trans = 0; | 918 | oi->ip_created_trans = 0; |
921 | oi->ip_last_trans = 0; | 919 | oi->ip_last_trans = 0; |
922 | oi->ip_dir_start_lookup = 0; | 920 | oi->ip_dir_start_lookup = 0; |