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