mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-09 23:00:21 +00:00
bcachefs: Fix refcount leak in bch2_do_invalidates()
If we fail to queue the work item because it's already in process, we need to drop the ref we just took. Signed-off-by: Kent Overstreet <kent.overstreet@gmail.com>
This commit is contained in:
parent
a3d7afa5c1
commit
1c6ff39445
@ -1192,8 +1192,9 @@ static void bch2_do_invalidates_work(struct work_struct *work)
|
||||
|
||||
void bch2_do_invalidates(struct bch_fs *c)
|
||||
{
|
||||
if (percpu_ref_tryget_live(&c->writes))
|
||||
queue_work(system_long_wq, &c->invalidate_work);
|
||||
if (percpu_ref_tryget_live(&c->writes) &&
|
||||
!queue_work(system_long_wq, &c->invalidate_work))
|
||||
percpu_ref_put(&c->writes);
|
||||
}
|
||||
|
||||
static int bucket_freespace_init(struct btree_trans *trans, struct btree_iter *iter)
|
||||
|
Loading…
x
Reference in New Issue
Block a user