X-Git-Url: https://git.kernel.dk/?p=fio.git;a=blobdiff_plain;f=workqueue.c;h=b59595124913338bc59dc20fb6a036c895b4f1f1;hp=841dbb9ffffa6de6252990592e7d750e876442b5;hb=63e3e40d47e1f318aa4d770d74a7b14d64867e1d;hpb=ae626d4ead6416adf464cf209cdf3e8b85d58190 diff --git a/workqueue.c b/workqueue.c index 841dbb9f..b5959512 100644 --- a/workqueue.c +++ b/workqueue.c @@ -97,7 +97,7 @@ void workqueue_flush(struct workqueue *wq) } /* - * Must be serialized by caller. Returns true for queued, false for busy. + * Must be serialized by caller. */ void workqueue_enqueue(struct workqueue *wq, struct workqueue_work *work) { @@ -190,8 +190,6 @@ static void *worker_thread(void *data) if (wq->wake_idle) pthread_cond_signal(&wq->flush_cond); } - if (wq->ops.update_acct_fn) - wq->ops.update_acct_fn(sw); pthread_cond_wait(&sw->cond, &sw->lock); } else { @@ -200,11 +198,10 @@ handle_work: } pthread_mutex_unlock(&sw->lock); handle_list(sw, &local_list); + if (wq->ops.update_acct_fn) + wq->ops.update_acct_fn(sw); } - if (wq->ops.update_acct_fn) - wq->ops.update_acct_fn(sw); - done: sk_out_drop(); return NULL;