arch/arm/src/stm32h7: Remove old references to RXDMA. Add configuration option to select the Rx FIFO threshold level.
This commit is contained in:
parent
ff1e6a66e9
commit
5c5b6ab8f6
@ -456,7 +456,7 @@
|
|||||||
|
|
||||||
/* NVIC register bit definitions ************************************************************/
|
/* NVIC register bit definitions ************************************************************/
|
||||||
|
|
||||||
/* Interrrupt controller type (INCTCTL_TYPE) */
|
/* Interrupt controller type (INCTCTL_TYPE) */
|
||||||
|
|
||||||
#define NVIC_ICTR_INTLINESNUM_SHIFT 0 /* Bits 0-3: Number of interrupt inputs / 32 - 1 */
|
#define NVIC_ICTR_INTLINESNUM_SHIFT 0 /* Bits 0-3: Number of interrupt inputs / 32 - 1 */
|
||||||
#define NVIC_ICTR_INTLINESNUM_MASK (15 << NVIC_ICTR_INTLINESNUM_SHIFT)
|
#define NVIC_ICTR_INTLINESNUM_MASK (15 << NVIC_ICTR_INTLINESNUM_SHIFT)
|
||||||
|
@ -299,8 +299,7 @@ config USART1_RS485
|
|||||||
default n
|
default n
|
||||||
---help---
|
---help---
|
||||||
Enable RS-485 interface on USART1. Your board config will have to
|
Enable RS-485 interface on USART1. Your board config will have to
|
||||||
provide GPIO_USART1_RS485_DIR pin definition. Currently it cannot be
|
provide GPIO_USART1_RS485_DIR pin definition.
|
||||||
used with USART1_RXDMA.
|
|
||||||
|
|
||||||
config USART1_RS485_DIR_POLARITY
|
config USART1_RS485_DIR_POLARITY
|
||||||
int "USART1 RS-485 DIR pin polarity"
|
int "USART1 RS-485 DIR pin polarity"
|
||||||
@ -311,12 +310,23 @@ config USART1_RS485_DIR_POLARITY
|
|||||||
Polarity of DIR pin for RS-485 on USART1. Set to state on DIR pin which
|
Polarity of DIR pin for RS-485 on USART1. Set to state on DIR pin which
|
||||||
enables TX (0 - low / nTXEN, 1 - high / TXEN).
|
enables TX (0 - low / nTXEN, 1 - high / TXEN).
|
||||||
|
|
||||||
config USART1_RXDMA
|
config USART1_RXFIFO_THRES
|
||||||
bool "USART1 Rx DMA"
|
int "USART1 Rx FIFO Threshold"
|
||||||
default n
|
default 3
|
||||||
depends on STM32H7_DMA1
|
range 0 5
|
||||||
---help---
|
---help---
|
||||||
In high data rate usage, Rx DMA may eliminate Rx overrun errors
|
Select the Rx FIFO threshold:
|
||||||
|
|
||||||
|
0 -> 1/8 full
|
||||||
|
1 -> 1/4 full
|
||||||
|
2 -> 1/2 full
|
||||||
|
3 -> 3/4 full
|
||||||
|
4 -> 7/8 full
|
||||||
|
5 -> Full
|
||||||
|
|
||||||
|
Higher values mean lower interrupt rates and better CPU performance.
|
||||||
|
Lower values are need at high BAUD rates to prevent Rx data overrun
|
||||||
|
errors.
|
||||||
|
|
||||||
endif # STM32H7_USART1
|
endif # STM32H7_USART1
|
||||||
|
|
||||||
@ -327,8 +337,7 @@ config USART2_RS485
|
|||||||
default n
|
default n
|
||||||
---help---
|
---help---
|
||||||
Enable RS-485 interface on USART2. Your board config will have to
|
Enable RS-485 interface on USART2. Your board config will have to
|
||||||
provide GPIO_USART2_RS485_DIR pin definition. Currently it cannot be
|
provide GPIO_USART2_RS485_DIR pin definition.
|
||||||
used with USART2_RXDMA.
|
|
||||||
|
|
||||||
config USART2_RS485_DIR_POLARITY
|
config USART2_RS485_DIR_POLARITY
|
||||||
int "USART2 RS-485 DIR pin polarity"
|
int "USART2 RS-485 DIR pin polarity"
|
||||||
@ -339,12 +348,23 @@ config USART2_RS485_DIR_POLARITY
|
|||||||
Polarity of DIR pin for RS-485 on USART2. Set to state on DIR pin which
|
Polarity of DIR pin for RS-485 on USART2. Set to state on DIR pin which
|
||||||
enables TX (0 - low / nTXEN, 1 - high / TXEN).
|
enables TX (0 - low / nTXEN, 1 - high / TXEN).
|
||||||
|
|
||||||
config USART2_RXDMA
|
config USART2_RXFIFO_THRES
|
||||||
bool "USART2 Rx DMA"
|
int "USART2 Rx FIFO Threshold"
|
||||||
default n
|
default 3
|
||||||
depends on STM32H7_DMA1
|
range 0 5
|
||||||
---help---
|
---help---
|
||||||
In high data rate usage, Rx DMA may eliminate Rx overrun errors
|
Select the Rx FIFO threshold:
|
||||||
|
|
||||||
|
0 -> 1/8 full
|
||||||
|
1 -> 1/4 full
|
||||||
|
2 -> 1/2 full
|
||||||
|
3 -> 3/4 full
|
||||||
|
4 -> 7/8 full
|
||||||
|
5 -> Full
|
||||||
|
|
||||||
|
Higher values mean lower interrupt rates and better CPU performance.
|
||||||
|
Lower values are need at high BAUD rates to prevent Rx data overrun
|
||||||
|
errors.
|
||||||
|
|
||||||
endif # STM32H7_USART2
|
endif # STM32H7_USART2
|
||||||
|
|
||||||
@ -355,8 +375,7 @@ config USART3_RS485
|
|||||||
default n
|
default n
|
||||||
---help---
|
---help---
|
||||||
Enable RS-485 interface on USART3. Your board config will have to
|
Enable RS-485 interface on USART3. Your board config will have to
|
||||||
provide GPIO_USART3_RS485_DIR pin definition. Currently it cannot be
|
provide GPIO_USART3_RS485_DIR pin definition.
|
||||||
used with USART3_RXDMA.
|
|
||||||
|
|
||||||
config USART3_RS485_DIR_POLARITY
|
config USART3_RS485_DIR_POLARITY
|
||||||
int "USART3 RS-485 DIR pin polarity"
|
int "USART3 RS-485 DIR pin polarity"
|
||||||
@ -367,13 +386,23 @@ config USART3_RS485_DIR_POLARITY
|
|||||||
Polarity of DIR pin for RS-485 on USART3. Set to state on DIR pin which
|
Polarity of DIR pin for RS-485 on USART3. Set to state on DIR pin which
|
||||||
enables TX (0 - low / nTXEN, 1 - high / TXEN).
|
enables TX (0 - low / nTXEN, 1 - high / TXEN).
|
||||||
|
|
||||||
config USART3_RXDMA
|
config USART3_RXFIFO_THRES
|
||||||
bool "USART3 Rx DMA"
|
int "USART3 Rx FIFO Threshold"
|
||||||
default n
|
default 3
|
||||||
depends on STM32H7_DMA1
|
range 0 5
|
||||||
---help---
|
---help---
|
||||||
In high data rate usage, Rx DMA may eliminate Rx overrun errors
|
Select the Rx FIFO threshold:
|
||||||
|
|
||||||
|
0 -> 1/8 full
|
||||||
|
1 -> 1/4 full
|
||||||
|
2 -> 1/2 full
|
||||||
|
3 -> 3/4 full
|
||||||
|
4 -> 7/8 full
|
||||||
|
5 -> Full
|
||||||
|
|
||||||
|
Higher values mean lower interrupt rates and better CPU performance.
|
||||||
|
Lower values are need at high BAUD rates to prevent Rx data overrun
|
||||||
|
errors.
|
||||||
|
|
||||||
endif # STM32H7_USART3
|
endif # STM32H7_USART3
|
||||||
|
|
||||||
@ -384,8 +413,7 @@ config UART4_RS485
|
|||||||
default n
|
default n
|
||||||
---help---
|
---help---
|
||||||
Enable RS-485 interface on UART4. Your board config will have to
|
Enable RS-485 interface on UART4. Your board config will have to
|
||||||
provide GPIO_UART4_RS485_DIR pin definition. Currently it cannot be
|
provide GPIO_UART4_RS485_DIR pin definition.
|
||||||
used with UART4_RXDMA.
|
|
||||||
|
|
||||||
config UART4_RS485_DIR_POLARITY
|
config UART4_RS485_DIR_POLARITY
|
||||||
int "UART4 RS-485 DIR pin polarity"
|
int "UART4 RS-485 DIR pin polarity"
|
||||||
@ -396,12 +424,23 @@ config UART4_RS485_DIR_POLARITY
|
|||||||
Polarity of DIR pin for RS-485 on UART4. Set to state on DIR pin which
|
Polarity of DIR pin for RS-485 on UART4. Set to state on DIR pin which
|
||||||
enables TX (0 - low / nTXEN, 1 - high / TXEN).
|
enables TX (0 - low / nTXEN, 1 - high / TXEN).
|
||||||
|
|
||||||
config UART4_RXDMA
|
config UART4_RXFIFO_THRES
|
||||||
bool "UART4 Rx DMA"
|
int "UART4 Rx FIFO Threshold"
|
||||||
default n
|
default 3
|
||||||
depends on STM32H7_DMA1
|
range 0 5
|
||||||
---help---
|
---help---
|
||||||
In high data rate usage, Rx DMA may eliminate Rx overrun errors
|
Select the Rx FIFO threshold:
|
||||||
|
|
||||||
|
0 -> 1/8 full
|
||||||
|
1 -> 1/4 full
|
||||||
|
2 -> 1/2 full
|
||||||
|
3 -> 3/4 full
|
||||||
|
4 -> 7/8 full
|
||||||
|
5 -> Full
|
||||||
|
|
||||||
|
Higher values mean lower interrupt rates and better CPU performance.
|
||||||
|
Lower values are need at high BAUD rates to prevent Rx data overrun
|
||||||
|
errors.
|
||||||
|
|
||||||
endif # STM32H7_UART4
|
endif # STM32H7_UART4
|
||||||
|
|
||||||
@ -412,8 +451,7 @@ config UART5_RS485
|
|||||||
default n
|
default n
|
||||||
---help---
|
---help---
|
||||||
Enable RS-485 interface on UART5. Your board config will have to
|
Enable RS-485 interface on UART5. Your board config will have to
|
||||||
provide GPIO_UART5_RS485_DIR pin definition. Currently it cannot be
|
provide GPIO_UART5_RS485_DIR pin definition.
|
||||||
used with UART5_RXDMA.
|
|
||||||
|
|
||||||
config UART5_RS485_DIR_POLARITY
|
config UART5_RS485_DIR_POLARITY
|
||||||
int "UART5 RS-485 DIR pin polarity"
|
int "UART5 RS-485 DIR pin polarity"
|
||||||
@ -424,12 +462,23 @@ config UART5_RS485_DIR_POLARITY
|
|||||||
Polarity of DIR pin for RS-485 on UART5. Set to state on DIR pin which
|
Polarity of DIR pin for RS-485 on UART5. Set to state on DIR pin which
|
||||||
enables TX (0 - low / nTXEN, 1 - high / TXEN).
|
enables TX (0 - low / nTXEN, 1 - high / TXEN).
|
||||||
|
|
||||||
config UART5_RXDMA
|
config UART5_RXFIFO_THRES
|
||||||
bool "UART5 Rx DMA"
|
int "UART5 Rx FIFO Threshold"
|
||||||
default n
|
default 3
|
||||||
depends on STM32H7_DMA1
|
range 0 5
|
||||||
---help---
|
---help---
|
||||||
In high data rate usage, Rx DMA may eliminate Rx overrun errors
|
Select the Rx FIFO threshold:
|
||||||
|
|
||||||
|
0 -> 1/8 full
|
||||||
|
1 -> 1/4 full
|
||||||
|
2 -> 1/2 full
|
||||||
|
3 -> 3/4 full
|
||||||
|
4 -> 7/8 full
|
||||||
|
5 -> Full
|
||||||
|
|
||||||
|
Higher values mean lower interrupt rates and better CPU performance.
|
||||||
|
Lower values are need at high BAUD rates to prevent Rx data overrun
|
||||||
|
errors.
|
||||||
|
|
||||||
endif # STM32H7_UART5
|
endif # STM32H7_UART5
|
||||||
|
|
||||||
@ -440,8 +489,7 @@ config USART6_RS485
|
|||||||
default n
|
default n
|
||||||
---help---
|
---help---
|
||||||
Enable RS-485 interface on USART6. Your board config will have to
|
Enable RS-485 interface on USART6. Your board config will have to
|
||||||
provide GPIO_USART6_RS485_DIR pin definition. Currently it cannot be
|
provide GPIO_USART6_RS485_DIR pin definition.
|
||||||
used with USART6_RXDMA.
|
|
||||||
|
|
||||||
config USART6_RS485_DIR_POLARITY
|
config USART6_RS485_DIR_POLARITY
|
||||||
int "USART6 RS-485 DIR pin polarity"
|
int "USART6 RS-485 DIR pin polarity"
|
||||||
@ -452,12 +500,23 @@ config USART6_RS485_DIR_POLARITY
|
|||||||
Polarity of DIR pin for RS-485 on USART6. Set to state on DIR pin which
|
Polarity of DIR pin for RS-485 on USART6. Set to state on DIR pin which
|
||||||
enables TX (0 - low / nTXEN, 1 - high / TXEN).
|
enables TX (0 - low / nTXEN, 1 - high / TXEN).
|
||||||
|
|
||||||
config USART6_RXDMA
|
config USART6_RXFIFO_THRES
|
||||||
bool "USART6 Rx DMA"
|
int "USART6 Rx FIFO Threshold"
|
||||||
default n
|
default 3
|
||||||
depends on STM32H7_DMA2
|
range 0 5
|
||||||
---help---
|
---help---
|
||||||
In high data rate usage, Rx DMA may eliminate Rx overrun errors
|
Select the Rx FIFO threshold:
|
||||||
|
|
||||||
|
0 -> 1/8 full
|
||||||
|
1 -> 1/4 full
|
||||||
|
2 -> 1/2 full
|
||||||
|
3 -> 3/4 full
|
||||||
|
4 -> 7/8 full
|
||||||
|
5 -> Full
|
||||||
|
|
||||||
|
Higher values mean lower interrupt rates and better CPU performance.
|
||||||
|
Lower values are need at high BAUD rates to prevent Rx data overrun
|
||||||
|
errors.
|
||||||
|
|
||||||
endif # STM32H7_USART
|
endif # STM32H7_USART
|
||||||
|
|
||||||
@ -468,8 +527,7 @@ config UART7_RS485
|
|||||||
default n
|
default n
|
||||||
---help---
|
---help---
|
||||||
Enable RS-485 interface on UART7. Your board config will have to
|
Enable RS-485 interface on UART7. Your board config will have to
|
||||||
provide GPIO_UART7_RS485_DIR pin definition. Currently it cannot be
|
provide GPIO_UART7_RS485_DIR pin definition.
|
||||||
used with UART7_RXDMA.
|
|
||||||
|
|
||||||
config UART7_RS485_DIR_POLARITY
|
config UART7_RS485_DIR_POLARITY
|
||||||
int "UART7 RS-485 DIR pin polarity"
|
int "UART7 RS-485 DIR pin polarity"
|
||||||
@ -480,12 +538,23 @@ config UART7_RS485_DIR_POLARITY
|
|||||||
Polarity of DIR pin for RS-485 on UART7. Set to state on DIR pin which
|
Polarity of DIR pin for RS-485 on UART7. Set to state on DIR pin which
|
||||||
enables TX (0 - low / nTXEN, 1 - high / TXEN).
|
enables TX (0 - low / nTXEN, 1 - high / TXEN).
|
||||||
|
|
||||||
config UART7_RXDMA
|
config UART7_RXFIFO_THRES
|
||||||
bool "UART7 Rx DMA"
|
int "UART7 Rx FIFO Threshold"
|
||||||
default n
|
default 3
|
||||||
depends on STM32H7_DMA2
|
range 0 5
|
||||||
---help---
|
---help---
|
||||||
In high data rate usage, Rx DMA may eliminate Rx overrun errors
|
Select the Rx FIFO threshold:
|
||||||
|
|
||||||
|
0 -> 1/8 full
|
||||||
|
1 -> 1/4 full
|
||||||
|
2 -> 1/2 full
|
||||||
|
3 -> 3/4 full
|
||||||
|
4 -> 7/8 full
|
||||||
|
5 -> Full
|
||||||
|
|
||||||
|
Higher values mean lower interrupt rates and better CPU performance.
|
||||||
|
Lower values are need at high BAUD rates to prevent Rx data overrun
|
||||||
|
errors.
|
||||||
|
|
||||||
endif # STM32H7_UART7
|
endif # STM32H7_UART7
|
||||||
|
|
||||||
@ -496,8 +565,7 @@ config UART8_RS485
|
|||||||
default n
|
default n
|
||||||
---help---
|
---help---
|
||||||
Enable RS-485 interface on UART8. Your board config will have to
|
Enable RS-485 interface on UART8. Your board config will have to
|
||||||
provide GPIO_UART8_RS485_DIR pin definition. Currently it cannot be
|
provide GPIO_UART8_RS485_DIR pin definition.
|
||||||
used with UART8_RXDMA.
|
|
||||||
|
|
||||||
config UART8_RS485_DIR_POLARITY
|
config UART8_RS485_DIR_POLARITY
|
||||||
int "UART8 RS-485 DIR pin polarity"
|
int "UART8 RS-485 DIR pin polarity"
|
||||||
@ -508,27 +576,26 @@ config UART8_RS485_DIR_POLARITY
|
|||||||
Polarity of DIR pin for RS-485 on UART8. Set to state on DIR pin which
|
Polarity of DIR pin for RS-485 on UART8. Set to state on DIR pin which
|
||||||
enables TX (0 - low / nTXEN, 1 - high / TXEN).
|
enables TX (0 - low / nTXEN, 1 - high / TXEN).
|
||||||
|
|
||||||
config UART8_RXDMA
|
config UART8_RXFIFO_THRES
|
||||||
bool "UART8 Rx DMA"
|
int "UART8 Rx FIFO Threshold"
|
||||||
default n
|
default 3
|
||||||
depends on STM32H7_DMA2
|
range 0 5
|
||||||
---help---
|
---help---
|
||||||
In high data rate usage, Rx DMA may eliminate Rx overrun errors
|
Select the Rx FIFO threshold:
|
||||||
|
|
||||||
|
0 -> 1/8 full
|
||||||
|
1 -> 1/4 full
|
||||||
|
2 -> 1/2 full
|
||||||
|
3 -> 3/4 full
|
||||||
|
4 -> 7/8 full
|
||||||
|
5 -> Full
|
||||||
|
|
||||||
|
Higher values mean lower interrupt rates and better CPU performance.
|
||||||
|
Lower values are need at high BAUD rates to prevent Rx data overrun
|
||||||
|
errors.
|
||||||
|
|
||||||
endif # STM32H7_UART8
|
endif # STM32H7_UART8
|
||||||
|
|
||||||
config STM32H7_SERIAL_RXDMA_BUFFER_SIZE
|
|
||||||
int "Rx DMA buffer size"
|
|
||||||
default 32
|
|
||||||
depends on USART1_RXDMA || USART2_RXDMA || USART3_RXDMA || UART4_RXDMA || UART5_RXDMA || USART6_RXDMA || UART7_RXDMA || UART8_RXDMA
|
|
||||||
---help---
|
|
||||||
The DMA buffer size when using RX DMA to emulate a FIFO.
|
|
||||||
|
|
||||||
When streaming data, the generic serial layer will be called
|
|
||||||
every time the FIFO receives half this number of bytes.
|
|
||||||
|
|
||||||
Value given here will be rounded up to next multiple of 32 bytes.
|
|
||||||
|
|
||||||
config STM32H7_SERIAL_DISABLE_REORDERING
|
config STM32H7_SERIAL_DISABLE_REORDERING
|
||||||
bool "Disable reordering of ttySx devices."
|
bool "Disable reordering of ttySx devices."
|
||||||
default n
|
default n
|
||||||
|
@ -292,6 +292,7 @@
|
|||||||
# define USART_CR3_SCARCNT(n) ((uint32_t)(n) << USART_CR3_SCARCNT_SHIFT)
|
# define USART_CR3_SCARCNT(n) ((uint32_t)(n) << USART_CR3_SCARCNT_SHIFT)
|
||||||
#define USART_CR3_RXFTCFG_SHIFT (25) /* Bit 25-27: Receive FIFO threshold configuration */
|
#define USART_CR3_RXFTCFG_SHIFT (25) /* Bit 25-27: Receive FIFO threshold configuration */
|
||||||
#define USART_CR3_RXFTCFG_MASK (7 << USART_CR3_RXFTCFG_SHIFT)
|
#define USART_CR3_RXFTCFG_MASK (7 << USART_CR3_RXFTCFG_SHIFT)
|
||||||
|
# define USART_CR3_RXFTCFG(n) ((uint32_t)(n) << USART_CR3_RXFTCFG_SHIFT)
|
||||||
# define USART_CR3_RXFTCFG_12PCT (0 << USART_CR3_RXFTCFG_SHIFT) /* RXFIFO 1/8 full */
|
# define USART_CR3_RXFTCFG_12PCT (0 << USART_CR3_RXFTCFG_SHIFT) /* RXFIFO 1/8 full */
|
||||||
# define USART_CR3_RXFTCFG_25PCT (1 << USART_CR3_RXFTCFG_SHIFT) /* RXFIFO 1/4 full */
|
# define USART_CR3_RXFTCFG_25PCT (1 << USART_CR3_RXFTCFG_SHIFT) /* RXFIFO 1/4 full */
|
||||||
# define USART_CR3_RXFTCFG_50PCT (2 << USART_CR3_RXFTCFG_SHIFT) /* RXFIFO 1/2 full */
|
# define USART_CR3_RXFTCFG_50PCT (2 << USART_CR3_RXFTCFG_SHIFT) /* RXFIFO 1/2 full */
|
||||||
@ -301,6 +302,7 @@
|
|||||||
#define USART_CR3_RXFTIE (1 << 28) /* Bit 28: RXFIFO threshold interrupt enable */
|
#define USART_CR3_RXFTIE (1 << 28) /* Bit 28: RXFIFO threshold interrupt enable */
|
||||||
#define USART_CR3_TXFTCFG_SHIFT (29) /* Bits 29-31: TXFIFO threshold configuration */
|
#define USART_CR3_TXFTCFG_SHIFT (29) /* Bits 29-31: TXFIFO threshold configuration */
|
||||||
#define USART_CR3_TXFTCFG_MASK (7 << USART_CR3_TXFTCFG_SHIFT)
|
#define USART_CR3_TXFTCFG_MASK (7 << USART_CR3_TXFTCFG_SHIFT)
|
||||||
|
# define USART_CR3_TXFTCFG(n) ((uint32_t)(n) << USART_CR3_TXFTCFG_SHIFT)
|
||||||
# define USART_CR3_TXFTCFG_12PCT (0 << USART_CR3_TXFTCFG_SHIFT) /* TXFIFO 1/8 full */
|
# define USART_CR3_TXFTCFG_12PCT (0 << USART_CR3_TXFTCFG_SHIFT) /* TXFIFO 1/8 full */
|
||||||
# define USART_CR3_TXFTCFG_24PCT (1 << USART_CR3_TXFTCFG_SHIFT) /* TXFIFO 1/4 full */
|
# define USART_CR3_TXFTCFG_24PCT (1 << USART_CR3_TXFTCFG_SHIFT) /* TXFIFO 1/4 full */
|
||||||
# define USART_CR3_TXFTCFG_50PCT (2 << USART_CR3_TXFTCFG_SHIFT) /* TXFIFO 1/2 full */
|
# define USART_CR3_TXFTCFG_50PCT (2 << USART_CR3_TXFTCFG_SHIFT) /* TXFIFO 1/2 full */
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* arch/arm/src/stm32h7/stm32_serial.c
|
* arch/arm/src/stm32h7/stm32_serial.c
|
||||||
*
|
*
|
||||||
* Copyright (C) 2015-2017 Gregory Nutt. All rights reserved.
|
* Copyright (C) 2015-2018 Gregory Nutt. All rights reserved.
|
||||||
* Authors: Gregory Nutt <gnutt@nuttx.org>
|
* Authors: Gregory Nutt <gnutt@nuttx.org>
|
||||||
* David Sidrane <david_s5@nscdg.com>
|
* David Sidrane <david_s5@nscdg.com>
|
||||||
*
|
*
|
||||||
@ -146,6 +146,7 @@ struct up_dev_s
|
|||||||
#endif
|
#endif
|
||||||
uint32_t baud; /* Configured baud */
|
uint32_t baud; /* Configured baud */
|
||||||
#else
|
#else
|
||||||
|
const uint8_t rxftcfg; /* Rx FIFO threshold level */
|
||||||
const uint8_t parity; /* 0=none, 1=odd, 2=even */
|
const uint8_t parity; /* 0=none, 1=odd, 2=even */
|
||||||
const uint8_t bits; /* Number of bits (7 or 8) */
|
const uint8_t bits; /* Number of bits (7 or 8) */
|
||||||
const bool stopbits2; /* True: Configure with 2 stop bits instead of 1 */
|
const bool stopbits2; /* True: Configure with 2 stop bits instead of 1 */
|
||||||
@ -295,6 +296,7 @@ static struct up_dev_s g_usart1priv =
|
|||||||
},
|
},
|
||||||
|
|
||||||
.irq = STM32_IRQ_USART1,
|
.irq = STM32_IRQ_USART1,
|
||||||
|
.rxftcfg = CONFIG_USART1_RXFIFO_THRES,
|
||||||
.parity = CONFIG_USART1_PARITY,
|
.parity = CONFIG_USART1_PARITY,
|
||||||
.bits = CONFIG_USART1_BITS,
|
.bits = CONFIG_USART1_BITS,
|
||||||
.stopbits2 = CONFIG_USART1_2STOP,
|
.stopbits2 = CONFIG_USART1_2STOP,
|
||||||
@ -348,6 +350,7 @@ static struct up_dev_s g_usart2priv =
|
|||||||
},
|
},
|
||||||
|
|
||||||
.irq = STM32_IRQ_USART2,
|
.irq = STM32_IRQ_USART2,
|
||||||
|
.rxftcfg = CONFIG_USART2_RXFIFO_THRES,
|
||||||
.parity = CONFIG_USART2_PARITY,
|
.parity = CONFIG_USART2_PARITY,
|
||||||
.bits = CONFIG_USART2_BITS,
|
.bits = CONFIG_USART2_BITS,
|
||||||
.stopbits2 = CONFIG_USART2_2STOP,
|
.stopbits2 = CONFIG_USART2_2STOP,
|
||||||
@ -401,6 +404,7 @@ static struct up_dev_s g_usart3priv =
|
|||||||
},
|
},
|
||||||
|
|
||||||
.irq = STM32_IRQ_USART3,
|
.irq = STM32_IRQ_USART3,
|
||||||
|
.rxftcfg = CONFIG_USART3_RXFIFO_THRES,
|
||||||
.parity = CONFIG_USART3_PARITY,
|
.parity = CONFIG_USART3_PARITY,
|
||||||
.bits = CONFIG_USART3_BITS,
|
.bits = CONFIG_USART3_BITS,
|
||||||
.stopbits2 = CONFIG_USART3_2STOP,
|
.stopbits2 = CONFIG_USART3_2STOP,
|
||||||
@ -454,6 +458,7 @@ static struct up_dev_s g_uart4priv =
|
|||||||
},
|
},
|
||||||
|
|
||||||
.irq = STM32_IRQ_UART4,
|
.irq = STM32_IRQ_UART4,
|
||||||
|
.rxftcfg = CONFIG_UART4_RXFIFO_THRES,
|
||||||
.parity = CONFIG_UART4_PARITY,
|
.parity = CONFIG_UART4_PARITY,
|
||||||
.bits = CONFIG_UART4_BITS,
|
.bits = CONFIG_UART4_BITS,
|
||||||
.stopbits2 = CONFIG_UART4_2STOP,
|
.stopbits2 = CONFIG_UART4_2STOP,
|
||||||
@ -496,35 +501,36 @@ static struct up_dev_s g_uart5priv =
|
|||||||
#if CONSOLE_UART == 5
|
#if CONSOLE_UART == 5
|
||||||
.isconsole = true,
|
.isconsole = true,
|
||||||
#endif
|
#endif
|
||||||
.recv =
|
.recv =
|
||||||
{
|
{
|
||||||
.size = CONFIG_UART5_RXBUFSIZE,
|
.size = CONFIG_UART5_RXBUFSIZE,
|
||||||
.buffer = g_uart5rxbuffer,
|
.buffer = g_uart5rxbuffer,
|
||||||
},
|
},
|
||||||
.xmit =
|
.xmit =
|
||||||
{
|
{
|
||||||
.size = CONFIG_UART5_TXBUFSIZE,
|
.size = CONFIG_UART5_TXBUFSIZE,
|
||||||
.buffer = g_uart5txbuffer,
|
.buffer = g_uart5txbuffer,
|
||||||
},
|
},
|
||||||
.ops = &g_uart_ops,
|
.ops = &g_uart_ops,
|
||||||
.priv = &g_uart5priv,
|
.priv = &g_uart5priv,
|
||||||
},
|
},
|
||||||
|
|
||||||
.irq = STM32_IRQ_UART5,
|
.irq = STM32_IRQ_UART5,
|
||||||
.parity = CONFIG_UART5_PARITY,
|
.rxftcfg = CONFIG_UART5_RXFIFO_THRES,
|
||||||
.bits = CONFIG_UART5_BITS,
|
.parity = CONFIG_UART5_PARITY,
|
||||||
.stopbits2 = CONFIG_UART5_2STOP,
|
.bits = CONFIG_UART5_BITS,
|
||||||
|
.stopbits2 = CONFIG_UART5_2STOP,
|
||||||
#ifdef CONFIG_SERIAL_IFLOWCONTROL
|
#ifdef CONFIG_SERIAL_IFLOWCONTROL
|
||||||
.iflow = false,
|
.iflow = false,
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_SERIAL_OFLOWCONTROL
|
#ifdef CONFIG_SERIAL_OFLOWCONTROL
|
||||||
.oflow = false,
|
.oflow = false,
|
||||||
#endif
|
#endif
|
||||||
.baud = CONFIG_UART5_BAUD,
|
.baud = CONFIG_UART5_BAUD,
|
||||||
.apbclock = STM32_PCLK1_FREQUENCY,
|
.apbclock = STM32_PCLK1_FREQUENCY,
|
||||||
.usartbase = STM32_UART5_BASE,
|
.usartbase = STM32_UART5_BASE,
|
||||||
.tx_gpio = GPIO_UART5_TX,
|
.tx_gpio = GPIO_UART5_TX,
|
||||||
.rx_gpio = GPIO_UART5_RX,
|
.rx_gpio = GPIO_UART5_RX,
|
||||||
#ifdef CONFIG_SERIAL_OFLOWCONTROL
|
#ifdef CONFIG_SERIAL_OFLOWCONTROL
|
||||||
.cts_gpio = 0,
|
.cts_gpio = 0,
|
||||||
#endif
|
#endif
|
||||||
@ -553,36 +559,37 @@ static struct up_dev_s g_usart6priv =
|
|||||||
#if CONSOLE_UART == 6
|
#if CONSOLE_UART == 6
|
||||||
.isconsole = true,
|
.isconsole = true,
|
||||||
#endif
|
#endif
|
||||||
.recv =
|
.recv =
|
||||||
{
|
{
|
||||||
.size = CONFIG_USART6_RXBUFSIZE,
|
.size = CONFIG_USART6_RXBUFSIZE,
|
||||||
.buffer = g_usart6rxbuffer,
|
.buffer = g_usart6rxbuffer,
|
||||||
},
|
},
|
||||||
.xmit =
|
.xmit =
|
||||||
{
|
{
|
||||||
.size = CONFIG_USART6_TXBUFSIZE,
|
.size = CONFIG_USART6_TXBUFSIZE,
|
||||||
.buffer = g_usart6txbuffer,
|
.buffer = g_usart6txbuffer,
|
||||||
},
|
},
|
||||||
.ops = &g_uart_ops,
|
.ops = &g_uart_ops,
|
||||||
.priv = &g_usart6priv,
|
.priv = &g_usart6priv,
|
||||||
},
|
},
|
||||||
|
|
||||||
.irq = STM32_IRQ_USART6,
|
.irq = STM32_IRQ_USART6,
|
||||||
.parity = CONFIG_USART6_PARITY,
|
.rxftcfg = CONFIG_USART6_RXFIFO_THRES,
|
||||||
.bits = CONFIG_USART6_BITS,
|
.parity = CONFIG_USART6_PARITY,
|
||||||
.stopbits2 = CONFIG_USART6_2STOP,
|
.bits = CONFIG_USART6_BITS,
|
||||||
.baud = CONFIG_USART6_BAUD,
|
.stopbits2 = CONFIG_USART6_2STOP,
|
||||||
.apbclock = STM32_PCLK2_FREQUENCY,
|
.baud = CONFIG_USART6_BAUD,
|
||||||
.usartbase = STM32_USART6_BASE,
|
.apbclock = STM32_PCLK2_FREQUENCY,
|
||||||
.tx_gpio = GPIO_USART6_TX,
|
.usartbase = STM32_USART6_BASE,
|
||||||
.rx_gpio = GPIO_USART6_RX,
|
.tx_gpio = GPIO_USART6_TX,
|
||||||
|
.rx_gpio = GPIO_USART6_RX,
|
||||||
#if defined(CONFIG_SERIAL_OFLOWCONTROL) && defined(CONFIG_USART6_OFLOWCONTROL)
|
#if defined(CONFIG_SERIAL_OFLOWCONTROL) && defined(CONFIG_USART6_OFLOWCONTROL)
|
||||||
.oflow = true,
|
.oflow = true,
|
||||||
.cts_gpio = GPIO_USART6_CTS,
|
.cts_gpio = GPIO_USART6_CTS,
|
||||||
#endif
|
#endif
|
||||||
#if defined(CONFIG_SERIAL_IFLOWCONTROL) && defined(CONFIG_USART6_IFLOWCONTROL)
|
#if defined(CONFIG_SERIAL_IFLOWCONTROL) && defined(CONFIG_USART6_IFLOWCONTROL)
|
||||||
.iflow = true,
|
.iflow = true,
|
||||||
.rts_gpio = GPIO_USART6_RTS,
|
.rts_gpio = GPIO_USART6_RTS,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef CONFIG_USART6_RS485
|
#ifdef CONFIG_USART6_RS485
|
||||||
@ -606,36 +613,37 @@ static struct up_dev_s g_uart7priv =
|
|||||||
#if CONSOLE_UART == 7
|
#if CONSOLE_UART == 7
|
||||||
.isconsole = true,
|
.isconsole = true,
|
||||||
#endif
|
#endif
|
||||||
.recv =
|
.recv =
|
||||||
{
|
{
|
||||||
.size = CONFIG_UART7_RXBUFSIZE,
|
.size = CONFIG_UART7_RXBUFSIZE,
|
||||||
.buffer = g_uart7rxbuffer,
|
.buffer = g_uart7rxbuffer,
|
||||||
},
|
},
|
||||||
.xmit =
|
.xmit =
|
||||||
{
|
{
|
||||||
.size = CONFIG_UART7_TXBUFSIZE,
|
.size = CONFIG_UART7_TXBUFSIZE,
|
||||||
.buffer = g_uart7txbuffer,
|
.buffer = g_uart7txbuffer,
|
||||||
},
|
},
|
||||||
.ops = &g_uart_ops,
|
.ops = &g_uart_ops,
|
||||||
.priv = &g_uart7priv,
|
.priv = &g_uart7priv,
|
||||||
},
|
},
|
||||||
|
|
||||||
.irq = STM32_IRQ_UART7,
|
.irq = STM32_IRQ_UART7,
|
||||||
.parity = CONFIG_UART7_PARITY,
|
.rxftcfg = CONFIG_UART7_RXFIFO_THRES,
|
||||||
.bits = CONFIG_UART7_BITS,
|
.parity = CONFIG_UART7_PARITY,
|
||||||
.stopbits2 = CONFIG_UART7_2STOP,
|
.bits = CONFIG_UART7_BITS,
|
||||||
.baud = CONFIG_UART7_BAUD,
|
.stopbits2 = CONFIG_UART7_2STOP,
|
||||||
.apbclock = STM32_PCLK1_FREQUENCY,
|
.baud = CONFIG_UART7_BAUD,
|
||||||
.usartbase = STM32_UART7_BASE,
|
.apbclock = STM32_PCLK1_FREQUENCY,
|
||||||
.tx_gpio = GPIO_UART7_TX,
|
.usartbase = STM32_UART7_BASE,
|
||||||
.rx_gpio = GPIO_UART7_RX,
|
.tx_gpio = GPIO_UART7_TX,
|
||||||
|
.rx_gpio = GPIO_UART7_RX,
|
||||||
#if defined(CONFIG_SERIAL_OFLOWCONTROL) && defined(CONFIG_UART7_OFLOWCONTROL)
|
#if defined(CONFIG_SERIAL_OFLOWCONTROL) && defined(CONFIG_UART7_OFLOWCONTROL)
|
||||||
.oflow = true,
|
.oflow = true,
|
||||||
.cts_gpio = GPIO_UART7_CTS,
|
.cts_gpio = GPIO_UART7_CTS,
|
||||||
#endif
|
#endif
|
||||||
#if defined(CONFIG_SERIAL_IFLOWCONTROL) && defined(CONFIG_UART7_IFLOWCONTROL)
|
#if defined(CONFIG_SERIAL_IFLOWCONTROL) && defined(CONFIG_UART7_IFLOWCONTROL)
|
||||||
.iflow = true,
|
.iflow = true,
|
||||||
.rts_gpio = GPIO_UART7_RTS,
|
.rts_gpio = GPIO_UART7_RTS,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef CONFIG_UART7_RS485
|
#ifdef CONFIG_UART7_RS485
|
||||||
@ -659,36 +667,37 @@ static struct up_dev_s g_uart8priv =
|
|||||||
#if CONSOLE_UART == 8
|
#if CONSOLE_UART == 8
|
||||||
.isconsole = true,
|
.isconsole = true,
|
||||||
#endif
|
#endif
|
||||||
.recv =
|
.recv =
|
||||||
{
|
{
|
||||||
.size = CONFIG_UART8_RXBUFSIZE,
|
.size = CONFIG_UART8_RXBUFSIZE,
|
||||||
.buffer = g_uart8rxbuffer,
|
.buffer = g_uart8rxbuffer,
|
||||||
},
|
},
|
||||||
.xmit =
|
.xmit =
|
||||||
{
|
{
|
||||||
.size = CONFIG_UART8_TXBUFSIZE,
|
.size = CONFIG_UART8_TXBUFSIZE,
|
||||||
.buffer = g_uart8txbuffer,
|
.buffer = g_uart8txbuffer,
|
||||||
},
|
},
|
||||||
.ops = &g_uart_ops,
|
.ops = &g_uart_ops,
|
||||||
.priv = &g_uart8priv,
|
.priv = &g_uart8priv,
|
||||||
},
|
},
|
||||||
|
|
||||||
.irq = STM32_IRQ_UART8,
|
.irq = STM32_IRQ_UART8,
|
||||||
.parity = CONFIG_UART8_PARITY,
|
.rxftcfg = CONFIG_USRT8_RXFIFO_THRES,
|
||||||
.bits = CONFIG_UART8_BITS,
|
.parity = CONFIG_UART8_PARITY,
|
||||||
.stopbits2 = CONFIG_UART8_2STOP,
|
.bits = CONFIG_UART8_BITS,
|
||||||
.baud = CONFIG_UART8_BAUD,
|
.stopbits2 = CONFIG_UART8_2STOP,
|
||||||
.apbclock = STM32_PCLK1_FREQUENCY,
|
.baud = CONFIG_UART8_BAUD,
|
||||||
.usartbase = STM32_UART8_BASE,
|
.apbclock = STM32_PCLK1_FREQUENCY,
|
||||||
.tx_gpio = GPIO_UART8_TX,
|
.usartbase = STM32_UART8_BASE,
|
||||||
.rx_gpio = GPIO_UART8_RX,
|
.tx_gpio = GPIO_UART8_TX,
|
||||||
|
.rx_gpio = GPIO_UART8_RX,
|
||||||
#if defined(CONFIG_SERIAL_OFLOWCONTROL) && defined(CONFIG_UART8_OFLOWCONTROL)
|
#if defined(CONFIG_SERIAL_OFLOWCONTROL) && defined(CONFIG_UART8_OFLOWCONTROL)
|
||||||
.oflow = true,
|
.oflow = true,
|
||||||
.cts_gpio = GPIO_UART8_CTS,
|
.cts_gpio = GPIO_UART8_CTS,
|
||||||
#endif
|
#endif
|
||||||
#if defined(CONFIG_SERIAL_IFLOWCONTROL) && defined(CONFIG_UART8_IFLOWCONTROL)
|
#if defined(CONFIG_SERIAL_IFLOWCONTROL) && defined(CONFIG_UART8_IFLOWCONTROL)
|
||||||
.iflow = true,
|
.iflow = true,
|
||||||
.rts_gpio = GPIO_UART8_RTS,
|
.rts_gpio = GPIO_UART8_RTS,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef CONFIG_UART8_RS485
|
#ifdef CONFIG_UART8_RS485
|
||||||
@ -1198,8 +1207,9 @@ static int up_setup(struct uart_dev_s *dev)
|
|||||||
regval = up_serialin(priv, STM32_USART_CR3_OFFSET);
|
regval = up_serialin(priv, STM32_USART_CR3_OFFSET);
|
||||||
regval &= ~(USART_CR3_CTSIE | USART_CR3_CTSE | USART_CR3_RTSE | USART_CR3_EIE);
|
regval &= ~(USART_CR3_CTSIE | USART_CR3_CTSE | USART_CR3_RTSE | USART_CR3_EIE);
|
||||||
|
|
||||||
/* Set FIFO threshold to empty */
|
/* Set Rx FIFO threshold to empty */
|
||||||
regval |= USART_CR3_RXFTCFG_FULL;
|
|
||||||
|
regval |= USART_CR3_RXFTCFG(priv->rxftcfg);
|
||||||
|
|
||||||
up_serialout(priv, STM32_USART_CR3_OFFSET, regval);
|
up_serialout(priv, STM32_USART_CR3_OFFSET, regval);
|
||||||
|
|
||||||
@ -1210,8 +1220,8 @@ static int up_setup(struct uart_dev_s *dev)
|
|||||||
/* Enable Rx, Tx, and the USART */
|
/* Enable Rx, Tx, and the USART */
|
||||||
/* Enable FIFO */
|
/* Enable FIFO */
|
||||||
|
|
||||||
regval = up_serialin(priv, STM32_USART_CR1_OFFSET);
|
regval = up_serialin(priv, STM32_USART_CR1_OFFSET);
|
||||||
regval |= (USART_CR1_UE | USART_CR1_TE | USART_CR1_RE);
|
regval |= (USART_CR1_UE | USART_CR1_TE | USART_CR1_RE);
|
||||||
regval |= USART_CR1_FIFOEN;
|
regval |= USART_CR1_FIFOEN;
|
||||||
|
|
||||||
up_serialout(priv, STM32_USART_CR1_OFFSET, regval);
|
up_serialout(priv, STM32_USART_CR1_OFFSET, regval);
|
||||||
@ -1220,7 +1230,7 @@ static int up_setup(struct uart_dev_s *dev)
|
|||||||
|
|
||||||
/* Set up the cached interrupt enables value */
|
/* Set up the cached interrupt enables value */
|
||||||
|
|
||||||
priv->ie = 0;
|
priv->ie = 0;
|
||||||
|
|
||||||
/* Mark device as initialized. */
|
/* Mark device as initialized. */
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user