X-Git-Url: https://err.no/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=fs%2Fjfs%2Finode.c;h=9f942ca8e4e3369440f408fd6b5650d1095ff5a8;hb=e2f99018eb7b29954747a2dd78e9fc0c36a60f0f;hp=cff352f4ec18d357d856d7a8758611ad2a7774ab;hpb=3874b98c655b9490bea1cf9c7697d5dc5338376f;p=linux-2.6 diff --git a/fs/jfs/inode.c b/fs/jfs/inode.c index cff352f4ec..9f942ca8e4 100644 --- a/fs/jfs/inode.c +++ b/fs/jfs/inode.c @@ -128,23 +128,22 @@ void jfs_delete_inode(struct inode *inode) { jfs_info("In jfs_delete_inode, inode = 0x%p", inode); - if (is_bad_inode(inode) || - (JFS_IP(inode)->fileset != cpu_to_le32(FILESYSTEM_I))) - return; + if (!is_bad_inode(inode) && + (JFS_IP(inode)->fileset == FILESYSTEM_I)) { + truncate_inode_pages(&inode->i_data, 0); - truncate_inode_pages(&inode->i_data, 0); + if (test_cflag(COMMIT_Freewmap, inode)) + jfs_free_zero_link(inode); - if (test_cflag(COMMIT_Freewmap, inode)) - jfs_free_zero_link(inode); + diFree(inode); - diFree(inode); - - /* - * Free the inode from the quota allocation. - */ - DQUOT_INIT(inode); - DQUOT_FREE_INODE(inode); - DQUOT_DROP(inode); + /* + * Free the inode from the quota allocation. + */ + DQUOT_INIT(inode); + DQUOT_FREE_INODE(inode); + DQUOT_DROP(inode); + } clear_inode(inode); }