r->len = 0;
r->status = -1;
r->returned_errno = -1;
+ r->submitted = 0;
return r;
}
struct asio_request *r = (struct asio_request *) work_wait(&q->queue);
if (!r)
return 0;
+ r->submitted = 0;
q->running_requests--;
if (r->op == ASIO_WRITE_BACK)
{
struct asio_queue *q = r->queue;
DBG("ASIO: Submitting %p on queue %p", r, q);
ASSERT(r->op != ASIO_FREE);
+ ASSERT(!r->submitted);
if (r->op == ASIO_WRITE_BACK)
{
while (q->running_writebacks >= q->max_writebacks)
q->running_writebacks++;
}
q->running_requests++;
+ r->submitted = 1;
r->work.go = asio_handler;
r->work.returned = NULL;
work_submit(&q->queue, &r->work);
{
struct asio_queue *q = r->queue;
DBG("ASIO: Put %p", r);
+ ASSERT(!r->submitted);
ASSERT(q->allocated_requests);
clist_add_tail(&q->idle_list, &r->work.n);
q->allocated_requests--;