summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRichard Purdie <richard.purdie@linuxfoundation.org>2016-01-10 18:01:01 +0000
committerRichard Purdie <richard.purdie@linuxfoundation.org>2016-01-11 23:26:33 +0000
commit43328feccc95a65e6774011aead5ae9f31a92275 (patch)
tree90a58b8b41e851fa48d2fab7dc17a1ccf6b492e5
parent7b905caf60b1d47e6ff1548ce134a5b678418534 (diff)
downloadpoky-43328feccc95a65e6774011aead5ae9f31a92275.tar.gz
bitbake: runqueue: Fix setscene task dependencies
Debugging suggests that setscene tasks are being a little greedy about their dependencies, for example, lsof is insisting that gcc-runtime's do_package is installed. If it isn't, its requiring gcc to rebuild. If gcc-runtime do_package_write_xxx and do_packagedata is available, there is no reason do_package should be needed. The reason this is happening appears to be from the batching up of task dependencies code, rather than setscene tasks stopping when passing over a setscene task, they were being carried forward. This patch fixes it so the data is 'zeroed' when passing over a setscene task boundary, which gives the dependency graph that is expected. After this patch, lsof will rebuild quite happily without gcc-runtime:do_package being present, as expected. This should lead to less dependencies being installed for builds from sstate and generally better performance in general. (Bitbake rev: f8bcb0a1e3b008b71c9a7cd21f76d0906f2d8068) Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r--bitbake/lib/bb/runqueue.py1
1 files changed, 1 insertions, 0 deletions
diff --git a/bitbake/lib/bb/runqueue.py b/bitbake/lib/bb/runqueue.py
index 57b1cca525..44f270be52 100644
--- a/bitbake/lib/bb/runqueue.py
+++ b/bitbake/lib/bb/runqueue.py
@@ -1721,6 +1721,7 @@ class RunQueueExecuteScenequeue(RunQueueExecute):
1721 sq_revdeps_new[point] = set() 1721 sq_revdeps_new[point] = set()
1722 if point in self.rqdata.runq_setscene: 1722 if point in self.rqdata.runq_setscene:
1723 sq_revdeps_new[point] = tasks 1723 sq_revdeps_new[point] = tasks
1724 tasks = set()
1724 for dep in self.rqdata.runq_depends[point]: 1725 for dep in self.rqdata.runq_depends[point]:
1725 if point in sq_revdeps[dep]: 1726 if point in sq_revdeps[dep]:
1726 sq_revdeps[dep].remove(point) 1727 sq_revdeps[dep].remove(point)