diff options
Diffstat (limited to 'fs/ubifs/super.c')
| -rw-r--r-- | fs/ubifs/super.c | 16 |
1 files changed, 11 insertions, 5 deletions
diff --git a/fs/ubifs/super.c b/fs/ubifs/super.c index 4d2f2157dd3f..cd5900b85d38 100644 --- a/fs/ubifs/super.c +++ b/fs/ubifs/super.c | |||
| @@ -327,7 +327,7 @@ static int ubifs_write_inode(struct inode *inode, struct writeback_control *wbc) | |||
| 327 | return err; | 327 | return err; |
| 328 | } | 328 | } |
| 329 | 329 | ||
| 330 | static void ubifs_delete_inode(struct inode *inode) | 330 | static void ubifs_evict_inode(struct inode *inode) |
| 331 | { | 331 | { |
| 332 | int err; | 332 | int err; |
| 333 | struct ubifs_info *c = inode->i_sb->s_fs_info; | 333 | struct ubifs_info *c = inode->i_sb->s_fs_info; |
| @@ -343,9 +343,12 @@ static void ubifs_delete_inode(struct inode *inode) | |||
| 343 | 343 | ||
| 344 | dbg_gen("inode %lu, mode %#x", inode->i_ino, (int)inode->i_mode); | 344 | dbg_gen("inode %lu, mode %#x", inode->i_ino, (int)inode->i_mode); |
| 345 | ubifs_assert(!atomic_read(&inode->i_count)); | 345 | ubifs_assert(!atomic_read(&inode->i_count)); |
| 346 | ubifs_assert(inode->i_nlink == 0); | ||
| 347 | 346 | ||
| 348 | truncate_inode_pages(&inode->i_data, 0); | 347 | truncate_inode_pages(&inode->i_data, 0); |
| 348 | |||
| 349 | if (inode->i_nlink) | ||
| 350 | goto done; | ||
| 351 | |||
| 349 | if (is_bad_inode(inode)) | 352 | if (is_bad_inode(inode)) |
| 350 | goto out; | 353 | goto out; |
| 351 | 354 | ||
| @@ -367,7 +370,8 @@ out: | |||
| 367 | c->nospace = c->nospace_rp = 0; | 370 | c->nospace = c->nospace_rp = 0; |
| 368 | smp_wmb(); | 371 | smp_wmb(); |
| 369 | } | 372 | } |
| 370 | clear_inode(inode); | 373 | done: |
| 374 | end_writeback(inode); | ||
| 371 | } | 375 | } |
| 372 | 376 | ||
| 373 | static void ubifs_dirty_inode(struct inode *inode) | 377 | static void ubifs_dirty_inode(struct inode *inode) |
| @@ -1307,6 +1311,8 @@ static int mount_ubifs(struct ubifs_info *c) | |||
| 1307 | if (err) | 1311 | if (err) |
| 1308 | goto out_orphans; | 1312 | goto out_orphans; |
| 1309 | err = ubifs_rcvry_gc_commit(c); | 1313 | err = ubifs_rcvry_gc_commit(c); |
| 1314 | if (err) | ||
| 1315 | goto out_orphans; | ||
| 1310 | } else { | 1316 | } else { |
| 1311 | err = take_gc_lnum(c); | 1317 | err = take_gc_lnum(c); |
| 1312 | if (err) | 1318 | if (err) |
| @@ -1318,7 +1324,7 @@ static int mount_ubifs(struct ubifs_info *c) | |||
| 1318 | */ | 1324 | */ |
| 1319 | err = ubifs_leb_unmap(c, c->gc_lnum); | 1325 | err = ubifs_leb_unmap(c, c->gc_lnum); |
| 1320 | if (err) | 1326 | if (err) |
| 1321 | return err; | 1327 | goto out_orphans; |
| 1322 | } | 1328 | } |
| 1323 | 1329 | ||
| 1324 | err = dbg_check_lprops(c); | 1330 | err = dbg_check_lprops(c); |
| @@ -1824,7 +1830,7 @@ const struct super_operations ubifs_super_operations = { | |||
| 1824 | .destroy_inode = ubifs_destroy_inode, | 1830 | .destroy_inode = ubifs_destroy_inode, |
| 1825 | .put_super = ubifs_put_super, | 1831 | .put_super = ubifs_put_super, |
| 1826 | .write_inode = ubifs_write_inode, | 1832 | .write_inode = ubifs_write_inode, |
| 1827 | .delete_inode = ubifs_delete_inode, | 1833 | .evict_inode = ubifs_evict_inode, |
| 1828 | .statfs = ubifs_statfs, | 1834 | .statfs = ubifs_statfs, |
| 1829 | .dirty_inode = ubifs_dirty_inode, | 1835 | .dirty_inode = ubifs_dirty_inode, |
| 1830 | .remount_fs = ubifs_remount_fs, | 1836 | .remount_fs = ubifs_remount_fs, |
