summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--bitbake/lib/bb/server/process.py19
1 files changed, 15 insertions, 4 deletions
diff --git a/bitbake/lib/bb/server/process.py b/bitbake/lib/bb/server/process.py
index 475931a728..d4beac4379 100644
--- a/bitbake/lib/bb/server/process.py
+++ b/bitbake/lib/bb/server/process.py
@@ -48,7 +48,7 @@ class ProcessServer(multiprocessing.Process):
48 48
49 self.event_handle = None 49 self.event_handle = None
50 self.haveui = False 50 self.haveui = False
51 self.lastui = False 51 self.maxuiwait = 30
52 self.xmlrpc = False 52 self.xmlrpc = False
53 53
54 self._idlefuns = {} 54 self._idlefuns = {}
@@ -155,6 +155,7 @@ class ProcessServer(multiprocessing.Process):
155 print("No timeout, exiting.") 155 print("No timeout, exiting.")
156 self.quit = True 156 self.quit = True
157 157
158 self.lastui = time.time()
158 while not self.quit: 159 while not self.quit:
159 if self.sock in ready: 160 if self.sock in ready:
160 while select.select([self.sock],[],[],0)[0]: 161 while select.select([self.sock],[],[],0)[0]:
@@ -191,11 +192,18 @@ class ProcessServer(multiprocessing.Process):
191 except (EOFError, OSError): 192 except (EOFError, OSError):
192 disconnect_client(self, fds) 193 disconnect_client(self, fds)
193 194
194 if not self.timeout == -1.0 and not self.haveui and self.lastui and self.timeout and \ 195 if not self.timeout == -1.0 and not self.haveui and self.timeout and \
195 (self.lastui + self.timeout) < time.time(): 196 (self.lastui + self.timeout) < time.time():
196 print("Server timeout, exiting.") 197 print("Server timeout, exiting.")
197 self.quit = True 198 self.quit = True
198 199
200 # If we don't see a UI connection within maxuiwait, its unlikely we're going to see
201 # one. We have had issue with processes hanging indefinitely so timing out UI-less
202 # servers is useful.
203 if not self.haveui and not self.timeout and (self.lastui + self.maxuiwait) < time.time():
204 print("No UI connection within max timeout, exiting to avoid infinite loop.")
205 self.quit = True
206
199 if self.command_channel in ready: 207 if self.command_channel in ready:
200 try: 208 try:
201 command = self.command_channel.get() 209 command = self.command_channel.get()
@@ -220,10 +228,13 @@ class ProcessServer(multiprocessing.Process):
220 228
221 print("Exiting") 229 print("Exiting")
222 # Remove the socket file so we don't get any more connections to avoid races 230 # Remove the socket file so we don't get any more connections to avoid races
223 os.unlink(self.sockname) 231 try:
232 os.unlink(self.sockname)
233 except:
234 pass
224 self.sock.close() 235 self.sock.close()
225 236
226 try: 237 try:
227 self.cooker.shutdown(True) 238 self.cooker.shutdown(True)
228 self.cooker.notifier.stop() 239 self.cooker.notifier.stop()
229 self.cooker.confignotifier.stop() 240 self.cooker.confignotifier.stop()