From 1813ca00e22db63d5f2291eaf5b93481592d449d Mon Sep 17 00:00:00 2001 From: Mark Fasheh Date: Fri, 9 Sep 2005 13:01:29 -0700 Subject: [PATCH] --- yaml --- r: 8062 b: refs/heads/master c: e85b565233236a2a833adea73fb2f0e0f8fa2a61 h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/fs/inode.c | 12 +++++++----- 2 files changed, 8 insertions(+), 6 deletions(-) diff --git a/[refs] b/[refs] index 80f5db91a6cf..a0fdcdaaa25d 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 7f6fd5db2dbc28d475d67f9a6b041fefe1d6f7c8 +refs/heads/master: e85b565233236a2a833adea73fb2f0e0f8fa2a61 diff --git a/trunk/fs/inode.c b/trunk/fs/inode.c index 71df1b1e8f75..f80a79ff156b 100644 --- a/trunk/fs/inode.c +++ b/trunk/fs/inode.c @@ -1034,19 +1034,21 @@ void generic_delete_inode(struct inode *inode) inodes_stat.nr_inodes--; spin_unlock(&inode_lock); - if (inode->i_data.nrpages) - truncate_inode_pages(&inode->i_data, 0); - security_inode_delete(inode); if (op->delete_inode) { void (*delete)(struct inode *) = op->delete_inode; if (!is_bad_inode(inode)) DQUOT_INIT(inode); - /* s_op->delete_inode internally recalls clear_inode() */ + /* Filesystems implementing their own + * s_op->delete_inode are required to call + * truncate_inode_pages and clear_inode() + * internally */ delete(inode); - } else + } else { + truncate_inode_pages(&inode->i_data, 0); clear_inode(inode); + } spin_lock(&inode_lock); hlist_del_init(&inode->i_hash); spin_unlock(&inode_lock);