native.bbclass 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248
  1. #
  2. # Copyright OpenEmbedded Contributors
  3. #
  4. # SPDX-License-Identifier: MIT
  5. #
  6. # We want native packages to be relocatable
  7. inherit relocatable
  8. # Native packages are built indirectly via dependency,
  9. # no need for them to be a direct target of 'world'
  10. EXCLUDE_FROM_WORLD = "1"
  11. PACKAGE_ARCH = "${BUILD_ARCH}"
  12. # used by cmake class
  13. OECMAKE_RPATH = "${libdir}"
  14. OECMAKE_RPATH:class-native = "${libdir}"
  15. TARGET_ARCH = "${BUILD_ARCH}"
  16. TARGET_OS = "${BUILD_OS}"
  17. TARGET_VENDOR = "${BUILD_VENDOR}"
  18. TARGET_PREFIX = "${BUILD_PREFIX}"
  19. TARGET_CC_ARCH = "${BUILD_CC_ARCH}"
  20. TARGET_LD_ARCH = "${BUILD_LD_ARCH}"
  21. TARGET_AS_ARCH = "${BUILD_AS_ARCH}"
  22. TARGET_CPPFLAGS = "${BUILD_CPPFLAGS}"
  23. TARGET_CFLAGS = "${BUILD_CFLAGS}"
  24. TARGET_CXXFLAGS = "${BUILD_CXXFLAGS}"
  25. TARGET_LDFLAGS = "${BUILD_LDFLAGS}"
  26. TARGET_FPU = ""
  27. TUNE_FEATURES = ""
  28. ABIEXTENSION = ""
  29. HOST_ARCH = "${BUILD_ARCH}"
  30. HOST_OS = "${BUILD_OS}"
  31. HOST_VENDOR = "${BUILD_VENDOR}"
  32. HOST_PREFIX = "${BUILD_PREFIX}"
  33. HOST_CC_ARCH = "${BUILD_CC_ARCH}"
  34. HOST_LD_ARCH = "${BUILD_LD_ARCH}"
  35. HOST_AS_ARCH = "${BUILD_AS_ARCH}"
  36. STAGING_BINDIR = "${STAGING_BINDIR_NATIVE}"
  37. STAGING_BINDIR_CROSS = "${STAGING_BINDIR_NATIVE}"
  38. # native pkg doesn't need the TOOLCHAIN_OPTIONS.
  39. TOOLCHAIN_OPTIONS = ""
  40. # Don't build ptest natively
  41. PTEST_ENABLED = "0"
  42. # Don't use site files for native builds
  43. export CONFIG_SITE = "${COREBASE}/meta/site/native"
  44. # set the compiler as well. It could have been set to something else
  45. CC = "${BUILD_CC}"
  46. CXX = "${BUILD_CXX}"
  47. FC = "${BUILD_FC}"
  48. CPP = "${BUILD_CPP}"
  49. LD = "${BUILD_LD}"
  50. CCLD = "${BUILD_CCLD}"
  51. AR = "${BUILD_AR}"
  52. AS = "${BUILD_AS}"
  53. RANLIB = "${BUILD_RANLIB}"
  54. STRIP = "${BUILD_STRIP}"
  55. NM = "${BUILD_NM}"
  56. OBJCOPY = "${BUILD_OBJCOPY}"
  57. OBJDUMP = "${BUILD_OBJDUMP}"
  58. READELF = "${BUILD_READELF}"
  59. # Path prefixes
  60. base_prefix = "${STAGING_DIR_NATIVE}"
  61. prefix = "${STAGING_DIR_NATIVE}${prefix_native}"
  62. exec_prefix = "${STAGING_DIR_NATIVE}${prefix_native}"
  63. bindir = "${STAGING_BINDIR_NATIVE}"
  64. sbindir = "${STAGING_SBINDIR_NATIVE}"
  65. base_libdir = "${STAGING_BASE_LIBDIR_NATIVE}"
  66. libdir = "${STAGING_LIBDIR_NATIVE}"
  67. includedir = "${STAGING_INCDIR_NATIVE}"
  68. sysconfdir = "${STAGING_ETCDIR_NATIVE}"
  69. datadir = "${STAGING_DATADIR_NATIVE}"
  70. baselib = "lib"
  71. export lt_cv_sys_lib_dlsearch_path_spec = "${libdir} ${base_libdir} /lib /lib64 /usr/lib /usr/lib64"
  72. NATIVE_PACKAGE_PATH_SUFFIX ?= ""
  73. bindir .= "${NATIVE_PACKAGE_PATH_SUFFIX}"
  74. sbindir .= "${NATIVE_PACKAGE_PATH_SUFFIX}"
  75. base_libdir .= "${NATIVE_PACKAGE_PATH_SUFFIX}"
  76. libdir .= "${NATIVE_PACKAGE_PATH_SUFFIX}"
  77. libexecdir .= "${NATIVE_PACKAGE_PATH_SUFFIX}"
  78. do_populate_sysroot[sstate-inputdirs] = "${SYSROOT_DESTDIR}/${STAGING_DIR_NATIVE}/"
  79. do_populate_sysroot[sstate-outputdirs] = "${COMPONENTS_DIR}/${PACKAGE_ARCH}/${PN}"
  80. # Since we actually install these into situ there is no staging prefix
  81. STAGING_DIR_HOST = ""
  82. STAGING_DIR_TARGET = ""
  83. PKG_CONFIG_DIR = "${libdir}/pkgconfig"
  84. EXTRA_NATIVE_PKGCONFIG_PATH ?= ""
  85. PKG_CONFIG_PATH .= "${EXTRA_NATIVE_PKGCONFIG_PATH}"
  86. PKG_CONFIG_SYSROOT_DIR = ""
  87. PKG_CONFIG_SYSTEM_LIBRARY_PATH[unexport] = "1"
  88. PKG_CONFIG_SYSTEM_INCLUDE_PATH[unexport] = "1"
  89. # we dont want libc-*libc to kick in for native recipes
  90. LIBCOVERRIDE = ""
  91. CLASSOVERRIDE = "class-native"
  92. MACHINEOVERRIDES = ""
  93. MACHINE_FEATURES = ""
  94. PATH:prepend = "${COREBASE}/scripts/native-intercept:"
  95. # This class encodes staging paths into its scripts data so can only be
  96. # reused if we manipulate the paths.
  97. SSTATE_SCAN_CMD ?= "${SSTATE_SCAN_CMD_NATIVE}"
  98. # No strip sysroot when DEBUG_BUILD is enabled
  99. INHIBIT_SYSROOT_STRIP ?= "${@oe.utils.vartrue('DEBUG_BUILD', '1', '', d)}"
  100. python native_virtclass_handler () {
  101. import re
  102. pn = e.data.getVar("PN")
  103. if not pn.endswith("-native"):
  104. return
  105. bpn = e.data.getVar("BPN")
  106. # Set features here to prevent appends and distro features backfill
  107. # from modifying native distro features
  108. features = set(d.getVar("DISTRO_FEATURES_NATIVE").split())
  109. filtered = set(bb.utils.filter("DISTRO_FEATURES", d.getVar("DISTRO_FEATURES_FILTER_NATIVE"), d).split())
  110. d.setVar("DISTRO_FEATURES", " ".join(sorted(features | filtered)))
  111. classextend = e.data.getVar('BBCLASSEXTEND') or ""
  112. if "native" not in classextend:
  113. return
  114. def map_dependencies(varname, d, suffix = "", selfref=True, regex=False):
  115. if suffix:
  116. varname = varname + ":" + suffix
  117. deps = d.getVar(varname)
  118. if not deps:
  119. return
  120. deps = bb.utils.explode_deps(deps)
  121. newdeps = []
  122. for dep in deps:
  123. if regex and dep.startswith("^") and dep.endswith("$"):
  124. newdeps.append(dep[:-1].replace(pn, bpn) + "-native$")
  125. elif dep == pn:
  126. if not selfref:
  127. continue
  128. newdeps.append(dep)
  129. elif "-cross-" in dep:
  130. newdeps.append(dep.replace("-cross", "-native"))
  131. elif not dep.endswith("-native"):
  132. # Replace ${PN} with ${BPN} in the dependency to make sure
  133. # dependencies on, e.g., ${PN}-foo become ${BPN}-foo-native
  134. # rather than ${BPN}-native-foo-native.
  135. newdeps.append(dep.replace(pn, bpn) + "-native")
  136. else:
  137. newdeps.append(dep)
  138. output_varname = varname
  139. # Handle ${PN}-xxx -> ${BPN}-xxx-native
  140. if suffix != "${PN}" and "${PN}" in suffix:
  141. output_varname = varname.replace("${PN}", "${BPN}") + "-native"
  142. d.renameVar(varname, output_varname)
  143. d.setVar(output_varname, " ".join(newdeps))
  144. map_dependencies("DEPENDS", e.data, selfref=False)
  145. # We need to handle things like ${@bb.utils.contains('PTEST_ENABLED', '1', '${PN}-ptest', '', d)}
  146. # and not pass ${PN}-test since in the native case it would be ignored. This does mean we ignore
  147. # anonymous python derived PACKAGES entries.
  148. for pkg in re.split(r"\${@(?:{.*?}|.)+?}|\s", d.getVar("PACKAGES", False)):
  149. if not pkg:
  150. continue
  151. map_dependencies("RDEPENDS", e.data, pkg)
  152. map_dependencies("RRECOMMENDS", e.data, pkg)
  153. map_dependencies("RSUGGESTS", e.data, pkg)
  154. map_dependencies("RPROVIDES", e.data, pkg)
  155. map_dependencies("RREPLACES", e.data, pkg)
  156. map_dependencies("PACKAGES", e.data)
  157. map_dependencies("PACKAGES_DYNAMIC", e.data, regex=True)
  158. provides = e.data.getVar("PROVIDES")
  159. nprovides = []
  160. for prov in provides.split():
  161. if prov.find(pn) != -1:
  162. nprovides.append(prov)
  163. elif not prov.endswith("-native"):
  164. nprovides.append(prov + "-native")
  165. else:
  166. nprovides.append(prov)
  167. e.data.setVar("PROVIDES", ' '.join(nprovides))
  168. }
  169. addhandler native_virtclass_handler
  170. native_virtclass_handler[eventmask] = "bb.event.RecipePreFinalise"
  171. python do_addto_recipe_sysroot () {
  172. bb.build.exec_func("extend_recipe_sysroot", d)
  173. }
  174. addtask addto_recipe_sysroot after do_populate_sysroot
  175. do_addto_recipe_sysroot[deptask] = "do_populate_sysroot"
  176. inherit nopackages
  177. do_packagedata[stamp-extra-info] = ""
  178. USE_NLS = "no"
  179. RECIPERDEPTASK = "do_populate_sysroot"
  180. do_populate_sysroot[rdeptask] = "${RECIPERDEPTASK}"
  181. #
  182. # Native task outputs are directly run on the target (host) system after being
  183. # built. Even if the output of this recipe doesn't change, a change in one of
  184. # its dependencies may cause a change in the output it generates (e.g. rpm
  185. # output depends on the output of its dependent zstd library).
  186. #
  187. # This can cause poor interactions with hash equivalence, since this recipes
  188. # output-changing dependency is "hidden" and downstream task only see that this
  189. # recipe has the same outhash and therefore is equivalent. This can result in
  190. # different output in different cases.
  191. #
  192. # To resolve this, unhide the output-changing dependency by adding its unihash
  193. # to this tasks outhash calculation. Unfortunately, don't know specifically
  194. # know which dependencies are output-changing, so we have to add all of them.
  195. #
  196. python native_add_do_populate_sysroot_deps () {
  197. current_task = "do_" + d.getVar("BB_CURRENTTASK")
  198. if current_task != "do_populate_sysroot":
  199. return
  200. taskdepdata = d.getVar("BB_TASKDEPDATA", False)
  201. pn = d.getVar("PN")
  202. deps = {
  203. dep[0]:dep[6] for dep in taskdepdata.values() if
  204. dep[1] == current_task and dep[0] != pn
  205. }
  206. d.setVar("HASHEQUIV_EXTRA_SIGDATA", "\n".join("%s: %s" % (k, deps[k]) for k in sorted(deps.keys())))
  207. }
  208. SSTATECREATEFUNCS += "native_add_do_populate_sysroot_deps"