diff options
author | sinanmohd <sinan@sinanmohd.com> | 2024-07-02 22:49:38 +0530 |
---|---|---|
committer | sinanmohd <sinan@sinanmohd.com> | 2024-07-02 22:58:54 +0530 |
commit | 4a00927f139c545288c1ae2d197d4fdc8fa36051 (patch) | |
tree | 4162d3e437955ec799a25ec1595d2086935fa792 /src | |
parent | efeaf15d037e58a0a6c41db226d79bec684efa99 (diff) |
queue/queue_ancestors_rm: init
Diffstat (limited to 'src')
-rw-r--r-- | src/jobs.c | 1 | ||||
-rw-r--r-- | src/queue.c | 25 |
2 files changed, 26 insertions, 0 deletions
@@ -370,6 +370,7 @@ static int job_new(struct job **j, char *name, char *drv_path, char *attr, job->scheduled = false; job->stale = false; job->id = -1; + job->age = 0; job->outputs_size = 0; job->outputs_filled = 0; diff --git a/src/queue.c b/src/queue.c index 655822e..148ca9a 100644 --- a/src/queue.c +++ b/src/queue.c @@ -51,6 +51,30 @@ static int queue_dag_isolate(struct job *job, struct job *keep_parent, return 0; } +/* remove a node along with all it's ancestors recursively */ +int queue_ancestors_rm(struct job *job, struct job_clist *jobs, + struct htab *htab) +{ + struct job *j; + int ret; + + job_stale_set(job); + CIRCLEQ_FOREACH(j, jobs, clist) { + if (j->stale == false) + continue; + + ret = queue_dag_isolate(j, NULL, jobs, htab); + if (ret < 0) + return ret; + + job_free(j); + /* we might have removed j->clist.cqe_next */ + j = jobs->cqh_last; + } + + return 0; +} + void *queue_thread_entry(void *queue_thread) { struct queue_thread *qt = queue_thread; @@ -221,6 +245,7 @@ int queue_thread_new(struct queue_thread **queue_thread, FILE *stream) ret = -errno; goto out_free_qt; } + qt->queue->age = 0; qt->queue->jobid = NULL; qt->queue->state = Q_SEM_WAIT; ret = sem_init(&qt->queue->sem, 0, 0); |