From 64d284b26c2e9b0fcd03119302bd8512fe317cc1 Mon Sep 17 00:00:00 2001 From: Ed Bartosh Date: Fri, 16 Sep 2016 17:22:31 +0100 Subject: [PATCH] bitbake: runbuilds: process builds on SIGUSR1 Run main processing function 'runbuild' only if SIGUSR1 is received. This signal is sent by Toaster when build status is changed (either started, cancelled or finished). This should stop continuous database polling as run_builds function will be called only when needed, i.e. after build status is changed. [YOCTO #8918] (Bitbake rev: 62d598cc5aa01d23f1e9284e9e926bd55b1d1878) Signed-off-by: Ed Bartosh Signed-off-by: Michael Wood Signed-off-by: Richard Purdie --- .../lib/toaster/bldcontrol/management/commands/runbuilds.py | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/bitbake/lib/toaster/bldcontrol/management/commands/runbuilds.py b/bitbake/lib/toaster/bldcontrol/management/commands/runbuilds.py index a70377012b..61a520c6ce 100644 --- a/bitbake/lib/toaster/bldcontrol/management/commands/runbuilds.py +++ b/bitbake/lib/toaster/bldcontrol/management/commands/runbuilds.py @@ -11,9 +11,9 @@ from orm.models import Build, ToasterSetting, LogMessage, Target import os import logging -import time import sys import traceback +import signal logger = logging.getLogger("toaster") @@ -175,6 +175,8 @@ class Command(NoArgsCommand): logger.warn("runbuilds: schedule exception %s" % str(e)) def handle_noargs(self, **options): + signal.signal(signal.SIGUSR1, lambda sig, frame: None) + while True: + signal.pause() self.runbuild() - time.sleep(1)