summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--bitbake/lib/bb/runqueue.py16
1 files changed, 12 insertions, 4 deletions
diff --git a/bitbake/lib/bb/runqueue.py b/bitbake/lib/bb/runqueue.py
index ba75660555..569520707b 100644
--- a/bitbake/lib/bb/runqueue.py
+++ b/bitbake/lib/bb/runqueue.py
@@ -1974,11 +1974,19 @@ class RunQueueExecute:
1974 self.setbuildable(revdep) 1974 self.setbuildable(revdep)
1975 logger.debug("Marking task %s as buildable", revdep) 1975 logger.debug("Marking task %s as buildable", revdep)
1976 1976
1977 for t in self.sq_deferred.copy(): 1977 found = None
1978 for t in sorted(self.sq_deferred.copy()):
1978 if self.sq_deferred[t] == task: 1979 if self.sq_deferred[t] == task:
1979 logger.debug2("Deferred task %s now buildable" % t) 1980 # Allow the next deferred task to run. Any other deferred tasks should be deferred after that task.
1980 del self.sq_deferred[t] 1981 # We shouldn't allow all to run at once as it is prone to races.
1981 update_scenequeue_data([t], self.sqdata, self.rqdata, self.rq, self.cooker, self.stampcache, self, summary=False) 1982 if not found:
1983 bb.note("Deferred task %s now buildable" % t)
1984 del self.sq_deferred[t]
1985 update_scenequeue_data([t], self.sqdata, self.rqdata, self.rq, self.cooker, self.stampcache, self, summary=False)
1986 found = t
1987 else:
1988 bb.note("Deferring %s after %s" % (t, found))
1989 self.sq_deferred[t] = found
1982 1990
1983 def task_complete(self, task): 1991 def task_complete(self, task):
1984 self.stats.taskCompleted() 1992 self.stats.taskCompleted()