550 lines
13 KiB
Plaintext
550 lines
13 KiB
Plaintext
#
|
|
# For a description of the syntax of this configuration file,
|
|
# see the file kconfig-language.txt in the NuttX tools repository.
|
|
#
|
|
|
|
config DEV_LOWCONSOLE
|
|
bool "Low-level console support"
|
|
default n
|
|
depends on ARCH_LOWPUTC && DEV_CONSOLE
|
|
---help---
|
|
Use the simple, low-level, write-only serial console driver (minimal support)
|
|
|
|
config SERIAL_PM_ACTIVITY_DOMAIN
|
|
int "PM activity domain"
|
|
default 0
|
|
depends on PM
|
|
---help---
|
|
When characters are received on a console device, pm_activity()
|
|
will be called with this PM domain
|
|
|
|
config SERIAL_PM_ACTIVITY_PRIORITY
|
|
int "PM activity priority when reive character"
|
|
default 6
|
|
depends on PM
|
|
---help---
|
|
When characters are received on a console device, pm_activity()
|
|
will be called with this PM priority
|
|
|
|
config SERIAL_REMOVABLE
|
|
bool
|
|
default n
|
|
|
|
config SERIAL_CONSOLE
|
|
bool
|
|
default n
|
|
|
|
menuconfig 16550_UART
|
|
bool "16550 UART Chip support"
|
|
select ARCH_HAVE_SERIAL_TERMIOS
|
|
default n
|
|
|
|
if 16550_UART
|
|
source drivers/serial/Kconfig-16550
|
|
endif
|
|
|
|
#
|
|
# MCU serial peripheral driver?
|
|
#
|
|
|
|
config OTHER_UART_SERIALDRIVER
|
|
bool
|
|
default n
|
|
select MCU_SERIAL
|
|
|
|
config MCU_SERIAL
|
|
bool
|
|
default n
|
|
|
|
#
|
|
# Standard serial driver configuration
|
|
#
|
|
|
|
config STANDARD_SERIAL
|
|
bool "Enable standard \"upper-half\" serial driver"
|
|
default y if MCU_SERIAL
|
|
default n if !MCU_SERIAL
|
|
depends on !DEV_LOWCONSOLE
|
|
---help---
|
|
Enable the standard, upper-half serial driver used by most MCU serial peripherals.
|
|
|
|
config SERIAL_NPOLLWAITERS
|
|
int "Number of poll threads"
|
|
default 2
|
|
depends on STANDARD_SERIAL
|
|
---help---
|
|
Maximum number of threads than can be waiting for POLL events.
|
|
Default: 2
|
|
|
|
config SERIAL_IFLOWCONTROL
|
|
bool
|
|
default n
|
|
|
|
config SERIAL_RS485CONTROL
|
|
bool
|
|
default n
|
|
---help---
|
|
Use RTS pin to control RS485 direction (Asserted while transmitting).
|
|
|
|
config SERIAL_OFLOWCONTROL
|
|
bool
|
|
default n
|
|
|
|
config SERIAL_TXDMA
|
|
bool
|
|
default n
|
|
|
|
config SERIAL_RXDMA
|
|
bool
|
|
default n
|
|
|
|
config SERIAL_IFLOWCONTROL_WATERMARKS
|
|
bool "RX flow control watermarks"
|
|
default n
|
|
depends on SERIAL_IFLOWCONTROL
|
|
---help---
|
|
Call the "lower half" rxflowcontrol method whenever the number of
|
|
characters in the serial RX buffer falls above an upper water mark
|
|
level or below a lower watermark level. The default behavior is to
|
|
call the rxflowcontrol method only when the RX buffer is empty or
|
|
full.
|
|
|
|
if SERIAL_IFLOWCONTROL_WATERMARKS
|
|
|
|
config SERIAL_IFLOWCONTROL_LOWER_WATERMARK
|
|
int "RX lower Watermark (percent)"
|
|
default 10
|
|
range 1 99
|
|
---help---
|
|
Call the rxflowcontrol method then there are this amount (or or less)
|
|
data buffered in the serial drivers RX buffer. This is expressed
|
|
as a percentage of the total size of the RX buffer which may vary
|
|
from instance-to-instance.
|
|
|
|
config SERIAL_IFLOWCONTROL_UPPER_WATERMARK
|
|
int "RX upper Watermark (percent)"
|
|
default 90
|
|
range 1 99
|
|
---help---
|
|
Call the rxflowcontrol method then there are this amount (or more)
|
|
data buffered in the serial drivers RX buffer. This is expressed
|
|
as a percentage of the total size of the RX buffer which may vary
|
|
from instance-to-instance.
|
|
|
|
endif # SERIAL_IFLOWCONTROL_WATERMARKS
|
|
|
|
config SERIAL_TIOCSERGSTRUCT
|
|
bool "Support TIOCSERGSTRUCT"
|
|
default n
|
|
depends on DEBUG_FEATURES && (MCU_SERIAL || 16550_UART)
|
|
---help---
|
|
As a debug option, many serial bottom half drivers support the TIOCSERGSTRUCT
|
|
that allows you to get the internal driver data structure. By default, this
|
|
IOCTL is not supported in order to reduce footprint. But if (1) the driver
|
|
supports the TIOCSERGSTRUCT ioctl, and (2) this option is selected, then
|
|
support for the TIOCSERGSTRUCT will be enabled.
|
|
|
|
config ARCH_HAVE_SERIAL_TERMIOS
|
|
bool
|
|
default n
|
|
|
|
config SERIAL_TERMIOS
|
|
bool "Serial TERMIOS support"
|
|
depends on ARCH_HAVE_SERIAL_TERMIOS
|
|
default n
|
|
---help---
|
|
Serial driver supports termios.h interfaces (tcsetattr, tcflush, etc.).
|
|
If this is not defined, then the terminal settings (baud, parity, etc).
|
|
are not configurable at runtime; serial streams cannot be flushed, etc..
|
|
|
|
config TTY_SIGINT
|
|
bool "Support SIGINT"
|
|
default n
|
|
select SIG_SIGKILL_ACTION
|
|
depends on SERIAL_TERMIOS
|
|
---help---
|
|
Whether support Ctrl-c/x event. Enabled automatically for console
|
|
devices. May be enabled for other serial devices using the ISIG bit
|
|
in the Termios c_lflag.
|
|
|
|
REVISIT: This implementation is compliant but incomplete. The
|
|
c_lflag ISIG bit normally enables/disables INTR, QUIT, SUSP, and
|
|
DSUSP character processing. The relationship between these names,
|
|
standard signals, and typical key presses are as follows:
|
|
|
|
INTR SIGINT Ctrl-C ETX(0x03) Interrupt
|
|
KILL SIGKILL Ctrl-U NAK(0x15) Kill
|
|
QUIT SIGQUIT Ctrl-\ FS (0x1c) Quit
|
|
SUSP SIGSTP Ctrl-Z SUB(0x1a) Suspend
|
|
DSUSP SIGSTP Ctrl-Y EM (0x19) Delayed suspend
|
|
|
|
Additional requirements:
|
|
- SIGKILL cannot be caught or ignored. Compared to SIGTERM which
|
|
is like SIGKILL but can be caught or ignored.
|
|
- SIGQUIT is like SIGINT but causes generation of a core dump
|
|
- SIGSTOP cannot be caught or ignored. SIGSTP is like SIGSTOP but
|
|
can be caught or ignored ignored.
|
|
- The delayed suspend (DSUSD) is like suspend (SUPD), except that
|
|
the suspension is delayed until the next read operation
|
|
|
|
Ctrl-D (EOT 0x04) normally should not generate a signal but, instead,
|
|
should cause an immediate End-of-File result.
|
|
|
|
config TTY_SIGINT_CHAR
|
|
hex "Serial parse SIGINT characters"
|
|
default 0x03 if SERIAL_CONSOLE
|
|
default 0x04 if !SERIAL_CONSOLE
|
|
depends on TTY_SIGINT
|
|
---help---
|
|
Use ASCII 0x03 (Ctrl-c) or 0x04 (ctrl-d) inputs to determine whether
|
|
to send a SIGINT event. Other characters may also be selected.
|
|
|
|
REVISIT: Traditionally Ctrl-C would generate SIGINT. Ctrl-D is the
|
|
End-of-File character that should close the stream.
|
|
|
|
config TTY_SIGSTP
|
|
bool "Support SIGSTP"
|
|
default n
|
|
select CONFIG_SIG_SIGSTOP_ACTION
|
|
depends on SERIAL_TERMIOS
|
|
---help---
|
|
Whether support Ctrl-z event. Enabled automatically for console
|
|
devices. May be enabled for other serial devices using the ISIG bit
|
|
in the Termios c_lflag.
|
|
|
|
REVISIT: This implementation is compliant but incomplete. The
|
|
c_lflag ISIG bit normally enables/disables INTR, QUIT, SUSP, and
|
|
DSUSP character processing. The relationship between these names,
|
|
standard signals, and typical key presses are as follows:
|
|
|
|
INTR SIGINT Ctrl-C ETX(0x03) Interrupt
|
|
KILL SIGKILL Ctrl-U NAK(0x15) Kill
|
|
QUIT SIGQUIT Ctrl-\ FS (0x1c) Quit
|
|
SUSP SIGSTP Ctrl-Z SUB(0x1a) Suspend
|
|
DSUSP SIGSTP Ctrl-Y EM (0x19) Delayed suspend
|
|
|
|
Additional requirements:
|
|
- SIGKILL cannot be caught or ignored. Compared to SIGTERM which
|
|
is like SIGKILL but can be caught or ignored.
|
|
- SIGQUIT is like SIGINT but causes generation of a core dump
|
|
- SIGSTOP cannot be caught or ignored. SIGSTP is like SIGSTOP but
|
|
can be caught or ignored ignored.
|
|
- The delayed suspend (DSUSD) is like suspend (SUPD), except that
|
|
the suspension is delayed until the next read operation
|
|
|
|
config TTY_SIGSTP_CHAR
|
|
hex "Serial parse SIGSTP characters"
|
|
default 0x1a
|
|
depends on TTY_SIGSTP
|
|
---help---
|
|
Use ASCII 0x1a (Ctrl-z) input to determine whether to send a SIGSTP
|
|
event. Other characters may also be selected.
|
|
|
|
#
|
|
# Serial console selection
|
|
#
|
|
|
|
choice
|
|
prompt "Serial console"
|
|
default NO_SERIAL_CONSOLE if !OTHER_UART_SERIALDRIVER
|
|
default OTHER_SERIAL_CONSOLE if OTHER_UART_SERIALDRIVER
|
|
depends on MCU_SERIAL
|
|
#depends on DEV_CONSOLE - We may have serial console with no file system at all
|
|
|
|
config UART_SERIAL_CONSOLE
|
|
bool "UART"
|
|
depends on UART_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config UART0_SERIAL_CONSOLE
|
|
bool "UART0"
|
|
depends on UART0_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config USART0_SERIAL_CONSOLE
|
|
bool "USART0"
|
|
depends on USART0_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config UART1_SERIAL_CONSOLE
|
|
bool "UART1"
|
|
depends on UART1_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config USART1_SERIAL_CONSOLE
|
|
bool "USART1"
|
|
depends on USART1_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config UART2_SERIAL_CONSOLE
|
|
bool "UART2"
|
|
depends on UART2_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config USART2_SERIAL_CONSOLE
|
|
bool "USART2"
|
|
depends on USART2_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config UART3_SERIAL_CONSOLE
|
|
bool "UART3"
|
|
depends on UART3_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config USART3_SERIAL_CONSOLE
|
|
bool "USART3"
|
|
depends on USART3_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config UART4_SERIAL_CONSOLE
|
|
bool "UART4"
|
|
depends on UART4_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config USART4_SERIAL_CONSOLE
|
|
bool "USART4"
|
|
depends on USART4_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config UART5_SERIAL_CONSOLE
|
|
bool "UART5"
|
|
depends on UART5_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config USART5_SERIAL_CONSOLE
|
|
bool "USART5"
|
|
depends on USART5_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config UART6_SERIAL_CONSOLE
|
|
bool "UART6"
|
|
depends on UART6_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config USART6_SERIAL_CONSOLE
|
|
bool "USART6"
|
|
depends on USART6_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config UART7_SERIAL_CONSOLE
|
|
bool "UART7"
|
|
depends on UART7_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config USART7_SERIAL_CONSOLE
|
|
bool "USART7"
|
|
depends on USART7_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config UART8_SERIAL_CONSOLE
|
|
bool "UART8"
|
|
depends on UART8_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config USART8_SERIAL_CONSOLE
|
|
bool "USART8"
|
|
depends on USART8_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config USART9_SERIAL_CONSOLE
|
|
bool "USART8"
|
|
depends on USART9_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config LPUART0_SERIAL_CONSOLE
|
|
bool "LPUART0"
|
|
depends on LPUART0_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config LPUART1_SERIAL_CONSOLE
|
|
bool "LPUART1"
|
|
depends on LPUART1_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config LPUART2_SERIAL_CONSOLE
|
|
bool "LPUART2"
|
|
depends on LPUART2_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config LPUART3_SERIAL_CONSOLE
|
|
bool "LPUART3"
|
|
depends on LPUART3_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config LPUART4_SERIAL_CONSOLE
|
|
bool "LPUART4"
|
|
depends on LPUART4_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config LPUART5_SERIAL_CONSOLE
|
|
bool "LPUART5"
|
|
depends on LPUART5_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config LPUART6_SERIAL_CONSOLE
|
|
bool "LPUART6"
|
|
depends on LPUART6_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config LPUART7_SERIAL_CONSOLE
|
|
bool "LPUART7"
|
|
depends on LPUART7_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config LPUART8_SERIAL_CONSOLE
|
|
bool "LPUART8"
|
|
depends on LPUART8_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config SCI0_SERIAL_CONSOLE
|
|
bool "SCI0"
|
|
depends on SCI0_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config SCI1_SERIAL_CONSOLE
|
|
bool "SCI1"
|
|
depends on SCI1_SERIALDRIVER
|
|
select SERIAL_CONSOLE
|
|
|
|
config OTHER_SERIAL_CONSOLE
|
|
bool "Other serial console"
|
|
select SERIAL_CONSOLE
|
|
|
|
config NO_SERIAL_CONSOLE
|
|
bool "No serial console"
|
|
|
|
endchoice
|
|
|
|
#
|
|
# U[S]ARTn_XYZ settings for MCU serial drivers
|
|
#
|
|
|
|
menu "UART Configuration"
|
|
depends on UART_SERIALDRIVER
|
|
|
|
config UART_RXBUFSIZE
|
|
int "Receive buffer size"
|
|
default 256
|
|
---help---
|
|
Characters are buffered as they are received. This specifies
|
|
the size of the receive buffer.
|
|
|
|
config UART_TXBUFSIZE
|
|
int "Transmit buffer size"
|
|
default 256
|
|
---help---
|
|
Characters are buffered before being sent. This specifies
|
|
the size of the transmit buffer.
|
|
|
|
config UART_BAUD
|
|
int "BAUD rate"
|
|
default 115200
|
|
---help---
|
|
The configured BAUD of the UART.
|
|
|
|
config UART_BITS
|
|
int "Character size"
|
|
default 8
|
|
---help---
|
|
The number of bits. Must be either 7 or 8.
|
|
|
|
config UART_PARITY
|
|
int "Parity setting"
|
|
default 0
|
|
range 0 2
|
|
---help---
|
|
0=no parity, 1=odd parity, 2=even parity
|
|
|
|
config UART_2STOP
|
|
int "use 2 stop bits"
|
|
default 0
|
|
---help---
|
|
1=Two stop bits
|
|
|
|
config UART_IFLOWCONTROL
|
|
bool "UART RTS flow control"
|
|
default n
|
|
select SERIAL_IFLOWCONTROL
|
|
---help---
|
|
Enable UART RTS flow control
|
|
|
|
config UART_OFLOWCONTROL
|
|
bool "UART CTS flow control"
|
|
default n
|
|
select SERIAL_OFLOWCONTROL
|
|
---help---
|
|
Enable UART CTS flow control
|
|
|
|
config UART_TXDMA
|
|
bool "UART Tx DMA support"
|
|
default n
|
|
select SERIAL_TXDMA
|
|
---help---
|
|
Enable DMA transfers on UART
|
|
|
|
config UART_RXDMA
|
|
bool "UART Rx DMA support"
|
|
default n
|
|
select SERIAL_RXDMA
|
|
---help---
|
|
Enable DMA transfers on UART
|
|
|
|
endmenu
|
|
|
|
source drivers/serial/Kconfig-uart
|
|
source drivers/serial/Kconfig-lpuart
|
|
source drivers/serial/Kconfig-usart
|
|
source drivers/serial/Kconfig-sci
|
|
|
|
menuconfig PSEUDOTERM
|
|
bool "Pseudo-Terminal (PTY) suppport"
|
|
default n
|
|
select PIPES
|
|
select ARCH_HAVE_SERIAL_TERMIOS
|
|
---help---
|
|
Enable support support for master and slave pseudo-terminal devices.
|
|
|
|
if PSEUDOTERM
|
|
|
|
choice
|
|
prompt "PTY model"
|
|
default PSEUDOTERM_BSD if DISABLE_PSEUDOFS_OPERATIONS
|
|
default PSEUDOTERM_SUSV1 if !DISABLE_PSEUDOFS_OPERATIONS
|
|
|
|
config PSEUDOTERM_BSD
|
|
bool "BSD style"
|
|
---help---
|
|
Deprecated BSD style PTYs.
|
|
|
|
Master: /dev/ptyN
|
|
Slave: /dev/ttypN
|
|
|
|
Where N is the minor number
|
|
|
|
config PSEUDOTERM_SUSV1
|
|
bool "SUSv1 style"
|
|
depends on !DISABLE_PSEUDOFS_OPERATIONS
|
|
---help---
|
|
PTYs as specified in the Single Unix Specification (SUSv1).
|
|
|
|
Master: /dev/ptmx (multiplexor)
|
|
Slave: /dev/pts/N
|
|
|
|
Where N is the minor number
|
|
|
|
endchoice # PTY model
|
|
|
|
config PSEUDOTERM_RXBUFSIZE
|
|
int "Pseudo-Terminal Rx buffer size"
|
|
default 256
|
|
---help---
|
|
Master-to-slave pipe buffer size. Default: 256
|
|
|
|
config PSEUDOTERM_TXBUFSIZE
|
|
int "Pseudo-Terminal Tx buffer size"
|
|
default 256
|
|
---help---
|
|
Slave-to-master pipe buffer size. Default: 256
|
|
|
|
endif # PSEUDOTERM
|