summaryrefslogtreecommitdiffstats
path: root/lib/bb/runqueue.py
diff options
context:
space:
mode:
authorChristopher Larson <chris_larson@mentor.com>2012-05-09 18:32:20 -0500
committerRichard Purdie <richard.purdie@linuxfoundation.org>2012-05-11 10:03:22 +0100
commit84ea614bc56d35a414eb5bf5658891b340bfc569 (patch)
tree088501c67b2f6ccbcca2ed5da6d14b64f5667240 /lib/bb/runqueue.py
parentd8a1fc4613ce1d6c1d0e3dad53d7af15b2011fd5 (diff)
downloadbitbake-84ea614bc56d35a414eb5bf5658891b340bfc569.tar.gz
runqueue: handle task exit due to signal/stop
- for a normal exit, use WEXITSTATUS, rather than manually shifting - for exit via signal, set the exit code to 128+N, per shell convention - if a process was stopped, return and don't handle it, as the process can yet be continued This should fix the case where bitbake says a task failed with an exit code of 0 (we assumed failure based on the overall status, but didn't pass all the information along to task_fail). Signed-off-by: Christopher Larson <chris_larson@mentor.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'lib/bb/runqueue.py')
-rw-r--r--lib/bb/runqueue.py33
1 files changed, 22 insertions, 11 deletions
diff --git a/lib/bb/runqueue.py b/lib/bb/runqueue.py
index b870caff4..8828e4af6 100644
--- a/lib/bb/runqueue.py
+++ b/lib/bb/runqueue.py
@@ -1046,18 +1046,29 @@ class RunQueueExecute:
Return none is there are no processes awaiting result collection, otherwise
collect the process exit codes and close the information pipe.
"""
- result = os.waitpid(-1, os.WNOHANG)
- if result[0] == 0 and result[1] == 0:
+ pid, status = os.waitpid(-1, os.WNOHANG)
+ if pid == 0 or os.WIFSTOPPED(status):
return None
- task = self.build_pids[result[0]]
- del self.build_pids[result[0]]
- self.build_pipes[result[0]].close()
- del self.build_pipes[result[0]]
- # self.build_stamps[result[0]] may not exist when use shared work directory.
- if result[0] in self.build_stamps.keys():
- del self.build_stamps[result[0]]
- if result[1] != 0:
- self.task_fail(task, result[1]>>8)
+
+ if os.WIFEXITED(status):
+ status = os.WEXITSTATUS(status)
+ elif os.WIFSIGNALED(status):
+ # Per shell conventions for $?, when a process exits due to
+ # a signal, we return an exit code of 128 + SIGNUM
+ status = 128 + os.WTERMSIG(status)
+
+ task = self.build_pids[pid]
+ del self.build_pids[pid]
+
+ self.build_pipes[pid].close()
+ del self.build_pipes[pid]
+
+ # self.build_stamps[pid] may not exist when use shared work directory.
+ if pid in self.build_stamps.keys():
+ del self.build_stamps[pid]
+
+ if status != 0:
+ self.task_fail(task, status)
else:
self.task_complete(task)
return True