arch/arm/src/stm32h7: Remove old references to RXDMA. Add configuration option to select the Rx FIFO threshold level.

This commit is contained in:
Gregory Nutt 2018-09-02 08:35:22 -06:00
parent ff1e6a66e9
commit 5c5b6ab8f6
4 changed files with 234 additions and 155 deletions

View File

@ -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)

View File

@ -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

View File

@ -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 */

View File

@ -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. */