From 001bc0e7ebce51f1a2d9c3f696f157cd6bed8bf5 Mon Sep 17 00:00:00 2001 From: Marian Buschsieweke Date: Fri, 9 Feb 2024 21:35:55 +0100 Subject: [PATCH 1/5] boards/esp32-olimex-evb: drop periph_ir feature There is no corresponding driver (yet), so this feature is just confusing. --- boards/esp32-olimex-evb/Kconfig | 1 - boards/esp32-olimex-evb/Makefile.features | 1 - 2 files changed, 2 deletions(-) diff --git a/boards/esp32-olimex-evb/Kconfig b/boards/esp32-olimex-evb/Kconfig index e3758545c4..916d3777f7 100644 --- a/boards/esp32-olimex-evb/Kconfig +++ b/boards/esp32-olimex-evb/Kconfig @@ -20,7 +20,6 @@ config BOARD_ESP32_OLIMEX_EVB select HAS_PERIPH_SDMMC select HAS_PERIPH_SPI select HAS_PERIPH_CAN - select HAS_PERIPH_IR select HAVE_MTD_SDMMC_DEFAULT diff --git a/boards/esp32-olimex-evb/Makefile.features b/boards/esp32-olimex-evb/Makefile.features index 29a36ef6fa..c6259a44e6 100644 --- a/boards/esp32-olimex-evb/Makefile.features +++ b/boards/esp32-olimex-evb/Makefile.features @@ -21,6 +21,5 @@ FEATURES_CONFLICT_MSG += "SD/MMC and SPI cannot be used at the same time on this # unique features of the board FEATURES_PROVIDED += esp_eth # Ethernet MAC (EMAC) FEATURES_PROVIDED += periph_can # CAN peripheral interface -FEATURES_PROVIDED += periph_ir # IR peripheral interface FEATURES_PROVIDED += arduino_pins From ce5bae3edb47ec31c5e317f042a7559eb1d82d18 Mon Sep 17 00:00:00 2001 From: Marian Buschsieweke Date: Thu, 8 Feb 2024 18:32:18 +0100 Subject: [PATCH 2/5] dist/tools/features_yaml2mx: feature management utility Add a python script that allows having a single YAML file as source of truth for what features are available, and also add documentation such as help texts and grouping to them. This utility converts such a YAML file to a Makefile with the contents ``` FEATURES_EXISTING := \ feature_a \ feature_b \ ... \ features_z \ # ``` This allows the Makefile based build system to easily check if all provided features and all requested features do actually exist. In addition, this also converts the YAML file to a markdown file that documents the features. This file is then intended to be used by Doxygen to document the provided features. Co-authored-by: mguetschow Co-authored-by: chrysn --- dist/tools/features_yaml2mx/README.md | 12 ++ .../features_yaml2mx/features_yaml2mx.py | 161 ++++++++++++++++++ 2 files changed, 173 insertions(+) create mode 100644 dist/tools/features_yaml2mx/README.md create mode 100755 dist/tools/features_yaml2mx/features_yaml2mx.py diff --git a/dist/tools/features_yaml2mx/README.md b/dist/tools/features_yaml2mx/README.md new file mode 100644 index 0000000000..f517fea9ed --- /dev/null +++ b/dist/tools/features_yaml2mx/README.md @@ -0,0 +1,12 @@ +Tool to export features described in a YAML to formats usable by our build system +================================================================================= + +The python script in this folder converts features specified in a YAML file to +a Makefile for use to check provided and requested features against, as well +as a markdown file for consumption by Doxygen to document the features. + +The YAML file containing the features is `features.yaml` in the root of the +repo. Its syntax is documented in a comment on top of said file. + +This script should be invoked by running `make generate-features` in the root +of the repository. diff --git a/dist/tools/features_yaml2mx/features_yaml2mx.py b/dist/tools/features_yaml2mx/features_yaml2mx.py new file mode 100755 index 0000000000..14f15c5e65 --- /dev/null +++ b/dist/tools/features_yaml2mx/features_yaml2mx.py @@ -0,0 +1,161 @@ +#!/usr/bin/env python3 +""" +Command line utility generate trivial Makefile listing all existing features in +RIOT and a matching documentation in Markdown format from single YAML file. +""" +import argparse +import yaml + + +def collect_features(parsed): + """ + Collect all features from a parsed YAML file + + :param parsed: Parsed YAML file + :type parsed: dict + :return: list of features in no particular, possible unstable, order + :rtype: list + """ + result = [] + for group in parsed.get("groups", []): + result += collect_features(group) + for feature in parsed.get("features", []): + result.append(feature["name"]) + return result + + +def write_makefile(outfile, yaml_path, parsed): + """ + Extract the list of features from the given parsed YAML file and writes + them into file at the given path in Makefile syntax, e.g. + + FEATURES_EXISTING := \ + feat_a \ + feat_b \ + feat_c \ + # + + :param outfile: path to the Makefile to write the features to + :type outfile: str + :param yaml_path: Path to the source YAML file + :type yaml_path: str + :param parsed: the parsed YAML file + :type parsed: dict + """ + outfile.write(f"""\ +# WARNING: This has been auto-generated from {yaml_path}. +# Do not edit this by hand, but update {yaml_path} instead. +# Finally, run `make generate-features` in the root of the RIOT repo. +""") + outfile.write("FEATURES_EXISTING := \\\n") + for feature in sorted(collect_features(parsed)): + outfile.write(f" {feature} \\\n") + outfile.write(" #\n") + outfile.flush() + + +def write_md_section(outfile, group, level): + """ + Write a section documenting certain features to the given file in markdown + format. + + :param outfile: The file to write the section to + :type outfile: file + :param group: The group content (e.g. a subtree from the parsed YAML) + :type group: dict + :param level: The current section level (e.g. 1=section, 2=subsection) + :type level: int + """ + title = group.get("title") + outfile.write("#" * level + f" {title}" if title else "" + "\n") + if "help" in group: + outfile.write("\n") + outfile.write(group["help"]) + outfile.write("\n") + + if "features" in group: + outfile.write("\n") + outfile.write("""\ +| Feature | Description | +|:--------------------------------- |:----------------------------------------------------------------------------- | +""") + + for feature in group["features"]: + name = f"`{feature['name']}`" + description = feature['help'].strip().replace("\n", " ") + outfile.write(f"| {name:<33} | {description:<77} |\n") + + for group in group.get('groups', []): + outfile.write("\n") + write_md_section(outfile, group, level + 1) + + +def write_mdfile(outfile, yaml_path, parsed): + """ + Write the given contents from the parsed YAML file as markdown + documentation to the given file + + :param outfile: The file to write the documentation to + :type outfile: file + :param yaml_path: Path to the source YAML file + :type yaml_path: str + :param parsed: The parsed YAML file contents + :type parsed: dict + """ + outfile.write(f"""\ +# List of Features (Features as Build System Enties) + + +[TOC] + +""") + write_md_section(outfile, parsed, 0) + + +def convert_features(yaml_file, mk_file, md_file): + """ + Convert the YAML file identified by the given path to a Makefile and + to a markdown file, if their paths are given. + + :param yaml_file: Path to the YAML file to read + :type yaml_file: str + :param mk_file: Path to the Makefile to write the features to or None + for not writing the Makefile + :type mk_file: str or None + :param md_file: Path to the markdown file to write the doc to or None + for not writing the doc + :type md_file: str or None + """ + with open(yaml_file, 'rb') as file: + parsed = yaml.safe_load(file) + + if mk_file is not None: + with open(mk_file, 'w', encoding="utf-8") as file: + write_makefile(file, yaml_file, parsed) + + if md_file is not None: + with open(md_file, 'w', encoding="utf-8") as file: + write_mdfile(file, yaml_file, parsed) + + +if __name__ == '__main__': + parser = argparse.ArgumentParser( + description='Generate documentation for features in markdown ' + + 'format and a Makefile listing existing features' + ) + parser.add_argument('INPUT', type=str, default=None, + help="Input file in YAML format") + parser.add_argument('--output-md', type=str, default=None, + help="Output file to write the markdown " + + "documentation to (default: no documentation") + parser.add_argument('--output-makefile', type=str, default=None, + help="Output file to write the makefile to " + + "(default: no makefile generated)") + + args = parser.parse_args() + + convert_features(args.INPUT, args.output_makefile, args.output_md) From 3ee25d02be18aa435a90cc6b426236b5814b0018 Mon Sep 17 00:00:00 2001 From: Marian Buschsieweke Date: Fri, 9 Feb 2024 13:45:45 +0100 Subject: [PATCH 3/5] features.yaml: List and document all RIOT features This lists and documents features in a machine readable form. It is intended to be used for documentation and the build system. Co-authored-by: mguetschow Co-authored-by: chrysn --- dist/tools/features_yaml2mx/schema.cddl | 16 + features.yaml | 881 ++++++++++++++++++++++++ 2 files changed, 897 insertions(+) create mode 100644 dist/tools/features_yaml2mx/schema.cddl create mode 100644 features.yaml diff --git a/dist/tools/features_yaml2mx/schema.cddl b/dist/tools/features_yaml2mx/schema.cddl new file mode 100644 index 0000000000..908265c56a --- /dev/null +++ b/dist/tools/features_yaml2mx/schema.cddl @@ -0,0 +1,16 @@ +root = group-toplevel + +group-toplevel = group .within { "groups" => any } +group-nested = group .within { "title" => tstr, any => any } + +group = { + ? "title" => tstr, + ? "help" => tstr, + ? "features" => [ + feature ], + ? "groups" => [ + group-nested ], + } + +feature = { + "name" => tstr, + ? "help" => tstr, +} diff --git a/features.yaml b/features.yaml new file mode 100644 index 0000000000..329fc42b46 --- /dev/null +++ b/features.yaml @@ -0,0 +1,881 @@ +%YAML 1.2 +--- +# This files is the source of truth what features (as build system entities) +# exist in RIOT. The file `makefiles/features_existing.inc.mk` is generated +# from this list, and so is the documentation in +# `doc/doxygen/src/feature_list.md`. To regenerate them, run +# `make generate-features` in the root of the repo. +# +# The syntax is relatively simple: A group is a mapping that may contain a +# string-valued "title" and "help", may contain a list of groups under the +# "groups" key, and a list of features under the "features" key, where a +# feature is expressed as a mapping that contains a "name" and a "help" string. +# The syntax is formally described in dist/tools/features_yaml2mx/schema.cddl. +# +# Note: The syntax or even the file format will likely change and evolve over +# time. +groups: +- title: Architecture Features + help: These indicate architecture features, such as word size of the CPU, + supported instruction sets and so on. All architecture features provided + by a given board will always be used, e.g. an 8-bit CPU cannot just stop + being an 8-bit CPU on request. + groups: + - title: Word size + help: Word size of the CPU + features: + - name: arch_8bit + help: CPU has a 8-bits architecture + - name: arch_16bit + help: CPU has a 16-bits architecture + - name: arch_32bit + help: CPU has a 32-bits architecture + - name: arch_64bit + help: CPU has a 64-bits architecture + - title: Architecture grouping + help: Instruction set of the CPU + features: + - name: arch_arm + help: CPU architecture is classic ARM or Cortex M + - name: arch_arm7 + help: CPU architecture is classic ARM (ARM7) + - name: arch_avr8 + help: CPU architecture is AVR-8 + - name: arch_efm32 + help: FIXME. This is not an architecture. Use cpu_efm32 for this + - name: arch_esp + help: "CPU architecture is an ESP. (Fixme: This is not an architecture)" + - name: arch_esp_xtensa + help: CPU architecture is Xtensa + - name: arch_esp_riscv + help: CPU architecture is RISC-V (ESP flavor) + - name: arch_esp32 + help: "CPU architecture is an ESP32. (Fixme: This is not an architecture)" + - name: arch_esp32_xtensa + help: CPU architecture is Xtensa (ESP32 flavor) + - name: arch_esp8266 + help: CPU architecture is Xtensa (ESP8266 flavor) + - name: arch_msp430 + help: CPU architecture is MSP430 + - name: arch_native + help: CPU architecture is `native` + - name: arch_riscv + help: CPU architecture is RISC-V + - name: arch_nuclei + help: The CPU is based on a Nuclei System Technology design. Hence, RIOT is + using the Nuclei Microcontroller Software Interface Standard + (NMSIS) vendor independent hardware abstraction layer. + +- title: CPU Features + help: These features are related to CPU capabilities or just used to + indicated which CPU family is used. + groups: + - title: CPU Capabilities + help: These correspond to features/capabilities provided by certain CPUs + groups: + - title: Cortex M Specific Features + help: These features are only available on (some) ARM Cortex M MCUs + features: + - name: cpu_check_address + help: The @ref cpu_check_address can be used to check if + accessing a given address would cause a bus fault. + - name: cortexm_svc + help: ARM Cortex-M Supervisor Calls are available. + - name: cortexm_fpu + help: A hardware floating point unit is available. + - name: cortexm_mpu + help: A memory protection unit (MPU) is available. + groups: + - title: nRF Capabilities + help: These features are only available on (some) nordic nRF MCUs + features: + - name: vdd_lc_filter_reg1 + help: An LC filter for use with the internal DC/DC converter is + present. If this is the case, the DC/DC converter is used over the + LDO regulator for improved power efficiency. + - name: vdd_lc_filter_reg0 + help: The MCU supports a high voltage supply via an two-stage regulator + and the board has an LC filter required for using the two-stage + DC/DC converter. This enables the two-stage DC/DC converter. + - title: AVR-8 Specific Features + groups: + - title: ATmega Specific Features + help: These features are only available on (some) ATmega MCUs. + features: + - name: atmega_pcint0 + help: Required pin-mapping for pin change interrupt on bank 0 is available. + See section on pin change interrupts in @ref cpu_atmega_common + - name: atmega_pcint1 + help: Required pin-mapping for pin change interrupt on bank 1 is available. + See section on pin change interrupts in @ref cpu_atmega_common + - name: atmega_pcint2 + help: Required pin-mapping for pin change interrupt on bank 2 is available. + See section on pin change interrupts in @ref cpu_atmega_common + - name: atmega_pcint3 + help: Required pin-mapping for pin change interrupt on bank 3 is available. + See section on pin change interrupts in @ref cpu_atmega_common + - title: ATxmega Specific Features + help: These features are only available on (some) ATxmega MCUs. + features: + - name: atxmega_ebi + help: MCU supports the external bus interface (EBI) to either extend + RAM with external RAM or attach memory mapped peripherals such + as (some) displays. + - title: EFM32 Specific Features + features: + - name: efm32_coretemp + help: Y R U not using `periph_temperature` for this? + - name: gecko_sdk_librail_nonfpu + help: The CPU offers librail support if the FPU is disabled. + Librail is shipped as pre-compiled blobs. Thus, we have to adapt to + their choice how to process floats. + - name: gecko_sdk_librail_fpu + help: The CPU offers librail support if the FPU is enabled. + Librail is shipped as pre-compiled blobs. Thus, we have to adapt to + their choice how to process floats. + - title: ESP Specific Features + help: These features are only available on (some) ESP MCUs. + features: + - name: esp_eth + help: > + An ESP Ethernet peripherals is available. + (FIXME: `periph_eth` instead.) + - name: esp_jtag + help: The MCU supports JTAG for programming and debugging. Enable this + feature to expose the interface at the cost of having fewer pins as + GPIOs available. + - name: esp_now + help: An ESP NOW-compatible radio is present. + - name: esp_spiffs + help: A Serial Peripheral Interface Flash File System can be used. + - name: esp_wifi + help: An ESP WiFi radio is present. + - name: esp_wifi_ap + help: ESP WiFi SoftAP support is present. + - name: esp_wifi_enterprise + help: The ESP WiFi interface supports WPA2 enterprise mode. + - name: esp_ble_esp32 + help: The ESP32x SoC uses the SDK Bluetooth LE library for the ESP32 + variant. + - name: esp_ble_esp32c3 + help: The ESP32x SoC uses the SDK Bluetooth LE library for the ESP32-C3 or + ESP32-S3 variant. + - name: esp_hw_counter + help: The used ESP32x SoC supports HW counters that can be used as timers. + - name: esp_rmt + help: The ESP32x SoC has an RMT (Remote Control Transceiver) peripheral. + - name: esp_rtc_timer_32k + help: An external 32.768 kHz crystal is connected to the ESP32x Soc on the + board. + - name: esp_spi_ram + help: An external RAM is connected via the SPI interface to + the ESP32x SoC on the board. + - name: esp_spi_oct + help: Octal SPI mode is used for Flash and SPI RAM. In this + case additional GPIOs are used for the SPI interface and cannot be + used for other purposes. + - name: esp_ble + help: An ESP32 Bluetooth LE transceiver is present. + - title: nordic nRF Specific Features + features: + - name: radio_nrf802154 + help: An nRF MCU with a peripheral radio that supports IEEE 802.15.4 is + present. + - name: radio_nrfble + help: An nRF MCU with a peripheral radio that supports Bluetooth LE is + present. + - name: radio_nrfmin + help: An nRF MCU with a peripheral radio that supports nordics proprietary + link layer protocol is present. + + - title: CPU Grouping + help: These are not actually features/capabilities, but just indicate to + which CPU family a certain CPU belongs + features: + - name: cpu_native + help: The board is simulated by a native program running on the host + + groups: + - title: Atmel / Microchip AVR-8 Grouping + groups: + - title: ATmega Grouping + features: + - name: cpu_core_atmega + help: The MCU has an ATmega CPU + - name: cpu_atmega8 + help: The MCU is an ATmega8 + - name: cpu_atmega32u4 + help: The MCU is an ATmega32U4 + - name: cpu_atmega128rfa1 + help: The MCU is an ATmega128RFA1 + - name: cpu_atmega256rfr2 + help: The MCU is an ATmega256RFR2 + - name: cpu_atmega328p + help: The MCU is an ATmega328P + - name: cpu_atmega1281 + help: The MCU is an ATmega1281 + - name: cpu_atmega1284p + help: The MCU is an ATmega1284P + - name: cpu_atmega2560 + help: The MCU is an ATmega2560 + - title: ATxmega Grouping + features: + - name: cpu_core_atxmega + help: The MCU has an ATxmega CPU + - name: cpu_atxmega + help: The MCU is an ATxmega XYZ CPU + - title: ARM Cortex-M and Classic ARM Grouping + features: + - name: cpu_core_cortexm + help: The MCU has an ARM Cortex-M CPU (any family) + - name: cpu_stm32 + help: The MCU has an STM32 MCU + + groups: + - title: Atmel / Microchip SAM Grouping + groups: + - title: SAM0 Grouping + features: + - name: cpu_samd21 + help: The MCU has an Atmel/Microchip SAM D10/D11/D20/D21 CPU + - name: cpu_samd5x + help: The MCU has an Atmel/Microchip SAM D5x CPU + - name: cpu_saml1x + help: The MCU has an Atmel/Microchip SAM L1x CPU + - name: cpu_saml21 + help: The MCU has an Atmel/Microchip SAM L2x / L3x CPU + - title: SAM3 Grouping + features: + - name: cpu_sam3 + help: The MCU has an Atmel/Microchip SAM 3 CPU + + - title: GigaDevice Semiconductor Inc Grouping + features: + - name: cpu_gd32v + help: The MCU is part of the GigaDevice GD32V family + + - title: nordic nRF Grouping + features: + - name: cpu_nrf51 + help: The MCU has an nordic nRF51 CPU + - name: cpu_nrf52 + help: The MCU has an nordic nRF52 CPU + - name: cpu_nrf53 + help: The MCU has an nordic nRF53 CPU + - name: cpu_nrf9160 + help: The MCU has an nordic nRF9160 CPU + + - title: NXP Grouping + features: + - name: cpu_kinetis + help: The MCU is part of the NXP Kinetis family + - name: cpu_lpc1768 + help: The MCU is an NXP LPC1768 + - name: cpu_lpc23xx + help: The MCU is part of the NXP LPC23xx classic ARM family + - name: cpu_qn908x + help: The MCU is part of the NXP QN908x family + + - title: Raspberry Pi Grouping + features: + - name: cpu_rpx0xx + help: The MCU is part of the Raspberry PI RPx0xx family. + + - title: Silicon Laboratories EFM32 Grouping + features: + - name: cpu_efm32 + help: The MCU is part of the Silicon Labs EFM32 family + + - title: SiFive, Inc. Grouping + features: + - name: cpu_fe310 + help: The MCU is in SiFive Freedom E310 + + - title: STMicroelectronics STM32 Grouping + features: + - name: cpu_stm32c0 + help: The MCU has an STM32 C0 MCU + - name: cpu_stm32f0 + help: The MCU has an STM32 F0 MCU + - name: cpu_stm32f1 + help: The MCU has an STM32 F1 MCU + - name: cpu_stm32f2 + help: The MCU has an STM32 F2 MCU + - name: cpu_stm32f3 + help: The MCU has an STM32 F3 MCU + - name: cpu_stm32f4 + help: The MCU has an STM32 F4 MCU + - name: cpu_stm32f7 + help: The MCU has an STM32 F7 MCU + - name: cpu_stm32g0 + help: The MCU has an STM32 G0 MCU + - name: cpu_stm32g4 + help: The MCU has an STM32 G4 MCU + - name: cpu_stm32l0 + help: The MCU has an STM32 L0 MCU + - name: cpu_stm32l1 + help: The MCU has an STM32 L1 MCU + - name: cpu_stm32l4 + help: The MCU has an STM32 L4 MCU + - name: cpu_stm32l5 + help: The MCU has an STM32 L5 MCU + - name: cpu_stm32mp1 + help: The MCU has an STM32 MP1 MCU + - name: cpu_stm32u5 + help: The MCU has an STM32 U5 MCU + - name: cpu_stm32wb + help: The MCU has an STM32 WB MCU + - name: cpu_stm32wl + help: The MCU has an STM32 WL MCU + + - title: Texas Instruments ARM MCU Grouping + features: + - name: cpu_cc26x2_cc13x2 + help: The CPU in an TI CC26x2 or an TI CC13x2 + - name: cpu_cc26x0_cc13x0 + help: The CPU in an TI CC26x0 or an TI CC13x0 + - name: cpu_cc2538 + help: The CPU in an TI CC2538 + - name: cpu_lm4f120 + help: The CPU is an TI LM4F120 + + - title: Expressif ESP Grouping + features: + - name: cpu_esp32 + help: The MCU is part of the ESP32 family + - name: cpu_esp8266 + help: The MCU is an ESP8266 + + - title: Texas Instruments MSP430 MCU Grouping + features: + - name: cpu_msp430 + help: The MCU is member of the MSP430 family. + - name: cpu_msp430_x1xx + help: The MCU is member of the MSP430 x1xx family. + - name: cpu_msp430_f2xx_g2xx + help: The MCU is member of the MSP430 F2xx/G2xx family. + +- title: Arduino Features + help: These features indicate that an Arduino style I/O mapping is available, + in which common descriptors refer to a GPIO pin / I²C bus / SPI bus / + PWM output / ADC input / etc. at a well-known location on a well-known + board form factor. + groups: + - title: Arduino I/O Mapping Features + help: These features indicate presence of I/O mappings (e.g. well-known + preprocessor macro names such as `ARDUINO_PIN_0` for a GPIO pin that + is routed to pin `D0` on the board. + features: + - name: arduino_analog + help: Indicates that Arduino analog pins mappings are provided. + - name: arduino_dac + help: Indicates that Arduino DAC pins mappings are provided. + - name: arduino_i2c + help: Indicates that Arduino I²C bus mappings are provided. + - name: arduino_pins + help: Indicates that Arduino digital pins mappings are provided. + - name: arduino_pwm + help: Indicates that Arduino digital pin to PWM mappings are provided. + - name: arduino_spi + help: Indicates that Arduino SPI bus mappings are provided. + - name: arduino_uart + help: Indicates that Arduino UART device mappings are provided. + - title: Arduino Form Factor Features + help: These features indicate compatibility with a specific form factor, + e.g. Arduino UNO or Adafruit Feather + features: + - name: arduino_shield_isp + help: Indicates that the board is mechanically and electrically compatible + with shields that mate with the ISP header for SPI connectivity. + - name: arduino_shield_mega + help: > + Indicates that the board is mechanically and electrically compatible + with shields developed for the Arduino Mega 2560. (Note: Except + the ISP header, that requires `arduino_shield_isp` in addition.) + - name: arduino_shield_nano + help: > + Indicates that the board is mechanically and electrically compatible + with shields developed for the Arduino Nano. (Note: Except the + ISP header, that requires `arduino_shield_isp` in addition.) + - name: arduino_shield_uno + help: > + Indicates that the board is mechanically and electrically compatible + with shields developed for the Arduino Nano. (Note: Except the + ISP header, that requires `arduino_shield_isp` in addition.) + +- title: RAM Related Features + help: These features indicate presence of special RAM regions or features + features: + - name: backup_ram + help: A special portion of RAM is retained during deep sleep. + Variables can be placed there by annotating them with the `BACKUP_RAM` + attribute. + - name: periph_rtc_mem + help: The RTC peripheral provides storage memory for deep sleep. Unlike + `backup_ram`, this memory is not mapped in the address space and requires + calls to @ref rtc_mem_read and @ref rtc_mem_write to access. + - name: puf_sram + help: The @ref sys_puf_sram module can be used to harvest entropy from + uninitialized SRAM on cold boot to seed PRNGs. + +- title: Bluetooth Low Energy Features + help: The capabilities of the integrated (peripheral) BLE transceiver are + modules using these features. + features: + - name: ble_adv_ext + help: Support for Bluetooth LE 5 Advertising Extension + - name: ble_nimble + help: Support for the NimBLE stack + - name: ble_nimble_netif + help: NimBLE supports the netif API, so that network stacks such as GNRC can + be used on top. See @ref pkg_nimble_netif for details. + - name: ble_phy_2mbit + help: The BLE radio supports the 2Mbit PHY mode + - name: ble_phy_coded + help: The BLE radio supports the CODED PHY mode + +- title: Toolchain Features + help: These features are used to indicate which toolchains are supported, + which languages they support, which libraries (e.g. picolibc, newlibc, + libstdc++, etc.) are supported. Unless using `BUILD_IN_DOCKER=1`, those + toolchains/libraries need to be installed on the system for the given + platform to actually be usable, though. + features: + - name: cpp + help: The C++ programming language is supported. Note that libstdc++ support + is not implied and indicated by a separate feature. + - name: libstdcpp + help: When using C++, a libstdc++ is available. + - name: picolibc + help: The picolibc C library is available for the platform. + - name: newlib + help: The newlib C library is available for the platform. + - name: rust_target + help: The Rust target definition ("triple") is known. This is + a mandatory requirement to build Rust code. + - name: emulator_renode + help: The platform is compatible with the Renode emulator. + +- title: Peripheral Features + help: These features indicate presence of peripheral IP block, presence of + a corresponding driver in RIOT, and any required board specific + configuration needed. + features: + - name: periph_cpuid + help: The CPU has identification information available. In the best case this + is a globally unique ID, in the worst case it is some calibration + parameters to compensate production variance that may or may not allow + telling the CPU apart from any given other. + - name: periph_pwm + help: A Pulse-Width Modulation (PWM) peripheral is present. + - name: periph_qdec + help: A Quadrature Decoder (QDEC) peripheral is present. + - name: periph_temperature + help: The MCU has a built-in temperature sensor. + - name: periph_vbat + help: Backup battery monitoring is supported + - name: periph_freqm + help: A Frequency Meter peripheral is present. + - name: periph_dma + help: A DMA peripheral is present. Enabling this feature affects the + implementation of other peripheral drivers. E.g. SPI/I²C/UART/... + transfers may use the DMA (possible only when transfers are longer than + a certain cut-off). The main benefit is that other threads can run + while the thread issuing the, say SPI transfer, is blocked until the + transfer is completed. It often also speeds up longer transfers. + - name: periph_pm + help: The MCU supports power management (PM) and RIOT can make use of that. + - name: periph_ltdc + help: An LCD/TFT Display Controller (LTDC) peripheral is present. (Currently + only provided by some STM32 MCUs.) + - name: periph_pio + help: A Programmable IO (PIO) is present. (Currently only RP2040) + + groups: + - title: General-Purpose Input/Output (GPIO) + features: + - name: periph_gpio_fast_read + help: This feature is currently available on Microchip SAM0 based MCUs only. + Enabling this feature reduces read latency for an increase in power + consumption. It affects both the classic GPIO API driver and the + GPIO LL driver. + + groups: + - title: Pin Level Peripheral GPIO API + help: This is a pin-level API that caters most use cases. Most code + should be using this API over GPIO LL. + features: + - name: periph_gpio + help: The classic GPIO API is implemented + - name: periph_gpio_irq + help: The classic GPIO driver supports external interrupts. + - name: periph_gpio_tamper_wake + help: This features is currently available on Microchip SAMD5x MCUs only. + Enabling this features allows GPIO IRQs to wake the CPU even in + deep sleep. The SAMD5x is not the only MCU that can be woken from + lower power modes via GPIO, but it is currently the only MCU were + this feature is configurable. + + - title: GPIO LL API + help: This is a lower level GPIO API that allows port based access. It + exposes a number of advanced features and lower latency GPIO + access at the cost of a more complex and more frequently + changing API. You should only use this if the Pin Level Peripheral + GPIO API is not catering your use case well enough. + features: + - name: periph_gpio_ll + help: The GPIO LL driver is implemented for the MCU's GPIO peripheral. + - name: periph_gpio_ll_irq + help: The GPIO LL driver has IRQ support. + - name: periph_gpio_ll_irq_level_triggered_high + help: Level triggered IRQs are supported for level high. + - name: periph_gpio_ll_irq_level_triggered_low + help: Level triggered IRQs are supported for level low. + - name: periph_gpio_ll_irq_unmask + help: The GPIO LL driver supports unmasking interrupts without + clearing pending IRQs that came in while masked. + - name: periph_gpio_ll_disconnect + help: Some or all GPIO pins can be electrically disconnected from the MCU + (high impedance state) with the GPIO LL API. + - name: periph_gpio_ll_input_pull_down + help: Some or all GPIO pins can enable an internal pull down resistor when + the GPIO is configured in input mode. + - name: periph_gpio_ll_input_pull_keep + help: Some or all GPIO pins can enable internal pull resistors that pull + towards the current bus level (pull down when bus is low, pull up + when bus is high). + - name: periph_gpio_ll_input_pull_up + help: Some or all GPIO pins can enable an internal pull up resistor when + the GPIO is configured in input mode. + - name: periph_gpio_ll_open_drain + help: Some or all pins can be configured in open drain mode. + - name: periph_gpio_ll_open_drain_pull_up + help: Some or all GPIO pins can enable an internal pull up resistor when + the GPIO is configured in open drain mode. + - name: periph_gpio_ll_open_source + help: Some or all pins can be configured in open source mode. + - name: periph_gpio_ll_open_source_pull_down + help: Some or all GPIO pins can enable an internal pull down resistor when + the GPIO is configured in open source mode. + - name: periph_gpio_ll_switch_dir + help: The GPIO LL driver allows switching the direction between input + and (push-pull) output in an efficient manner. The main use case + is bit-banging bidirectional protocols when open-drain / open-source + mode is not supported. GPIO LL drivers for peripherals that do + support open drain mode typically do not bother implementing this, + even if the hardware would allow it. + + - title: Serial Interfaces + help: Features related to serial interfaces + + groups: + - title: UART Features + help: Features related to the Universal Asynchronous Receiver-Transmitter + peripheral + features: + - name: periph_uart + help: An UART peripheral is present. + - name: periph_lpuart + help: A low-power UART peripheral is present. + - name: periph_uart_collision + help: The UART peripheral supports hardware collision detection. + - name: periph_uart_hw_fc + help: The UART peripheral supports hardware flow control. + - name: periph_uart_modecfg + help: The UART peripheral allows configuration to non-default modes. + - name: periph_uart_tx_ondemand + help: Indicates that the UART peripheral can enable / disable the TX line + using @ref uart_enable_tx / @ref uart_disable_tx + - name: periph_uart_nonblocking + help: The UART peripheral allows non-blocking operations. + - name: periph_uart_reconfigure + help: The UART pins can be made available as regular GPIOS using + @ref uart_deinit_pins and be attached back to the UART peripheral using + @ref uart_init_pins + - name: periph_uart_rxstart_irq + help: The UART can issue an interrupt when the start condition detected. + Use @ref uart_rxstart_irq_configure to associate a callback with the + ISR of a given UART peripheral. + + - title: SPI Features + help: Features related to the Serial Peripheral Interface peripheral + features: + - name: periph_spi + help: An SPI peripheral is present. + - name: periph_spi_on_qspi + help: The QSPI peripheral can be used in SPI mode. + - name: periph_spi_reconfigure + help: The SPI pins can be made available as regular GPIOs using + @ref spi_deinit_pins and re-attached to the SPI peripheral using + @ref spi_init_pins + - name: periph_spi_gpio_mode + help: The SPI peripheral supports specifying the GPIO mode of each SPI + pin upon initialization of the peripheral. + + - title: I²C Features + help: Features related to the Inter-Integrated Circuit peripheral + features: + - name: periph_i2c + help: An I²C peripheral is present. + - name: pio_i2c + help: An I²C bus can be provided via the PIO peripheral. + - name: periph_i2c_reconfigure + help: The I²C pins can be made available as regular GPIOs using + @ref i2c_deinit_pins and re-attached to the I²C peripheral using + @ref i2c_init_pins + + - title: USB Features + help: Features related to the Universal Serial Bus + features: + - name: periph_usbdev + help: An USB peripheral is present. + - name: periph_usbdev_hs + help: The USB peripheral supports High-Speed. + - name: periph_usbdev_hs_utmi + help: An USB high-speed peripheral with internal UTMI+ HS PHY is present. + - name: periph_usbdev_hs_ulpi + help: An USB high-speed peripheral with ULPI HS PHY is present. + + - title: Analog Features + help: Features related to ADCs/DACs + features: + - name: periph_adc + help: An ADC peripheral is present. + - name: periph_adc_continuous + help: The ADC peripheral can be left on between measurements. + - name: periph_dac + help: A DAC peripheral is present. + + - title: Integrated Connectivity + help: Peripheral network and communication interfaces. + features: + - name: periph_can + help: A CAN peripheral is present. + - name: periph_eth + help: An Ethernet peripheral is present. + + - title: SD / MMC Card Features + features: + - name: periph_sdmmc + help: An SDIO/SD/MMC peripheral is present and used by the board. This feature + shall be provided by the board configuration, if available. + - name: periph_sdmmc_8bit + help: The SDIO/SD/MMC peripheral supports the 8-bit bus width and at least one + component of the board is connected with 8 data lines. This feature + shall be provided by the board configuration, if available. + - name: periph_sdmmc_auto_clk + help: The SDIO/SD/MMC peripheral supports the Auto-CLK feature, i.e. the + automatic activation and deactivation of the SD CLK signal when + required. This feature shall be provided by the MCU if supported. + - name: periph_sdmmc_auto_cmd12 + help: The SDIO/SD/MMC peripheral supports the Auto-CMD12 feature, i.e. CMD12 is + sent automatically to stop the transmission in multiple block operations. + This feature shall be provided by the MCU if supported. + - name: periph_sdmmc_clk + help: The SDIO/SD/MMC peripheral has special clock functionality used by the + peripheral driver. + - name: periph_sdmmc_hs + help: The SDIO/SD/MMC peripheral supports the high speed access, that is + 50 MHz for SD and 52 MHz for MMC. This feature shall be provided by the + MCU. + - name: periph_sdmmc_mmc + help: The SDIO/SD/MMC peripheral supports MMC/eMMCs. This feature shall be + provided by the MCU. + - name: periph_sdmmc_sdhc + help: The SDIO/SD/MMC peripheral is compliant with the SD Host Controller + Specification. This feature shall be provided by the MCU. + + - title: Flash Features + features: + - name: periph_flashpage + help: A Flashpage peripheral is present. + - name: periph_flashpage_in_address_space + help: Static memory sections can fundamentally be turned into flash pages. + - name: periph_flashpage_pagewise + help: The Flashpage peripheral supports pagewise writing. + - name: periph_flashpage_rwee + help: The Flashpage peripheral is of the Read While Write. + + - title: Other Peripheral Storage Features + features: + - name: periph_eeprom + help: An EEPROM peripheral is present. + - name: periph_fmc + help: An Flexible Memory Controller (FMC) or an Flexible Static Memory + Controller (FSMC) is present. It can be used to extend memory or + drive display controllers. + - name: periph_fmc_16bit + help: The FMC/FSMC peripheral supports a 16-bit data bus + - name: periph_fmc_32bit + help: The FMC/FSMC peripheral supports a 32-bit data bus + - name: periph_fmc_sdram + help: A board configuration is provided to attach map the board's SDRAM into + the address space using the FMC/FSMC. + - name: periph_fmc_nor_sram + help: A board configuration is provided to attach map the board's NOR flash + or (P)SRAM into the address space using the FMC/FSMC. + - name: periph_nvm + help: A non-volatile memory peripheral is present. This is currently + only provided by ATxmega MCUs to read the production signature which + then is used as CPU ID. + + - title: Timer Features + help: Features related to timers + features: + - name: periph_rtc + help: An Real Time Clock (RTC) peripheral is present. This timer works with + time broken down into year, month, day, hour, minute, second. + - name: periph_rtc_ms + help: The RTC peripheral can provide sub-second timestamps. + - name: periph_rtt + help: An Real Time Timer (RTT) (a.k.a. Real Time Counter) peripheral is + present. This timer is similar to `periph_timer`, except for using + a different API (for no reason), being low power, slower ticking, + and typically less affected by clock drift. + - name: periph_rtt_set_counter + help: The RTT peripheral implements @ref rtt_set_counter + - name: periph_rtt_overflow + help: The RTT provides an overflow callback. + - name: periph_wdt + help: A Watchdog Timer (WDT) peripheral is present. + - name: periph_wdt_cb + help: The WDT peripheral allows setting a callback function to be called + before the reboot is actually triggered. + - name: periph_wdt_warning_period + help: By setting @ref CONFIG_WDT_WARNING_PERIOD the time when the WDT callback + is triggered can be set. It specifies how many milliseconds before the + reboot the callback should be executed. + + groups: + - title: High Frequency Timers + help: Features related to high frequency timers, a.k.a. `periph_timer` + features: + - name: periph_timer + help: A high frequency timer peripheral is present. + - name: periph_timer_periodic + help: The Timer peripheral allows setting periodic timeouts in addition to + the mandatory one-shot timeouts. + - name: periph_timer_poll + help: The Timer peripheral allows polling if a one-shot timer channel has + already been expired using @ref timer_poll_channel to allow high + accuracy busy waiting. + - name: periph_timer_query_freqs + help: The timer driver supports querying supported frequencies. + + - title: PTP Timers + help: These features are related to the hardware requirements to implement + the Precision Time Protocol. + features: + - name: periph_ptp + help: A PTP clock is present. The clock must have nanoseconds as unit and be + at least 64 bit wide. + - name: periph_ptp_speed_adjustment + help: The PTP clock speed can be adjusted. This can be used for clock drift + correction and synchronization without "jumping" to the new network + time, but rather pace faster/slow for some time until the clocks are + back in sync. + - name: periph_ptp_timer + help: The PTP clock can be used as timer (so that (absolute) timeouts can + be set on the clock). + - name: periph_ptp_txrx_timestamps + help: The PTP clock can provide exact time stamps of the reception and + transmission of frames (typically received at the peripheral Ethernet + interface). + + - title: Platform Specific + help: Things specific to a single MCU family / MCU vendor + features: + - name: periph_ics + help: An NXP Kinetis Internal Clock Source Controller (ICS peripheral) is + present. + - name: periph_mcg + help: An Kinetis Multipurpose Clock Generator (MCG peripheral) is present. + - name: periph_mcg_lite + help: An Kinetis Multipurpose Clock Generator (MCG peripheral) is present in + the lite version. + - name: periph_coretimer + help: A RISC-V CLINT timer is available and usable via the High Speed + timer API. The CLINT only supports running at the RTC clock, typically + 32.678 kHz, though. + - name: periph_pmp + help: A RISC-V physical memory protection (PMP) peripheral is present. + (Similar to ARM's MPU) + - name: periph_clic + help: A RISC-V Core-local Interrupt Controller (CLIC) peripheral is present. + - name: periph_plic + help: A RISC-V Platform-local Interrupt Controller (PLIC) peripheral is present. + + - title: Cryptographic Features + help: Hardware acceleration for cryptographic primitives, hardware random + number generators, and other features useful for cryptography. + + Please keep in mind that some of the cryptographic primitives provided + by the hardware have not aged well in terms of security. They may + still be nifty for use cases other than security, though. + features: + - name: periph_cryptocell_310 + help: A cryptocell peripheral is present. + - name: periph_hash_md5 + help: MD5 hardware acceleration present. + - name: periph_hash_sha_1 + help: SHA-1 hardware acceleration present. + - name: periph_hash_sha_224 + help: SHA-224 hardware acceleration present. + - name: periph_hash_sha_256 + help: SHA-256 hardware acceleration present. + - name: periph_hash_sha_512 + help: SHA-512 hardware acceleration present. + - name: periph_hmac_sha_256 + help: HMAC SHA-256 hardware acceleration present. + - name: periph_hwrng + help: A Hardware Random Number Generator (HWRNG) peripheral is present. + - name: periph_cipher_aes_128_cbc + help: AES 128 CBC hardware acceleration present + - name: periph_ecc_p192r1 + help: ECC P192R1 hardware acceleration peripheral present. + - name: periph_ecc_p256r1 + help: ECC P256R1 hardware acceleration peripheral present. + - name: periph_ecc_ed25519 + help: ECC Edwards25519 hardware acceleration peripheral present. + +- title: Other Features + help: Features that did not fit in any category + features: + - name: dbgpin + help: The platform provides the necessary initialization hooks + for the `dbgpin` module. + - name: no_idle_thread + help: The MCU can idle without an idle thread + - name: riotboot + help: The `riotboot` bootloader is supported. + - name: ssp + help: Stack Smashing Protection is supported. + - name: tinyusb_device + help: The TinyUSB network stack is supported and can be selected with + `USEPKG += tinyusb`. + - name: bootloader_stm32 + help: The MCU has a STM32 bootloader in ROM that can be used for flashing. + +- title: Board Features + help: These features indicate features of the board + features: + - name: ethernet + help: The board has Ethernet connectivity + - name: highlevel_stdio + help: A high-level stdio method (such as CDC ACM) is used. This requires a + running thread and set-up and will not print during a crash. + - name: motor_driver + help: A motor_driver configuration is present. + - name: sdcard_spi + help: An SD-Card SPI configuration is provided. + + groups: + - title: STM32L496G Discovery Board Features + help: Features available and selectable on the `stm32l496-disco` board only + features: + - name: periph_spi_stmod + help: By default, solder bridges SB6, SB7, SB8 are closed and USART1 is + connected to the Pmod/STMmod+ connector. If these solder bridges are + open and solder bridges SB4, SB5 and SB6 are closed instead, SPI2 is + connected to the STMmod+/Pmod connector. Request this feature to use + SPI2 with this board configuration. From dc040a0fdb0297b2525b8fa2f1ad422d0cb0037e Mon Sep 17 00:00:00 2001 From: Marian Buschsieweke Date: Fri, 9 Feb 2024 14:52:29 +0100 Subject: [PATCH 4/5] build system: Make use of YAML feature list --- Makefile | 10 +- doc/doxygen/riot.doxyfile | 1 + doc/doxygen/src/.gitignore | 1 + makefiles/dependency_resolution.inc.mk | 22 +++ makefiles/features_existing.inc.mk | 255 +++++++++++++++++++++++++ 5 files changed, 288 insertions(+), 1 deletion(-) create mode 100644 doc/doxygen/src/.gitignore create mode 100644 makefiles/features_existing.inc.mk diff --git a/Makefile b/Makefile index d42a1f2718..ba8689fab5 100644 --- a/Makefile +++ b/Makefile @@ -7,6 +7,9 @@ all: welcome @exit 1 doc: + @./dist/tools/features_yaml2mx/features_yaml2mx.py \ + features.yaml \ + --output-md doc/doxygen/src/feature_list.md "$(MAKE)" -BC doc/doxygen doc-man: @@ -33,6 +36,11 @@ distclean: docclean pkg-clean print-versions: @./dist/tools/ci/print_toolchain_versions.sh +generate-features: + @./dist/tools/features_yaml2mx/features_yaml2mx.py \ + features.yaml \ + --output-makefile makefiles/features_existing.inc.mk + include makefiles/boards.inc.mk include makefiles/app_dirs.inc.mk @@ -53,7 +61,7 @@ welcome: @echo " https://forum.riot-os.org" @echo "" @echo "Available targets for the RIOT base directory include:" - @echo " generate-{board,driver,example,module,pkg,test}" + @echo " generate-{board,driver,example,module,pkg,test,features}" @echo " info-{applications,boards,emulated-boards} info-applications-supported-boards" @echo " print-versions" @echo " clean distclean pkg-clean" diff --git a/doc/doxygen/riot.doxyfile b/doc/doxygen/riot.doxyfile index 57dba232ab..ffee6c6f40 100644 --- a/doc/doxygen/riot.doxyfile +++ b/doc/doxygen/riot.doxyfile @@ -769,6 +769,7 @@ INPUT = ../../doc.txt \ src/build-in-docker.md \ ../../tests/README.md \ src/build-system-basics.md \ + src/feature_list.md \ src/kconfig/kconfig.md \ src/using-cpp.md \ src/using-rust.md \ diff --git a/doc/doxygen/src/.gitignore b/doc/doxygen/src/.gitignore new file mode 100644 index 0000000000..d2b2ccc014 --- /dev/null +++ b/doc/doxygen/src/.gitignore @@ -0,0 +1 @@ +/feature_list.md diff --git a/makefiles/dependency_resolution.inc.mk b/makefiles/dependency_resolution.inc.mk index 274c96c1a2..8003a10e90 100644 --- a/makefiles/dependency_resolution.inc.mk +++ b/makefiles/dependency_resolution.inc.mk @@ -68,6 +68,28 @@ else "$(DEPRECATED_MODULES_USED)" 1>&2) endif + # Detect provided / used / optional features that do not exist + include $(RIOTMAKE)/features_existing.inc.mk + FEATURES_NONEXISTING := $(sort $(filter-out $(FEATURES_EXISTING),$(FEATURES_PROVIDED))) + ifneq (,$(FEATURES_NONEXISTING)) + $(error "The following non-existing features are provided by the board $(BOARD): $(FEATURES_NONEXISTING)") + endif + + FEATURES_NONEXISTING := $(sort $(filter-out $(FEATURES_EXISTING),$(FEATURES_REQUIRED))) + ifneq (,$(FEATURES_NONEXISTING)) + $(error "The following non-existing features are listed in FEATURES_REQUIRED: $(FEATURES_NONEXISTING)") + endif + + FEATURES_NONEXISTING := $(sort $(filter-out $(FEATURES_EXISTING),$(subst |, ,$(FEATURES_REQUIRED_ANY)))) + ifneq (,$(FEATURES_NONEXISTING)) + $(error "The following non-existing features are listed in FEATURES_REQUIRED_ANY: $(FEATURES_NONEXISTING)") + endif + + FEATURES_NONEXISTING := $(sort $(filter-out $(FEATURES_EXISTING),$(FEATURES_OPTIONAL))) + ifneq (,$(FEATURES_NONEXISTING)) + $(error "The following non-existing features are listed in FEATURES_OPTIONAL: $(FEATURES_NONEXISTING)") + endif + # Warn about telnet ifneq (,$(filter auto_init_telnet,$(USEMODULE))) ifneq (1,$(I_UNDERSTAND_THAT_TELNET_IS_INSECURE)) diff --git a/makefiles/features_existing.inc.mk b/makefiles/features_existing.inc.mk new file mode 100644 index 0000000000..e7dde9f5e0 --- /dev/null +++ b/makefiles/features_existing.inc.mk @@ -0,0 +1,255 @@ +# WARNING: This has been auto-generated from features.yaml. +# Do not edit this by hand, but update features.yaml instead. +# Finally, run `make generate-features` in the root of the RIOT repo. +FEATURES_EXISTING := \ + arch_16bit \ + arch_32bit \ + arch_64bit \ + arch_8bit \ + arch_arm \ + arch_arm7 \ + arch_avr8 \ + arch_efm32 \ + arch_esp \ + arch_esp32 \ + arch_esp32_xtensa \ + arch_esp8266 \ + arch_esp_riscv \ + arch_esp_xtensa \ + arch_msp430 \ + arch_native \ + arch_nuclei \ + arch_riscv \ + arduino_analog \ + arduino_dac \ + arduino_i2c \ + arduino_pins \ + arduino_pwm \ + arduino_shield_isp \ + arduino_shield_mega \ + arduino_shield_nano \ + arduino_shield_uno \ + arduino_spi \ + arduino_uart \ + atmega_pcint0 \ + atmega_pcint1 \ + atmega_pcint2 \ + atmega_pcint3 \ + atxmega_ebi \ + backup_ram \ + ble_adv_ext \ + ble_nimble \ + ble_nimble_netif \ + ble_phy_2mbit \ + ble_phy_coded \ + bootloader_stm32 \ + cortexm_fpu \ + cortexm_mpu \ + cortexm_svc \ + cpp \ + cpu_atmega1281 \ + cpu_atmega1284p \ + cpu_atmega128rfa1 \ + cpu_atmega2560 \ + cpu_atmega256rfr2 \ + cpu_atmega328p \ + cpu_atmega32u4 \ + cpu_atmega8 \ + cpu_atxmega \ + cpu_cc2538 \ + cpu_cc26x0_cc13x0 \ + cpu_cc26x2_cc13x2 \ + cpu_check_address \ + cpu_core_atmega \ + cpu_core_atxmega \ + cpu_core_cortexm \ + cpu_efm32 \ + cpu_esp32 \ + cpu_esp8266 \ + cpu_fe310 \ + cpu_gd32v \ + cpu_kinetis \ + cpu_lm4f120 \ + cpu_lpc1768 \ + cpu_lpc23xx \ + cpu_msp430 \ + cpu_msp430_f2xx_g2xx \ + cpu_msp430_x1xx \ + cpu_native \ + cpu_nrf51 \ + cpu_nrf52 \ + cpu_nrf53 \ + cpu_nrf9160 \ + cpu_qn908x \ + cpu_rpx0xx \ + cpu_sam3 \ + cpu_samd21 \ + cpu_samd5x \ + cpu_saml1x \ + cpu_saml21 \ + cpu_stm32 \ + cpu_stm32c0 \ + cpu_stm32f0 \ + cpu_stm32f1 \ + cpu_stm32f2 \ + cpu_stm32f3 \ + cpu_stm32f4 \ + cpu_stm32f7 \ + cpu_stm32g0 \ + cpu_stm32g4 \ + cpu_stm32l0 \ + cpu_stm32l1 \ + cpu_stm32l4 \ + cpu_stm32l5 \ + cpu_stm32mp1 \ + cpu_stm32u5 \ + cpu_stm32wb \ + cpu_stm32wl \ + dbgpin \ + efm32_coretemp \ + emulator_renode \ + esp_ble \ + esp_ble_esp32 \ + esp_ble_esp32c3 \ + esp_eth \ + esp_hw_counter \ + esp_jtag \ + esp_now \ + esp_rmt \ + esp_rtc_timer_32k \ + esp_spi_oct \ + esp_spi_ram \ + esp_spiffs \ + esp_wifi \ + esp_wifi_ap \ + esp_wifi_enterprise \ + ethernet \ + gecko_sdk_librail_fpu \ + gecko_sdk_librail_nonfpu \ + highlevel_stdio \ + libstdcpp \ + motor_driver \ + newlib \ + no_idle_thread \ + periph_adc \ + periph_adc_continuous \ + periph_can \ + periph_cipher_aes_128_cbc \ + periph_clic \ + periph_coretimer \ + periph_cpuid \ + periph_cryptocell_310 \ + periph_dac \ + periph_dma \ + periph_ecc_ed25519 \ + periph_ecc_p192r1 \ + periph_ecc_p256r1 \ + periph_eeprom \ + periph_eth \ + periph_flashpage \ + periph_flashpage_in_address_space \ + periph_flashpage_pagewise \ + periph_flashpage_rwee \ + periph_fmc \ + periph_fmc_16bit \ + periph_fmc_32bit \ + periph_fmc_nor_sram \ + periph_fmc_sdram \ + periph_freqm \ + periph_gpio \ + periph_gpio_fast_read \ + periph_gpio_irq \ + periph_gpio_ll \ + periph_gpio_ll_disconnect \ + periph_gpio_ll_input_pull_down \ + periph_gpio_ll_input_pull_keep \ + periph_gpio_ll_input_pull_up \ + periph_gpio_ll_irq \ + periph_gpio_ll_irq_level_triggered_high \ + periph_gpio_ll_irq_level_triggered_low \ + periph_gpio_ll_irq_unmask \ + periph_gpio_ll_open_drain \ + periph_gpio_ll_open_drain_pull_up \ + periph_gpio_ll_open_source \ + periph_gpio_ll_open_source_pull_down \ + periph_gpio_ll_switch_dir \ + periph_gpio_tamper_wake \ + periph_hash_md5 \ + periph_hash_sha_1 \ + periph_hash_sha_224 \ + periph_hash_sha_256 \ + periph_hash_sha_512 \ + periph_hmac_sha_256 \ + periph_hwrng \ + periph_i2c \ + periph_i2c_reconfigure \ + periph_ics \ + periph_lpuart \ + periph_ltdc \ + periph_mcg \ + periph_mcg_lite \ + periph_nvm \ + periph_pio \ + periph_plic \ + periph_pm \ + periph_pmp \ + periph_ptp \ + periph_ptp_speed_adjustment \ + periph_ptp_timer \ + periph_ptp_txrx_timestamps \ + periph_pwm \ + periph_qdec \ + periph_rtc \ + periph_rtc_mem \ + periph_rtc_ms \ + periph_rtt \ + periph_rtt_overflow \ + periph_rtt_set_counter \ + periph_sdmmc \ + periph_sdmmc_8bit \ + periph_sdmmc_auto_clk \ + periph_sdmmc_auto_cmd12 \ + periph_sdmmc_clk \ + periph_sdmmc_hs \ + periph_sdmmc_mmc \ + periph_sdmmc_sdhc \ + periph_spi \ + periph_spi_gpio_mode \ + periph_spi_on_qspi \ + periph_spi_reconfigure \ + periph_spi_stmod \ + periph_temperature \ + periph_timer \ + periph_timer_periodic \ + periph_timer_poll \ + periph_timer_query_freqs \ + periph_uart \ + periph_uart_collision \ + periph_uart_hw_fc \ + periph_uart_modecfg \ + periph_uart_nonblocking \ + periph_uart_reconfigure \ + periph_uart_rxstart_irq \ + periph_uart_tx_ondemand \ + periph_usbdev \ + periph_usbdev_hs \ + periph_usbdev_hs_ulpi \ + periph_usbdev_hs_utmi \ + periph_vbat \ + periph_wdt \ + periph_wdt_cb \ + periph_wdt_warning_period \ + picolibc \ + pio_i2c \ + puf_sram \ + radio_nrf802154 \ + radio_nrfble \ + radio_nrfmin \ + riotboot \ + rust_target \ + sdcard_spi \ + ssp \ + tinyusb_device \ + vdd_lc_filter_reg0 \ + vdd_lc_filter_reg1 \ + # From aa356d8b7bc2948a93a31f7e230f2f1cd0bb2d0f Mon Sep 17 00:00:00 2001 From: Marian Buschsieweke Date: Mon, 12 Feb 2024 12:32:04 +0100 Subject: [PATCH 5/5] ci: add test that features_existing.inc.mk is up to date --- .../check_features_existing_inc_mk_is_up_to_date.sh | 11 +++++++++++ dist/tools/ci/static_tests.sh | 1 + 2 files changed, 12 insertions(+) create mode 100755 dist/tools/ci/check_features_existing_inc_mk_is_up_to_date.sh diff --git a/dist/tools/ci/check_features_existing_inc_mk_is_up_to_date.sh b/dist/tools/ci/check_features_existing_inc_mk_is_up_to_date.sh new file mode 100755 index 0000000000..e27e38e98d --- /dev/null +++ b/dist/tools/ci/check_features_existing_inc_mk_is_up_to_date.sh @@ -0,0 +1,11 @@ +#!/bin/sh +# This tools checks if the makefiles/features_existing.inc.mk is up to date +hash_feature_list_pre="$(sha256sum "$(dirname "$0")/../../../makefiles/features_existing.inc.mk")" +make --silent -C "$(dirname "$0")"/../../.. generate-features || exit 1 +hash_feature_list_post="$(sha256sum "$(dirname "$0")/../../../makefiles/features_existing.inc.mk")" +if [ "$hash_feature_list_pre" != "$hash_feature_list_post" ]; then + echo "Forgot to run make generate-features after updating features.yaml!" + exit 1 +fi + +exit 0 diff --git a/dist/tools/ci/static_tests.sh b/dist/tools/ci/static_tests.sh index 39235af9d7..fd78944ffa 100755 --- a/dist/tools/ci/static_tests.sh +++ b/dist/tools/ci/static_tests.sh @@ -114,6 +114,7 @@ export BASE_BRANCH="${CI_BASE_BRANCH}" run ./dist/tools/whitespacecheck/check.sh "${BASE_BRANCH}" DIFFFILTER="MR" ERROR_EXIT_CODE=0 run ./dist/tools/licenses/check.sh DIFFFILTER="AC" run ./dist/tools/licenses/check.sh +run ./dist/tools/ci/check_features_existing_inc_mk_is_up_to_date.sh run ./dist/tools/doccheck/check.sh run ./dist/tools/externc/check.sh # broken configuration produces many false positives