diff options
author | Ira Weiny <ira.weiny@intel.com> | 2020-11-12 09:42:44 -0800 |
---|---|---|
committer | Jan Kara <jack@suse.cz> | 2020-11-13 11:19:30 +0100 |
commit | a6fbd0ab3d7a1a02e61733a80c22fb01c65819b9 (patch) | |
tree | bf52e9b7de2af835d4066e88569b13a006799dee /fs/ext2/namei.c | |
parent | 2356eb80ca42deba0bf2523c62530d4c79dad08f (diff) | |
download | lwn-a6fbd0ab3d7a1a02e61733a80c22fb01c65819b9.tar.gz lwn-a6fbd0ab3d7a1a02e61733a80c22fb01c65819b9.zip |
fs/ext2: Use ext2_put_page
There are 3 places in namei.c where the equivalent of ext2_put_page() is
open coded on a page which was returned from the ext2_get_page() call
[through the use of ext2_find_entry() and ext2_dotdot()].
Move ext2_put_page() to ext2.h and use it in namei.c
Also add a comment regarding the proper way to release the page returned
from ext2_find_entry() and ext2_dotdot().
Link: https://lore.kernel.org/r/20201112174244.701325-1-ira.weiny@intel.com
Signed-off-by: Ira Weiny <ira.weiny@intel.com>
Signed-off-by: Jan Kara <jack@suse.cz>
Diffstat (limited to 'fs/ext2/namei.c')
-rw-r--r-- | fs/ext2/namei.c | 15 |
1 files changed, 5 insertions, 10 deletions
diff --git a/fs/ext2/namei.c b/fs/ext2/namei.c index 5bf2c145643b..ea980f1e2e99 100644 --- a/fs/ext2/namei.c +++ b/fs/ext2/namei.c @@ -389,23 +389,18 @@ static int ext2_rename (struct inode * old_dir, struct dentry * old_dentry, if (dir_de) { if (old_dir != new_dir) ext2_set_link(old_inode, dir_de, dir_page, new_dir, 0); - else { - kunmap(dir_page); - put_page(dir_page); - } + else + ext2_put_page(dir_page); inode_dec_link_count(old_dir); } return 0; out_dir: - if (dir_de) { - kunmap(dir_page); - put_page(dir_page); - } + if (dir_de) + ext2_put_page(dir_page); out_old: - kunmap(old_page); - put_page(old_page); + ext2_put_page(old_page); out: return err; } |