summaryrefslogtreecommitdiffstats
path: root/meta/recipes-devtools/meson/nativesdk-meson_0.46.1.bb
diff options
context:
space:
mode:
authorMartin Kelly <mkelly@xevo.com>2018-06-04 16:06:02 -0700
committerRichard Purdie <richard.purdie@linuxfoundation.org>2018-06-07 08:52:55 +0100
commite14171cc594e8c3dfee8119847c26e10b15bacf4 (patch)
treef29803be476eac841f621f140a63d3de5b5b8697 /meta/recipes-devtools/meson/nativesdk-meson_0.46.1.bb
parent2a73be1b0e5adecd29e3dfb3f987d6bc761bc8f3 (diff)
downloadpoky-e14171cc594e8c3dfee8119847c26e10b15bacf4.tar.gz
meson: enable nativesdk
Currently, we can't build meson into SDKs because we don't autogenerate the required meson.cross file. Enable this by using the post-relocate hooks and generating a meson.cross file based on the SDK environment passed into the post-relocate hook. (From OE-Core rev: aabb846b165fec218024a7a57f3c9fdaa2514179) Signed-off-by: Martin Kelly <mkelly@xevo.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
Diffstat (limited to 'meta/recipes-devtools/meson/nativesdk-meson_0.46.1.bb')
-rw-r--r--meta/recipes-devtools/meson/nativesdk-meson_0.46.1.bb74
1 files changed, 74 insertions, 0 deletions
diff --git a/meta/recipes-devtools/meson/nativesdk-meson_0.46.1.bb b/meta/recipes-devtools/meson/nativesdk-meson_0.46.1.bb
new file mode 100644
index 0000000000..53503aa998
--- /dev/null
+++ b/meta/recipes-devtools/meson/nativesdk-meson_0.46.1.bb
@@ -0,0 +1,74 @@
1include meson.inc
2
3inherit nativesdk
4
5SRC_URI += "file://meson-setup.py \
6 file://meson-wrapper"
7
8def meson_array(var, d):
9 return "', '".join(d.getVar(var).split()).join(("'", "'"))
10
11# both are required but not used by meson
12MESON_SDK_ENDIAN = "bogus-endian"
13MESON_TARGET_ENDIAN = "bogus-endian"
14
15MESON_TOOLCHAIN_ARGS = "${BUILDSDK_CC_ARCH}${TOOLCHAIN_OPTIONS}"
16MESON_C_ARGS = "${MESON_TOOLCHAIN_ARGS} ${BUILDSDK_CFLAGS}"
17MESON_CPP_ARGS = "${MESON_TOOLCHAIN_ARGS} ${BUILDSDK_CXXFLAGS}"
18MESON_LINK_ARGS = "${MESON_TOOLCHAIN_ARGS} ${BUILDSDK_LDFLAGS}"
19
20# This logic is similar but not identical to that in meson.bbclass, since it's
21# generating for an SDK rather than a cross-compile. Important differences are:
22# - We can't set vars like CC, CXX, etc. yet because they will be filled in with
23# real paths by meson-setup.sh when the SDK is extracted.
24# - Some overrides aren't needed, since the SDK injects paths that take care of
25# them.
26addtask write_config before do_install
27do_write_config[vardeps] += "MESON_C_ARGS MESON_CPP_ARGS MESON_LINK_ARGS CC CXX LD AR NM STRIP READELF"
28do_write_config() {
29 # This needs to be Py to split the args into single-element lists
30 cat >${WORKDIR}/meson.cross <<EOF
31[binaries]
32c = @@CC@@
33cpp = @@CXX@@
34ar = @@AR@@
35nm = @@NM@@
36ld = @@LD@@
37strip = @@STRIP@@
38pkgconfig = 'pkg-config'
39
40[properties]
41needs_exe_wrapper = true
42c_args = @@CFLAGS@@
43c_link_args = @@LDFLAGS@@
44cpp_args = @@CPPFLAGS@@
45cpp_link_args = @@LDFLAGS@@
46
47[host_machine]
48system = '${SDK_OS}'
49cpu_family = '${SDK_ARCH}'
50cpu = '${SDK_ARCH}'
51endian = '${MESON_SDK_ENDIAN}'
52EOF
53}
54
55do_install_append() {
56 install -d ${D}${datadir}/meson
57 install -m 0644 ${WORKDIR}/meson.cross ${D}${datadir}/meson/
58
59 install -d ${D}${SDKPATHNATIVE}/post-relocate-setup.d
60 install -m 0755 ${WORKDIR}/meson-setup.py ${D}${SDKPATHNATIVE}/post-relocate-setup.d/
61
62 # We need to wrap the real meson with a thin env setup wrapper.
63 mv ${D}${bindir}/meson ${D}${bindir}/meson.real
64 install -m 0755 ${WORKDIR}/meson-wrapper ${D}${bindir}/meson
65}
66
67RDEPENDS_${PN} += "\
68 nativesdk-ninja \
69 nativesdk-python3-core \
70 nativesdk-python3-misc \
71 nativesdk-python3-modules \
72 "
73
74FILES_${PN} += "${datadir}/meson ${SDKPATHNATIVE}"