Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 1 | # We want native packages to be relocatable |
| 2 | inherit relocatable |
| 3 | |
| 4 | # Native packages are built indirectly via dependency, |
| 5 | # no need for them to be a direct target of 'world' |
| 6 | EXCLUDE_FROM_WORLD = "1" |
| 7 | |
| 8 | PACKAGES = "" |
| 9 | PACKAGES_class-native = "" |
| 10 | PACKAGES_DYNAMIC = "" |
| 11 | PACKAGES_DYNAMIC_class-native = "" |
| 12 | PACKAGE_ARCH = "${BUILD_ARCH}" |
| 13 | |
| 14 | # used by cmake class |
| 15 | OECMAKE_RPATH = "${libdir}" |
| 16 | OECMAKE_RPATH_class-native = "${libdir}" |
| 17 | |
| 18 | # When this class has packaging enabled, setting |
| 19 | # RPROVIDES becomes unnecessary. |
| 20 | RPROVIDES = "${PN}" |
| 21 | |
| 22 | TARGET_ARCH = "${BUILD_ARCH}" |
| 23 | TARGET_OS = "${BUILD_OS}" |
| 24 | TARGET_VENDOR = "${BUILD_VENDOR}" |
| 25 | TARGET_PREFIX = "${BUILD_PREFIX}" |
| 26 | TARGET_CC_ARCH = "${BUILD_CC_ARCH}" |
| 27 | TARGET_LD_ARCH = "${BUILD_LD_ARCH}" |
| 28 | TARGET_AS_ARCH = "${BUILD_AS_ARCH}" |
| 29 | TARGET_CPPFLAGS = "${BUILD_CPPFLAGS}" |
| 30 | TARGET_CFLAGS = "${BUILD_CFLAGS}" |
| 31 | TARGET_CXXFLAGS = "${BUILD_CXXFLAGS}" |
| 32 | TARGET_LDFLAGS = "${BUILD_LDFLAGS}" |
| 33 | TARGET_FPU = "" |
| 34 | |
| 35 | HOST_ARCH = "${BUILD_ARCH}" |
| 36 | HOST_OS = "${BUILD_OS}" |
| 37 | HOST_VENDOR = "${BUILD_VENDOR}" |
| 38 | HOST_PREFIX = "${BUILD_PREFIX}" |
| 39 | HOST_CC_ARCH = "${BUILD_CC_ARCH}" |
| 40 | HOST_LD_ARCH = "${BUILD_LD_ARCH}" |
| 41 | HOST_AS_ARCH = "${BUILD_AS_ARCH}" |
| 42 | |
| 43 | CPPFLAGS = "${BUILD_CPPFLAGS}" |
| 44 | CFLAGS = "${BUILD_CFLAGS}" |
Patrick Williams | d8c66bc | 2016-06-20 12:57:21 -0500 | [diff] [blame] | 45 | CXXFLAGS = "${BUILD_CXXFLAGS}" |
Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 46 | LDFLAGS = "${BUILD_LDFLAGS}" |
| 47 | LDFLAGS_build-darwin = "-L${STAGING_LIBDIR_NATIVE} " |
| 48 | |
| 49 | STAGING_BINDIR = "${STAGING_BINDIR_NATIVE}" |
| 50 | STAGING_BINDIR_CROSS = "${STAGING_BINDIR_NATIVE}" |
| 51 | |
| 52 | # native pkg doesn't need the TOOLCHAIN_OPTIONS. |
| 53 | TOOLCHAIN_OPTIONS = "" |
| 54 | |
Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 55 | # Don't build ptest natively |
| 56 | PTEST_ENABLED = "0" |
| 57 | |
| 58 | # Don't use site files for native builds |
| 59 | export CONFIG_SITE = "${COREBASE}/meta/site/native" |
| 60 | |
| 61 | # set the compiler as well. It could have been set to something else |
| 62 | export CC = "${BUILD_CC}" |
| 63 | export CXX = "${BUILD_CXX}" |
| 64 | export FC = "${BUILD_FC}" |
| 65 | export CPP = "${BUILD_CPP}" |
| 66 | export LD = "${BUILD_LD}" |
| 67 | export CCLD = "${BUILD_CCLD}" |
| 68 | export AR = "${BUILD_AR}" |
| 69 | export AS = "${BUILD_AS}" |
| 70 | export RANLIB = "${BUILD_RANLIB}" |
| 71 | export STRIP = "${BUILD_STRIP}" |
| 72 | export NM = "${BUILD_NM}" |
| 73 | |
| 74 | # Path prefixes |
| 75 | base_prefix = "${STAGING_DIR_NATIVE}" |
| 76 | prefix = "${STAGING_DIR_NATIVE}${prefix_native}" |
| 77 | exec_prefix = "${STAGING_DIR_NATIVE}${prefix_native}" |
| 78 | |
| 79 | bindir = "${STAGING_BINDIR_NATIVE}" |
| 80 | sbindir = "${STAGING_SBINDIR_NATIVE}" |
| 81 | libdir = "${STAGING_LIBDIR_NATIVE}" |
| 82 | includedir = "${STAGING_INCDIR_NATIVE}" |
| 83 | sysconfdir = "${STAGING_ETCDIR_NATIVE}" |
| 84 | datadir = "${STAGING_DATADIR_NATIVE}" |
| 85 | |
| 86 | baselib = "lib" |
| 87 | |
Patrick Williams | c0f7c04 | 2017-02-23 20:41:17 -0600 | [diff] [blame] | 88 | export lt_cv_sys_lib_dlsearch_path_spec = "${libdir} ${base_libdir} /lib /lib64 /usr/lib /usr/lib64" |
Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 89 | |
| 90 | NATIVE_PACKAGE_PATH_SUFFIX ?= "" |
| 91 | bindir .= "${NATIVE_PACKAGE_PATH_SUFFIX}" |
| 92 | libdir .= "${NATIVE_PACKAGE_PATH_SUFFIX}" |
| 93 | libexecdir .= "${NATIVE_PACKAGE_PATH_SUFFIX}" |
| 94 | |
| 95 | do_populate_sysroot[sstate-inputdirs] = "${SYSROOT_DESTDIR}/${STAGING_DIR_NATIVE}/" |
Brad Bishop | 6e60e8b | 2018-02-01 10:27:11 -0500 | [diff] [blame] | 96 | do_populate_sysroot[sstate-outputdirs] = "${COMPONENTS_DIR}/${PACKAGE_ARCH}/${PN}" |
Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 97 | |
| 98 | # Since we actually install these into situ there is no staging prefix |
| 99 | STAGING_DIR_HOST = "" |
| 100 | STAGING_DIR_TARGET = "" |
| 101 | PKG_CONFIG_DIR = "${libdir}/pkgconfig" |
| 102 | |
| 103 | EXTRA_NATIVE_PKGCONFIG_PATH ?= "" |
| 104 | PKG_CONFIG_PATH .= "${EXTRA_NATIVE_PKGCONFIG_PATH}" |
| 105 | PKG_CONFIG_SYSROOT_DIR = "" |
Patrick Williams | d8c66bc | 2016-06-20 12:57:21 -0500 | [diff] [blame] | 106 | PKG_CONFIG_SYSTEM_LIBRARY_PATH[unexport] = "1" |
| 107 | PKG_CONFIG_SYSTEM_INCLUDE_PATH[unexport] = "1" |
Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 108 | |
Brad Bishop | d7bf8c1 | 2018-02-25 22:55:05 -0500 | [diff] [blame] | 109 | # we dont want libc-*libc to kick in for native recipes |
Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 110 | LIBCOVERRIDE = "" |
| 111 | CLASSOVERRIDE = "class-native" |
| 112 | MACHINEOVERRIDES = "" |
Brad Bishop | 6e60e8b | 2018-02-01 10:27:11 -0500 | [diff] [blame] | 113 | MACHINE_FEATURES = "" |
Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 114 | |
| 115 | PATH_prepend = "${COREBASE}/scripts/native-intercept:" |
| 116 | |
Brad Bishop | 6e60e8b | 2018-02-01 10:27:11 -0500 | [diff] [blame] | 117 | # This class encodes staging paths into its scripts data so can only be |
| 118 | # reused if we manipulate the paths. |
| 119 | SSTATE_SCAN_CMD ?= "${SSTATE_SCAN_CMD_NATIVE}" |
| 120 | |
Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 121 | python native_virtclass_handler () { |
Brad Bishop | 6e60e8b | 2018-02-01 10:27:11 -0500 | [diff] [blame] | 122 | pn = e.data.getVar("PN") |
| 123 | if not pn.endswith("-native"): |
Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 124 | return |
| 125 | |
Brad Bishop | 6e60e8b | 2018-02-01 10:27:11 -0500 | [diff] [blame] | 126 | # Set features here to prevent appends and distro features backfill |
| 127 | # from modifying native distro features |
| 128 | features = set(d.getVar("DISTRO_FEATURES_NATIVE").split()) |
| 129 | filtered = set(bb.utils.filter("DISTRO_FEATURES", d.getVar("DISTRO_FEATURES_FILTER_NATIVE"), d).split()) |
| 130 | d.setVar("DISTRO_FEATURES", " ".join(sorted(features | filtered))) |
| 131 | |
| 132 | classextend = e.data.getVar('BBCLASSEXTEND') or "" |
| 133 | if "native" not in classextend: |
Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 134 | return |
| 135 | |
| 136 | def map_dependencies(varname, d, suffix = ""): |
| 137 | if suffix: |
| 138 | varname = varname + "_" + suffix |
Brad Bishop | 6e60e8b | 2018-02-01 10:27:11 -0500 | [diff] [blame] | 139 | deps = d.getVar(varname) |
Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 140 | if not deps: |
| 141 | return |
| 142 | deps = bb.utils.explode_deps(deps) |
| 143 | newdeps = [] |
| 144 | for dep in deps: |
| 145 | if dep == pn: |
| 146 | continue |
| 147 | elif "-cross-" in dep: |
| 148 | newdeps.append(dep.replace("-cross", "-native")) |
| 149 | elif not dep.endswith("-native"): |
| 150 | newdeps.append(dep + "-native") |
| 151 | else: |
| 152 | newdeps.append(dep) |
| 153 | d.setVar(varname, " ".join(newdeps)) |
| 154 | |
| 155 | e.data.setVar("OVERRIDES", e.data.getVar("OVERRIDES", False) + ":virtclass-native") |
| 156 | |
| 157 | map_dependencies("DEPENDS", e.data) |
Brad Bishop | 6e60e8b | 2018-02-01 10:27:11 -0500 | [diff] [blame] | 158 | for pkg in [e.data.getVar("PN"), "", "${PN}"]: |
Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 159 | map_dependencies("RDEPENDS", e.data, pkg) |
| 160 | map_dependencies("RRECOMMENDS", e.data, pkg) |
| 161 | map_dependencies("RSUGGESTS", e.data, pkg) |
| 162 | map_dependencies("RPROVIDES", e.data, pkg) |
| 163 | map_dependencies("RREPLACES", e.data, pkg) |
| 164 | |
Brad Bishop | 6e60e8b | 2018-02-01 10:27:11 -0500 | [diff] [blame] | 165 | provides = e.data.getVar("PROVIDES") |
Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 166 | nprovides = [] |
| 167 | for prov in provides.split(): |
| 168 | if prov.find(pn) != -1: |
| 169 | nprovides.append(prov) |
| 170 | elif not prov.endswith("-native"): |
| 171 | nprovides.append(prov.replace(prov, prov + "-native")) |
| 172 | else: |
| 173 | nprovides.append(prov) |
| 174 | e.data.setVar("PROVIDES", ' '.join(nprovides)) |
| 175 | |
| 176 | |
| 177 | } |
| 178 | |
| 179 | addhandler native_virtclass_handler |
| 180 | native_virtclass_handler[eventmask] = "bb.event.RecipePreFinalise" |
| 181 | |
Brad Bishop | 6e60e8b | 2018-02-01 10:27:11 -0500 | [diff] [blame] | 182 | python do_addto_recipe_sysroot () { |
| 183 | bb.build.exec_func("extend_recipe_sysroot", d) |
| 184 | } |
| 185 | addtask addto_recipe_sysroot after do_populate_sysroot |
| 186 | |
Patrick Williams | d8c66bc | 2016-06-20 12:57:21 -0500 | [diff] [blame] | 187 | inherit nopackages |
Patrick Williams | c124f4f | 2015-09-15 14:41:29 -0500 | [diff] [blame] | 188 | |
| 189 | do_packagedata[stamp-extra-info] = "" |
| 190 | do_populate_sysroot[stamp-extra-info] = "" |
| 191 | |
| 192 | USE_NLS = "no" |