diff options
author | Robert Yang <liezhi.yang@windriver.com> | 2014-11-17 02:27:36 -0800 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2014-11-20 14:15:28 +0000 |
commit | 40d2ae0723de2bf5fee343faafb4afda40546839 (patch) | |
tree | bfc349cdfc5f6b9a245a60858a363e50a9189b2a /bin/bitbake-worker | |
parent | 5cfdebe7a67dccc7552ff80c1ccc970e36d562df (diff) | |
download | bitbake-40d2ae0723de2bf5fee343faafb4afda40546839.tar.gz |
bitbake-worker: exit normally when SIGHUP
Fixed:
1) Run "bitbake recipe" in the terminal
2) Close the terminal while building
3) $ ps aux | grep bitbake-worker
There will be many processes, and they will keep the resources (e.g.,
memory), and won't exit unless kill or kill -9.
Signed-off-by: Robert Yang <liezhi.yang@windriver.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'bin/bitbake-worker')
-rwxr-xr-x | bin/bitbake-worker | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/bin/bitbake-worker b/bin/bitbake-worker index dde2c9c8f..371c99a67 100755 --- a/bin/bitbake-worker +++ b/bin/bitbake-worker @@ -147,6 +147,8 @@ def fork_off_task(cfg, data, workerdata, fn, task, taskname, appends, taskdepdat pipein.close() signal.signal(signal.SIGTERM, sigterm_handler) + # Let SIGHUP exit as SIGTERM + signal.signal(signal.SIGHUP, sigterm_handler) # Save out the PID so that the event can include it the # events @@ -266,9 +268,14 @@ class BitbakeWorker(object): self.build_pipes = {} signal.signal(signal.SIGTERM, self.sigterm_exception) + # Let SIGHUP exit as SIGTERM + signal.signal(signal.SIGHUP, self.sigterm_exception) def sigterm_exception(self, signum, stackframe): - bb.warn("Worker recieved SIGTERM, shutting down...") + if signum == signal.SIGTERM: + bb.warn("Worker recieved SIGTERM, shutting down...") + elif signum == signal.SIGHUP: + bb.warn("Worker recieved SIGHUP, shutting down...") self.handle_finishnow(None) signal.signal(signal.SIGTERM, signal.SIG_DFL) os.kill(os.getpid(), signal.SIGTERM) |