summaryrefslogtreecommitdiffstats
path: root/bitbake/bin
diff options
context:
space:
mode:
authorAlexandru DAMIAN <alexandru.damian@intel.com>2014-01-09 15:11:59 +0000
committerRichard Purdie <richard.purdie@linuxfoundation.org>2014-03-25 11:17:34 +0000
commit70f1a3db5e102cff658e51007e0cac5207f197bb (patch)
treeea3db15a1dd9ab0a7d75b0c30c3608d51e0e805e /bitbake/bin
parent1913a1751d50c6e6011faea57999a4d342963de9 (diff)
downloadast2050-yocto-poky-70f1a3db5e102cff658e51007e0cac5207f197bb.zip
ast2050-yocto-poky-70f1a3db5e102cff658e51007e0cac5207f197bb.tar.gz
bitbake: toaster: clean exit on bb server shutdown
This patch adds the capability to have the Toaster UI detect when the Bitbake server exited and cleanly trigger a clean shutdown of the system through the toaster starting script. (Bitbake rev: a9cfa3eacfc99550e1ad3f8bb61b2a0bc9b44332) Signed-off-by: Alexandru DAMIAN <alexandru.damian@intel.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'bitbake/bin')
-rwxr-xr-xbitbake/bin/toaster28
1 files changed, 26 insertions, 2 deletions
diff --git a/bitbake/bin/toaster b/bitbake/bin/toaster
index 9c0a15f..b27f7c2 100755
--- a/bitbake/bin/toaster
+++ b/bitbake/bin/toaster
@@ -68,11 +68,16 @@ function addtoConfiguration()
echo $1 >> ${BUILDDIR}/conf/$2
}
+INSTOPSYSTEM=0
+
# define the stop command
function stop_system()
{
+ # prevent reentry
+ if [ $INSTOPSYSTEM == 1 ]; then return; fi
+ INSTOPSYSTEM=1
if [ -f ${BUILDDIR}/.toasterui.pid ]; then
- kill $(< ${BUILDDIR}/.toasterui.pid )
+ kill $(< ${BUILDDIR}/.toasterui.pid ) 2>/dev/null
rm ${BUILDDIR}/.toasterui.pid
fi
BBSERVER=localhost:8200 bitbake -m
@@ -80,8 +85,24 @@ function stop_system()
webserverKillAll
# force stop any misbehaving bitbake server
lsof bitbake.lock | awk '{print $2}' | grep "[0-9]\+" | xargs -n1 -r kill
+ trap - SIGHUP
+ trap - SIGCHLD
+ INSTOPSYSTEM=0
+}
+
+function check_pidbyfile() {
+ [ -e $1 ] && kill -0 $(< $1) 2>/dev/null
}
+
+function notify_chldexit() {
+ if [ $NOTOASTERUI == 0 ]; then
+ check_pidbyfile ${BUILDDIR}/.toasterui.pid && return
+ stop_system
+ fi
+}
+
+
# We make sure we're running in the current shell and in a good environment
if [ -z "$ZSH_NAME" ] && [ `basename \"$0\"` = `basename \"$BASH_SOURCE\"` ]; then
@@ -179,10 +200,13 @@ case $CMD in
stop_system
echo "Failed ${CMD}."
fi
+ # stop system on terminal exit
+ set -o monitor
+ trap stop_system SIGHUP
+ trap notify_chldexit SIGCHLD
;;
stop )
stop_system
- trap '' SIGHUP
echo "Successful ${CMD}."
;;
esac
OpenPOWER on IntegriCloud