X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fcore%2Fjob.c;h=835cfe173b1f093e85cb2eb19f3e9c91e5598291;hb=68a8723c8592c06b2c978f391cb47db266d9d6de;hp=8e98bd93ab1163c02fe8266167a6e8d606b0966c;hpb=2c5859afecee81e345fc9526b1083bf79990ffb8;p=elogind.git diff --git a/src/core/job.c b/src/core/job.c index 8e98bd93a..835cfe173 100644 --- a/src/core/job.c +++ b/src/core/job.c @@ -873,7 +873,12 @@ int job_start_timer(Job *j) { if (j->unit->job_timeout <= 0) return 0; - r = sd_event_add_monotonic(j->manager->event, &j->timer_event_source, j->begin_usec + j->unit->job_timeout, 0, job_dispatch_timer, j); + r = sd_event_add_time( + j->manager->event, + &j->timer_event_source, + CLOCK_MONOTONIC, + j->begin_usec + j->unit->job_timeout, 0, + job_dispatch_timer, j); if (r < 0) return r; @@ -1061,7 +1066,15 @@ int job_coldplug(Job *j) { if (j->timer_event_source) j->timer_event_source = sd_event_source_unref(j->timer_event_source); - r = sd_event_add_monotonic(j->manager->event, &j->timer_event_source, j->begin_usec + j->unit->job_timeout, 0, job_dispatch_timer, j); + if (j->state == JOB_WAITING) + job_add_to_run_queue(j); + + r = sd_event_add_time( + j->manager->event, + &j->timer_event_source, + CLOCK_MONOTONIC, + j->begin_usec + j->unit->job_timeout, 0, + job_dispatch_timer, j); if (r < 0) log_debug("Failed to restart timeout for job: %s", strerror(-r));