diff options
author | Jiro SEKIBA <jir@unicus.jp> | 2009-11-27 05:41:10 -0500 |
---|---|---|
committer | Ryusuke Konishi <konishi.ryusuke@lab.ntt.co.jp> | 2009-11-27 06:05:15 -0500 |
commit | 4cd76c3c930993cf70657775bb521cad006e37b4 (patch) | |
tree | f29b80420e2214d08785580f11e400728750d10a | |
parent | 17491472769abbf4dac694d96c65eed5a7e1c81c (diff) |
nilfs2: split nilfs_unlink as nilfs_do_unlink and nilfs_unlink
Split nilfs_unlink() to reduce nested transaction and duplicate
mark_inode_dirty() calls when calling nilfs_unlink() from nilfs_rmdir().
nilfs_do_unlink() is an actual unlink functionality which is not
in transaction and does not call mark_inode_dirty() for dentry argument.
nilfs_unlink() is a wrapper function for do_nilfs_unlink() with
transaction and mark_inode_dirty() for dentry argument.
Signed-off-by: Jiro SEKIBA <jir@unicus.jp>
Signed-off-by: Ryusuke Konishi <konishi.ryusuke@lab.ntt.co.jp>
-rw-r--r-- | fs/nilfs2/namei.c | 29 |
1 files changed, 19 insertions, 10 deletions
diff --git a/fs/nilfs2/namei.c b/fs/nilfs2/namei.c index 35f59da16bbf..d92e83905f01 100644 --- a/fs/nilfs2/namei.c +++ b/fs/nilfs2/namei.c | |||
@@ -288,18 +288,13 @@ out_dir: | |||
288 | goto out; | 288 | goto out; |
289 | } | 289 | } |
290 | 290 | ||
291 | static int nilfs_unlink(struct inode *dir, struct dentry *dentry) | 291 | static int nilfs_do_unlink(struct inode *dir, struct dentry *dentry) |
292 | { | 292 | { |
293 | struct inode *inode; | 293 | struct inode *inode; |
294 | struct nilfs_dir_entry *de; | 294 | struct nilfs_dir_entry *de; |
295 | struct page *page; | 295 | struct page *page; |
296 | struct nilfs_transaction_info ti; | ||
297 | int err; | 296 | int err; |
298 | 297 | ||
299 | err = nilfs_transaction_begin(dir->i_sb, &ti, 0); | ||
300 | if (err) | ||
301 | return err; | ||
302 | |||
303 | err = -ENOENT; | 298 | err = -ENOENT; |
304 | de = nilfs_find_entry(dir, dentry, &page); | 299 | de = nilfs_find_entry(dir, dentry, &page); |
305 | if (!de) | 300 | if (!de) |
@@ -322,12 +317,26 @@ static int nilfs_unlink(struct inode *dir, struct dentry *dentry) | |||
322 | 317 | ||
323 | inode->i_ctime = dir->i_ctime; | 318 | inode->i_ctime = dir->i_ctime; |
324 | drop_nlink(inode); | 319 | drop_nlink(inode); |
325 | mark_inode_dirty(inode); | ||
326 | err = 0; | 320 | err = 0; |
327 | out: | 321 | out: |
328 | if (!err) | 322 | return err; |
323 | } | ||
324 | |||
325 | static int nilfs_unlink(struct inode *dir, struct dentry *dentry) | ||
326 | { | ||
327 | struct nilfs_transaction_info ti; | ||
328 | int err; | ||
329 | |||
330 | err = nilfs_transaction_begin(dir->i_sb, &ti, 0); | ||
331 | if (err) | ||
332 | return err; | ||
333 | |||
334 | err = nilfs_do_unlink(dir, dentry); | ||
335 | |||
336 | if (!err) { | ||
337 | mark_inode_dirty(dentry->d_inode); | ||
329 | err = nilfs_transaction_commit(dir->i_sb); | 338 | err = nilfs_transaction_commit(dir->i_sb); |
330 | else | 339 | } else |
331 | nilfs_transaction_abort(dir->i_sb); | 340 | nilfs_transaction_abort(dir->i_sb); |
332 | 341 | ||
333 | return err; | 342 | return err; |
@@ -345,7 +354,7 @@ static int nilfs_rmdir(struct inode *dir, struct dentry *dentry) | |||
345 | 354 | ||
346 | err = -ENOTEMPTY; | 355 | err = -ENOTEMPTY; |
347 | if (nilfs_empty_dir(inode)) { | 356 | if (nilfs_empty_dir(inode)) { |
348 | err = nilfs_unlink(dir, dentry); | 357 | err = nilfs_do_unlink(dir, dentry); |
349 | if (!err) { | 358 | if (!err) { |
350 | inode->i_size = 0; | 359 | inode->i_size = 0; |
351 | drop_nlink(inode); | 360 | drop_nlink(inode); |