summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRichard Purdie <richard.purdie@linuxfoundation.org>2016-12-07 14:20:48 +0000
committerRichard Purdie <richard.purdie@linuxfoundation.org>2016-12-08 10:32:21 +0000
commite10da7d9dfc4da714092a63987d564ef67f73718 (patch)
tree82116c9761a475057f250056d40eb1bb72128e35
parent9977576fe97c6a67dec04171e64678676cbf1c22 (diff)
downloadpoky-e10da7d9dfc4da714092a63987d564ef67f73718.tar.gz
bitbake: cooker: Handle inofity queue overflows more gracefully
If many files change and the inotify queue overflows, rather than print a traceback, invalidate the caches and warn the user. [YOCTO #10676] (Bitbake rev: 058f8517c041b80e8b591ad7d34a68281b2d03fc) Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r--bitbake/lib/bb/cooker.py8
1 files changed, 8 insertions, 0 deletions
diff --git a/bitbake/lib/bb/cooker.py b/bitbake/lib/bb/cooker.py
index aca9470607..5e5708ee2b 100644
--- a/bitbake/lib/bb/cooker.py
+++ b/bitbake/lib/bb/cooker.py
@@ -252,6 +252,10 @@ class BBCooker:
252 signal.signal(signal.SIGHUP, self.sigterm_exception) 252 signal.signal(signal.SIGHUP, self.sigterm_exception)
253 253
254 def config_notifications(self, event): 254 def config_notifications(self, event):
255 if event.maskname == "IN_Q_OVERFLOW":
256 bb.warn("inotify event queue overflowed, invalidating caches.")
257 self.baseconfig_valid = False
258 return
255 if not event.pathname in self.configwatcher.bbwatchedfiles: 259 if not event.pathname in self.configwatcher.bbwatchedfiles:
256 return 260 return
257 if not event.pathname in self.inotify_modified_files: 261 if not event.pathname in self.inotify_modified_files:
@@ -259,6 +263,10 @@ class BBCooker:
259 self.baseconfig_valid = False 263 self.baseconfig_valid = False
260 264
261 def notifications(self, event): 265 def notifications(self, event):
266 if event.maskname == "IN_Q_OVERFLOW":
267 bb.warn("inotify event queue overflowed, invalidating caches.")
268 self.parsecache_valid = False
269 return
262 if not event.pathname in self.inotify_modified_files: 270 if not event.pathname in self.inotify_modified_files:
263 self.inotify_modified_files.append(event.pathname) 271 self.inotify_modified_files.append(event.pathname)
264 self.parsecache_valid = False 272 self.parsecache_valid = False