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:
parent
651b506fd4
commit
cf482c5d46
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
50
doc/doxygen/src/using-cpp.md
Normal file
50
doc/doxygen/src/using-cpp.md
Normal 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
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user