diff options
author | Paul Eggleton <paul.eggleton@linux.intel.com> | 2017-04-07 16:57:23 +1200 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2017-04-11 18:10:18 +0100 |
commit | 3df7ee4755653f3783a9eaa81b019abf6be7a29a (patch) | |
tree | 2b9a9e1da7c9d60f526c8b00dd0b806d18a36117 | |
parent | 54426c3a3b913a37a3e16895138e9f33f214aed1 (diff) | |
download | poky-3df7ee4755653f3783a9eaa81b019abf6be7a29a.tar.gz |
classes/buildhistory: save output file signatures for sstate tasks
Save a file per task listing sha256sums for each file staged, i.e.
the output of the task. Some caveats:
1) This only covers sstate tasks since it uses SSTATEPOSTUNPACKFUNCS,
however those are generally the most interesting in terms of output
anyway.
2) The signature is taken before applying any relocations, so any
relocated files will actually have different signatures, but that's
churn that you probably won't want to see here.
3) At the moment if you run the same build twice without sstate you will
very likely see changes in the output for certain tasks due to things
like timestamps being present in the binary output. Fixing that is
a general Linux ecosystem problem - see this page for our efforts to
resolve it on our side:
https://wiki.yoctoproject.org/wiki/Reproducible_Builds
NOTE: you need to set your BUILDHISTORY_FEATURES value to include
"task" to enable collection of these signatures as it is is disabled by
default.
(From OE-Core rev: ca5d1273432e20059ab66d721a9eb314a54e81e7)
Signed-off-by: Paul Eggleton <paul.eggleton@linux.intel.com>
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r-- | meta/classes/buildhistory.bbclass | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/meta/classes/buildhistory.bbclass b/meta/classes/buildhistory.bbclass index 4fc19a0fc2..f543bb73d6 100644 --- a/meta/classes/buildhistory.bbclass +++ b/meta/classes/buildhistory.bbclass | |||
@@ -47,6 +47,11 @@ sstate_install[vardepsexclude] += "buildhistory_emit_pkghistory" | |||
47 | # then the value added to SSTATEPOSTINSTFUNCS: | 47 | # then the value added to SSTATEPOSTINSTFUNCS: |
48 | SSTATEPOSTINSTFUNCS[vardepvalueexclude] .= "| buildhistory_emit_pkghistory" | 48 | SSTATEPOSTINSTFUNCS[vardepvalueexclude] .= "| buildhistory_emit_pkghistory" |
49 | 49 | ||
50 | # Similarly for our function that gets the output signatures | ||
51 | SSTATEPOSTUNPACKFUNCS_append = " buildhistory_emit_outputsigs" | ||
52 | sstate_installpkgdir[vardepsexclude] += "buildhistory_emit_outputsigs" | ||
53 | SSTATEPOSTUNPACKFUNCS[vardepvalueexclude] .= "| buildhistory_emit_outputsigs" | ||
54 | |||
50 | # All items excepts those listed here will be removed from a recipe's | 55 | # All items excepts those listed here will be removed from a recipe's |
51 | # build history directory by buildhistory_emit_pkghistory(). This is | 56 | # build history directory by buildhistory_emit_pkghistory(). This is |
52 | # necessary because some of these items (package directories, files that | 57 | # necessary because some of these items (package directories, files that |
@@ -292,6 +297,29 @@ python buildhistory_emit_pkghistory() { | |||
292 | bb.build.exec_func("buildhistory_list_pkg_files", d) | 297 | bb.build.exec_func("buildhistory_list_pkg_files", d) |
293 | } | 298 | } |
294 | 299 | ||
300 | python buildhistory_emit_outputsigs() { | ||
301 | if not "task" in (d.getVar('BUILDHISTORY_FEATURES') or "").split(): | ||
302 | return | ||
303 | |||
304 | taskoutdir = os.path.join(d.getVar('BUILDHISTORY_DIR'), 'task', 'output') | ||
305 | bb.utils.mkdirhier(taskoutdir) | ||
306 | currenttask = d.getVar('BB_CURRENTTASK') | ||
307 | pn = d.getVar('PN') | ||
308 | taskfile = os.path.join(taskoutdir, '%s.%s' % (pn, currenttask)) | ||
309 | |||
310 | cwd = os.getcwd() | ||
311 | filesigs = {} | ||
312 | for root, _, files in os.walk(cwd): | ||
313 | for fname in files: | ||
314 | if fname == 'fixmepath': | ||
315 | continue | ||
316 | fullpath = os.path.join(root, fname) | ||
317 | filesigs[os.path.relpath(fullpath, cwd)] = bb.utils.sha256_file(fullpath) | ||
318 | with open(taskfile, 'w') as f: | ||
319 | for fpath, fsig in sorted(filesigs.items(), key=lambda item: item[0]): | ||
320 | f.write('%s %s\n' % (fpath, fsig)) | ||
321 | } | ||
322 | |||
295 | 323 | ||
296 | def write_recipehistory(rcpinfo, d): | 324 | def write_recipehistory(rcpinfo, d): |
297 | bb.debug(2, "Writing recipe history") | 325 | bb.debug(2, "Writing recipe history") |