1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-17 05:52:44 +01:00

build system: Add libstdcpp feature and doc

- Add libstdcpp feature to indicate a platform is providing a libstdc++
  implementation ready for use
- The existing cpp feature now only indicates a working C++ toolchain without
  libstdc++. (E.g. still useful for the Arduino compatibility layer.)
- Added libstdcpp as required feature were needed
- Added some documentation on C++ on RIOT
This commit is contained in:
Marian Buschsieweke 2020-07-12 22:53:30 +02:00
parent 651b506fd4
commit cf482c5d46
No known key found for this signature in database
GPG Key ID: 61F64C6599B1539F
15 changed files with 75 additions and 4 deletions

View File

@ -617,6 +617,7 @@ ifneq (,$(filter cpp11-compat,$(USEMODULE)))
USEMODULE += xtimer USEMODULE += xtimer
USEMODULE += timex USEMODULE += timex
FEATURES_REQUIRED += cpp FEATURES_REQUIRED += cpp
FEATURES_REQUIRED += libstdcpp
endif endif
ifneq (,$(filter gnrc,$(USEMODULE))) ifneq (,$(filter gnrc,$(USEMODULE)))
@ -1085,6 +1086,11 @@ FEATURES_REQUIRED += $(filter cpu_core_%,$(FEATURES_PROVIDED))
# don't use idle thread if architecture has needed support # don't use idle thread if architecture has needed support
FEATURES_OPTIONAL += no_idle_thread FEATURES_OPTIONAL += no_idle_thread
ifneq (,$(filter libstdcpp,$(FEATURES_USED)))
# Also use C++ if libstdc++ is used
FEATURES_REQUIRED += cpp
endif
ifneq (,$(filter ecc_%,$(USEMODULE))) ifneq (,$(filter ecc_%,$(USEMODULE)))
USEMODULE += ecc USEMODULE += ecc
endif endif

View File

@ -2,6 +2,7 @@ FEATURES_PROVIDED += arch_32bit
FEATURES_PROVIDED += arch_arm FEATURES_PROVIDED += arch_arm
FEATURES_PROVIDED += arch_arm7 FEATURES_PROVIDED += arch_arm7
FEATURES_PROVIDED += cpp FEATURES_PROVIDED += cpp
FEATURES_PROVIDED += libstdcpp
FEATURES_PROVIDED += periph_pm FEATURES_PROVIDED += periph_pm
FEATURES_PROVIDED += puf_sram FEATURES_PROVIDED += puf_sram
FEATURES_PROVIDED += ssp FEATURES_PROVIDED += ssp

View File

@ -31,6 +31,7 @@ config CPU_CORE_CORTEX_M
select HAS_CPU_CORE_CORTEXM select HAS_CPU_CORE_CORTEXM
select HAS_PERIPH_PM select HAS_PERIPH_PM
select HAS_CPP select HAS_CPP
select HAS_LIBSTDCPP
select HAS_CPU_CHECK_ADDRESS select HAS_CPU_CHECK_ADDRESS
select HAS_SSP select HAS_SSP
select HAS_CORTEXM_SVC select HAS_CORTEXM_SVC

View File

@ -1,10 +1,11 @@
FEATURES_PROVIDED += arch_32bit FEATURES_PROVIDED += arch_32bit
FEATURES_PROVIDED += arch_arm FEATURES_PROVIDED += arch_arm
FEATURES_PROVIDED += cpu_core_cortexm
FEATURES_PROVIDED += periph_pm
FEATURES_PROVIDED += cortexm_svc FEATURES_PROVIDED += cortexm_svc
FEATURES_PROVIDED += cpp FEATURES_PROVIDED += cpp
FEATURES_PROVIDED += cpu_check_address FEATURES_PROVIDED += cpu_check_address
FEATURES_PROVIDED += cpu_core_cortexm
FEATURES_PROVIDED += libstdcpp
FEATURES_PROVIDED += periph_pm
FEATURES_PROVIDED += ssp FEATURES_PROVIDED += ssp
# cortex-m4f and cortex-m7 provide FPU support # cortex-m4f and cortex-m7 provide FPU support

View File

@ -15,6 +15,7 @@ config CPU_COMMON_ESP
select HAS_ESP_NOW select HAS_ESP_NOW
select HAS_ESP_SPIFFS select HAS_ESP_SPIFFS
select HAS_ESP_WIFI select HAS_ESP_WIFI
select HAS_LIBSTDCPP
select HAS_PERIPH_CPUID select HAS_PERIPH_CPUID
select HAS_PERIPH_HWRNG select HAS_PERIPH_HWRNG
select HAS_PERIPH_PM select HAS_PERIPH_PM

View File

@ -8,6 +8,7 @@ FEATURES_PROVIDED += cpp
FEATURES_PROVIDED += esp_now FEATURES_PROVIDED += esp_now
FEATURES_PROVIDED += esp_spiffs FEATURES_PROVIDED += esp_spiffs
FEATURES_PROVIDED += esp_wifi FEATURES_PROVIDED += esp_wifi
FEATURES_PROVIDED += libstdcpp
FEATURES_PROVIDED += periph_cpuid FEATURES_PROVIDED += periph_cpuid
FEATURES_PROVIDED += periph_hwrng FEATURES_PROVIDED += periph_hwrng
FEATURES_PROVIDED += periph_pm FEATURES_PROVIDED += periph_pm

View File

@ -24,6 +24,7 @@ config CPU_FAM_FE310
select HAS_PERIPH_PM select HAS_PERIPH_PM
select HAS_PERIPH_WDT select HAS_PERIPH_WDT
select HAS_CPP select HAS_CPP
select HAS_LIBSTDCPP
select HAS_SSP select HAS_SSP
config CPU_MODEL_FE310_G000 config CPU_MODEL_FE310_G000

View File

@ -1,6 +1,7 @@
FEATURES_PROVIDED += arch_32bit FEATURES_PROVIDED += arch_32bit
FEATURES_PROVIDED += arch_riscv FEATURES_PROVIDED += arch_riscv
FEATURES_PROVIDED += cpp FEATURES_PROVIDED += cpp
FEATURES_PROVIDED += libstdcpp
FEATURES_PROVIDED += periph_cpuid FEATURES_PROVIDED += periph_cpuid
FEATURES_PROVIDED += periph_gpio periph_gpio_irq FEATURES_PROVIDED += periph_gpio periph_gpio_irq
FEATURES_PROVIDED += periph_pm FEATURES_PROVIDED += periph_pm

View File

@ -1,4 +1,5 @@
FEATURES_PROVIDED += arch_32bit FEATURES_PROVIDED += arch_32bit
FEATURES_PROVIDED += arch_mips32r2 FEATURES_PROVIDED += arch_mips32r2
FEATURES_PROVIDED += cpp FEATURES_PROVIDED += cpp
FEATURES_PROVIDED += libstdcpp
FEATURES_PROVIDED += periph_pm FEATURES_PROVIDED += periph_pm

View File

@ -1,6 +1,7 @@
FEATURES_PROVIDED += arch_32bit FEATURES_PROVIDED += arch_32bit
FEATURES_PROVIDED += arch_native FEATURES_PROVIDED += arch_native
FEATURES_PROVIDED += cpp FEATURES_PROVIDED += cpp
FEATURES_PROVIDED += libstdcpp
FEATURES_PROVIDED += periph_cpuid FEATURES_PROVIDED += periph_cpuid
FEATURES_PROVIDED += periph_eeprom FEATURES_PROVIDED += periph_eeprom
FEATURES_PROVIDED += periph_hwrng FEATURES_PROVIDED += periph_hwrng

View File

@ -770,6 +770,7 @@ INPUT = ../../doc.txt \
../../tests/README.md \ ../../tests/README.md \
src/build-system-basics.md \ src/build-system-basics.md \
src/kconfig/kconfig.md \ src/kconfig/kconfig.md \
src/using-cpp.md \
src/advanced-build-system-tricks.md \ src/advanced-build-system-tricks.md \
src/changelog.md \ src/changelog.md \
../../LOSTANDFOUND.md ../../LOSTANDFOUND.md

View File

@ -0,0 +1,50 @@
Using C++ in RIOT {#using-cpp}
=================
[TOC]
Levels of Support {#levels-of-support}
=================
A CPU in RIOT can have three levels of support for C++ code:
1. No support for C++ at all
2. C++ is supported, but no libstdc++ implementation is available
3. C++ is supported and a libstdc++ implementation is available
The reason for missing or only partial C++ support can be one (or more) of
the following:
- No libstdc++ implementation for the target platform is available to RIOT, or
the official RIOT docker image is missing it
- Missing toolchain support for a given target platform
- The C++ toolchain requires library code (such as constructor guards for the
thread safe initialization of statically allocated instances) or hooks in
the startup process to perform initialization
Using C++
=========
In order for C++ code to compile with RIOT, the following needs to be done:
- All C++ files must have the file extension `.cpp`, all C++ headers `.hpp`
- For external code, overwriting the make variable `SRCXXEXT` e.g. to
`cxx` can be used to compile C++ files with other extensions, e.g. `.cxx`
- `FEATURES_REQUIRED += cpp` must be added to the applications `Makefile`
- If additionally the libstdc++ is used, `FEATURES_REQUIRED += libstdcpp`
must be used additionally
RIOT Modules in C++ {#cpp-in-riot}
===================
RIOT modules should be written in C, so that boards/platforms without or partial
C++ support can still use these modules. However, external modules, packages,
and modules that require C++ support anyway (e.g. the Arduino compatibility
features) can be written in C++. These modules/packages have to depend on the
`cpp` feature (`FEATURES_REQUIRED += cpp`) and possibly the `libstdcpp`
feature using their `Makefile.dep`.
See Also {#see-also}
========
@ref sys_c11_atomics_cpp_compat, @ref cpp11-compat

View File

@ -67,6 +67,11 @@ config HAS_ETHERNET
help help
Indicates that Ethernet connectivity is present. Indicates that Ethernet connectivity is present.
config HAS_LIBSTDCPP
bool
help
Indicates that in addition to C++ support an libstdc++ is available.
config HAS_NO_IDLE_THREAD config HAS_NO_IDLE_THREAD
bool bool
help help

View File

@ -1,6 +1,6 @@
include ../Makefile.tests_common include ../Makefile.tests_common
FEATURES_REQUIRED += cpp FEATURES_REQUIRED += cpp libstdcpp
USEMODULE += module_exclude USEMODULE += module_exclude
EXTERNAL_MODULE_DIRS += $(CURDIR)/module_exclude EXTERNAL_MODULE_DIRS += $(CURDIR)/module_exclude

View File

@ -1,6 +1,6 @@
include ../Makefile.tests_common include ../Makefile.tests_common
FEATURES_REQUIRED += cpp FEATURES_REQUIRED += cpp libstdcpp
USEMODULE += module USEMODULE += module
EXTERNAL_MODULE_DIRS += $(CURDIR)/module EXTERNAL_MODULE_DIRS += $(CURDIR)/module