X-Git-Url: https://git.kernel.dk/?p=fio.git;a=blobdiff_plain;f=workqueue.c;h=b59595124913338bc59dc20fb6a036c895b4f1f1;hp=18ec198bee7e9de9c81db22758ad5c1e28ec62e4;hb=370f38977a241e173b0c60b66252757be809ad3a;hpb=b93a8eb09c7904790f78956cb481bd55b3ac8c82 diff --git a/workqueue.c b/workqueue.c index 18ec198b..b5959512 100644 --- a/workqueue.c +++ b/workqueue.c @@ -10,6 +10,7 @@ #include "flist.h" #include "workqueue.h" #include "smalloc.h" +#include "pshared.h" enum { SW_F_IDLE = 1 << 0, @@ -96,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) { @@ -189,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 { @@ -199,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;