1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

build system: Improve failure mode for FEAUTRES_REQUIRED_ANY

Failing to provide any of the required features can provide a message
such as:

    There are unsatisfied feature requirements: periph_uart|periph_lpuart

This can be confusing and may hide the actual. E.g. above message
was generated when using SPI on the `msb-430` and `stdio_uart`. However,
the MSB-430 board *does* provide `periph_uart`, so this looks like a bug
in the feature resolution. This changes the failure mode of
`FEATURES_REQUIRED_ANY` to just pick the first of the alternatives
given if none of the alternative is usable, which gives in the example
the following message instead:

    The following features may conflict: periph_spi periph_uart
    Rationale: Both SPI and UART are provided by the same USART
               peripheral

The output is less surprising and can provide non-obvious reasons
why `FEATURES_REQUIRED_ANY` failed to pick a feature. The downside is
that the alternatives are no longer visible. However, that output
likely was so confusing this might be for the best.

Co-authored-by: mguetschow <mikolai.guetschow@tu-dresden.de>
This commit is contained in:
Marian Buschsieweke 2024-02-21 20:55:41 +01:00
parent 8b832804e8
commit d29652350b
No known key found for this signature in database
GPG Key ID: 77AA882EC78084E6
3 changed files with 11 additions and 10 deletions

View File

@ -44,17 +44,18 @@ FEATURES_USED_SO_FAR := $(sort $(FEATURES_REQUIRED) $(FEATURES_OPTIONAL_USED))
# ==> If one (or more) already used features is listed in item, this (or # ==> If one (or more) already used features is listed in item, this (or
# one of these) will be in the front of "tmp" and be taken # one of these) will be in the front of "tmp" and be taken
# ==> If one (or more) usable features is listed in item, this will come # ==> If one (or more) usable features is listed in item, this will come
# afterwards. If no no feature in item is used so for, one of the # afterwards. If no feature in item is used so far, one of the
# features supported and listed in item will be picked # features supported and listed in item will be picked
# ==> At the end of the list item itself (with pipes between features) is the # ==> At the end of the list, feature alternatives in item itself are added.
# last item in "tmp". If no feature is item is supported or used, this # If no feature in item is already used or usable, the first alternative is
# will be the only item in "tmp" and be picked # just added, triggering a warning about a feature being missing or
# conflicting later on.
FEATURES_REQUIRED_ONE_OUT_OF := $(foreach item,\ FEATURES_REQUIRED_ONE_OUT_OF := $(foreach item,\
$(FEATURES_REQUIRED_ANY),\ $(FEATURES_REQUIRED_ANY),\
$(word 1,\ $(word 1,\
$(filter $(FEATURES_USED_SO_FAR),$(subst |, ,$(item)))\ $(filter $(FEATURES_USED_SO_FAR),$(subst |, ,$(item)))\
$(filter $(FEATURES_USABLE),$(subst |, ,$(item)))\ $(filter $(FEATURES_USABLE),$(subst |, ,$(item)))\
$(item))) $(subst |, ,$(item))))
# Features that are required by the application but not provided by the BSP # Features that are required by the application but not provided by the BSP
# Having features missing may case the build to fail. # Having features missing may case the build to fail.

View File

@ -7,9 +7,9 @@ FEATURES_BLACKLIST := a
FEATURES_CONFLICT := f:e c:d FEATURES_CONFLICT := f:e c:d
# expected results # expected results
EXPECTED_FEATURES_USED := a|h|i b c d EXPECTED_FEATURES_USED := a b c d
EXPECTED_FEATURES_MISSING := a|h|i EXPECTED_FEATURES_MISSING :=
EXPECTED_FEATURES_USED_BLACKLISTED := EXPECTED_FEATURES_USED_BLACKLISTED := a
EXPECTED_FEATURES_CONFLICTING := c d EXPECTED_FEATURES_CONFLICTING := c d
include Makefile.test include Makefile.test

View File

@ -7,8 +7,8 @@ FEATURES_BLACKLIST :=
FEATURES_CONFLICT := FEATURES_CONFLICT :=
# expected results # expected results
EXPECTED_FEATURES_USED := d|b|a EXPECTED_FEATURES_USED := d
EXPECTED_FEATURES_MISSING := d|b|a EXPECTED_FEATURES_MISSING := d
EXPECTED_FEATURES_USED_BLACKLISTED := EXPECTED_FEATURES_USED_BLACKLISTED :=
EXPECTED_FEATURES_CONFLICTING := EXPECTED_FEATURES_CONFLICTING :=