2018-06-11 19:54:18 +08:00
|
|
|
menu "Driver configurations"
|
2018-03-07 15:04:43 +08:00
|
|
|
|
2019-01-25 17:10:53 +01:00
|
|
|
menu "ADC configuration"
|
2018-03-07 15:04:43 +08:00
|
|
|
|
2019-01-25 17:10:53 +01:00
|
|
|
config ADC_FORCE_XPD_FSM
|
|
|
|
bool "Use the FSM to control ADC power"
|
|
|
|
default n
|
|
|
|
help
|
|
|
|
ADC power can be controlled by the FSM instead of software. This allows the ADC to
|
|
|
|
be shut off when it is not working leading to lower power consumption. However
|
|
|
|
using the FSM control ADC power will increase the noise of ADC.
|
2018-03-07 15:04:43 +08:00
|
|
|
|
2019-04-29 14:22:57 +02:00
|
|
|
config ADC_DISABLE_DAC
|
2019-01-25 17:10:53 +01:00
|
|
|
bool "Disable DAC when ADC2 is used on GPIO 25 and 26"
|
|
|
|
default y
|
|
|
|
help
|
2019-04-29 14:22:57 +02:00
|
|
|
If this is set, the ADC2 driver will disable the output of the DAC corresponding to the specified
|
2019-01-25 17:10:53 +01:00
|
|
|
channel. This is the default value.
|
2018-01-24 18:46:34 +08:00
|
|
|
|
2019-01-25 17:10:53 +01:00
|
|
|
For testing, disable this option so that we can measure the output of DAC by internal ADC.
|
2018-01-24 18:46:34 +08:00
|
|
|
|
2019-01-25 17:10:53 +01:00
|
|
|
endmenu # ADC Configuration
|
2018-03-07 15:04:43 +08:00
|
|
|
|
2019-01-25 17:10:53 +01:00
|
|
|
menu "SPI configuration"
|
2018-03-07 15:04:43 +08:00
|
|
|
|
2019-01-25 17:10:53 +01:00
|
|
|
config SPI_MASTER_IN_IRAM
|
|
|
|
bool "Place transmitting functions of SPI master into IRAM"
|
|
|
|
default n
|
|
|
|
select SPI_MASTER_ISR_IN_IRAM
|
|
|
|
help
|
|
|
|
Normally only the ISR of SPI master is placed in the IRAM, so that it
|
|
|
|
can work without the flash when interrupt is triggered.
|
|
|
|
For other functions, there's some possibility that the flash cache
|
|
|
|
miss when running inside and out of SPI functions, which may increase
|
|
|
|
the interval of SPI transactions.
|
|
|
|
Enable this to put ``queue_trans``, ``get_trans_result`` and
|
|
|
|
``transmit`` functions into the IRAM to avoid possible cache miss.
|
2018-06-11 19:54:18 +08:00
|
|
|
|
2019-01-25 17:10:53 +01:00
|
|
|
During unit test, this is enabled to measure the ideal case of api.
|
2018-06-11 19:54:18 +08:00
|
|
|
|
2019-01-25 17:10:53 +01:00
|
|
|
config SPI_MASTER_ISR_IN_IRAM
|
|
|
|
bool "Place SPI master ISR function into IRAM"
|
|
|
|
default y
|
|
|
|
help
|
|
|
|
Place the SPI master ISR in to IRAM to avoid possible cache miss.
|
2018-10-23 16:57:32 +08:00
|
|
|
|
2019-01-25 17:10:53 +01:00
|
|
|
Also you can forbid the ISR being disabled during flash writing
|
|
|
|
access, by add ESP_INTR_FLAG_IRAM when initializing the driver.
|
2018-06-11 19:54:18 +08:00
|
|
|
|
2019-01-25 17:10:53 +01:00
|
|
|
config SPI_SLAVE_IN_IRAM
|
|
|
|
bool "Place transmitting functions of SPI slave into IRAM"
|
|
|
|
default n
|
|
|
|
select SPI_SLAVE_ISR_IN_IRAM
|
|
|
|
help
|
|
|
|
Normally only the ISR of SPI slave is placed in the IRAM, so that it
|
|
|
|
can work without the flash when interrupt is triggered.
|
|
|
|
For other functions, there's some possibility that the flash cache
|
|
|
|
miss when running inside and out of SPI functions, which may increase
|
|
|
|
the interval of SPI transactions.
|
|
|
|
Enable this to put ``queue_trans``, ``get_trans_result`` and
|
|
|
|
``transmit`` functions into the IRAM to avoid possible cache miss.
|
2018-08-20 18:30:40 +08:00
|
|
|
|
2019-01-25 17:10:53 +01:00
|
|
|
config SPI_SLAVE_ISR_IN_IRAM
|
|
|
|
bool "Place SPI slave ISR function into IRAM"
|
|
|
|
default y
|
|
|
|
help
|
|
|
|
Place the SPI slave ISR in to IRAM to avoid possible cache miss.
|
2018-10-23 16:57:32 +08:00
|
|
|
|
2019-01-25 17:10:53 +01:00
|
|
|
Also you can forbid the ISR being disabled during flash writing
|
|
|
|
access, by add ESP_INTR_FLAG_IRAM when initializing the driver.
|
2018-08-20 18:30:40 +08:00
|
|
|
|
2019-01-25 17:10:53 +01:00
|
|
|
endmenu # SPI Configuration
|
2018-06-11 19:54:18 +08:00
|
|
|
|
2020-11-23 23:41:09 +08:00
|
|
|
menu "CAN Configuration"
|
|
|
|
|
|
|
|
config CAN_ISR_IN_IRAM
|
|
|
|
bool "Place CAN ISR function into IRAM"
|
|
|
|
default n
|
|
|
|
select SUPPORT_STATIC_ALLOCATION
|
|
|
|
# We need to enable FREERTOS_SUPPORT_STATIC_ALLOCATION because the
|
|
|
|
# CAN driver requires the use of FreeRTOS Queues and Semaphores from
|
|
|
|
# the driver ISR. These Queues and Semaphores need to be placed in
|
|
|
|
# DRAM thus FreeRTOS static allocation API is required.
|
|
|
|
help
|
|
|
|
Place the CAN ISR in to IRAM. This will allow the ISR to avoid
|
|
|
|
cache misses, and also be able to run whilst the cache is disabled
|
|
|
|
(such as when writing to SPI Flash).
|
|
|
|
Note that if this option is enabled:
|
|
|
|
- Users should also set the ESP_INTR_FLAG_IRAM in the driver
|
|
|
|
configuration structure when installing the driver (see docs for
|
|
|
|
specifics).
|
|
|
|
- Alert logging (i.e., setting of the CAN_ALERT_AND_LOG flag)
|
|
|
|
will have no effect.
|
|
|
|
|
|
|
|
endmenu # CAN Configuration
|
|
|
|
|
2021-04-14 17:57:32 +08:00
|
|
|
menu "UART configuration"
|
|
|
|
|
|
|
|
config UART_ISR_IN_IRAM
|
|
|
|
bool "Place UART ISR function into IRAM"
|
|
|
|
default n
|
|
|
|
help
|
|
|
|
If this option is not selected, UART interrupt will be disabled for a long time and
|
|
|
|
may cause data lost when doing spi flash operation.
|
|
|
|
|
|
|
|
endmenu # UART Configuration
|
|
|
|
|
2018-06-11 19:54:18 +08:00
|
|
|
endmenu # Driver configurations
|