runqueue_task_cancel(t, t->cancel_type);
}
-void runqueue_task_add(struct runqueue *q, struct runqueue_task *t, bool running)
+static void _runqueue_task_add(struct runqueue *q, struct runqueue_task *t, bool running, bool first)
{
struct safe_list *head;
t->timeout.cb = __runqueue_task_timeout;
t->q = q;
- safe_list_add(&t->list, head);
+ if (first)
+ safe_list_add_first(&t->list, head);
+ else
+ safe_list_add(&t->list, head);
t->cancelled = false;
t->queued = true;
t->running = running;
runqueue_start_next(q);
}
+void runqueue_task_add(struct runqueue *q, struct runqueue_task *t, bool running)
+{
+ _runqueue_task_add(q, t, running, 0);
+}
+
+void runqueue_task_add_first(struct runqueue *q, struct runqueue_task *t, bool running)
+{
+ _runqueue_task_add(q, t, running, 1);
+}
+
void runqueue_task_kill(struct runqueue_task *t)
{
struct runqueue *q = t->q;
void runqueue_task_complete(struct runqueue_task *t)
{
+ struct runqueue *q = t->q;
+
if (!t->queued)
return;
if (t->running)
t->q->running_tasks--;
+ uloop_timeout_cancel(&t->timeout);
+
safe_list_del(&t->list);
t->queued = false;
t->running = false;
t->cancelled = false;
+ if (t->complete)
+ t->complete(q, t);
runqueue_start_next(t->q);
}
__runqueue_proc_cb(struct uloop_process *p, int ret)
{
struct runqueue_process *t = container_of(p, struct runqueue_process, proc);
- struct runqueue *q = t->task.q;
runqueue_task_complete(&t->task);
- if (t->complete)
- t->complete(q, t, ret);
}
void runqueue_process_cancel_cb(struct runqueue *q, struct runqueue_task *t, int type)
uloop_process_delete(&p->proc);
kill(p->proc.pid, SIGKILL);
- __runqueue_proc_cb(&p->proc, -1);
}
static const struct runqueue_task_type runqueue_proc_type = {