summaryrefslogtreecommitdiffstats
path: root/fs/reiserfs/super.c
diff options
context:
space:
mode:
authorJiri Slaby <jslaby@suse.cz>2014-12-12 16:29:29 +0100
committerJan Kara <jack@suse.cz>2014-12-12 22:18:07 +0100
commitfa0c5540739320258c3e3a45aaae9dae467b2504 (patch)
tree7fe60c0e78539c2f8c8e93eb45ce10b408f86a71 /fs/reiserfs/super.c
parentudf: One function call less in udf_fill_super() after error detection (diff)
downloadlinux-fa0c5540739320258c3e3a45aaae9dae467b2504.tar.xz
linux-fa0c5540739320258c3e3a45aaae9dae467b2504.zip
reiserfs: destroy allocated commit workqueue
When resirefs is trying to mount a partition, it creates a commit workqueue (sbi->commit_wq). But when mount fails later, the workqueue is not freed. Signed-off-by: Jiri Slaby <jslaby@suse.cz> Reported-by: auxsvr@gmail.com Reported-by: BenoƮt Monin <benoit.monin@gmx.fr> Cc: Jan Kara <jack@suse.cz> Cc: stable@vger.kernel.org # >= 3.16 Cc: reiserfs-devel@vger.kernel.org Fixes: 797d9016ceca69879bb273218810fa0beef46aac Signed-off-by: Jan Kara <jack@suse.cz>
Diffstat (limited to 'fs/reiserfs/super.c')
-rw-r--r--fs/reiserfs/super.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/fs/reiserfs/super.c b/fs/reiserfs/super.c
index ea63ab13ef92..71fbbe3e2dab 100644
--- a/fs/reiserfs/super.c
+++ b/fs/reiserfs/super.c
@@ -2172,6 +2172,9 @@ error_unlocked:
reiserfs_write_unlock(s);
}
+ if (sbi->commit_wq)
+ destroy_workqueue(sbi->commit_wq);
+
cancel_delayed_work_sync(&REISERFS_SB(s)->old_work);
reiserfs_free_bitmap_cache(s);