diff options
author | Richard Purdie <richard.purdie@linuxfoundation.org> | 2021-09-10 14:47:37 +0100 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2021-09-11 22:39:15 +0100 |
commit | 339d4d6be515a71311b81fb9e99742af0d8a5130 (patch) | |
tree | fd8d08025aaa36aa9f0c659c5453e33011d54ba6 /lib | |
parent | 699634bec47964fa7ab18689dc23db6f0bc22fb3 (diff) | |
download | bitbake-339d4d6be515a71311b81fb9e99742af0d8a5130.tar.gz |
build: Catch and error upon circular task references
If there are circular task references, error on them rather than show
a recursion error. A simple reproducer is:
"""
do_packageswu () {
:
}
addtask do_packageswu after do_image_complete before do_image_qa
"""
into image_types.bbclass. There is code in runqueue to detect these but
we never get that far with the current codebase.
[YOCTO #13140]
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'lib')
-rw-r--r-- | lib/bb/build.py | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/lib/bb/build.py b/lib/bb/build.py index 1e062adb5..c2479dd16 100644 --- a/lib/bb/build.py +++ b/lib/bb/build.py @@ -1034,6 +1034,8 @@ def tasksbetween(task_start, task_end, d): def follow_chain(task, endtask, chain=None): if not chain: chain = [] + if task in chain: + bb.fatal("Circular task dependencies as %s depends on itself via the chain %s" % (task, " -> ".join(chain))) chain.append(task) for othertask in tasks: if othertask == task: |