mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
203 lines
7.6 KiB
Plaintext
203 lines
7.6 KiB
Plaintext
menu "Modbus configuration"
|
|
|
|
config FMB_COMM_MODE_RTU_EN
|
|
bool "Enable Modbus stack support for RTU mode"
|
|
default y
|
|
help
|
|
Enable RTU Modbus communication mode option for Modbus serial stack.
|
|
|
|
config FMB_COMM_MODE_ASCII_EN
|
|
bool "Enable Modbus stack support for ASCII mode"
|
|
default y
|
|
help
|
|
Enable ASCII Modbus communication mode option for Modbus serial stack.
|
|
|
|
config FMB_MASTER_TIMEOUT_MS_RESPOND
|
|
int "Slave respond timeout (Milliseconds)"
|
|
default 150
|
|
range 50 400
|
|
help
|
|
If master sends a frame which is not broadcast, it has to wait sometime for slave response.
|
|
if slave is not respond in this time, the master will process timeout error.
|
|
|
|
config FMB_MASTER_DELAY_MS_CONVERT
|
|
int "Slave conversion delay (Milliseconds)"
|
|
default 200
|
|
range 50 400
|
|
help
|
|
If master sends a broadcast frame, it has to wait conversion time to delay,
|
|
then master can send next frame.
|
|
|
|
config FMB_QUEUE_LENGTH
|
|
int "Modbus serial task queue length"
|
|
range 0 200
|
|
default 20
|
|
help
|
|
Modbus serial driver queue length. It is used by event queue task.
|
|
See the serial driver API for more information.
|
|
|
|
config FMB_SERIAL_TASK_STACK_SIZE
|
|
int "Modbus serial task stack size"
|
|
range 768 8192
|
|
default 2048
|
|
help
|
|
Modbus serial task stack size for event queue task.
|
|
It may be adjusted when debugging is enabled (for example).
|
|
|
|
config FMB_SERIAL_BUF_SIZE
|
|
int "Modbus serial task RX/TX buffer size"
|
|
range 0 2048
|
|
default 256
|
|
help
|
|
Modbus serial task RX and TX buffer size for UART driver initialization.
|
|
This buffer is used for modbus frame transfer. The Modbus protocol maximum
|
|
frame size is 256 bytes. Bigger size can be used for non standard implementations.
|
|
|
|
config FMB_SERIAL_ASCII_BITS_PER_SYMB
|
|
int "Number of data bits per ASCII character"
|
|
default 8
|
|
range 7 8
|
|
depends on FMB_COMM_MODE_ASCII_EN
|
|
help
|
|
This option defines the number of data bits per ASCII character.
|
|
|
|
config FMB_SERIAL_ASCII_TIMEOUT_RESPOND_MS
|
|
int "Response timeout for ASCII communication mode (ms)"
|
|
default 1000
|
|
range 300 2000
|
|
depends on FMB_COMM_MODE_ASCII_EN
|
|
help
|
|
This option defines response timeout of slave in milliseconds for ASCII communication mode.
|
|
Thus the timeout will expire and allow the master program to handle the error.
|
|
|
|
config FMB_SERIAL_TASK_PRIO
|
|
int "Modbus serial task priority"
|
|
range 3 23
|
|
default 10
|
|
help
|
|
Modbus UART driver event task priority.
|
|
The priority of Modbus controller task is equal to (CONFIG_FMB_SERIAL_TASK_PRIO - 1).
|
|
|
|
choice FMB_PORT_TASK_AFFINITY
|
|
prompt "Modbus task affinity"
|
|
default FMB_PORT_TASK_AFFINITY_CPU0
|
|
depends on !FREERTOS_UNICORE
|
|
help
|
|
Allows setting the core affinity of the Modbus controller task, i.e. whether the task is pinned to
|
|
particular CPU, or allowed to run on any CPU.
|
|
|
|
config FMB_PORT_TASK_AFFINITY_NO_AFFINITY
|
|
bool "No affinity"
|
|
config FMB_PORT_TASK_AFFINITY_CPU0
|
|
bool "CPU0"
|
|
config FMB_PORT_TASK_AFFINITY_CPU1
|
|
bool "CPU1"
|
|
|
|
endchoice
|
|
|
|
config FMB_PORT_TASK_AFFINITY
|
|
hex
|
|
default FREERTOS_NO_AFFINITY if FMB_PORT_TASK_AFFINITY_NO_AFFINITY || FREERTOS_UNICORE
|
|
default 0x0 if FMB_PORT_TASK_AFFINITY_CPU0
|
|
default 0x1 if FMB_PORT_TASK_AFFINITY_CPU1
|
|
|
|
config FMB_CONTROLLER_SLAVE_ID_SUPPORT
|
|
bool "Modbus controller slave ID support"
|
|
default n
|
|
help
|
|
Modbus slave ID support enable.
|
|
When enabled the Modbus <Report Slave ID> command is supported by stack.
|
|
|
|
config FMB_CONTROLLER_SLAVE_ID
|
|
hex "Modbus controller slave ID"
|
|
range 0 4294967295
|
|
default 0x00112233
|
|
depends on FMB_CONTROLLER_SLAVE_ID_SUPPORT
|
|
help
|
|
Modbus slave ID value to identify modbus device
|
|
in the network using <Report Slave ID> command.
|
|
Most significant byte of ID is used as short device ID and
|
|
other three bytes used as long ID.
|
|
|
|
config FMB_CONTROLLER_NOTIFY_TIMEOUT
|
|
int "Modbus controller notification timeout (ms)"
|
|
range 0 200
|
|
default 20
|
|
help
|
|
Modbus controller notification timeout in milliseconds.
|
|
This timeout is used to send notification about accessed parameters.
|
|
|
|
config FMB_CONTROLLER_NOTIFY_QUEUE_SIZE
|
|
int "Modbus controller notification queue size"
|
|
range 0 200
|
|
default 20
|
|
help
|
|
Modbus controller notification queue size.
|
|
The notification queue is used to get information about accessed parameters.
|
|
|
|
config FMB_CONTROLLER_STACK_SIZE
|
|
int "Modbus controller stack size"
|
|
range 0 8192
|
|
default 4096
|
|
help
|
|
Modbus controller task stack size. The Stack size may be adjusted when
|
|
debug mode is used which requires more stack size (for example).
|
|
|
|
config FMB_EVENT_QUEUE_TIMEOUT
|
|
int "Modbus stack event queue timeout (ms)"
|
|
range 0 500
|
|
default 20
|
|
help
|
|
Modbus stack event queue timeout in milliseconds. This may help to optimize
|
|
Modbus stack event processing time.
|
|
|
|
config FMB_TIMER_PORT_ENABLED
|
|
bool "Modbus stack use timer for 3.5T symbol time measurement"
|
|
default n
|
|
help
|
|
If this option is set the Modbus stack uses timer for T3.5 time measurement.
|
|
Else the internal UART TOUT timeout is used for 3.5T symbol time measurement.
|
|
|
|
config FMB_TIMER_GROUP
|
|
int "Slave Timer group number"
|
|
range 0 1
|
|
default 0
|
|
help
|
|
Modbus slave Timer group number that is used for timeout measurement.
|
|
|
|
config FMB_TIMER_INDEX
|
|
int "Slave Timer index in the group"
|
|
range 0 1
|
|
default 0
|
|
help
|
|
Modbus slave Timer Index in the group that is used for timeout measurement.
|
|
|
|
config FMB_MASTER_TIMER_GROUP
|
|
int "Master Timer group number"
|
|
range 0 1
|
|
default FMB_TIMER_GROUP
|
|
help
|
|
Modbus master Timer group number that is used for timeout measurement.
|
|
|
|
config FMB_MASTER_TIMER_INDEX
|
|
int "Master Timer index"
|
|
range 0 1
|
|
default FMB_TIMER_INDEX
|
|
help
|
|
Modbus master Timer Index in the group that is used for timeout measurement.
|
|
Note: Modbus master and slave should have different timer index to be able to work simultaneously.
|
|
|
|
config FMB_TIMER_ISR_IN_IRAM
|
|
bool "Place timer interrupt handler into IRAM"
|
|
default n
|
|
select UART_ISR_IN_IRAM
|
|
help
|
|
This option places Modbus timer IRQ handler into IRAM.
|
|
This allows to avoid delays related to processing of non-IRAM-safe interrupts
|
|
during a flash write operation (NVS updating a value, or some other
|
|
flash API which has to perform an read/write operation and disable CPU cache).
|
|
This option has dependency with the UART_ISR_IN_IRAM option which places UART interrupt
|
|
handler into IRAM to prevent delays related to processing of UART events.
|
|
|
|
endmenu
|