summaryrefslogtreecommitdiffstats
path: root/meta/lib
diff options
context:
space:
mode:
authorRichard Purdie <richard.purdie@linuxfoundation.org>2020-01-29 17:28:46 +0000
committerRichard Purdie <richard.purdie@linuxfoundation.org>2020-11-12 13:07:52 +0000
commit5d3de28c9db463b5e7950a86c1606b95d69b2dfc (patch)
tree61651c9e89957893a3ca296e408c1cda03089cd9 /meta/lib
parent2bb40f8c231c256f90aff597934ce6f88421e80a (diff)
downloadpoky-5d3de28c9db463b5e7950a86c1606b95d69b2dfc.tar.gz
sstatesig: Log timestamps for hashequiv in reprodubile builds for do_package
Currently if a task generates the same output with different timestamps, hasequiv won't detect it but reproducibile builds will fail tests due to the different timestamps. Add do_package timestamps to the hash when reproducibile builds are enabled to avoid this. (From OE-Core rev: cda769ed7c120edd7db0ff77e34fa1aa611a3082) Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org> (cherry picked from commit 11e8200ccec765ff6a4263e06512e5751eca261a) Signed-off-by: Steve Sakoman <steve@sakoman.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/lib')
-rw-r--r--meta/lib/oe/sstatesig.py6
1 files changed, 6 insertions, 0 deletions
diff --git a/meta/lib/oe/sstatesig.py b/meta/lib/oe/sstatesig.py
index d24e3738ae..d5a6200562 100644
--- a/meta/lib/oe/sstatesig.py
+++ b/meta/lib/oe/sstatesig.py
@@ -477,6 +477,9 @@ def OEOuthashBasic(path, sigfile, task, d):
477 h = hashlib.sha256() 477 h = hashlib.sha256()
478 prev_dir = os.getcwd() 478 prev_dir = os.getcwd()
479 include_owners = os.environ.get('PSEUDO_DISABLED') == '0' 479 include_owners = os.environ.get('PSEUDO_DISABLED') == '0'
480 include_timestamps = False
481 if task == "package":
482 include_timestamps = d.getVar('BUILD_REPRODUCIBLE_BINARIES') == '1'
480 extra_content = d.getVar('HASHEQUIV_HASH_VERSION') 483 extra_content = d.getVar('HASHEQUIV_HASH_VERSION')
481 484
482 try: 485 try:
@@ -551,6 +554,9 @@ def OEOuthashBasic(path, sigfile, task, d):
551 bb.warn("KeyError in %s" % path) 554 bb.warn("KeyError in %s" % path)
552 raise 555 raise
553 556
557 if include_timestamps:
558 update_hash(" %10d" % s.st_mtime)
559
554 update_hash(" ") 560 update_hash(" ")
555 if stat.S_ISBLK(s.st_mode) or stat.S_ISCHR(s.st_mode): 561 if stat.S_ISBLK(s.st_mode) or stat.S_ISCHR(s.st_mode):
556 update_hash("%9s" % ("%d.%d" % (os.major(s.st_rdev), os.minor(s.st_rdev)))) 562 update_hash("%9s" % ("%d.%d" % (os.major(s.st_rdev), os.minor(s.st_rdev))))