summaryrefslogtreecommitdiffstats
path: root/bitbake/bin
diff options
context:
space:
mode:
authorRichard Purdie <richard.purdie@linuxfoundation.org>2020-08-24 17:12:30 +0100
committerRichard Purdie <richard.purdie@linuxfoundation.org>2020-08-25 18:14:53 +0100
commit7002d67de02206fca0782c3373e915de20a71e9e (patch)
treeea6b56cbd121d617801220dc42ed12bb1399fcff /bitbake/bin
parent6bab132879c0abf6f2b1670174445766198d3cac (diff)
downloadpoky-7002d67de02206fca0782c3373e915de20a71e9e.tar.gz
bitbake: server/process: Add bitbake-server and exec() a new server process
Trying to have a new python process forked off an original doesn't work out well and ends up having race issues. To avoid this, exec() a new bitbake server process. This starts with a fresh python interpreter and resolves various atexit and other multiprocessing issues once and for all. (Bitbake rev: 9501dd6fdd7a7c25cbfa4464cf881fcf8c049ce2) Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'bitbake/bin')
-rwxr-xr-xbitbake/bin/bitbake-server54
1 files changed, 54 insertions, 0 deletions
diff --git a/bitbake/bin/bitbake-server b/bitbake/bin/bitbake-server
new file mode 100755
index 0000000000..ffbc7894ef
--- /dev/null
+++ b/bitbake/bin/bitbake-server
@@ -0,0 +1,54 @@
1#!/usr/bin/env python3
2#
3# SPDX-License-Identifier: GPL-2.0-only
4#
5# Copyright (C) 2020 Richard Purdie
6#
7
8import os
9import sys
10import warnings
11import logging
12sys.path.insert(0, os.path.join(os.path.dirname(os.path.dirname(sys.argv[0])), 'lib'))
13
14if sys.getfilesystemencoding() != "utf-8":
15 sys.exit("Please use a locale setting which supports UTF-8 (such as LANG=en_US.UTF-8).\nPython can't change the filesystem locale after loading so we need a UTF-8 when Python starts or things won't work.")
16
17# Users shouldn't be running this code directly
18if len(sys.argv) != 10 or not sys.argv[1].startswith("decafbad"):
19 print("bitbake-server is meant for internal execution by bitbake itself, please don't use it standalone.")
20 sys.exit(1)
21
22import bb.server.process
23
24lockfd = int(sys.argv[2])
25readypipeinfd = int(sys.argv[3])
26logfile = sys.argv[4]
27lockname = sys.argv[5]
28sockname = sys.argv[6]
29timeout = sys.argv[7]
30xmlrpcinterface = (sys.argv[8], int(sys.argv[9]))
31if xmlrpcinterface[0] == "None":
32 xmlrpcinterface = (None, xmlrpcinterface[1])
33if timeout == "None":
34 timeout = None
35
36# Replace standard fds with our own
37with open('/dev/null', 'r') as si:
38 os.dup2(si.fileno(), sys.stdin.fileno())
39
40so = open(logfile, 'a+')
41os.dup2(so.fileno(), sys.stdout.fileno())
42os.dup2(so.fileno(), sys.stderr.fileno())
43
44# Have stdout and stderr be the same so log output matches chronologically
45# and there aren't two seperate buffers
46sys.stderr = sys.stdout
47
48logger = logging.getLogger("BitBake")
49# Ensure logging messages get sent to the UI as events
50handler = bb.event.LogHandler()
51logger.addHandler(handler)
52
53bb.server.process.execServer(lockfd, readypipeinfd, lockname, sockname, timeout, xmlrpcinterface)
54