X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?p=src%2Fapp-framework-binder.git;a=blobdiff_plain;f=src%2Fjobs.c;h=3b617b567e63058a6c45a4c6b417e3d1605957ef;hp=a9773aa54b9bac32bd89bf6c3910155a0dc4557c;hb=7129df470867291f917e6718dad2a964e113aad6;hpb=45a4e69d4ef15c70d2b74ea4d0d2e4cd22e3adea diff --git a/src/jobs.c b/src/jobs.c index a9773aa5..3b617b56 100644 --- a/src/jobs.c +++ b/src/jobs.c @@ -510,7 +510,7 @@ static int queue_job( enum start_mode start_mode) { struct job *job; - int rc; + int rc, busy; pthread_mutex_lock(&mutex); @@ -527,8 +527,9 @@ static int queue_job( goto error; /* start a thread if needed */ + busy = busy_thread_count == started_thread_count; if (start_mode != Start_Lazy - && busy_thread_count == started_thread_count + && busy && (start_mode == Start_Urgent || remaining_job_count + started_thread_count < allowed_job_count) && started_thread_count < allowed_thread_count) { /* all threads are busy and a new can be started */ @@ -537,11 +538,16 @@ static int queue_job( ERROR("can't start initial thread: %m"); goto error2; } + busy = 0; } /* queues the job */ job_add(job); + /* wakeup an evloop if needed */ + if (busy) + evloop_wakeup(); + /* signal an existing job */ pthread_cond_signal(&cond); pthread_mutex_unlock(&mutex);