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