summaryrefslogtreecommitdiffstats
path: root/meta/classes/sstate.bbclass
diff options
context:
space:
mode:
Diffstat (limited to 'meta/classes/sstate.bbclass')
-rw-r--r--meta/classes/sstate.bbclass94
1 files changed, 47 insertions, 47 deletions
diff --git a/meta/classes/sstate.bbclass b/meta/classes/sstate.bbclass
index 6abf55bb14..a777c79bb3 100644
--- a/meta/classes/sstate.bbclass
+++ b/meta/classes/sstate.bbclass
@@ -20,7 +20,7 @@ SSTATEPOSTINSTFUNCS ?= ""
20 20
21python () { 21python () {
22 if bb.data.inherits_class('native', d): 22 if bb.data.inherits_class('native', d):
23 bb.data.setVar('SSTATE_PKGARCH', bb.data.getVar('BUILD_ARCH', d), d) 23 bb.data.setVar('SSTATE_PKGARCH', d.getVar('BUILD_ARCH'), d)
24 elif bb.data.inherits_class('cross', d): 24 elif bb.data.inherits_class('cross', d):
25 bb.data.setVar('SSTATE_PKGARCH', bb.data.expand("${BUILD_ARCH}_${TUNE_PKGARCH}", d), d) 25 bb.data.setVar('SSTATE_PKGARCH', bb.data.expand("${BUILD_ARCH}_${TUNE_PKGARCH}", d), d)
26 bb.data.setVar('SSTATE_MANMACH', bb.data.expand("${BUILD_ARCH}_${MACHINE}", d), d) 26 bb.data.setVar('SSTATE_MANMACH', bb.data.expand("${BUILD_ARCH}_${MACHINE}", d), d)
@@ -37,19 +37,19 @@ python () {
37 # reused if we manipulate the paths 37 # reused if we manipulate the paths
38 if bb.data.inherits_class('native', d) or bb.data.inherits_class('cross', d) or bb.data.inherits_class('sdk', d) or bb.data.inherits_class('crosssdk', d): 38 if bb.data.inherits_class('native', d) or bb.data.inherits_class('cross', d) or bb.data.inherits_class('sdk', d) or bb.data.inherits_class('crosssdk', d):
39 scan_cmd = "grep -Irl ${STAGING_DIR} ${SSTATE_BUILDDIR}" 39 scan_cmd = "grep -Irl ${STAGING_DIR} ${SSTATE_BUILDDIR}"
40 bb.data.setVar('SSTATE_SCAN_CMD', scan_cmd, d) 40 d.setVar('SSTATE_SCAN_CMD', scan_cmd)
41 41
42 unique_tasks = set((bb.data.getVar('SSTATETASKS', d, True) or "").split()) 42 unique_tasks = set((d.getVar('SSTATETASKS', True) or "").split())
43 d.setVar('SSTATETASKS', " ".join(unique_tasks)) 43 d.setVar('SSTATETASKS', " ".join(unique_tasks))
44 namemap = [] 44 namemap = []
45 for task in unique_tasks: 45 for task in unique_tasks:
46 namemap.append(bb.data.getVarFlag(task, 'sstate-name', d)) 46 namemap.append(d.getVarFlag(task, 'sstate-name'))
47 funcs = bb.data.getVarFlag(task, 'prefuncs', d) or "" 47 funcs = d.getVarFlag(task, 'prefuncs') or ""
48 funcs = "sstate_task_prefunc " + funcs 48 funcs = "sstate_task_prefunc " + funcs
49 bb.data.setVarFlag(task, 'prefuncs', funcs, d) 49 d.setVarFlag(task, 'prefuncs', funcs)
50 funcs = bb.data.getVarFlag(task, 'postfuncs', d) or "" 50 funcs = d.getVarFlag(task, 'postfuncs') or ""
51 funcs = funcs + " sstate_task_postfunc" 51 funcs = funcs + " sstate_task_postfunc"
52 bb.data.setVarFlag(task, 'postfuncs', funcs, d) 52 d.setVarFlag(task, 'postfuncs', funcs)
53 d.setVar('SSTATETASKNAMES', " ".join(namemap)) 53 d.setVar('SSTATETASKNAMES', " ".join(namemap))
54} 54}
55 55
@@ -65,18 +65,18 @@ def sstate_init(name, task, d):
65 65
66def sstate_state_fromvars(d, task = None): 66def sstate_state_fromvars(d, task = None):
67 if task is None: 67 if task is None:
68 task = bb.data.getVar('BB_CURRENTTASK', d, True) 68 task = d.getVar('BB_CURRENTTASK', True)
69 if not task: 69 if not task:
70 bb.fatal("sstate code running without task context?!") 70 bb.fatal("sstate code running without task context?!")
71 task = task.replace("_setscene", "") 71 task = task.replace("_setscene", "")
72 72
73 name = bb.data.expand(bb.data.getVarFlag("do_" + task, 'sstate-name', d), d) 73 name = bb.data.expand(d.getVarFlag("do_" + task, 'sstate-name'), d)
74 inputs = (bb.data.expand(bb.data.getVarFlag("do_" + task, 'sstate-inputdirs', d) or "", d)).split() 74 inputs = (bb.data.expand(d.getVarFlag("do_" + task, 'sstate-inputdirs') or "", d)).split()
75 outputs = (bb.data.expand(bb.data.getVarFlag("do_" + task, 'sstate-outputdirs', d) or "", d)).split() 75 outputs = (bb.data.expand(d.getVarFlag("do_" + task, 'sstate-outputdirs') or "", d)).split()
76 plaindirs = (bb.data.expand(bb.data.getVarFlag("do_" + task, 'sstate-plaindirs', d) or "", d)).split() 76 plaindirs = (bb.data.expand(d.getVarFlag("do_" + task, 'sstate-plaindirs') or "", d)).split()
77 lockfiles = (bb.data.expand(bb.data.getVarFlag("do_" + task, 'sstate-lockfile', d) or "", d)).split() 77 lockfiles = (bb.data.expand(d.getVarFlag("do_" + task, 'sstate-lockfile') or "", d)).split()
78 lockfilesshared = (bb.data.expand(bb.data.getVarFlag("do_" + task, 'sstate-lockfile-shared', d) or "", d)).split() 78 lockfilesshared = (bb.data.expand(d.getVarFlag("do_" + task, 'sstate-lockfile-shared') or "", d)).split()
79 interceptfuncs = (bb.data.expand(bb.data.getVarFlag("do_" + task, 'sstate-interceptfuncs', d) or "", d)).split() 79 interceptfuncs = (bb.data.expand(d.getVarFlag("do_" + task, 'sstate-interceptfuncs') or "", d)).split()
80 if not name or len(inputs) != len(outputs): 80 if not name or len(inputs) != len(outputs):
81 bb.fatal("sstate variables not setup correctly?!") 81 bb.fatal("sstate variables not setup correctly?!")
82 82
@@ -139,7 +139,7 @@ def sstate_install(ss, d):
139 f.write(di + "\n") 139 f.write(di + "\n")
140 f.close() 140 f.close()
141 141
142 for postinst in (bb.data.getVar('SSTATEPOSTINSTFUNCS', d, True) or '').split(): 142 for postinst in (d.getVar('SSTATEPOSTINSTFUNCS', True) or '').split():
143 bb.build.exec_func(postinst, d) 143 bb.build.exec_func(postinst, d)
144 144
145 for lock in locks: 145 for lock in locks:
@@ -156,7 +156,7 @@ def sstate_installpkg(ss, d):
156 oe.path.remove(dir) 156 oe.path.remove(dir)
157 157
158 sstateinst = bb.data.expand("${WORKDIR}/sstate-install-%s/" % ss['name'], d) 158 sstateinst = bb.data.expand("${WORKDIR}/sstate-install-%s/" % ss['name'], d)
159 sstatepkg = bb.data.getVar('SSTATE_PKG', d, True) + '_' + ss['name'] + ".tgz" 159 sstatepkg = d.getVar('SSTATE_PKG', True) + '_' + ss['name'] + ".tgz"
160 160
161 if not os.path.exists(sstatepkg): 161 if not os.path.exists(sstatepkg):
162 pstaging_fetch(sstatepkg, d) 162 pstaging_fetch(sstatepkg, d)
@@ -167,16 +167,16 @@ def sstate_installpkg(ss, d):
167 167
168 sstate_clean(ss, d) 168 sstate_clean(ss, d)
169 169
170 bb.data.setVar('SSTATE_INSTDIR', sstateinst, d) 170 d.setVar('SSTATE_INSTDIR', sstateinst)
171 bb.data.setVar('SSTATE_PKG', sstatepkg, d) 171 d.setVar('SSTATE_PKG', sstatepkg)
172 bb.build.exec_func('sstate_unpack_package', d) 172 bb.build.exec_func('sstate_unpack_package', d)
173 173
174 # Fixup hardcoded paths 174 # Fixup hardcoded paths
175 fixmefn = sstateinst + "fixmepath" 175 fixmefn = sstateinst + "fixmepath"
176 if os.path.isfile(fixmefn): 176 if os.path.isfile(fixmefn):
177 staging = bb.data.getVar('STAGING_DIR', d, True) 177 staging = d.getVar('STAGING_DIR', True)
178 staging_target = bb.data.getVar('STAGING_DIR_TARGET', d, True) 178 staging_target = d.getVar('STAGING_DIR_TARGET', True)
179 staging_host = bb.data.getVar('STAGING_DIR_HOST', d, True) 179 staging_host = d.getVar('STAGING_DIR_HOST', True)
180 fixmefd = open(fixmefn, "r") 180 fixmefd = open(fixmefn, "r")
181 fixmefiles = fixmefd.readlines() 181 fixmefiles = fixmefd.readlines()
182 fixmefd.close() 182 fixmefd.close()
@@ -206,13 +206,13 @@ def sstate_installpkg(ss, d):
206def sstate_clean_cachefile(ss, d): 206def sstate_clean_cachefile(ss, d):
207 import oe.path 207 import oe.path
208 208
209 sstatepkgdir = bb.data.getVar('SSTATE_DIR', d, True) 209 sstatepkgdir = d.getVar('SSTATE_DIR', True)
210 sstatepkgfile = sstatepkgdir + '/' + bb.data.getVar('SSTATE_PKGSPEC', d, True) + "*_" + ss['name'] + ".tgz*" 210 sstatepkgfile = sstatepkgdir + '/' + d.getVar('SSTATE_PKGSPEC', True) + "*_" + ss['name'] + ".tgz*"
211 bb.note("Removing %s" % sstatepkgfile) 211 bb.note("Removing %s" % sstatepkgfile)
212 oe.path.remove(sstatepkgfile) 212 oe.path.remove(sstatepkgfile)
213 213
214def sstate_clean_cachefiles(d): 214def sstate_clean_cachefiles(d):
215 for task in (bb.data.getVar('SSTATETASKS', d, True) or "").split(): 215 for task in (d.getVar('SSTATETASKS', True) or "").split():
216 ss = sstate_state_fromvars(d, task[3:]) 216 ss = sstate_state_fromvars(d, task[3:])
217 sstate_clean_cachefile(ss, d) 217 sstate_clean_cachefile(ss, d)
218 218
@@ -274,10 +274,10 @@ CLEANFUNCS += "sstate_cleanall"
274python sstate_cleanall() { 274python sstate_cleanall() {
275 import fnmatch 275 import fnmatch
276 276
277 bb.note("Removing shared state for package %s" % bb.data.getVar('PN', d, True)) 277 bb.note("Removing shared state for package %s" % d.getVar('PN', True))
278 278
279 manifest_dir = bb.data.getVar('SSTATE_MANIFESTS', d, True) 279 manifest_dir = d.getVar('SSTATE_MANIFESTS', True)
280 manifest_prefix = bb.data.getVar("SSTATE_MANFILEPREFIX", d, True) 280 manifest_prefix = d.getVar("SSTATE_MANFILEPREFIX", True)
281 manifest_pattern = os.path.basename(manifest_prefix) + ".*" 281 manifest_pattern = os.path.basename(manifest_prefix) + ".*"
282 282
283 if not os.path.exists(manifest_dir): 283 if not os.path.exists(manifest_dir):
@@ -298,7 +298,7 @@ python sstate_cleanall() {
298def sstate_hardcode_path(d): 298def sstate_hardcode_path(d):
299 # Need to remove hardcoded paths and fix these when we install the 299 # Need to remove hardcoded paths and fix these when we install the
300 # staging packages. 300 # staging packages.
301 sstate_scan_cmd = bb.data.getVar('SSTATE_SCAN_CMD', d, True) 301 sstate_scan_cmd = d.getVar('SSTATE_SCAN_CMD', True)
302 p = os.popen("%s" % sstate_scan_cmd) 302 p = os.popen("%s" % sstate_scan_cmd)
303 file_list = p.read() 303 file_list = p.read()
304 304
@@ -306,10 +306,10 @@ def sstate_hardcode_path(d):
306 p.close() 306 p.close()
307 return 307 return
308 308
309 staging = bb.data.getVar('STAGING_DIR', d, True) 309 staging = d.getVar('STAGING_DIR', True)
310 staging_target = bb.data.getVar('STAGING_DIR_TARGET', d, True) 310 staging_target = d.getVar('STAGING_DIR_TARGET', True)
311 staging_host = bb.data.getVar('STAGING_DIR_HOST', d, True) 311 staging_host = d.getVar('STAGING_DIR_HOST', True)
312 sstate_builddir = bb.data.getVar('SSTATE_BUILDDIR', d, True) 312 sstate_builddir = d.getVar('SSTATE_BUILDDIR', True)
313 313
314 for i in file_list.split('\n'): 314 for i in file_list.split('\n'):
315 if not i: 315 if not i:
@@ -349,10 +349,10 @@ def sstate_package(ss, d):
349 os.remove(path) 349 os.remove(path)
350 os.symlink(base, path) 350 os.symlink(base, path)
351 351
352 tmpdir = bb.data.getVar('TMPDIR', d, True) 352 tmpdir = d.getVar('TMPDIR', True)
353 353
354 sstatebuild = bb.data.expand("${WORKDIR}/sstate-build-%s/" % ss['name'], d) 354 sstatebuild = bb.data.expand("${WORKDIR}/sstate-build-%s/" % ss['name'], d)
355 sstatepkg = bb.data.getVar('SSTATE_PKG', d, True) + '_'+ ss['name'] + ".tgz" 355 sstatepkg = d.getVar('SSTATE_PKG', True) + '_'+ ss['name'] + ".tgz"
356 bb.mkdirhier(sstatebuild) 356 bb.mkdirhier(sstatebuild)
357 bb.mkdirhier(os.path.dirname(sstatepkg)) 357 bb.mkdirhier(os.path.dirname(sstatepkg))
358 for state in ss['dirs']: 358 for state in ss['dirs']:
@@ -369,15 +369,15 @@ def sstate_package(ss, d):
369 bb.debug(2, "Preparing tree %s for packaging at %s" % (state[1], sstatebuild + state[0])) 369 bb.debug(2, "Preparing tree %s for packaging at %s" % (state[1], sstatebuild + state[0]))
370 oe.path.copytree(state[1], sstatebuild + state[0]) 370 oe.path.copytree(state[1], sstatebuild + state[0])
371 371
372 workdir = bb.data.getVar('WORKDIR', d, True) 372 workdir = d.getVar('WORKDIR', True)
373 for plain in ss['plaindirs']: 373 for plain in ss['plaindirs']:
374 pdir = plain.replace(workdir, sstatebuild) 374 pdir = plain.replace(workdir, sstatebuild)
375 bb.mkdirhier(plain) 375 bb.mkdirhier(plain)
376 bb.mkdirhier(pdir) 376 bb.mkdirhier(pdir)
377 oe.path.copytree(plain, pdir) 377 oe.path.copytree(plain, pdir)
378 378
379 bb.data.setVar('SSTATE_BUILDDIR', sstatebuild, d) 379 d.setVar('SSTATE_BUILDDIR', sstatebuild)
380 bb.data.setVar('SSTATE_PKG', sstatepkg, d) 380 d.setVar('SSTATE_PKG', sstatepkg)
381 sstate_hardcode_path(d) 381 sstate_hardcode_path(d)
382 bb.build.exec_func('sstate_create_package', d) 382 bb.build.exec_func('sstate_create_package', d)
383 383
@@ -389,7 +389,7 @@ def pstaging_fetch(sstatepkg, d):
389 import bb.fetch2 389 import bb.fetch2
390 390
391 # Only try and fetch if the user has configured a mirror 391 # Only try and fetch if the user has configured a mirror
392 mirrors = bb.data.getVar('SSTATE_MIRRORS', d, True) 392 mirrors = d.getVar('SSTATE_MIRRORS', True)
393 if not mirrors: 393 if not mirrors:
394 return 394 return
395 395
@@ -402,9 +402,9 @@ def pstaging_fetch(sstatepkg, d):
402 402
403 bb.mkdirhier(dldir) 403 bb.mkdirhier(dldir)
404 404
405 bb.data.setVar('DL_DIR', dldir, localdata) 405 localdata.setVar('DL_DIR', dldir)
406 bb.data.setVar('PREMIRRORS', mirrors, localdata) 406 localdata.setVar('PREMIRRORS', mirrors)
407 bb.data.setVar('SRC_URI', srcuri, localdata) 407 localdata.setVar('SRC_URI', srcuri)
408 408
409 # Try a fetch from the sstate mirror, if it fails just return and 409 # Try a fetch from the sstate mirror, if it fails just return and
410 # we will build the package 410 # we will build the package
@@ -493,15 +493,15 @@ def sstate_checkhashes(sq_fn, sq_task, sq_hash, sq_hashfn, d):
493 else: 493 else:
494 bb.debug(2, "SState: Looked for but didn't find file %s" % sstatefile) 494 bb.debug(2, "SState: Looked for but didn't find file %s" % sstatefile)
495 495
496 mirrors = bb.data.getVar("SSTATE_MIRRORS", d, True) 496 mirrors = d.getVar("SSTATE_MIRRORS", True)
497 if mirrors: 497 if mirrors:
498 # Copy the data object and override DL_DIR and SRC_URI 498 # Copy the data object and override DL_DIR and SRC_URI
499 localdata = bb.data.createCopy(d) 499 localdata = bb.data.createCopy(d)
500 bb.data.update_data(localdata) 500 bb.data.update_data(localdata)
501 501
502 dldir = bb.data.expand("${SSTATE_DIR}", localdata) 502 dldir = bb.data.expand("${SSTATE_DIR}", localdata)
503 bb.data.setVar('DL_DIR', dldir, localdata) 503 localdata.setVar('DL_DIR', dldir)
504 bb.data.setVar('PREMIRRORS', mirrors, localdata) 504 localdata.setVar('PREMIRRORS', mirrors)
505 505
506 bb.debug(2, "SState using premirror of: %s" % mirrors) 506 bb.debug(2, "SState using premirror of: %s" % mirrors)
507 507
@@ -513,7 +513,7 @@ def sstate_checkhashes(sq_fn, sq_task, sq_hash, sq_hashfn, d):
513 sstatefile = sstatefile.replace("${BB_TASKHASH}", sq_hash[task]) 513 sstatefile = sstatefile.replace("${BB_TASKHASH}", sq_hash[task])
514 514
515 srcuri = "file://" + os.path.basename(sstatefile) 515 srcuri = "file://" + os.path.basename(sstatefile)
516 bb.data.setVar('SRC_URI', srcuri, localdata) 516 localdata.setVar('SRC_URI', srcuri)
517 bb.debug(2, "SState: Attempting to fetch %s" % srcuri) 517 bb.debug(2, "SState: Attempting to fetch %s" % srcuri)
518 518
519 try: 519 try: