2016-08-17 23:08:22 +08:00
|
|
|
menu "Serial flasher config"
|
2023-01-30 18:03:59 +08:00
|
|
|
depends on !APP_BUILD_TYPE_PURE_RAM_APP
|
2016-08-17 23:08:22 +08:00
|
|
|
|
2020-08-21 04:28:05 +03:00
|
|
|
config ESPTOOLPY_NO_STUB
|
|
|
|
bool "Disable download stub"
|
2023-06-20 16:04:41 +08:00
|
|
|
default "y" if IDF_ENV_FPGA || IDF_ENV_BRINGUP
|
2020-08-21 04:28:05 +03:00
|
|
|
default "n"
|
2021-09-02 20:48:39 +08:00
|
|
|
|
2020-08-21 04:28:05 +03:00
|
|
|
help
|
|
|
|
The flasher tool sends a precompiled download stub first by default. That stub allows things
|
|
|
|
like compressed downloads and more. Usually you should not need to disable that feature
|
2020-04-25 16:44:27 +10:00
|
|
|
|
2021-04-15 17:13:48 +08:00
|
|
|
config ESPTOOLPY_OCT_FLASH
|
|
|
|
depends on IDF_TARGET_ESP32S3
|
|
|
|
bool "Enable Octal Flash"
|
|
|
|
default n
|
|
|
|
|
2022-09-23 17:32:16 +08:00
|
|
|
config ESPTOOLPY_FLASH_MODE_AUTO_DETECT
|
|
|
|
depends on IDF_TARGET_ESP32S3
|
|
|
|
bool "Choose flash mode automatically (please read help)"
|
|
|
|
default y
|
|
|
|
help
|
|
|
|
This config option helps decide whether flash is Quad or Octal, but please note some limitations:
|
|
|
|
|
|
|
|
1. If the flash chip is an Octal one, even if one of "QIO", "QOUT", "DIO", "DOUT" options is
|
|
|
|
selected in `ESPTOOLPY_FLASHMODE`, our code will automatically change the
|
|
|
|
mode to "OPI" and the sample mode will be STR.
|
|
|
|
2. If the flash chip is a Quad one, even if "OPI" is selected in `ESPTOOLPY_FLASHMODE`, our code will
|
|
|
|
automatically change the mode to "DIO".
|
2023-06-24 20:38:53 +08:00
|
|
|
3. This option is mainly to improve the out-of-box experience of developers. It doesn't guarantee
|
|
|
|
the feature-complete. Some code still rely on `ESPTOOLPY_OCT_FLASH`. Please do not rely on this option
|
|
|
|
when you are pretty sure that you are using Octal flash.
|
|
|
|
In this case, please enable `ESPTOOLPY_OCT_FLASH` option, then you can choose `DTR` sample mode
|
2022-09-23 17:32:16 +08:00
|
|
|
in `ESPTOOLPY_FLASH_SAMPLE_MODE`. Otherwise, only `STR` mode is available.
|
|
|
|
4. Enabling this feature reduces available internal RAM size (around 900 bytes).
|
|
|
|
If your IRAM space is insufficient and you're aware of your flash type,
|
|
|
|
disable this option and select corresponding flash type options.
|
|
|
|
|
2019-05-09 13:39:30 +02:00
|
|
|
choice ESPTOOLPY_FLASHMODE
|
2019-01-25 17:10:53 +01:00
|
|
|
prompt "Flash SPI mode"
|
2019-05-09 13:39:30 +02:00
|
|
|
default ESPTOOLPY_FLASHMODE_DIO
|
2021-09-01 15:58:15 +08:00
|
|
|
default ESPTOOLPY_FLASHMODE_OPI if ESPTOOLPY_OCT_FLASH
|
2019-01-25 17:10:53 +01:00
|
|
|
help
|
|
|
|
Mode the flash chip is flashed in, as well as the default mode for the
|
|
|
|
binary to run in.
|
|
|
|
|
2019-05-09 13:39:30 +02:00
|
|
|
config ESPTOOLPY_FLASHMODE_QIO
|
2021-09-01 15:58:15 +08:00
|
|
|
depends on !ESPTOOLPY_OCT_FLASH
|
2019-01-25 17:10:53 +01:00
|
|
|
bool "QIO"
|
2019-05-09 13:39:30 +02:00
|
|
|
config ESPTOOLPY_FLASHMODE_QOUT
|
2021-09-01 15:58:15 +08:00
|
|
|
depends on !ESPTOOLPY_OCT_FLASH
|
2019-01-25 17:10:53 +01:00
|
|
|
bool "QOUT"
|
2019-05-09 13:39:30 +02:00
|
|
|
config ESPTOOLPY_FLASHMODE_DIO
|
2021-09-01 15:58:15 +08:00
|
|
|
depends on !ESPTOOLPY_OCT_FLASH
|
2019-01-25 17:10:53 +01:00
|
|
|
bool "DIO"
|
2019-05-09 13:39:30 +02:00
|
|
|
config ESPTOOLPY_FLASHMODE_DOUT
|
2021-09-01 15:58:15 +08:00
|
|
|
depends on !ESPTOOLPY_OCT_FLASH
|
2019-01-25 17:10:53 +01:00
|
|
|
bool "DOUT"
|
2021-09-01 15:58:15 +08:00
|
|
|
config ESPTOOLPY_FLASHMODE_OPI
|
|
|
|
depends on ESPTOOLPY_OCT_FLASH
|
|
|
|
bool "OPI"
|
|
|
|
endchoice
|
|
|
|
|
2021-09-09 15:34:42 +08:00
|
|
|
choice ESPTOOLPY_FLASH_SAMPLE_MODE
|
|
|
|
prompt "Flash Sampling Mode"
|
|
|
|
default ESPTOOLPY_FLASH_SAMPLE_MODE_DTR if ESPTOOLPY_OCT_FLASH
|
|
|
|
default ESPTOOLPY_FLASH_SAMPLE_MODE_STR if !ESPTOOLPY_OCT_FLASH
|
|
|
|
|
|
|
|
config ESPTOOLPY_FLASH_SAMPLE_MODE_STR
|
|
|
|
bool "STR Mode"
|
|
|
|
config ESPTOOLPY_FLASH_SAMPLE_MODE_DTR
|
|
|
|
depends on ESPTOOLPY_OCT_FLASH
|
|
|
|
bool "DTR Mode"
|
2019-01-25 17:10:53 +01:00
|
|
|
endchoice
|
|
|
|
|
|
|
|
# Note: we use esptool.py to flash bootloader in
|
|
|
|
# dio mode for QIO/QOUT, bootloader then upgrades
|
|
|
|
# itself to quad mode during initialisation
|
|
|
|
config ESPTOOLPY_FLASHMODE
|
|
|
|
string
|
2019-05-09 13:39:30 +02:00
|
|
|
default "dio" if ESPTOOLPY_FLASHMODE_QIO
|
|
|
|
default "dio" if ESPTOOLPY_FLASHMODE_QOUT
|
|
|
|
default "dio" if ESPTOOLPY_FLASHMODE_DIO
|
|
|
|
default "dout" if ESPTOOLPY_FLASHMODE_DOUT
|
2021-09-01 15:58:15 +08:00
|
|
|
# The 1st and 2nd bootloader doesn't support opi mode,
|
|
|
|
# using fastrd instead. For now the ESPTOOL doesn't support
|
|
|
|
# fasted (see ESPTOOL-274), using dout instead. In ROM the flash mode
|
|
|
|
# information get from efuse, so don't care this dout choice.
|
|
|
|
default "dout" if ESPTOOLPY_FLASHMODE_OPI
|
2019-01-25 17:10:53 +01:00
|
|
|
|
|
|
|
choice ESPTOOLPY_FLASHFREQ
|
|
|
|
prompt "Flash SPI speed"
|
2023-12-19 13:49:26 +08:00
|
|
|
# TODO: [ESP32C5] IDF-8649 switch back to 80M
|
|
|
|
default ESPTOOLPY_FLASHFREQ_40M if IDF_TARGET_ESP32 || IDF_TARGET_ESP32C5
|
2022-11-18 17:59:05 +08:00
|
|
|
default ESPTOOLPY_FLASHFREQ_80M if ESPTOOLPY_FLASHFREQ_80M_DEFAULT
|
2022-04-12 16:37:40 +08:00
|
|
|
default ESPTOOLPY_FLASHFREQ_60M if IDF_TARGET_ESP32C2
|
2021-08-05 11:40:22 +08:00
|
|
|
config ESPTOOLPY_FLASHFREQ_120M
|
2023-06-24 20:38:53 +08:00
|
|
|
bool "120 MHz (READ DOCS FIRST)"
|
2023-03-28 17:35:35 +08:00
|
|
|
depends on SOC_MEMSPI_SRC_FREQ_120M && \
|
2023-06-24 20:38:53 +08:00
|
|
|
(SPI_FLASH_HPM_ON || ESPTOOLPY_OCT_FLASH) && \
|
2023-03-28 17:35:35 +08:00
|
|
|
(ESPTOOLPY_FLASH_SAMPLE_MODE_STR || IDF_EXPERIMENTAL_FEATURES)
|
|
|
|
help
|
2023-06-24 20:38:53 +08:00
|
|
|
- Optional feature for QSPI Flash. Read docs and enable `CONFIG_SPI_FLASH_HPM_ENA` first!
|
2023-03-28 17:35:35 +08:00
|
|
|
- Flash 120 MHz SDR mode is stable.
|
|
|
|
- Flash 120 MHz DDR mode is an experimental feature, it works when
|
|
|
|
the temperature is stable.
|
|
|
|
|
|
|
|
Risks:
|
|
|
|
If your chip powers on at a certain temperature, then after the temperature
|
|
|
|
increases or decreases by approximately 20 Celsius degrees (depending on the
|
|
|
|
chip), the program will crash randomly.
|
|
|
|
|
2019-01-25 17:10:53 +01:00
|
|
|
config ESPTOOLPY_FLASHFREQ_80M
|
|
|
|
bool "80 MHz"
|
2022-04-12 16:37:40 +08:00
|
|
|
depends on SOC_MEMSPI_SRC_FREQ_80M_SUPPORTED
|
2023-02-22 17:31:48 +08:00
|
|
|
config ESPTOOLPY_FLASHFREQ_64M
|
|
|
|
bool "64 MHz"
|
|
|
|
depends on SOC_MEMSPI_SRC_FREQ_64M_SUPPORTED
|
2022-04-12 16:37:40 +08:00
|
|
|
config ESPTOOLPY_FLASHFREQ_60M
|
|
|
|
bool "60 MHz"
|
|
|
|
depends on SOC_MEMSPI_SRC_FREQ_60M_SUPPORTED
|
|
|
|
config ESPTOOLPY_FLASHFREQ_48M
|
|
|
|
bool "48 MHz"
|
|
|
|
depends on SOC_MEMSPI_SRC_FREQ_48M_SUPPORTED
|
2019-01-25 17:10:53 +01:00
|
|
|
config ESPTOOLPY_FLASHFREQ_40M
|
|
|
|
bool "40 MHz"
|
2022-04-12 16:37:40 +08:00
|
|
|
depends on SOC_MEMSPI_SRC_FREQ_40M_SUPPORTED
|
2023-02-22 17:31:48 +08:00
|
|
|
config ESPTOOLPY_FLASHFREQ_32M
|
|
|
|
bool "32 MHz"
|
|
|
|
depends on SOC_MEMSPI_SRC_FREQ_32M_SUPPORTED
|
2022-04-12 16:37:40 +08:00
|
|
|
config ESPTOOLPY_FLASHFREQ_30M
|
|
|
|
bool "30 MHz"
|
|
|
|
depends on SOC_MEMSPI_SRC_FREQ_30M_SUPPORTED
|
2019-01-25 17:10:53 +01:00
|
|
|
config ESPTOOLPY_FLASHFREQ_26M
|
|
|
|
bool "26 MHz"
|
2022-04-12 16:37:40 +08:00
|
|
|
depends on SOC_MEMSPI_SRC_FREQ_26M_SUPPORTED
|
|
|
|
config ESPTOOLPY_FLASHFREQ_24M
|
|
|
|
bool "24 MHz"
|
|
|
|
depends on SOC_MEMSPI_SRC_FREQ_24M_SUPPORTED
|
2019-01-25 17:10:53 +01:00
|
|
|
config ESPTOOLPY_FLASHFREQ_20M
|
|
|
|
bool "20 MHz"
|
2022-04-12 16:37:40 +08:00
|
|
|
depends on SOC_MEMSPI_SRC_FREQ_20M_SUPPORTED
|
2023-02-22 17:31:48 +08:00
|
|
|
config ESPTOOLPY_FLASHFREQ_16M
|
|
|
|
bool "16 MHz"
|
|
|
|
depends on SOC_MEMSPI_SRC_FREQ_16M_SUPPORTED
|
2022-04-12 16:37:40 +08:00
|
|
|
config ESPTOOLPY_FLASHFREQ_15M
|
|
|
|
bool "15 MHz"
|
|
|
|
depends on SOC_MEMSPI_SRC_FREQ_15M_SUPPORTED
|
2019-01-25 17:10:53 +01:00
|
|
|
endchoice
|
|
|
|
|
2022-11-18 17:59:05 +08:00
|
|
|
config ESPTOOLPY_FLASHFREQ_80M_DEFAULT
|
|
|
|
bool
|
|
|
|
default y if IDF_TARGET_ESP32S2 || IDF_TARGET_ESP32S3 || IDF_TARGET_ESP32C3 || IDF_TARGET_ESP32C6
|
|
|
|
help
|
|
|
|
This is an invisible item, used to define the targets that defaults to use 80MHz Flash SPI speed.
|
|
|
|
|
2019-01-25 17:10:53 +01:00
|
|
|
config ESPTOOLPY_FLASHFREQ
|
|
|
|
string
|
2021-08-05 11:40:22 +08:00
|
|
|
# On some of the ESP chips, max boot frequency would be equal to (or even lower than) 80m.
|
|
|
|
# We currently define this to `80m`.
|
2022-04-12 16:37:40 +08:00
|
|
|
default '80m' if ESPTOOLPY_FLASHFREQ_120M
|
|
|
|
default '80m' if ESPTOOLPY_FLASHFREQ_80M
|
|
|
|
default '60m' if ESPTOOLPY_FLASHFREQ_60M
|
2023-02-22 17:31:48 +08:00
|
|
|
default '48m' if ESPTOOLPY_FLASHFREQ_64M # For 0xf in esptool
|
2022-04-12 16:37:40 +08:00
|
|
|
default '48m' if ESPTOOLPY_FLASHFREQ_48M
|
2023-02-22 17:31:48 +08:00
|
|
|
default '24m' if ESPTOOLPY_FLASHFREQ_32M # For 0x0 in esptool
|
2022-04-12 16:37:40 +08:00
|
|
|
default '30m' if ESPTOOLPY_FLASHFREQ_30M
|
|
|
|
default '24m' if ESPTOOLPY_FLASHFREQ_24M
|
|
|
|
default '40m' if ESPTOOLPY_FLASHFREQ_40M
|
|
|
|
default '26m' if ESPTOOLPY_FLASHFREQ_26M
|
|
|
|
default '20m' if ESPTOOLPY_FLASHFREQ_20M
|
2023-02-22 17:31:48 +08:00
|
|
|
default '12m' if ESPTOOLPY_FLASHFREQ_16M # For 0x2 in esptool
|
2022-04-12 16:37:40 +08:00
|
|
|
default '20m' # if no clock can match in bin headers, go with minimal.
|
2019-01-25 17:10:53 +01:00
|
|
|
|
|
|
|
|
|
|
|
choice ESPTOOLPY_FLASHSIZE
|
|
|
|
prompt "Flash size"
|
|
|
|
default ESPTOOLPY_FLASHSIZE_2MB
|
|
|
|
help
|
|
|
|
SPI flash size, in megabytes
|
|
|
|
|
|
|
|
config ESPTOOLPY_FLASHSIZE_1MB
|
|
|
|
bool "1 MB"
|
|
|
|
config ESPTOOLPY_FLASHSIZE_2MB
|
|
|
|
bool "2 MB"
|
|
|
|
config ESPTOOLPY_FLASHSIZE_4MB
|
|
|
|
bool "4 MB"
|
|
|
|
config ESPTOOLPY_FLASHSIZE_8MB
|
|
|
|
bool "8 MB"
|
|
|
|
config ESPTOOLPY_FLASHSIZE_16MB
|
|
|
|
bool "16 MB"
|
2021-10-13 22:37:10 +02:00
|
|
|
config ESPTOOLPY_FLASHSIZE_32MB
|
|
|
|
bool "32 MB"
|
|
|
|
config ESPTOOLPY_FLASHSIZE_64MB
|
|
|
|
bool "64 MB"
|
|
|
|
config ESPTOOLPY_FLASHSIZE_128MB
|
|
|
|
bool "128 MB"
|
2019-01-25 17:10:53 +01:00
|
|
|
endchoice
|
|
|
|
|
|
|
|
config ESPTOOLPY_FLASHSIZE
|
|
|
|
string
|
|
|
|
default "1MB" if ESPTOOLPY_FLASHSIZE_1MB
|
|
|
|
default "2MB" if ESPTOOLPY_FLASHSIZE_2MB
|
|
|
|
default "4MB" if ESPTOOLPY_FLASHSIZE_4MB
|
|
|
|
default "8MB" if ESPTOOLPY_FLASHSIZE_8MB
|
|
|
|
default "16MB" if ESPTOOLPY_FLASHSIZE_16MB
|
2021-10-13 22:37:10 +02:00
|
|
|
default "32MB" if ESPTOOLPY_FLASHSIZE_32MB
|
|
|
|
default "64MB" if ESPTOOLPY_FLASHSIZE_64MB
|
|
|
|
default "128MB" if ESPTOOLPY_FLASHSIZE_128MB
|
2019-01-25 17:10:53 +01:00
|
|
|
|
2022-06-14 13:39:50 +02:00
|
|
|
config ESPTOOLPY_HEADER_FLASHSIZE_UPDATE
|
2019-01-25 17:10:53 +01:00
|
|
|
bool "Detect flash size when flashing bootloader"
|
2022-05-25 11:33:50 +02:00
|
|
|
default n
|
2019-01-25 17:10:53 +01:00
|
|
|
help
|
2019-06-23 11:54:31 +10:00
|
|
|
If this option is set, flashing the project will automatically detect
|
|
|
|
the flash size of the target chip and update the bootloader image
|
|
|
|
before it is flashed.
|
2019-01-25 17:10:53 +01:00
|
|
|
|
2022-05-25 11:33:50 +02:00
|
|
|
Enabling this option turns off the image protection against corruption
|
|
|
|
by a SHA256 digest. Updating the bootloader image before flashing would
|
|
|
|
invalidate the digest.
|
|
|
|
|
2019-01-25 17:10:53 +01:00
|
|
|
choice ESPTOOLPY_BEFORE
|
|
|
|
prompt "Before flashing"
|
|
|
|
default ESPTOOLPY_BEFORE_RESET
|
|
|
|
help
|
|
|
|
Configure whether esptool.py should reset the ESP32 before flashing.
|
|
|
|
|
|
|
|
Automatic resetting depends on the RTS & DTR signals being
|
|
|
|
wired from the serial port to the ESP32. Most USB development
|
|
|
|
boards do this internally.
|
|
|
|
|
|
|
|
config ESPTOOLPY_BEFORE_RESET
|
|
|
|
bool "Reset to bootloader"
|
|
|
|
config ESPTOOLPY_BEFORE_NORESET
|
|
|
|
bool "No reset"
|
|
|
|
endchoice
|
|
|
|
|
|
|
|
config ESPTOOLPY_BEFORE
|
|
|
|
string
|
|
|
|
default "default_reset" if ESPTOOLPY_BEFORE_RESET
|
|
|
|
default "no_reset" if ESPTOOLPY_BEFORE_NORESET
|
|
|
|
|
|
|
|
choice ESPTOOLPY_AFTER
|
|
|
|
prompt "After flashing"
|
|
|
|
default ESPTOOLPY_AFTER_RESET
|
|
|
|
help
|
|
|
|
Configure whether esptool.py should reset the ESP32 after flashing.
|
|
|
|
|
|
|
|
Automatic resetting depends on the RTS & DTR signals being
|
|
|
|
wired from the serial port to the ESP32. Most USB development
|
|
|
|
boards do this internally.
|
|
|
|
|
|
|
|
config ESPTOOLPY_AFTER_RESET
|
|
|
|
bool "Reset after flashing"
|
|
|
|
config ESPTOOLPY_AFTER_NORESET
|
|
|
|
bool "Stay in bootloader"
|
|
|
|
endchoice
|
|
|
|
|
|
|
|
config ESPTOOLPY_AFTER
|
|
|
|
string
|
|
|
|
default "hard_reset" if ESPTOOLPY_AFTER_RESET
|
|
|
|
default "no_reset" if ESPTOOLPY_AFTER_NORESET
|
|
|
|
|
2019-05-09 13:39:30 +02:00
|
|
|
config ESPTOOLPY_MONITOR_BAUD
|
2019-01-25 17:10:53 +01:00
|
|
|
int
|
2022-01-24 17:54:04 +01:00
|
|
|
default ESP_CONSOLE_UART_BAUDRATE if ESP_CONSOLE_UART
|
|
|
|
default 115200 if !ESP_CONSOLE_UART
|
2016-08-17 23:08:22 +08:00
|
|
|
endmenu
|