mirror of
https://git.yoctoproject.org/poky
synced 2026-01-29 21:08:42 +01:00
multilib: Add missing files from broken patch merge
Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
89
meta/classes/multilib.bbclass
Normal file
89
meta/classes/multilib.bbclass
Normal file
@@ -0,0 +1,89 @@
|
||||
python multilib_virtclass_handler () {
|
||||
if not isinstance(e, bb.event.RecipePreFinalise):
|
||||
return
|
||||
|
||||
cls = e.data.getVar("BBEXTENDCURR", True)
|
||||
variant = e.data.getVar("BBEXTENDVARIANT", True)
|
||||
if cls != "multilib" or not variant:
|
||||
return
|
||||
|
||||
override = ":virtclass-multilib-" + variant
|
||||
|
||||
e.data.setVar("MLPREFIX", variant + "-")
|
||||
e.data.setVar("PN", variant + "-" + e.data.getVar("PN", False))
|
||||
e.data.setVar("SHLIBSDIR_virtclass-multilib-" + variant ,e.data.getVar("SHLIBSDIR", False) + "/" + variant)
|
||||
e.data.setVar("TARGET_VENDOR_virtclass-multilib-" + variant, e.data.getVar("TARGET_VENDOR", False) + "ml" + variant)
|
||||
e.data.setVar("OVERRIDES", e.data.getVar("OVERRIDES", False) + override)
|
||||
}
|
||||
|
||||
addhandler multilib_virtclass_handler
|
||||
|
||||
STAGINGCC_prepend = "${BBEXTENDVARIANT}-"
|
||||
|
||||
python __anonymous () {
|
||||
variant = d.getVar("BBEXTENDVARIANT", True)
|
||||
|
||||
def extend_name(name):
|
||||
if name.startswith("virtual/"):
|
||||
subs = name.split("/", 1)[1]
|
||||
if not subs.startswith(variant):
|
||||
return "virtual/" + variant + "-" + subs
|
||||
return name
|
||||
if not name.startswith(variant):
|
||||
return variant + "-" + name
|
||||
return name
|
||||
|
||||
def map_dependencies(varname, d, suffix = ""):
|
||||
if suffix:
|
||||
varname = varname + "_" + suffix
|
||||
deps = d.getVar(varname, True)
|
||||
if not deps:
|
||||
return
|
||||
deps = bb.utils.explode_deps(deps)
|
||||
newdeps = []
|
||||
for dep in deps:
|
||||
if dep.endswith(("-native", "-native-runtime")):
|
||||
newdeps.append(dep)
|
||||
else:
|
||||
newdeps.append(extend_name(dep))
|
||||
d.setVar(varname, " ".join(newdeps))
|
||||
|
||||
def map_variable(varname, d):
|
||||
var = d.getVar(varname, True)
|
||||
if not var:
|
||||
return
|
||||
var = var.split()
|
||||
newvar = []
|
||||
for v in var:
|
||||
newvar.append(extend_name(v))
|
||||
d.setVar(varname, " ".join(newvar))
|
||||
|
||||
pkgs = []
|
||||
pkgrename = {}
|
||||
for pkg in (d.getVar("PACKAGES", True) or "").split():
|
||||
if pkg.startswith(variant):
|
||||
pkgs.append(pkg)
|
||||
continue
|
||||
pkgrename[pkg] = extend_name(pkg)
|
||||
pkgs.append(pkgrename[pkg])
|
||||
|
||||
if pkgrename:
|
||||
d.setVar("PACKAGES", " ".join(pkgs))
|
||||
for pkg in pkgrename:
|
||||
for subs in ["FILES", "RDEPENDS", "RRECOMMENDS", "SUMMARY", "DESCRIPTION", "RSUGGESTS", "RPROVIDES", "RCONFLICTS", "PKG", "ALLOW_EMPTY"]:
|
||||
d.renameVar("%s_%s" % (subs, pkg), "%s_%s" % (subs, pkgrename[pkg]))
|
||||
|
||||
map_dependencies("DEPENDS", d)
|
||||
for pkg in (d.getVar("PACKAGES", True).split() + [""]):
|
||||
map_dependencies("RDEPENDS", d, pkg)
|
||||
map_dependencies("RRECOMMENDS", d, pkg)
|
||||
map_dependencies("RSUGGESTS", d, pkg)
|
||||
map_dependencies("RPROVIDES", d, pkg)
|
||||
map_dependencies("RREPLACES", d, pkg)
|
||||
map_dependencies("RCONFLICTS", d, pkg)
|
||||
map_dependencies("PKG", d, pkg)
|
||||
|
||||
map_variable("PROVIDES", d)
|
||||
map_variable("PACKAGES_DYNAMIC", d)
|
||||
map_variable("PACKAGE_INSTALL", d)
|
||||
}
|
||||
24
meta/conf/multilib.conf
Normal file
24
meta/conf/multilib.conf
Normal file
@@ -0,0 +1,24 @@
|
||||
|
||||
baselib = "${@d.getVar('BASE_LIB_tune-' + (d.getVar('DEFAULTTUNE', True) or 'INVALID'), True) or 'lib'}"
|
||||
|
||||
MULTILIBS ??= "multilib:lib32"
|
||||
BBCLASSEXTEND_append_pn-linux-libc-headers = " ${MULTILIBS}"
|
||||
BBCLASSEXTEND_append_pn-eglibc-initial = " ${MULTILIBS}"
|
||||
BBCLASSEXTEND_append_pn-eglibc = " ${MULTILIBS}"
|
||||
BBCLASSEXTEND_append_pn-libgcc = " ${MULTILIBS}"
|
||||
BBCLASSEXTEND_append_pn-gcc-runtime = " ${MULTILIBS}"
|
||||
BBCLASSEXTEND_append_pn-libtool-cross = " ${MULTILIBS}"
|
||||
BBCLASSEXTEND_append_pn-zlib = " ${MULTILIBS}"
|
||||
BBCLASSEXTEND_append_pn-binutils-cross = " ${MULTILIBS}"
|
||||
BBCLASSEXTEND_append_pn-gcc-cross-initial = " ${MULTILIBS}"
|
||||
BBCLASSEXTEND_append_pn-gcc-cross-intermediate = " ${MULTILIBS}"
|
||||
BBCLASSEXTEND_append_pn-gcc-cross = " ${MULTILIBS}"
|
||||
BBCLASSEXTEND_append_pn-busybox = " ${MULTILIBS}"
|
||||
BBCLASSEXTEND_append_pn-update-rc.d = " ${MULTILIBS}"
|
||||
BBCLASSEXTEND_append_pn-util-linux = " ${MULTILIBS}"
|
||||
BBCLASSEXTEND_append_pn-gettext = " ${MULTILIBS}"
|
||||
BBCLASSEXTEND_append_pn-bash = " ${MULTILIBS}"
|
||||
BBCLASSEXTEND_append_pn-ncurses = " ${MULTILIBS}"
|
||||
BBCLASSEXTEND_append_pn-expat = " ${MULTILIBS}"
|
||||
BBCLASSEXTEND_append_pn-eglibc-locale = " ${MULTILIBS}"
|
||||
|
||||
Reference in New Issue
Block a user