diff options
-rw-r--r-- | meta/classes/base.bbclass | 68 | ||||
-rw-r--r-- | meta/classes/packaged-staging.bbclass | 53 |
2 files changed, 70 insertions, 51 deletions
diff --git a/meta/classes/base.bbclass b/meta/classes/base.bbclass index b536f92e48..086a6d05d0 100644 --- a/meta/classes/base.bbclass +++ b/meta/classes/base.bbclass | |||
@@ -976,15 +976,22 @@ sysroot_stage_dirs() { | |||
976 | sysroot_stage_dir $from${datadir} $to${STAGING_DATADIR} | 976 | sysroot_stage_dir $from${datadir} $to${STAGING_DATADIR} |
977 | } | 977 | } |
978 | 978 | ||
979 | |||
980 | sysroot_stage_all() { | 979 | sysroot_stage_all() { |
981 | sysroot_stage_dirs ${D} ${SYSROOT_DESTDIR} | 980 | sysroot_stage_dirs ${D} ${SYSROOT_DESTDIR} |
982 | } | 981 | } |
983 | 982 | ||
984 | 983 | def is_legacy_staging(d): | |
985 | base_do_stage () { | 984 | stagefunc = bb.data.getVar('do_stage', d, True) |
986 | : | 985 | legacy = True |
987 | } | 986 | if stagefunc is None: |
987 | legacy = False | ||
988 | elif stagefunc.strip() == "autotools_stage_all": | ||
989 | legacy = False | ||
990 | elif stagefunc.strip() == "do_stage_native" and bb.data.getVar('AUTOTOOLS_NATIVE_STAGE_INSTALL', d, 1) == "1": | ||
991 | legacy = False | ||
992 | if bb.data.getVar('PSTAGE_BROKEN_DESTDIR', d, 1) == "1": | ||
993 | legacy = True | ||
994 | return legacy | ||
988 | 995 | ||
989 | do_populate_staging[dirs] = "${STAGING_DIR_TARGET}/${bindir} ${STAGING_DIR_TARGET}/${libdir} \ | 996 | do_populate_staging[dirs] = "${STAGING_DIR_TARGET}/${bindir} ${STAGING_DIR_TARGET}/${libdir} \ |
990 | ${STAGING_DIR_TARGET}/${includedir} \ | 997 | ${STAGING_DIR_TARGET}/${includedir} \ |
@@ -996,19 +1003,60 @@ do_populate_staging[dirs] = "${STAGING_DIR_TARGET}/${bindir} ${STAGING_DIR_TARGE | |||
996 | # Could be compile but populate_staging and do_install shouldn't run at the same time | 1003 | # Could be compile but populate_staging and do_install shouldn't run at the same time |
997 | addtask populate_staging after do_install | 1004 | addtask populate_staging after do_install |
998 | 1005 | ||
1006 | PSTAGING_ACTIVE = "0" | ||
999 | SYSROOT_PREPROCESS_FUNCS ?= "" | 1007 | SYSROOT_PREPROCESS_FUNCS ?= "" |
1000 | SYSROOT_DESTDIR = "${WORKDIR}/sysroot-destdir/" | 1008 | SYSROOT_DESTDIR = "${WORKDIR}/sysroot-destdir/" |
1001 | SYSROOT_LOCK = "${STAGING_DIR}/staging.lock" | 1009 | SYSROOT_LOCK = "${STAGING_DIR}/staging.lock" |
1002 | 1010 | ||
1011 | python populate_staging_prehook () { | ||
1012 | return | ||
1013 | } | ||
1014 | |||
1015 | python populate_staging_posthook () { | ||
1016 | return | ||
1017 | } | ||
1018 | |||
1019 | packagedstageing_fastpath () { | ||
1020 | : | ||
1021 | } | ||
1022 | |||
1003 | python do_populate_staging () { | 1023 | python do_populate_staging () { |
1004 | # | 1024 | # |
1005 | # Only run do_stage if its not the empty default above | 1025 | # if do_stage exists, we're legacy. In that case run the do_stage, |
1026 | # modify the SYSROOT_DESTDIR variable and then run the staging preprocess | ||
1027 | # functions against staging directly. | ||
1006 | # | 1028 | # |
1007 | stagefunc = bb.data.getVar('do_stage', d, 1).strip() | 1029 | # Otherwise setup a destdir, copy the results from do_install |
1008 | if stagefunc != "base_do_stage": | 1030 | # and run the staging preprocess against that |
1031 | # | ||
1032 | pstageactive = (bb.data.getVar("PSTAGING_ACTIVE", d, True) == "1") | ||
1033 | lockfile = bb.data.getVar("SYSROOT_LOCK", d, True) | ||
1034 | stagefunc = bb.data.getVar('do_stage', d, True) | ||
1035 | legacy = is_legacy_staging(d) | ||
1036 | if legacy: | ||
1037 | bb.data.setVar("SYSROOT_DESTDIR", "", d) | ||
1038 | bb.note("Legacy staging mode for %s" % bb.data.getVar("FILE", d, True)) | ||
1039 | lock = bb.utils.lockfile(lockfile) | ||
1009 | bb.build.exec_func('do_stage', d) | 1040 | bb.build.exec_func('do_stage', d) |
1041 | bb.build.exec_func('populate_staging_prehook', d) | ||
1042 | for f in (bb.data.getVar('SYSROOT_PREPROCESS_FUNCS', d, True) or '').split(): | ||
1043 | bb.build.exec_func(f, d) | ||
1044 | bb.build.exec_func('populate_staging_posthook', d) | ||
1045 | bb.utils.unlockfile(lock) | ||
1046 | else: | ||
1047 | dest = bb.data.getVar('D', d, True) | ||
1048 | sysrootdest = bb.data.expand('${SYSROOT_DESTDIR}${STAGING_DIR_TARGET}', d) | ||
1049 | bb.mkdirhier(sysrootdest) | ||
1050 | |||
1051 | bb.build.exec_func("sysroot_stage_all", d) | ||
1052 | #os.system('cp -pPR %s/* %s/' % (dest, sysrootdest)) | ||
1010 | for f in (bb.data.getVar('SYSROOT_PREPROCESS_FUNCS', d, True) or '').split(): | 1053 | for f in (bb.data.getVar('SYSROOT_PREPROCESS_FUNCS', d, True) or '').split(): |
1011 | bb.build.exec_func(f, d) | 1054 | bb.build.exec_func(f, d) |
1055 | bb.build.exec_func("packagedstageing_fastpath", d) | ||
1056 | |||
1057 | lock = bb.utils.lockfile(lockfile) | ||
1058 | os.system('cp -pPR %s/* /' % (sysrootdest)) | ||
1059 | bb.utils.unlockfile(lock) | ||
1012 | } | 1060 | } |
1013 | 1061 | ||
1014 | addtask install after do_compile | 1062 | addtask install after do_compile |
@@ -1149,6 +1197,8 @@ def base_after_parse(d): | |||
1149 | 1197 | ||
1150 | python () { | 1198 | python () { |
1151 | base_after_parse(d) | 1199 | base_after_parse(d) |
1200 | if is_legacy_staging(d): | ||
1201 | bb.debug(1, "Legacy staging mode for %s" % bb.data.getVar("FILE", d, True)) | ||
1152 | } | 1202 | } |
1153 | 1203 | ||
1154 | def check_app_exists(app, d): | 1204 | def check_app_exists(app, d): |
@@ -1175,7 +1225,7 @@ inherit patch | |||
1175 | # Move to autotools.bbclass? | 1225 | # Move to autotools.bbclass? |
1176 | inherit siteinfo | 1226 | inherit siteinfo |
1177 | 1227 | ||
1178 | EXPORT_FUNCTIONS do_setscene do_clean do_fetch do_unpack do_configure do_compile do_install do_package do_populate_pkgs do_stage do_rebuild do_fetchall | 1228 | EXPORT_FUNCTIONS do_setscene do_clean do_fetch do_unpack do_configure do_compile do_install do_package do_populate_pkgs do_rebuild do_fetchall |
1179 | 1229 | ||
1180 | MIRRORS[func] = "0" | 1230 | MIRRORS[func] = "0" |
1181 | MIRRORS () { | 1231 | MIRRORS () { |
diff --git a/meta/classes/packaged-staging.bbclass b/meta/classes/packaged-staging.bbclass index 6df13876c2..44f657a2c0 100644 --- a/meta/classes/packaged-staging.bbclass +++ b/meta/classes/packaged-staging.bbclass | |||
@@ -63,29 +63,6 @@ python () { | |||
63 | bb.data.setVarFlag('do_setscene', 'recrdeptask', deps, d) | 63 | bb.data.setVarFlag('do_setscene', 'recrdeptask', deps, d) |
64 | 64 | ||
65 | bb.data.setVar("PSTAGING_ACTIVE", "1", d) | 65 | bb.data.setVar("PSTAGING_ACTIVE", "1", d) |
66 | |||
67 | # | ||
68 | # Here we notice if the staging function is one of our standard staging | ||
69 | # routines. If it is, we can remvoe the need to lock staging and take | ||
70 | # timestamps which gives a nice speedup | ||
71 | # | ||
72 | fastpath = False | ||
73 | stagefunc = bb.data.getVar('do_stage', d, 1).strip() | ||
74 | if stagefunc == "autotools_stage_all": | ||
75 | fastpath = True | ||
76 | elif stagefunc == "base_do_stage": | ||
77 | fastpath = True | ||
78 | elif stagefunc == "do_stage_native" and bb.data.getVar('AUTOTOOLS_NATIVE_STAGE_INSTALL', d, 1) == "1": | ||
79 | fastpath = True | ||
80 | if bb.data.getVar('PSTAGE_BROKEN_DESTDIR', d, 1) == "1": | ||
81 | fastpath = False | ||
82 | if fastpath: | ||
83 | #bb.note("Optimised for staging: " + bb.data.getVar('FILE', d, 1)) | ||
84 | bb.data.setVar("PSTAGING_NEEDSTAMP", "0", d) | ||
85 | bb.data.setVar("STAGE_TEMP_PREFIX", "${WORKDIR}/temp-staging-pstage", d) | ||
86 | else: | ||
87 | #bb.note("Can optimise staging better: " + bb.data.getVar('FILE', d, 1)) | ||
88 | bb.data.setVar("PSTAGING_NEEDSTAMP", "1", d) | ||
89 | else: | 66 | else: |
90 | bb.data.setVar("PSTAGING_ACTIVE", "0", d) | 67 | bb.data.setVar("PSTAGING_ACTIVE", "0", d) |
91 | } | 68 | } |
@@ -320,30 +297,22 @@ populate_staging_postamble () { | |||
320 | fi | 297 | fi |
321 | } | 298 | } |
322 | 299 | ||
323 | autotools_staging_pstage () { | 300 | packagedstageing_fastpath () { |
324 | mkdir -p ${PSTAGE_TMPDIR_STAGE}/staging/ | 301 | if [ "$PSTAGING_ACTIVE" = "1" ]; then |
325 | cp -fpPR ${WORKDIR}/temp-staging-pstage/${STAGING_DIR}/* ${PSTAGE_TMPDIR_STAGE}/staging/ || /bin/true | 302 | mkdir -p ${PSTAGE_TMPDIR_STAGE}/staging/ |
326 | cp -fpPR ${WORKDIR}/temp-staging-pstage/${STAGING_DIR}/* ${STAGING_DIR}/ || /bin/true | 303 | mkdir -p ${PSTAGE_TMPDIR_STAGE}/cross/ |
304 | cp -fpPR ${SYSROOT_DESTDIR}/${STAGING_DIR}/* ${PSTAGE_TMPDIR_STAGE}/staging/ || /bin/true | ||
305 | cp -fpPR ${SYSROOT_DESTDIR}/${CROSS_DIR}/* ${PSTAGE_TMPDIR_STAGE}/cross/ || /bin/true | ||
306 | fi | ||
327 | } | 307 | } |
328 | 308 | ||
329 | do_populate_staging[dirs] =+ "${DEPLOY_DIR_PSTAGE}" | 309 | do_populate_staging[dirs] =+ "${DEPLOY_DIR_PSTAGE}" |
330 | python do_populate_staging_prepend() { | 310 | python populate_staging_prehook() { |
331 | needstamp = bb.data.getVar("PSTAGING_NEEDSTAMP", d, 1) | 311 | bb.build.exec_func("populate_staging_preamble", d) |
332 | pstageactive = bb.data.getVar("PSTAGING_ACTIVE", d, True) | ||
333 | lock = bb.data.expand("${SYSROOT_LOCK}", d) | ||
334 | if needstamp == "1": | ||
335 | stamplock = bb.utils.lockfile(lock) | ||
336 | bb.build.exec_func("populate_staging_preamble", d) | ||
337 | } | 312 | } |
338 | 313 | ||
339 | python do_populate_staging_append() { | 314 | python populate_staging_posthook() { |
340 | if needstamp == "1": | 315 | bb.build.exec_func("populate_staging_postamble", d) |
341 | bb.build.exec_func("populate_staging_postamble", d) | ||
342 | bb.utils.unlockfile(stamplock) | ||
343 | elif pstageactive == "1": | ||
344 | stamplock = bb.utils.lockfile(lock) | ||
345 | bb.build.exec_func("autotools_staging_pstage", d) | ||
346 | bb.utils.unlockfile(stamplock) | ||
347 | } | 316 | } |
348 | 317 | ||
349 | 318 | ||