diff options
author | Richard Purdie <richard.purdie@linuxfoundation.org> | 2016-12-07 14:20:48 +0000 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2016-12-08 10:32:21 +0000 |
commit | e10da7d9dfc4da714092a63987d564ef67f73718 (patch) | |
tree | 82116c9761a475057f250056d40eb1bb72128e35 /bitbake | |
parent | 9977576fe97c6a67dec04171e64678676cbf1c22 (diff) | |
download | poky-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>
Diffstat (limited to 'bitbake')
-rw-r--r-- | bitbake/lib/bb/cooker.py | 8 |
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 |