Commit 1e0f358e authored by Artem Bityutskiy's avatar Artem Bityutskiy

UBIFS: free budget in delete_inode as well

Although the inode is marked as clean when it is being deleted,
it might stay and be used as orphan, and be marked as dirty.
So we have to free the budget when we delete it.
Signed-off-by: default avatarArtem Bityutskiy <Artem.Bityutskiy@nokia.com>
parent 7d32c2bb
...@@ -314,8 +314,9 @@ static void ubifs_delete_inode(struct inode *inode) ...@@ -314,8 +314,9 @@ static void ubifs_delete_inode(struct inode *inode)
{ {
int err; int err;
struct ubifs_info *c = inode->i_sb->s_fs_info; struct ubifs_info *c = inode->i_sb->s_fs_info;
struct ubifs_inode *ui = ubifs_inode(inode);
if (ubifs_inode(inode)->xattr) if (ui->xattr)
/* /*
* Extended attribute inode deletions are fully handled in * Extended attribute inode deletions are fully handled in
* 'ubifs_removexattr()'. These inodes are special and have * 'ubifs_removexattr()'. These inodes are special and have
...@@ -326,13 +327,12 @@ static void ubifs_delete_inode(struct inode *inode) ...@@ -326,13 +327,12 @@ static void ubifs_delete_inode(struct inode *inode)
dbg_gen("inode %lu, mode %#x", inode->i_ino, (int)inode->i_mode); dbg_gen("inode %lu, mode %#x", inode->i_ino, (int)inode->i_mode);
ubifs_assert(!atomic_read(&inode->i_count)); ubifs_assert(!atomic_read(&inode->i_count));
ubifs_assert(inode->i_nlink == 0); ubifs_assert(inode->i_nlink == 0);
ubifs_assert(!ubifs_inode(inode)->dirty);
truncate_inode_pages(&inode->i_data, 0); truncate_inode_pages(&inode->i_data, 0);
if (is_bad_inode(inode)) if (is_bad_inode(inode))
goto out; goto out;
ubifs_inode(inode)->ui_size = inode->i_size = 0; ui->ui_size = inode->i_size = 0;
err = ubifs_jnl_write_inode(c, inode, 1); err = ubifs_jnl_write_inode(c, inode, 1);
if (err) if (err)
/* /*
...@@ -341,6 +341,8 @@ static void ubifs_delete_inode(struct inode *inode) ...@@ -341,6 +341,8 @@ static void ubifs_delete_inode(struct inode *inode)
*/ */
ubifs_err("can't write inode %lu, error %d", inode->i_ino, err); ubifs_err("can't write inode %lu, error %d", inode->i_ino, err);
out: out:
if (ui->dirty)
ubifs_release_dirty_inode_budget(c, ui);
clear_inode(inode); clear_inode(inode);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment