summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--bitbake/lib/bb/cache.py17
-rw-r--r--bitbake/lib/bb/cooker.py2
2 files changed, 13 insertions, 6 deletions
diff --git a/bitbake/lib/bb/cache.py b/bitbake/lib/bb/cache.py
index 99d7395f86..6e152fa0c9 100644
--- a/bitbake/lib/bb/cache.py
+++ b/bitbake/lib/bb/cache.py
@@ -43,7 +43,7 @@ except ImportError:
43 logger.info("Importing cPickle failed. " 43 logger.info("Importing cPickle failed. "
44 "Falling back to a very slow implementation.") 44 "Falling back to a very slow implementation.")
45 45
46__cache_version__ = "140" 46__cache_version__ = "141"
47 47
48def getCacheFile(path, filename): 48def getCacheFile(path, filename):
49 return os.path.join(path, filename) 49 return os.path.join(path, filename)
@@ -94,6 +94,7 @@ class CoreRecipeInfo(RecipeInfoCommon):
94 self.file_depends = metadata.getVar('__depends', False) 94 self.file_depends = metadata.getVar('__depends', False)
95 self.timestamp = bb.parse.cached_mtime(filename) 95 self.timestamp = bb.parse.cached_mtime(filename)
96 self.variants = self.listvar('__VARIANTS', metadata) + [''] 96 self.variants = self.listvar('__VARIANTS', metadata) + ['']
97 self.appends = self.listvar('__BBAPPEND', metadata)
97 self.nocache = self.getvar('__BB_DONT_CACHE', metadata) 98 self.nocache = self.getvar('__BB_DONT_CACHE', metadata)
98 99
99 self.skipreason = self.getvar('__SKIPPED', metadata) 100 self.skipreason = self.getvar('__SKIPPED', metadata)
@@ -429,7 +430,7 @@ class Cache(object):
429 automatically add the information to the cache or to your 430 automatically add the information to the cache or to your
430 CacheData. Use the add or add_info method to do so after 431 CacheData. Use the add or add_info method to do so after
431 running this, or use loadData instead.""" 432 running this, or use loadData instead."""
432 cached = self.cacheValid(filename) 433 cached = self.cacheValid(filename, appends)
433 if cached: 434 if cached:
434 infos = [] 435 infos = []
435 # info_array item is a list of [CoreRecipeInfo, XXXRecipeInfo] 436 # info_array item is a list of [CoreRecipeInfo, XXXRecipeInfo]
@@ -460,13 +461,13 @@ class Cache(object):
460 461
461 return cached, skipped, virtuals 462 return cached, skipped, virtuals
462 463
463 def cacheValid(self, fn): 464 def cacheValid(self, fn, appends):
464 """ 465 """
465 Is the cache valid for fn? 466 Is the cache valid for fn?
466 Fast version, no timestamps checked. 467 Fast version, no timestamps checked.
467 """ 468 """
468 if fn not in self.checked: 469 if fn not in self.checked:
469 self.cacheValidUpdate(fn) 470 self.cacheValidUpdate(fn, appends)
470 471
471 # Is cache enabled? 472 # Is cache enabled?
472 if not self.has_cache: 473 if not self.has_cache:
@@ -475,7 +476,7 @@ class Cache(object):
475 return True 476 return True
476 return False 477 return False
477 478
478 def cacheValidUpdate(self, fn): 479 def cacheValidUpdate(self, fn, appends):
479 """ 480 """
480 Is the cache valid for fn? 481 Is the cache valid for fn?
481 Make thorough (slower) checks including timestamps. 482 Make thorough (slower) checks including timestamps.
@@ -524,6 +525,12 @@ class Cache(object):
524 self.remove(fn) 525 self.remove(fn)
525 return False 526 return False
526 527
528 if appends != info_array[0].appends:
529 logger.debug(2, "Cache: appends for %s changed", fn)
530 bb.note("%s to %s" % (str(appends), str(info_array[0].appends)))
531 self.remove(fn)
532 return False
533
527 invalid = False 534 invalid = False
528 for cls in info_array[0].variants: 535 for cls in info_array[0].variants:
529 virtualfn = self.realfn2virtual(fn, cls) 536 virtualfn = self.realfn2virtual(fn, cls)
diff --git a/bitbake/lib/bb/cooker.py b/bitbake/lib/bb/cooker.py
index 7976d299c0..ecf20dcf68 100644
--- a/bitbake/lib/bb/cooker.py
+++ b/bitbake/lib/bb/cooker.py
@@ -1298,7 +1298,7 @@ class CookerParser(object):
1298 self.willparse = [] 1298 self.willparse = []
1299 for filename in self.filelist: 1299 for filename in self.filelist:
1300 appends = self.cooker.get_file_appends(filename) 1300 appends = self.cooker.get_file_appends(filename)
1301 if not self.bb_cache.cacheValid(filename): 1301 if not self.bb_cache.cacheValid(filename, appends):
1302 self.willparse.append((filename, appends, cooker.caches_array)) 1302 self.willparse.append((filename, appends, cooker.caches_array))
1303 else: 1303 else:
1304 self.fromcache.append((filename, appends)) 1304 self.fromcache.append((filename, appends))