Fio 3.15
[fio.git] / workqueue.c
index faed2452e91a341be207d73108e075e44dd274b6..b59595124913338bc59dc20fb6a036c895b4f1f1 100644 (file)
@@ -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;