mirror of
https://git.yoctoproject.org/poky
synced 2026-05-09 05:29:32 +00:00
bitbake: bitbake-worker: Extra profiling data dump
Currently we get no profiling oversight into either the main bitbake worker process, or the overall parsing before task execution. This adds in extra profiling hooks so we can truly capture all parts of bitbake's execution into the profile data. To do this we modify the 'magic' value passed to bitbake-worker to trigger the profiling, before the configuration data is sent over to the worker. (Bitbake rev: 446e490bf485b712e5cee733dab5805254cdcad0) Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
@@ -12,10 +12,18 @@ import errno
|
|||||||
import signal
|
import signal
|
||||||
|
|
||||||
# Users shouldn't be running this code directly
|
# Users shouldn't be running this code directly
|
||||||
if len(sys.argv) != 2 or sys.argv[1] != "decafbad":
|
if len(sys.argv) != 2 or not sys.argv[1].startswith("decafbad"):
|
||||||
print("bitbake-worker is meant for internal execution by bitbake itself, please don't use it standalone.")
|
print("bitbake-worker is meant for internal execution by bitbake itself, please don't use it standalone.")
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
|
profiling = False
|
||||||
|
if sys.argv[1] == "decafbadbad":
|
||||||
|
profiling = True
|
||||||
|
try:
|
||||||
|
import cProfile as profile
|
||||||
|
except:
|
||||||
|
import profile
|
||||||
|
|
||||||
logger = logging.getLogger("BitBake")
|
logger = logging.getLogger("BitBake")
|
||||||
|
|
||||||
try:
|
try:
|
||||||
@@ -134,6 +142,7 @@ def fork_off_task(cfg, data, workerdata, fn, task, taskname, appends, taskdepdat
|
|||||||
bb.msg.fatal("RunQueue", "fork failed: %d (%s)" % (e.errno, e.strerror))
|
bb.msg.fatal("RunQueue", "fork failed: %d (%s)" % (e.errno, e.strerror))
|
||||||
|
|
||||||
if pid == 0:
|
if pid == 0:
|
||||||
|
def child():
|
||||||
global worker_pipe
|
global worker_pipe
|
||||||
pipein.close()
|
pipein.close()
|
||||||
|
|
||||||
@@ -185,10 +194,20 @@ def fork_off_task(cfg, data, workerdata, fn, task, taskname, appends, taskdepdat
|
|||||||
os._exit(1)
|
os._exit(1)
|
||||||
try:
|
try:
|
||||||
if not cfg.dry_run:
|
if not cfg.dry_run:
|
||||||
ret = bb.build.exec_task(fn, taskname, the_data, cfg.profile)
|
return bb.build.exec_task(fn, taskname, the_data, cfg.profile)
|
||||||
os._exit(ret)
|
|
||||||
except:
|
except:
|
||||||
os._exit(1)
|
os._exit(1)
|
||||||
|
if not profiling:
|
||||||
|
os._exit(child())
|
||||||
|
else:
|
||||||
|
profname = "profile-%s.log" % (fn.replace("/", "-") + "-" + taskname)
|
||||||
|
prof = profile.Profile()
|
||||||
|
try:
|
||||||
|
ret = profile.Profile.runcall(prof, child)
|
||||||
|
finally:
|
||||||
|
prof.dump_stats(profname)
|
||||||
|
bb.utils.process_profilelog(profname)
|
||||||
|
os._exit(ret)
|
||||||
else:
|
else:
|
||||||
for key, value in envbackup.iteritems():
|
for key, value in envbackup.iteritems():
|
||||||
if value is None:
|
if value is None:
|
||||||
@@ -363,7 +382,16 @@ class BitbakeWorker(object):
|
|||||||
|
|
||||||
try:
|
try:
|
||||||
worker = BitbakeWorker(sys.stdin)
|
worker = BitbakeWorker(sys.stdin)
|
||||||
worker.serve()
|
if not profiling:
|
||||||
|
worker.serve()
|
||||||
|
else:
|
||||||
|
profname = "profile-worker.log"
|
||||||
|
prof = profile.Profile()
|
||||||
|
try:
|
||||||
|
profile.Profile.runcall(prof, worker.serve)
|
||||||
|
finally:
|
||||||
|
prof.dump_stats(profname)
|
||||||
|
bb.utils.process_profilelog(profname)
|
||||||
except BaseException as e:
|
except BaseException as e:
|
||||||
if not normalexit:
|
if not normalexit:
|
||||||
import traceback
|
import traceback
|
||||||
|
|||||||
@@ -859,15 +859,18 @@ class RunQueue:
|
|||||||
|
|
||||||
def _start_worker(self, fakeroot = False, rqexec = None):
|
def _start_worker(self, fakeroot = False, rqexec = None):
|
||||||
logger.debug(1, "Starting bitbake-worker")
|
logger.debug(1, "Starting bitbake-worker")
|
||||||
|
magic = "decafbad"
|
||||||
|
if self.cooker.configuration.profile:
|
||||||
|
magic = "decafbadbad"
|
||||||
if fakeroot:
|
if fakeroot:
|
||||||
fakerootcmd = self.cfgData.getVar("FAKEROOTCMD", True)
|
fakerootcmd = self.cfgData.getVar("FAKEROOTCMD", True)
|
||||||
fakerootenv = (self.cfgData.getVar("FAKEROOTBASEENV", True) or "").split()
|
fakerootenv = (self.cfgData.getVar("FAKEROOTBASEENV", True) or "").split()
|
||||||
env = os.environ.copy()
|
env = os.environ.copy()
|
||||||
for key, value in (var.split('=') for var in fakerootenv):
|
for key, value in (var.split('=') for var in fakerootenv):
|
||||||
env[key] = value
|
env[key] = value
|
||||||
worker = subprocess.Popen([fakerootcmd, "bitbake-worker", "decafbad"], stdout=subprocess.PIPE, stdin=subprocess.PIPE, env=env)
|
worker = subprocess.Popen([fakerootcmd, "bitbake-worker", magic], stdout=subprocess.PIPE, stdin=subprocess.PIPE, env=env)
|
||||||
else:
|
else:
|
||||||
worker = subprocess.Popen(["bitbake-worker", "decafbad"], stdout=subprocess.PIPE, stdin=subprocess.PIPE)
|
worker = subprocess.Popen(["bitbake-worker", magic], stdout=subprocess.PIPE, stdin=subprocess.PIPE)
|
||||||
bb.utils.nonblockingfd(worker.stdout)
|
bb.utils.nonblockingfd(worker.stdout)
|
||||||
workerpipe = runQueuePipe(worker.stdout, None, self.cfgData, self, rqexec)
|
workerpipe = runQueuePipe(worker.stdout, None, self.cfgData, self, rqexec)
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user