2016-08-17 23:08:22 +08:00
|
|
|
#
|
2021-12-14 15:31:08 +01:00
|
|
|
# Please run the following command for opening a page with more information about this configuration file:
|
|
|
|
# idf.py docs -sp api-reference/kconfig.html
|
2016-08-17 23:08:22 +08:00
|
|
|
#
|
2016-08-19 14:30:39 +08:00
|
|
|
mainmenu "Espressif IoT Development Framework Configuration"
|
2016-08-17 23:08:22 +08:00
|
|
|
|
2021-11-05 17:23:24 +08:00
|
|
|
orsource "./components/soc/$IDF_TARGET/include/soc/Kconfig.soc_caps.in"
|
|
|
|
|
2018-12-06 15:08:18 +01:00
|
|
|
config IDF_CMAKE
|
|
|
|
bool
|
2021-11-04 15:28:07 +01:00
|
|
|
default "y"
|
2018-12-06 15:08:18 +01:00
|
|
|
|
2019-11-28 21:08:20 +08:00
|
|
|
config IDF_ENV_FPGA
|
|
|
|
bool
|
2020-01-15 21:50:19 +08:00
|
|
|
option env="IDF_ENV_FPGA"
|
2023-06-20 16:04:41 +08:00
|
|
|
help
|
|
|
|
- This option is for internal use only.
|
|
|
|
- Enabling this option will help enable all FPGA support so as to
|
|
|
|
run ESP-IDF on an FPGA. This can help reproduce some issues that
|
|
|
|
only happens on FPGA condition, or when you have to burn some
|
|
|
|
efuses multiple times.
|
|
|
|
|
|
|
|
config IDF_ENV_BRINGUP
|
|
|
|
bool
|
|
|
|
help
|
|
|
|
- This option is ONLY used when doing new chip bringup.
|
|
|
|
- This option will only enable necessary hw / sw settings for running
|
|
|
|
a hello_world application.
|
|
|
|
|
2019-11-28 21:08:20 +08:00
|
|
|
|
2022-10-25 21:47:13 +08:00
|
|
|
config IDF_CI_BUILD
|
|
|
|
bool
|
2022-11-05 15:46:13 +08:00
|
|
|
default y if "$(IDF_CI_BUILD)" = "y" || "$(IDF_CI_BUILD)" = 1
|
2022-10-25 21:47:13 +08:00
|
|
|
|
2023-09-08 10:10:07 +08:00
|
|
|
config IDF_DOC_BUILD
|
|
|
|
bool
|
|
|
|
default y if "$(IDF_DOC_BUILD)" = "y" || "$(IDF_DOC_BUILD)" = 1
|
|
|
|
|
2022-11-23 15:00:11 +03:00
|
|
|
config IDF_TOOLCHAIN
|
|
|
|
# This option records the IDF target when sdkconfig is generated the first time.
|
|
|
|
# It is not updated if environment variable $IDF_TOOLCHAIN changes later, and
|
|
|
|
# the build system is responsible for detecting the mismatch between
|
|
|
|
# CONFIG_IDF_TOOLCHAIN and $IDF_TOOLCHAIN.
|
|
|
|
string
|
|
|
|
default "$IDF_TOOLCHAIN"
|
|
|
|
|
|
|
|
config IDF_TOOLCHAIN_CLANG
|
|
|
|
bool
|
|
|
|
default "y" if IDF_TOOLCHAIN="clang"
|
|
|
|
|
2020-11-06 15:00:07 +11:00
|
|
|
config IDF_TARGET_ARCH_RISCV
|
|
|
|
bool
|
|
|
|
default "n"
|
|
|
|
|
|
|
|
config IDF_TARGET_ARCH_XTENSA
|
|
|
|
bool
|
|
|
|
default "n"
|
|
|
|
|
2021-12-01 23:00:01 +01:00
|
|
|
config IDF_TARGET_ARCH
|
|
|
|
string
|
|
|
|
default "riscv" if IDF_TARGET_ARCH_RISCV
|
|
|
|
default "xtensa" if IDF_TARGET_ARCH_XTENSA
|
|
|
|
|
2018-12-06 15:08:18 +01:00
|
|
|
config IDF_TARGET
|
|
|
|
# This option records the IDF target when sdkconfig is generated the first time.
|
|
|
|
# It is not updated if environment variable $IDF_TARGET changes later, and
|
|
|
|
# the build system is responsible for detecting the mismatch between
|
|
|
|
# CONFIG_IDF_TARGET and $IDF_TARGET.
|
|
|
|
string
|
2019-11-08 14:40:28 +01:00
|
|
|
default "$IDF_TARGET"
|
2018-12-06 15:08:18 +01:00
|
|
|
|
2023-06-12 14:30:53 +02:00
|
|
|
config IDF_INIT_VERSION
|
|
|
|
# This option records the IDF version when sdkconfig is generated the first time.
|
|
|
|
# It is not updated if environment variable $IDF_VERSION changes later
|
|
|
|
string
|
|
|
|
default "$IDF_INIT_VERSION"
|
|
|
|
|
2021-11-15 23:58:32 +01:00
|
|
|
config IDF_TARGET_LINUX
|
|
|
|
bool
|
|
|
|
default "y" if IDF_TARGET="linux"
|
|
|
|
|
2019-04-03 17:08:02 +08:00
|
|
|
config IDF_TARGET_ESP32
|
|
|
|
bool
|
2019-04-08 18:02:05 +08:00
|
|
|
default "y" if IDF_TARGET="esp32"
|
2020-11-06 15:00:07 +11:00
|
|
|
select IDF_TARGET_ARCH_XTENSA
|
2019-04-03 17:08:02 +08:00
|
|
|
|
2020-01-17 11:47:08 +08:00
|
|
|
config IDF_TARGET_ESP32S2
|
2019-04-03 17:08:02 +08:00
|
|
|
bool
|
2020-01-17 11:47:08 +08:00
|
|
|
default "y" if IDF_TARGET="esp32s2"
|
2019-08-19 15:02:34 +10:00
|
|
|
select FREERTOS_UNICORE
|
2020-11-06 15:00:07 +11:00
|
|
|
select IDF_TARGET_ARCH_XTENSA
|
2018-12-06 15:08:18 +01:00
|
|
|
|
2020-01-15 21:50:19 +08:00
|
|
|
config IDF_TARGET_ESP32S3
|
|
|
|
bool
|
|
|
|
default "y" if IDF_TARGET="esp32s3"
|
2020-11-06 15:00:07 +11:00
|
|
|
select IDF_TARGET_ARCH_XTENSA
|
2020-01-15 21:50:19 +08:00
|
|
|
|
2020-12-29 11:28:27 +08:00
|
|
|
config IDF_TARGET_ESP32C3
|
|
|
|
bool
|
|
|
|
default "y" if IDF_TARGET="esp32c3"
|
|
|
|
select FREERTOS_UNICORE
|
|
|
|
select IDF_TARGET_ARCH_RISCV
|
|
|
|
|
2022-01-18 10:32:56 +08:00
|
|
|
config IDF_TARGET_ESP32C2
|
2021-09-23 14:30:50 +08:00
|
|
|
bool
|
2022-01-18 10:32:56 +08:00
|
|
|
default "y" if IDF_TARGET="esp32c2"
|
2021-09-23 14:30:50 +08:00
|
|
|
select FREERTOS_UNICORE
|
|
|
|
select IDF_TARGET_ARCH_RISCV
|
|
|
|
|
2022-08-10 19:01:42 +08:00
|
|
|
config IDF_TARGET_ESP32C6
|
|
|
|
bool
|
|
|
|
default "y" if IDF_TARGET="esp32c6"
|
|
|
|
select FREERTOS_UNICORE
|
|
|
|
select IDF_TARGET_ARCH_RISCV
|
|
|
|
|
2023-11-09 17:18:39 +08:00
|
|
|
config IDF_TARGET_ESP32C5
|
|
|
|
bool
|
|
|
|
default "y" if IDF_TARGET="esp32c5"
|
|
|
|
select FREERTOS_UNICORE
|
|
|
|
select IDF_TARGET_ARCH_RISCV
|
|
|
|
|
2024-02-20 14:57:30 +08:00
|
|
|
# TODO: IDF-9197
|
2023-12-19 13:49:26 +08:00
|
|
|
choice IDF_TARGET_ESP32C5_VERSION
|
|
|
|
prompt "ESP32-C5 version"
|
|
|
|
depends on IDF_TARGET_ESP32C5
|
|
|
|
default IDF_TARGET_ESP32C5_BETA3_VERSION
|
|
|
|
help
|
2024-01-02 22:19:49 +08:00
|
|
|
ESP32-C5 will support two versions for a period.
|
2023-12-19 13:49:26 +08:00
|
|
|
This option is for internal use only.
|
|
|
|
Select the one that matches your chip model.
|
|
|
|
|
|
|
|
config IDF_TARGET_ESP32C5_BETA3_VERSION
|
|
|
|
bool
|
|
|
|
prompt "ESP32-C5 beta3"
|
|
|
|
select ESPTOOLPY_NO_STUB
|
2024-02-20 14:57:30 +08:00
|
|
|
|
|
|
|
config IDF_TARGET_ESP32C5_MP_VERSION
|
|
|
|
bool
|
|
|
|
prompt "ESP32-C5 MP"
|
|
|
|
select ESPTOOLPY_NO_STUB
|
2023-12-19 13:49:26 +08:00
|
|
|
endchoice
|
|
|
|
|
2023-06-09 20:31:22 +08:00
|
|
|
config IDF_TARGET_ESP32P4
|
|
|
|
bool
|
|
|
|
default "y" if IDF_TARGET="esp32p4"
|
|
|
|
select IDF_TARGET_ARCH_RISCV
|
|
|
|
|
2022-12-29 11:01:13 +08:00
|
|
|
config IDF_TARGET_ESP32H2
|
|
|
|
bool
|
|
|
|
default "y" if IDF_TARGET="esp32h2"
|
|
|
|
select FREERTOS_UNICORE
|
|
|
|
select IDF_TARGET_ARCH_RISCV
|
|
|
|
|
2024-02-26 11:29:46 +08:00
|
|
|
config IDF_TARGET_ESP32C61
|
|
|
|
bool
|
|
|
|
default "y" if IDF_TARGET="esp32c61"
|
|
|
|
select FREERTOS_UNICORE
|
|
|
|
select IDF_TARGET_ARCH_RISCV
|
|
|
|
select IDF_ENV_FPGA
|
|
|
|
|
2021-05-13 17:04:31 +08:00
|
|
|
config IDF_TARGET_LINUX
|
|
|
|
bool
|
|
|
|
default "y" if IDF_TARGET="linux"
|
|
|
|
|
2019-09-16 11:47:23 +08:00
|
|
|
config IDF_FIRMWARE_CHIP_ID
|
|
|
|
hex
|
2019-09-19 21:17:31 +10:00
|
|
|
default 0x0000 if IDF_TARGET_ESP32
|
2020-01-17 11:47:08 +08:00
|
|
|
default 0x0002 if IDF_TARGET_ESP32S2
|
2020-12-29 11:28:27 +08:00
|
|
|
default 0x0005 if IDF_TARGET_ESP32C3
|
2021-06-02 12:14:13 +08:00
|
|
|
default 0x0009 if IDF_TARGET_ESP32S3
|
2022-08-10 19:01:42 +08:00
|
|
|
default 0x000C if IDF_TARGET_ESP32C2
|
|
|
|
default 0x000D if IDF_TARGET_ESP32C6
|
2022-12-29 11:01:13 +08:00
|
|
|
default 0x0010 if IDF_TARGET_ESP32H2
|
2023-06-09 20:31:22 +08:00
|
|
|
default 0x0012 if IDF_TARGET_ESP32P4
|
2024-02-20 14:57:30 +08:00
|
|
|
default 0x0011 if IDF_TARGET_ESP32C5 && IDF_TARGET_ESP32C5_BETA3_VERSION # TODO: IDF-9197
|
|
|
|
default 0x0017 if IDF_TARGET_ESP32C5 && IDF_TARGET_ESP32C5_MP_VERSION # TODO: IDF-9197
|
2024-02-26 11:29:46 +08:00
|
|
|
default 0x0014 if IDF_TARGET_ESP32C61
|
2019-09-16 11:47:23 +08:00
|
|
|
default 0xFFFF
|
2018-12-06 15:08:18 +01:00
|
|
|
|
2021-11-05 17:23:24 +08:00
|
|
|
|
2019-07-22 16:04:03 +02:00
|
|
|
menu "Build type"
|
|
|
|
|
|
|
|
choice APP_BUILD_TYPE
|
|
|
|
prompt "Application build type"
|
|
|
|
default APP_BUILD_TYPE_APP_2NDBOOT
|
|
|
|
help
|
|
|
|
Select the way the application is built.
|
|
|
|
|
|
|
|
By default, the application is built as a binary file in a format compatible with
|
2021-02-01 16:53:13 +08:00
|
|
|
the ESP-IDF bootloader. In addition to this application, 2nd stage bootloader is
|
2019-07-22 16:04:03 +02:00
|
|
|
also built. Application and bootloader binaries can be written into flash and
|
|
|
|
loaded/executed from there.
|
|
|
|
|
|
|
|
Another option, useful for only very small and limited applications, is to only link
|
|
|
|
the .elf file of the application, such that it can be loaded directly into RAM over
|
2023-01-30 18:03:59 +08:00
|
|
|
JTAG or UART. Note that since IRAM and DRAM sizes are very limited, it is not possible
|
|
|
|
to build any complex application this way. However for some kinds of testing and debugging,
|
2019-07-22 16:04:03 +02:00
|
|
|
this option may provide faster iterations, since the application does not need to be
|
|
|
|
written into flash.
|
2023-01-30 18:03:59 +08:00
|
|
|
|
|
|
|
Note: when APP_BUILD_TYPE_RAM is selected and loaded with JTAG, ESP-IDF does not contain
|
|
|
|
all the startup code required to initialize the CPUs and ROM memory (data/bss).
|
|
|
|
Therefore it is necessary to execute a bit of ROM code prior to executing the application.
|
|
|
|
A gdbinit file may look as follows (for ESP32):
|
2019-07-22 16:04:03 +02:00
|
|
|
|
|
|
|
# Connect to a running instance of OpenOCD
|
|
|
|
target remote :3333
|
|
|
|
# Reset and halt the target
|
|
|
|
mon reset halt
|
|
|
|
# Run to a specific point in ROM code,
|
|
|
|
# where most of initialization is complete.
|
2021-05-04 16:22:50 +02:00
|
|
|
thb *0x40007d54
|
2019-07-22 16:04:03 +02:00
|
|
|
c
|
|
|
|
# Load the application into RAM
|
|
|
|
load
|
|
|
|
# Run till app_main
|
|
|
|
tb app_main
|
|
|
|
c
|
|
|
|
|
|
|
|
Execute this gdbinit file as follows:
|
|
|
|
|
|
|
|
xtensa-esp32-elf-gdb build/app-name.elf -x gdbinit
|
|
|
|
|
2021-02-01 16:53:13 +08:00
|
|
|
Example gdbinit files for other targets can be found in tools/test_apps/system/gdb_loadable_elf/
|
|
|
|
|
2023-01-30 18:03:59 +08:00
|
|
|
When loading the BIN with UART, the ROM will jump to ram and run the app after finishing the ROM
|
|
|
|
startup code, so there's no additional startup initialization required. You can use the
|
|
|
|
`load_ram` in esptool.py to load the generated .bin file into ram and execute.
|
|
|
|
|
|
|
|
Example:
|
|
|
|
esptool.py --chip {chip} -p {port} -b {baud} --no-stub load_ram {app.bin}
|
|
|
|
|
2019-07-22 16:04:03 +02:00
|
|
|
Recommended sdkconfig.defaults for building loadable ELF files is as follows.
|
2023-01-30 18:03:41 +08:00
|
|
|
CONFIG_APP_BUILD_TYPE_RAM is required, other options help reduce application
|
2019-07-22 16:04:03 +02:00
|
|
|
memory footprint.
|
|
|
|
|
2023-01-30 18:03:41 +08:00
|
|
|
CONFIG_APP_BUILD_TYPE_RAM=y
|
2019-07-22 16:04:03 +02:00
|
|
|
CONFIG_VFS_SUPPORT_TERMIOS=
|
|
|
|
CONFIG_NEWLIB_NANO_FORMAT=y
|
2020-02-02 23:23:16 +08:00
|
|
|
CONFIG_ESP_SYSTEM_PANIC_PRINT_HALT=y
|
2020-04-30 18:23:21 +02:00
|
|
|
CONFIG_ESP_DEBUG_STUBS_ENABLE=
|
2019-07-22 16:04:03 +02:00
|
|
|
CONFIG_ESP_ERR_TO_NAME_LOOKUP=
|
|
|
|
|
|
|
|
|
|
|
|
config APP_BUILD_TYPE_APP_2NDBOOT
|
|
|
|
bool
|
|
|
|
prompt "Default (binary application + 2nd stage bootloader)"
|
2021-11-15 23:58:32 +01:00
|
|
|
depends on !IDF_TARGET_LINUX
|
2019-07-22 16:04:03 +02:00
|
|
|
select APP_BUILD_GENERATE_BINARIES
|
|
|
|
select APP_BUILD_BOOTLOADER
|
|
|
|
select APP_BUILD_USE_FLASH_SECTIONS
|
|
|
|
|
2023-01-30 18:03:59 +08:00
|
|
|
config APP_BUILD_TYPE_RAM
|
2019-07-22 16:04:03 +02:00
|
|
|
bool
|
2023-01-30 18:03:59 +08:00
|
|
|
prompt "Build app runs entirely in RAM (EXPERIMENTAL)"
|
|
|
|
select APP_BUILD_GENERATE_BINARIES
|
|
|
|
|
2019-07-22 16:04:03 +02:00
|
|
|
endchoice # APP_BUILD_TYPE
|
|
|
|
|
|
|
|
# Hidden options, set according to the choice above
|
|
|
|
config APP_BUILD_GENERATE_BINARIES
|
|
|
|
bool # Whether to generate .bin files or not
|
|
|
|
|
|
|
|
config APP_BUILD_BOOTLOADER
|
|
|
|
bool # Whether to build the bootloader
|
|
|
|
|
2023-01-30 18:03:59 +08:00
|
|
|
config APP_BUILD_TYPE_PURE_RAM_APP
|
|
|
|
bool
|
|
|
|
prompt "Build app without SPI_FLASH/PSRAM support (saves ram)"
|
|
|
|
depends on APP_BUILD_TYPE_RAM
|
|
|
|
help
|
|
|
|
If this option is enabled, external memory and related peripherals, such as Cache, MMU,
|
|
|
|
Flash and PSRAM, won't be initialized. Corresponding drivers won't be introduced either.
|
|
|
|
Components that depend on the spi_flash component will also be unavailable, such as
|
|
|
|
app_update, etc. When this option is enabled, about 26KB of RAM space can be saved.
|
|
|
|
|
2019-07-22 16:04:03 +02:00
|
|
|
config APP_BUILD_USE_FLASH_SECTIONS
|
|
|
|
bool # Whether to place code/data into memory-mapped flash sections
|
|
|
|
|
2021-10-09 15:42:14 +08:00
|
|
|
config APP_REPRODUCIBLE_BUILD
|
|
|
|
bool "Enable reproducible build"
|
|
|
|
default n
|
|
|
|
select COMPILER_HIDE_PATHS_MACROS
|
|
|
|
help
|
2021-10-14 20:00:05 +08:00
|
|
|
If enabled, all date, time, and path information would be eliminated. A .gdbinit file would be create
|
|
|
|
automatically. (or will be append if you have one already)
|
2021-10-09 15:42:14 +08:00
|
|
|
|
2022-01-07 12:22:56 +08:00
|
|
|
config APP_NO_BLOBS
|
|
|
|
bool "No Binary Blobs"
|
|
|
|
default n
|
|
|
|
help
|
|
|
|
If enabled, this disables the linking of binary libraries in the application build. Note
|
|
|
|
that after enabling this Wi-Fi/Bluetooth will not work.
|
|
|
|
|
2022-05-10 12:27:36 +08:00
|
|
|
config APP_COMPATIBLE_PRE_V2_1_BOOTLOADERS
|
|
|
|
bool "App compatible with bootloaders before ESP-IDF v2.1"
|
|
|
|
select APP_COMPATIBLE_PRE_V3_1_BOOTLOADERS
|
|
|
|
depends on IDF_TARGET_ESP32
|
|
|
|
default n
|
|
|
|
help
|
|
|
|
Bootloaders before ESP-IDF v2.1 did less initialisation of the
|
|
|
|
system clock. This setting needs to be enabled to build an app
|
|
|
|
which can be booted by these older bootloaders.
|
|
|
|
|
|
|
|
If this setting is enabled, the app can be booted by any bootloader
|
|
|
|
from IDF v1.0 up to the current version.
|
|
|
|
|
|
|
|
If this setting is disabled, the app can only be booted by bootloaders
|
|
|
|
from IDF v2.1 or newer.
|
|
|
|
|
|
|
|
Enabling this setting adds approximately 1KB to the app's IRAM usage.
|
|
|
|
|
|
|
|
config APP_COMPATIBLE_PRE_V3_1_BOOTLOADERS
|
|
|
|
bool "App compatible with bootloader and partition table before ESP-IDF v3.1"
|
|
|
|
depends on IDF_TARGET_ESP32
|
|
|
|
default n
|
|
|
|
help
|
|
|
|
Partition tables before ESP-IDF V3.1 do not contain an MD5 checksum
|
|
|
|
field, and the bootloader before ESP-IDF v3.1 cannot read a partition
|
|
|
|
table that contains an MD5 checksum field.
|
|
|
|
|
|
|
|
Enable this option only if your app needs to boot on a bootloader and/or
|
|
|
|
partition table that was generated from a version *before* ESP-IDF v3.1.
|
|
|
|
|
|
|
|
If this option and Flash Encryption are enabled at the same time, and any
|
|
|
|
data partitions in the partition table are marked Encrypted, then the
|
|
|
|
partition encrypted flag should be manually verified in the app before accessing
|
|
|
|
the partition (see CVE-2021-27926).
|
|
|
|
|
|
|
|
config APP_INIT_CLK
|
|
|
|
bool
|
|
|
|
depends on IDF_TARGET_ESP32
|
|
|
|
default y if APP_COMPATIBLE_PRE_V2_1_BOOTLOADERS
|
2023-01-30 18:03:41 +08:00
|
|
|
default y if APP_BUILD_TYPE_RAM
|
2022-05-10 12:27:36 +08:00
|
|
|
|
|
|
|
|
2019-07-22 16:04:03 +02:00
|
|
|
endmenu # Build type
|
|
|
|
|
2019-09-10 09:58:52 +02:00
|
|
|
source "$COMPONENT_KCONFIGS_PROJBUILD_SOURCE_FILE"
|
2018-12-06 15:08:18 +01:00
|
|
|
|
|
|
|
menu "Compiler options"
|
|
|
|
|
2019-04-24 15:02:25 +02:00
|
|
|
choice COMPILER_OPTIMIZATION
|
2018-12-06 15:08:18 +01:00
|
|
|
prompt "Optimization Level"
|
2023-06-02 15:16:50 +08:00
|
|
|
default COMPILER_OPTIMIZATION_DEBUG
|
2018-12-06 15:08:18 +01:00
|
|
|
help
|
2020-02-26 14:19:32 +11:00
|
|
|
This option sets compiler optimization level (gcc -O argument) for the app.
|
2018-12-06 15:08:18 +01:00
|
|
|
|
2023-06-02 15:16:50 +08:00
|
|
|
- The "Debug" setting will add the -0g flag to CFLAGS.
|
2019-09-03 13:12:58 +08:00
|
|
|
- The "Size" setting will add the -0s flag to CFLAGS.
|
|
|
|
- The "Performance" setting will add the -O2 flag to CFLAGS.
|
|
|
|
- The "None" setting will add the -O0 flag to CFLAGS.
|
2018-12-06 15:08:18 +01:00
|
|
|
|
2019-09-03 13:12:58 +08:00
|
|
|
The "Size" setting cause the compiled code to be smaller and faster, but
|
|
|
|
may lead to difficulties of correlating code addresses to source file
|
|
|
|
lines when debugging.
|
2018-12-06 15:08:18 +01:00
|
|
|
|
2019-09-03 13:12:58 +08:00
|
|
|
The "Performance" setting causes the compiled code to be larger and faster,
|
|
|
|
but will be easier to correlated code addresses to source file lines.
|
2018-12-06 15:08:18 +01:00
|
|
|
|
2019-09-03 13:12:58 +08:00
|
|
|
"None" with -O0 produces compiled code without optimization.
|
2018-12-06 15:08:18 +01:00
|
|
|
|
2019-09-03 13:12:58 +08:00
|
|
|
Note that custom optimization levels may be unsupported.
|
|
|
|
|
2020-02-26 14:19:32 +11:00
|
|
|
Compiler optimization for the IDF bootloader is set separately,
|
|
|
|
see the BOOTLOADER_COMPILER_OPTIMIZATION setting.
|
|
|
|
|
2023-06-02 15:16:50 +08:00
|
|
|
config COMPILER_OPTIMIZATION_DEBUG
|
2018-12-06 15:08:18 +01:00
|
|
|
bool "Debug (-Og)"
|
2019-09-03 13:12:58 +08:00
|
|
|
config COMPILER_OPTIMIZATION_SIZE
|
|
|
|
bool "Optimize for size (-Os)"
|
|
|
|
config COMPILER_OPTIMIZATION_PERF
|
|
|
|
bool "Optimize for performance (-O2)"
|
|
|
|
config COMPILER_OPTIMIZATION_NONE
|
|
|
|
bool "Debug without optimization (-O0)"
|
|
|
|
|
2018-12-06 15:08:18 +01:00
|
|
|
endchoice
|
|
|
|
|
2019-04-24 15:02:25 +02:00
|
|
|
choice COMPILER_OPTIMIZATION_ASSERTION_LEVEL
|
2018-12-06 15:08:18 +01:00
|
|
|
prompt "Assertion level"
|
2019-04-24 15:02:25 +02:00
|
|
|
default COMPILER_OPTIMIZATION_ASSERTIONS_ENABLE
|
2018-12-06 15:08:18 +01:00
|
|
|
help
|
|
|
|
Assertions can be:
|
|
|
|
|
|
|
|
- Enabled. Failure will print verbose assertion details. This is the default.
|
|
|
|
|
|
|
|
- Set to "silent" to save code size (failed assertions will abort() but user
|
|
|
|
needs to use the aborting address to find the line number with the failed assertion.)
|
|
|
|
|
|
|
|
- Disabled entirely (not recommended for most configurations.) -DNDEBUG is added
|
|
|
|
to CPPFLAGS in this case.
|
|
|
|
|
2019-04-24 15:02:25 +02:00
|
|
|
config COMPILER_OPTIMIZATION_ASSERTIONS_ENABLE
|
2018-12-06 15:08:18 +01:00
|
|
|
prompt "Enabled"
|
|
|
|
bool
|
|
|
|
help
|
|
|
|
Enable assertions. Assertion content and line number will be printed on failure.
|
|
|
|
|
2019-04-24 15:02:25 +02:00
|
|
|
config COMPILER_OPTIMIZATION_ASSERTIONS_SILENT
|
2018-12-06 15:08:18 +01:00
|
|
|
prompt "Silent (saves code size)"
|
|
|
|
bool
|
|
|
|
help
|
|
|
|
Enable silent assertions. Failed assertions will abort(), user needs to
|
|
|
|
use the aborting address to find the line number with the failed assertion.
|
|
|
|
|
2019-04-24 15:02:25 +02:00
|
|
|
config COMPILER_OPTIMIZATION_ASSERTIONS_DISABLE
|
2018-12-06 15:08:18 +01:00
|
|
|
prompt "Disabled (sets -DNDEBUG)"
|
|
|
|
bool
|
|
|
|
help
|
|
|
|
If assertions are disabled, -DNDEBUG is added to CPPFLAGS.
|
|
|
|
|
|
|
|
endchoice # assertions
|
|
|
|
|
2022-05-08 17:57:40 +08:00
|
|
|
choice COMPILER_FLOAT_LIB_FROM
|
|
|
|
prompt "Compiler float lib source"
|
|
|
|
default COMPILER_FLOAT_LIB_FROM_RVFPLIB if ESP_ROM_HAS_RVFPLIB
|
|
|
|
default COMPILER_FLOAT_LIB_FROM_GCCLIB
|
|
|
|
help
|
|
|
|
In the soft-fp part of libgcc, riscv version is written in C,
|
|
|
|
and handles all edge cases in IEEE754, which makes it larger
|
|
|
|
and performance is slow.
|
|
|
|
|
|
|
|
RVfplib is an optimized RISC-V library for FP arithmetic on 32-bit
|
|
|
|
integer processors, for single and double-precision FP.
|
|
|
|
RVfplib is "fast", but it has a few exceptions from IEEE 754 compliance.
|
|
|
|
|
|
|
|
config COMPILER_FLOAT_LIB_FROM_GCCLIB
|
|
|
|
bool "libgcc"
|
|
|
|
config COMPILER_FLOAT_LIB_FROM_RVFPLIB
|
|
|
|
depends on ESP_ROM_HAS_RVFPLIB
|
|
|
|
bool "librvfp"
|
|
|
|
endchoice # COMPILER_FLOAT_LIB_FROM
|
|
|
|
|
2021-05-19 10:53:21 +08:00
|
|
|
config COMPILER_OPTIMIZATION_ASSERTION_LEVEL
|
|
|
|
int
|
|
|
|
default 0 if COMPILER_OPTIMIZATION_ASSERTIONS_DISABLE
|
|
|
|
default 1 if COMPILER_OPTIMIZATION_ASSERTIONS_SILENT
|
|
|
|
default 2 if COMPILER_OPTIMIZATION_ASSERTIONS_ENABLE
|
|
|
|
|
2021-03-03 17:18:11 +08:00
|
|
|
config COMPILER_OPTIMIZATION_CHECKS_SILENT
|
|
|
|
bool "Disable messages in ESP_RETURN_ON_* and ESP_EXIT_ON_* macros"
|
|
|
|
default n
|
|
|
|
help
|
|
|
|
If enabled, the error messages will be discarded in following check macros:
|
|
|
|
- ESP_RETURN_ON_ERROR
|
|
|
|
- ESP_EXIT_ON_ERROR
|
|
|
|
- ESP_RETURN_ON_FALSE
|
|
|
|
- ESP_EXIT_ON_FALSE
|
|
|
|
|
2021-02-18 16:02:23 +11:00
|
|
|
menuconfig COMPILER_HIDE_PATHS_MACROS
|
|
|
|
bool "Replace ESP-IDF and project paths in binaries"
|
|
|
|
default y
|
|
|
|
help
|
|
|
|
When expanding the __FILE__ and __BASE_FILE__ macros, replace paths inside ESP-IDF
|
|
|
|
with paths relative to the placeholder string "IDF", and convert paths inside the
|
|
|
|
project directory to relative paths.
|
|
|
|
|
|
|
|
This allows building the project with assertions or other code that embeds file paths,
|
|
|
|
without the binary containing the exact path to the IDF or project directories.
|
|
|
|
|
|
|
|
This option passes -fmacro-prefix-map options to the GCC command line. To replace additional
|
|
|
|
paths in your binaries, modify the project CMakeLists.txt file to pass custom -fmacro-prefix-map or
|
|
|
|
-ffile-prefix-map arguments.
|
|
|
|
|
2019-04-24 15:02:25 +02:00
|
|
|
menuconfig COMPILER_CXX_EXCEPTIONS
|
2018-12-06 15:08:18 +01:00
|
|
|
bool "Enable C++ exceptions"
|
|
|
|
default n
|
|
|
|
help
|
|
|
|
Enabling this option compiles all IDF C++ files with exception support enabled.
|
|
|
|
|
|
|
|
Disabling this option disables C++ exception support in all compiled files, and any libstdc++ code
|
|
|
|
which throws an exception will abort instead.
|
|
|
|
|
|
|
|
Enabling this option currently adds an additional ~500 bytes of heap overhead
|
|
|
|
when an exception is thrown in user code for the first time.
|
|
|
|
|
2019-04-24 15:02:25 +02:00
|
|
|
config COMPILER_CXX_EXCEPTIONS_EMG_POOL_SIZE
|
2018-12-06 15:08:18 +01:00
|
|
|
int "Emergency Pool Size"
|
|
|
|
default 0
|
2019-04-24 15:02:25 +02:00
|
|
|
depends on COMPILER_CXX_EXCEPTIONS
|
2018-12-06 15:08:18 +01:00
|
|
|
help
|
|
|
|
Size (in bytes) of the emergency memory pool for C++ exceptions. This pool will be used to allocate
|
|
|
|
memory for thrown exceptions when there is not enough memory on the heap.
|
|
|
|
|
2019-06-06 16:53:26 +08:00
|
|
|
config COMPILER_CXX_RTTI
|
2019-10-13 14:59:43 +02:00
|
|
|
bool "Enable C++ run-time type info (RTTI)"
|
|
|
|
default n
|
2019-06-06 16:53:26 +08:00
|
|
|
help
|
|
|
|
Enabling this option compiles all C++ files with RTTI support enabled.
|
|
|
|
This increases binary size (typically by tens of kB) but allows using
|
|
|
|
dynamic_cast conversion and typeid operator.
|
|
|
|
|
2019-04-24 15:02:25 +02:00
|
|
|
choice COMPILER_STACK_CHECK_MODE
|
2018-12-06 15:08:18 +01:00
|
|
|
prompt "Stack smashing protection mode"
|
2019-04-24 15:02:25 +02:00
|
|
|
default COMPILER_STACK_CHECK_MODE_NONE
|
2018-12-06 15:08:18 +01:00
|
|
|
help
|
|
|
|
Stack smashing protection mode. Emit extra code to check for buffer overflows, such as stack
|
|
|
|
smashing attacks. This is done by adding a guard variable to functions with vulnerable objects.
|
|
|
|
The guards are initialized when a function is entered and then checked when the function exits.
|
|
|
|
If a guard check fails, program is halted. Protection has the following modes:
|
|
|
|
|
|
|
|
- In NORMAL mode (GCC flag: -fstack-protector) only functions that call alloca, and functions with
|
|
|
|
buffers larger than 8 bytes are protected.
|
|
|
|
|
|
|
|
- STRONG mode (GCC flag: -fstack-protector-strong) is like NORMAL, but includes additional functions
|
|
|
|
to be protected -- those that have local array definitions, or have references to local frame
|
|
|
|
addresses.
|
|
|
|
|
|
|
|
- In OVERALL mode (GCC flag: -fstack-protector-all) all functions are protected.
|
|
|
|
|
|
|
|
Modes have the following impact on code performance and coverage:
|
|
|
|
|
|
|
|
- performance: NORMAL > STRONG > OVERALL
|
|
|
|
|
|
|
|
- coverage: NORMAL < STRONG < OVERALL
|
|
|
|
|
2021-02-19 18:39:26 +11:00
|
|
|
The performance impact includes increasing the amount of stack memory required for each task.
|
2018-12-06 15:08:18 +01:00
|
|
|
|
2019-04-24 15:02:25 +02:00
|
|
|
config COMPILER_STACK_CHECK_MODE_NONE
|
2018-12-06 15:08:18 +01:00
|
|
|
bool "None"
|
2019-04-24 15:02:25 +02:00
|
|
|
config COMPILER_STACK_CHECK_MODE_NORM
|
2018-12-06 15:08:18 +01:00
|
|
|
bool "Normal"
|
2019-04-24 15:02:25 +02:00
|
|
|
config COMPILER_STACK_CHECK_MODE_STRONG
|
2018-12-06 15:08:18 +01:00
|
|
|
bool "Strong"
|
2019-04-24 15:02:25 +02:00
|
|
|
config COMPILER_STACK_CHECK_MODE_ALL
|
2018-12-06 15:08:18 +01:00
|
|
|
bool "Overall"
|
|
|
|
endchoice
|
|
|
|
|
2019-04-24 15:02:25 +02:00
|
|
|
config COMPILER_STACK_CHECK
|
2018-12-06 15:08:18 +01:00
|
|
|
bool
|
2019-04-24 15:02:25 +02:00
|
|
|
default !COMPILER_STACK_CHECK_MODE_NONE
|
2018-12-06 15:08:18 +01:00
|
|
|
help
|
|
|
|
Stack smashing protection.
|
|
|
|
|
2019-04-24 15:02:25 +02:00
|
|
|
config COMPILER_WARN_WRITE_STRINGS
|
2018-12-06 15:08:18 +01:00
|
|
|
bool "Enable -Wwrite-strings warning flag"
|
|
|
|
default "n"
|
|
|
|
help
|
|
|
|
Adds -Wwrite-strings flag for the C/C++ compilers.
|
|
|
|
|
|
|
|
For C, this gives string constants the type ``const char[]`` so that
|
|
|
|
copying the address of one into a non-const ``char *`` pointer
|
|
|
|
produces a warning. This warning helps to find at compile time code
|
|
|
|
that tries to write into a string constant.
|
|
|
|
|
|
|
|
For C++, this warns about the deprecated conversion from string
|
|
|
|
literals to ``char *``.
|
|
|
|
|
2021-08-18 12:02:20 +05:00
|
|
|
config COMPILER_SAVE_RESTORE_LIBCALLS
|
|
|
|
bool "Enable -msave-restore flag to reduce code size"
|
|
|
|
depends on IDF_TARGET_ARCH_RISCV
|
|
|
|
help
|
|
|
|
Adds -msave-restore to C/C++ compilation flags.
|
|
|
|
|
|
|
|
When this flag is enabled, compiler will call library functions to
|
|
|
|
save/restore registers in function prologues/epilogues. This results
|
|
|
|
in lower overall code size, at the expense of slightly reduced performance.
|
|
|
|
|
|
|
|
This option can be enabled for RISC-V targets only.
|
|
|
|
|
2023-02-15 15:01:52 +07:00
|
|
|
config COMPILER_DISABLE_GCC12_WARNINGS
|
|
|
|
bool "Disable new warnings introduced in GCC 12"
|
|
|
|
default "n"
|
|
|
|
help
|
|
|
|
Enable this option if use GCC 12 or newer, and want to disable warnings which don't appear with
|
|
|
|
GCC 11.
|
|
|
|
|
2023-07-12 12:28:58 +04:00
|
|
|
config COMPILER_DISABLE_GCC13_WARNINGS
|
|
|
|
bool "Disable new warnings introduced in GCC 13"
|
|
|
|
default "n"
|
|
|
|
help
|
|
|
|
Enable this option if use GCC 13 or newer, and want to disable warnings which don't appear with
|
|
|
|
GCC 12.
|
|
|
|
|
2020-07-07 20:40:17 +02:00
|
|
|
config COMPILER_DUMP_RTL_FILES
|
|
|
|
bool "Dump RTL files during compilation"
|
|
|
|
help
|
|
|
|
If enabled, RTL files will be produced during compilation. These files
|
|
|
|
can be used by other tools, for example to calculate call graphs.
|
|
|
|
|
2022-11-23 15:00:11 +03:00
|
|
|
choice COMPILER_RT_LIB
|
|
|
|
prompt "Compiler runtime library"
|
|
|
|
default COMPILER_RT_LIB_CLANGRT if IDF_TOOLCHAIN_CLANG
|
2023-06-14 16:40:04 +02:00
|
|
|
default COMPILER_RT_LIB_HOST if IDF_TARGET_LINUX
|
2022-11-23 15:00:11 +03:00
|
|
|
default COMPILER_RT_LIB_GCCLIB
|
|
|
|
help
|
|
|
|
Select runtime library to be used by compiler.
|
|
|
|
- GCC toolchain supports libgcc only.
|
|
|
|
- Clang allows to choose between libgcc or libclang_rt.
|
2023-06-14 16:40:04 +02:00
|
|
|
- For host builds ("linux" target), uses the default library.
|
2022-11-23 15:00:11 +03:00
|
|
|
|
|
|
|
config COMPILER_RT_LIB_GCCLIB
|
2023-06-14 16:40:04 +02:00
|
|
|
depends on !IDF_TARGET_LINUX
|
2022-11-23 15:00:11 +03:00
|
|
|
bool "libgcc"
|
|
|
|
config COMPILER_RT_LIB_CLANGRT
|
2023-06-14 16:40:04 +02:00
|
|
|
depends on IDF_TOOLCHAIN_CLANG && !IDF_TARGET_LINUX
|
2022-11-23 15:00:11 +03:00
|
|
|
bool "libclang_rt"
|
2023-06-14 16:40:04 +02:00
|
|
|
config COMPILER_RT_LIB_HOST
|
|
|
|
depends on IDF_TARGET_LINUX
|
|
|
|
bool "Host"
|
2022-11-23 15:00:11 +03:00
|
|
|
endchoice
|
|
|
|
|
|
|
|
config COMPILER_RT_LIB_NAME
|
|
|
|
string
|
|
|
|
default "clang_rt.builtins" if COMPILER_RT_LIB_CLANGRT
|
|
|
|
default "gcc" if COMPILER_RT_LIB_GCCLIB
|
2023-06-14 16:40:04 +02:00
|
|
|
default "" if COMPILER_RT_LIB_HOST
|
2022-11-23 15:00:11 +03:00
|
|
|
|
2018-12-06 15:08:18 +01:00
|
|
|
endmenu # Compiler Options
|
|
|
|
|
|
|
|
menu "Component config"
|
2019-09-10 09:58:52 +02:00
|
|
|
source "$COMPONENT_KCONFIGS_SOURCE_FILE"
|
2018-12-06 15:08:18 +01:00
|
|
|
endmenu
|
2023-03-28 17:35:35 +08:00
|
|
|
|
|
|
|
config IDF_EXPERIMENTAL_FEATURES
|
|
|
|
bool "Make experimental features visible"
|
|
|
|
default "n"
|
|
|
|
help
|
|
|
|
By enabling this option, ESP-IDF experimental feature options will be visible.
|
|
|
|
|
|
|
|
Note you should still enable a certain experimental feature option to use it, and you
|
|
|
|
should read the corresponding risk warning and known issue list carefully.
|
2023-06-01 12:04:16 +08:00
|
|
|
|
|
|
|
Current experimental feature list:
|
|
|
|
|
2023-06-24 20:38:53 +08:00
|
|
|
- CONFIG_ESPTOOLPY_FLASHFREQ_120M && CONFIG_ESPTOOLPY_FLASH_SAMPLE_MODE_DTR
|
|
|
|
- CONFIG_SPIRAM_SPEED_120M && CONFIG_SPIRAM_MODE_OCT
|
|
|
|
- CONFIG_BOOTLOADER_CACHE_32BIT_ADDR_QUAD_FLASH
|
2023-08-08 20:58:44 +08:00
|
|
|
- CONFIG_MBEDTLS_USE_CRYPTO_ROM_IMPL
|