mirror of
https://git.yoctoproject.org/poky
synced 2026-05-30 12:29:55 +00:00
sanity.bbclass: Implement initial toolchain sanity checks
This introduces a sanity check for the toolchain, which verifies each tuning (including any multilibs), producing meaningful diagnostics for problems, and also provides some higher-level tuning features. The TUNEVALID and TUNECONFLICT/TUNECONFLICTS settings were not implemented. Listed one or two missing features in TUNEVALID, also (in a previous patch) fixed the references to features which didn't exist. This patch also provides a whitelisting mechanism (which is completely unused) to allow vendors providing prebuilt toolchain components to restrict tunings to those based on or compatible with a particular ABI. (From OE-Core rev: 2a91ff0ba0d587c516a5a972553280364853faa4) Signed-off-by: Peter Seebach <peter.seebach@windriver.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
This commit is contained in:
committed by
Richard Purdie
parent
87b6197d1d
commit
36784da878
@@ -11,6 +11,76 @@ def raise_sanity_error(msg):
|
|||||||
|
|
||||||
%s""" % msg)
|
%s""" % msg)
|
||||||
|
|
||||||
|
# Check a single tune for validity.
|
||||||
|
def check_toolchain_tune(data, tune, multilib):
|
||||||
|
tune_errors = []
|
||||||
|
if not tune:
|
||||||
|
return "No tuning found for %s multilib." % multilib
|
||||||
|
bb.debug(2, "Sanity-checking tuning '%s' (%s) features:" % (tune, multilib))
|
||||||
|
features = (data.getVar("TUNE_FEATURES_tune-%s" % tune, True) or "").split()
|
||||||
|
if not features:
|
||||||
|
return "Tuning '%s' has no defined features, and cannot be used." % tune
|
||||||
|
valid_tunes = data.getVarFlags('TUNEVALID') or {}
|
||||||
|
conflicts = data.getVarFlags('TUNECONFLICTS') or {}
|
||||||
|
# [doc] is the documentation for the variable, not a real feature
|
||||||
|
if 'doc' in valid_tunes:
|
||||||
|
del valid_tunes['doc']
|
||||||
|
if 'doc' in conflicts:
|
||||||
|
del conflicts['doc']
|
||||||
|
for feature in features:
|
||||||
|
if feature in conflicts:
|
||||||
|
for conflict in conflicts[feature].split():
|
||||||
|
if conflict in features:
|
||||||
|
tune_errors.append("Feature '%s' conflicts with '%s'." %
|
||||||
|
(feature, conflict))
|
||||||
|
if feature in valid_tunes:
|
||||||
|
bb.debug(2, " %s: %s" % (feature, valid_tunes[feature]))
|
||||||
|
else:
|
||||||
|
tune_errors.append("Feature '%s' is not defined." % feature)
|
||||||
|
whitelist = data.getVar("TUNEABI_WHITELIST", True) or ''
|
||||||
|
override = data.getVar("TUNEABI_OVERRIDE", True) or ''
|
||||||
|
if whitelist:
|
||||||
|
tuneabi = data.getVar("TUNEABI_tune-%s" % tune, True) or ''
|
||||||
|
if not tuneabi:
|
||||||
|
tuneabi = tune
|
||||||
|
if True not in [x in whitelist.split() for x in tuneabi.split()]:
|
||||||
|
tune_errors.append("Tuning '%s' (%s) cannot be used with any supported tuning/ABI." %
|
||||||
|
(tune, tuneabi))
|
||||||
|
if tune_errors:
|
||||||
|
return "Tuning '%s' has the following errors:\n" + '\n'.join(tune_errors)
|
||||||
|
|
||||||
|
def check_toolchain(data):
|
||||||
|
tune_error_set = []
|
||||||
|
deftune = data.getVar("DEFAULTTUNE", True)
|
||||||
|
tune_errors = check_toolchain_tune(data, deftune, 'default')
|
||||||
|
if tune_errors:
|
||||||
|
tune_error_set.append(tune_errors)
|
||||||
|
|
||||||
|
multilibs = (data.getVar("MULTILIB_VARIANTS", True) or "").split()
|
||||||
|
if multilibs:
|
||||||
|
seen_libs = []
|
||||||
|
seen_tunes = []
|
||||||
|
for lib in multilibs:
|
||||||
|
if lib in seen_libs:
|
||||||
|
tune_error_set.append("The multilib '%s' appears more than once." % lib)
|
||||||
|
else:
|
||||||
|
seen_libs.append(lib)
|
||||||
|
tune = data.getVar("DEFAULTTUNE_virtclass-multilib-%s" % lib, True)
|
||||||
|
if tune in seen_tunes:
|
||||||
|
tune_error_set.append("The tuning '%s' appears in more than one multilib." % tune)
|
||||||
|
else:
|
||||||
|
seen_libs.append(tune)
|
||||||
|
if tune == deftune:
|
||||||
|
tune_error_set.append("Multilib '%s' (%s) is also the default tuning." % (lib, deftune))
|
||||||
|
else:
|
||||||
|
tune_errors = check_toolchain_tune(data, tune, lib)
|
||||||
|
if tune_errors:
|
||||||
|
tune_error_set.append(tune_errors)
|
||||||
|
if tune_error_set:
|
||||||
|
return "Toolchain tunings invalid:\n" + '\n'.join(tune_error_set)
|
||||||
|
|
||||||
|
return ""
|
||||||
|
|
||||||
def check_conf_exists(fn, data):
|
def check_conf_exists(fn, data):
|
||||||
bbpath = []
|
bbpath = []
|
||||||
fn = data.expand(fn)
|
fn = data.expand(fn)
|
||||||
@@ -327,6 +397,9 @@ def check_sanity(e):
|
|||||||
messages = messages + pseudo_msg + '\n'
|
messages = messages + pseudo_msg + '\n'
|
||||||
|
|
||||||
check_supported_distro(e)
|
check_supported_distro(e)
|
||||||
|
toolchain_msg = check_toolchain(e.data)
|
||||||
|
if toolchain_msg != "":
|
||||||
|
messages = messages + toolchain_msg + '\n'
|
||||||
|
|
||||||
# Check if DISPLAY is set if IMAGETEST is set
|
# Check if DISPLAY is set if IMAGETEST is set
|
||||||
if not data.getVar( 'DISPLAY', e.data, True ) and data.getVar( 'IMAGETEST', e.data, True ) == 'qemu':
|
if not data.getVar( 'DISPLAY', e.data, True ) and data.getVar( 'IMAGETEST', e.data, True ) == 'qemu':
|
||||||
|
|||||||
@@ -36,6 +36,12 @@ for hardware floating point instructions."
|
|||||||
|
|
||||||
TUNEVALID[doc] = "Descriptions of valid tuning features, stored as flags."
|
TUNEVALID[doc] = "Descriptions of valid tuning features, stored as flags."
|
||||||
TUNECONFLICTS[doc] = "List of conflicting features for a given feature."
|
TUNECONFLICTS[doc] = "List of conflicting features for a given feature."
|
||||||
|
TUNEABI[doc] = "An underlying ABI used by a particular tuning in a given \
|
||||||
|
toolchain layer. This feature allows providers using prebuilt \
|
||||||
|
libraries to check compatibility of a tuning against their selection \
|
||||||
|
of libraries."
|
||||||
|
TUNEABI_WHITELIST[doc] = "A whitelist of permissible TUNEABI values; if unset, all are allowed."
|
||||||
|
TUNEABI_OVERRIDE[doc] = "If set, ignores TUNEABI_WHITELIST."
|
||||||
|
|
||||||
ASSUME_PROVIDED[doc] = "List of packages (recipes actually) which are assumed to be implicitly available.\
|
ASSUME_PROVIDED[doc] = "List of packages (recipes actually) which are assumed to be implicitly available.\
|
||||||
These packages won't be built by bitbake."
|
These packages won't be built by bitbake."
|
||||||
|
|||||||
Reference in New Issue
Block a user