From: Michal Sekletar Date: Thu, 25 Nov 2021 17:28:25 +0000 (+0100) Subject: unit: add jobs that were skipped because of ratelimit back to run_queue X-Git-Tag: v250-rc1~121 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=c29e6a9530316823b0455cd83eb6d0bb8dd664f4;p=thirdparty%2Fsystemd.git unit: add jobs that were skipped because of ratelimit back to run_queue Assumption in edc027b was that job we first skipped because of active ratelimit is still in run_queue. Hence we trigger the queue and dispatch it in the next iteration. Actually we remove jobs from run_queue in job_run_and_invalidate() before we call unit_start(). Hence if we want to attempt to run the job again in the future we need to add it back to run_queue. Fixes #21458 --- diff --git a/src/core/mount.c b/src/core/mount.c index 90b11347f71..35368fe8e68 100644 --- a/src/core/mount.c +++ b/src/core/mount.c @@ -1840,9 +1840,18 @@ static bool mount_is_mounted(Mount *m) { static int mount_on_ratelimit_expire(sd_event_source *s, void *userdata) { Manager *m = userdata; + Job *j; assert(m); + /* Let's enqueue all start jobs that were previously skipped because of active ratelimit. */ + HASHMAP_FOREACH(j, m->jobs) { + if (j->unit->type != UNIT_MOUNT) + continue; + + job_add_to_run_queue(j); + } + /* By entering ratelimited state we made all mount start jobs not runnable, now rate limit is over so * let's make sure we dispatch them in the next iteration. */ manager_trigger_run_queue(m);