arch/xmc4 uart driver fix

This commit is contained in:
Nicolas Lemblé 2024-06-07 09:37:26 +02:00 committed by Xiang Xiao
parent 008803865f
commit 50fadb93f2
5 changed files with 376 additions and 99 deletions

View File

@ -199,11 +199,14 @@ endmenu
menu "XMC4xxx USIC Configuration" menu "XMC4xxx USIC Configuration"
depends on XMC4_USIC depends on XMC4_USIC
choice menu "USIC0 Channel 0 Configuration"
prompt "USIC0 Channel 0 Configuration" depends on XMC4_USIC
default XMC4_USIC0_CHAN0_ISUART
depends on XMC4_USIC0 depends on XMC4_USIC0
choice
prompt "Protocol"
default XMC4_USIC0_CHAN0_ISUART
config XMC4_USIC0_CHAN0_NONE config XMC4_USIC0_CHAN0_NONE
bool "Not used" bool "Not used"
---help--- ---help---
@ -244,12 +247,36 @@ config XMC4_USIC0_CHAN0_ISI2S
---help--- ---help---
Configure USIC0 Channel 0 for I2S audio Configure USIC0 Channel 0 for I2S audio
endchoice # USIC0 Channel 0 Configuration endchoice # USIC0 Channel 0 Protocol
config XMC4_USIC0_CHAN0_TX_BUFFER_SIZE
int "Tx Fifo Buffer Size"
depends on XMC4_USIC0_CHAN0_ISUART
default 16
---help---
Should be a power of 2 between 2 and 64
The sum of Rx and Tx buffers sizes of both
channels should be inferior to 64
config XMC4_USIC0_CHAN0_RX_BUFFER_SIZE
int "Rx Fifo Buffer Size"
depends on XMC4_USIC0_CHAN0_ISUART
default 16
---help---
Should be a power of 2 between 2 and 64
The sum of Rx and Tx buffers sizes of both
channels should be inferior to 64
endmenu # USIC0 Channel 0 Configuration
menu "USIC0 Channel 1 Configuration"
depends on XMC4_USIC
depends on XMC4_USIC0
choice choice
prompt "USIC0 Channel 1 Configuration" prompt "Protocol"
default XMC4_USIC0_CHAN1_ISUART default XMC4_USIC0_CHAN1_ISUART
depends on XMC4_USIC0
config XMC4_USIC0_CHAN1_NONE config XMC4_USIC0_CHAN1_NONE
bool "Not used" bool "Not used"
@ -291,12 +318,35 @@ config XMC4_USIC0_CHAN1_ISI2S
---help--- ---help---
Configure USIC0 Channel 1 for I2S audio Configure USIC0 Channel 1 for I2S audio
endchoice # USIC0 Channel 1 Configuration endchoice # USIC0 Channel 1 Protocol
config XMC4_USIC0_CHAN1_TX_BUFFER_SIZE
int "Tx Fifo Buffer Size"
depends on XMC4_USIC0_CHAN1_ISUART
default 16
---help---
Should be a power of 2 between 2 and 64
The sum of Rx and Tx buffers sizes of both
channels should be inferior to 64
config XMC4_USIC0_CHAN1_RX_BUFFER_SIZE
int "Rx Fifo Buffer Size"
depends on XMC4_USIC0_CHAN1_ISUART
default 16
---help---
Should be a power of 2 between 2 and 64
The sum of Rx and Tx buffers sizes of both
channels should be inferior to 64
endmenu # USIC0 Channel 1 Configuration
menu "USIC1 Channel 0 Configuration"
depends on XMC4_USIC
depends on XMC4_USIC1
choice choice
prompt "USIC1 Channel 0 Configuration" prompt "Protocol"
default XMC4_USIC1_CHAN0_ISUART default XMC4_USIC1_CHAN0_ISUART
depends on XMC4_USIC1
config XMC4_USIC1_CHAN0_NONE config XMC4_USIC1_CHAN0_NONE
bool "Not used" bool "Not used"
@ -338,12 +388,35 @@ config XMC4_USIC1_CHAN0_ISI2S
---help--- ---help---
Configure USIC1 Channel 0 for I2S audio Configure USIC1 Channel 0 for I2S audio
endchoice # USIC1 Channel 0 Configuration endchoice # USIC1 Channel 0 Protocol
config XMC4_USIC1_CHAN0_TX_BUFFER_SIZE
int "Tx Fifo Buffer Size"
depends on XMC4_USIC1_CHAN0_ISUART
default 16
---help---
Should be a power of 2 between 2 and 64
The sum of Rx and Tx buffers sizes of both
channels should be inferior to 64
config XMC4_USIC1_CHAN0_RX_BUFFER_SIZE
int "Rx Fifo Buffer Size"
depends on XMC4_USIC1_CHAN0_ISUART
default 16
---help---
Should be a power of 2 between 2 and 64
The sum of Rx and Tx buffers sizes of both
channels should be inferior to 64
endmenu # USIC1 Channel 0 Configuration
menu "USIC1 Channel 1 Configuration"
depends on XMC4_USIC
depends on XMC4_USIC1
choice choice
prompt "USIC1 Channel 1 Configuration" prompt "Protocol"
default XMC4_USIC1_CHAN1_ISUART default XMC4_USIC1_CHAN1_ISUART
depends on XMC4_USIC1
config XMC4_USIC1_CHAN1_NONE config XMC4_USIC1_CHAN1_NONE
bool "Not used" bool "Not used"
@ -385,12 +458,35 @@ config XMC4_USIC1_CHAN1_ISI2S
---help--- ---help---
Configure USIC1 Channel 1 for I2S audio Configure USIC1 Channel 1 for I2S audio
endchoice # USIC1 Channel 1 Configuration endchoice # USIC1 Channel 1 Protocol
config XMC4_USIC1_CHAN1_TX_BUFFER_SIZE
int "Tx Fifo Buffer Size"
depends on XMC4_USIC1_CHAN1_ISUART
default 16
---help---
Should be a power of 2 between 2 and 64
The sum of Rx and Tx buffers sizes of both
channels should be inferior to 64
config XMC4_USIC1_CHAN1_RX_BUFFER_SIZE
int "Rx Fifo Buffer Size"
depends on XMC4_USIC1_CHAN1_ISUART
default 16
---help---
Should be a power of 2 between 2 and 64
The sum of Rx and Tx buffers sizes of both
channels should be inferior to 64
endmenu # USIC1 Channel 1 Configuration
menu "USIC2 Channel 0 Configuration"
depends on XMC4_USIC
depends on XMC4_USIC2
choice choice
prompt "USIC2 Channel 0 Configuration" prompt "Protocol"
default XMC4_USIC2_CHAN0_ISUART default XMC4_USIC2_CHAN0_ISUART
depends on XMC4_USIC2
config XMC4_USIC2_CHAN0_NONE config XMC4_USIC2_CHAN0_NONE
bool "Not used" bool "Not used"
@ -432,12 +528,35 @@ config XMC4_USIC2_CHAN0_ISI2S
---help--- ---help---
Configure USIC2 Channel 0 for I2S audio Configure USIC2 Channel 0 for I2S audio
endchoice # USIC2 Channel 0 Configuration endchoice # USIC2 Channel 0 Protocol
config XMC4_USIC2_CHAN0_TX_BUFFER_SIZE
int "Tx Fifo Buffer Size"
depends on XMC4_USIC2_CHAN0_ISUART
default 16
---help---
Should be a power of 2 between 2 and 64
The sum of Rx and Tx buffers sizes of both
channels should be inferior to 64
config XMC4_USIC2_CHAN0_RX_BUFFER_SIZE
int "Rx Fifo Buffer Size"
depends on XMC4_USIC2_CHAN0_ISUART
default 16
---help---
Should be a power of 2 between 2 and 64
The sum of Rx and Tx buffers sizes of both
channels should be inferior to 64
endmenu # USIC2 Channel 0 Configuration
menu "USIC2 Channel 1 Configuration"
depends on XMC4_USIC
depends on XMC4_USIC2
choice choice
prompt "USIC2 Channel 1 Configuration" prompt "Protocol"
default XMC4_USIC2_CHAN1_ISUART default XMC4_USIC2_CHAN1_ISUART
depends on XMC4_USIC2
config XMC4_USIC2_CHAN1_NONE config XMC4_USIC2_CHAN1_NONE
bool "Not used" bool "Not used"
@ -478,6 +597,26 @@ config XMC4_USIC2_CHAN1_ISI2S
select XMC4_USCI_I2S select XMC4_USCI_I2S
---help--- ---help---
Configure USIC2 Channel 1 for I2S audio Configure USIC2 Channel 1 for I2S audio
endchoice # USIC2 Channel 1 Protocol
config XMC4_USIC2_CHAN1_TX_BUFFER_SIZE
int "Tx Fifo Buffer Size"
depends on XMC4_USIC2_CHAN1_ISUART
default 16
---help---
Should be a power of 2 between 2 and 64
The sum of Rx and Tx buffers sizes of both
channels should be inferior to 64
config XMC4_USIC2_CHAN1_RX_BUFFER_SIZE
int "Rx Fifo Buffer Size"
depends on XMC4_USIC2_CHAN1_ISUART
default 16
---help---
Should be a power of 2 between 2 and 64
The sum of Rx and Tx buffers sizes of both
channels should be inferior to 64
endmenu # USIC2 Channel 1 Configuration
endchoice # USIC2 Channel 1 Configuration
endmenu # XMC4xxx USIC Configuration endmenu # XMC4xxx USIC Configuration

View File

@ -57,6 +57,7 @@
****************************************************************************/ ****************************************************************************/
#include <nuttx/config.h> #include <nuttx/config.h>
#include <nuttx/lib/math32.h>
#include "hardware/xmc4_memorymap.h" #include "hardware/xmc4_memorymap.h"
@ -1008,12 +1009,7 @@
#define USIC_TBCTR_SIZE_SHIFT (24) /* Bits 24-26: Buffer Size */ #define USIC_TBCTR_SIZE_SHIFT (24) /* Bits 24-26: Buffer Size */
#define USIC_TBCTR_SIZE_MASK (7 << USIC_TBCTR_SIZE_SHIFT) #define USIC_TBCTR_SIZE_MASK (7 << USIC_TBCTR_SIZE_SHIFT)
# define USIC_TBCTR_SIZE_DISABLE (0 << USIC_TBCTR_SIZE_SHIFT) /* FIFO mechanism is disabled */ # define USIC_TBCTR_SIZE_DISABLE (0 << USIC_TBCTR_SIZE_SHIFT) /* FIFO mechanism is disabled */
# define USIC_TBCTR_SIZE_2 (1 << USIC_TBCTR_SIZE_SHIFT) /* FIFO buffer contains 2 entries */ # define USIC_TBCTR_SIZE(n) ((uint32_t)(LOG2_CEIL(n)) << USIC_TBCTR_SIZE_SHIFT)
# define USIC_TBCTR_SIZE_4 (2 << USIC_TBCTR_SIZE_SHIFT) /* FIFO buffer contains 4 entries */
# define USIC_TBCTR_SIZE_8 (3 << USIC_TBCTR_SIZE_SHIFT) /* FIFO buffer contains 8 entries */
# define USIC_TBCTR_SIZE_16 (4 << USIC_TBCTR_SIZE_SHIFT) /* FIFO buffer contains 16 entries */
# define USIC_TBCTR_SIZE_32 (5 << USIC_TBCTR_SIZE_SHIFT) /* FIFO buffer contains 32 entries */
# define USIC_TBCTR_SIZE_64 (6 << USIC_TBCTR_SIZE_SHIFT) /* FIFO buffer contains 64 entries */
#define USIC_TBCTR_LOF (1 << 28) /* Bit 28: Buffer Event on Limit Overflow */ #define USIC_TBCTR_LOF (1 << 28) /* Bit 28: Buffer Event on Limit Overflow */
#define USIC_TBCTR_STBIEN (1 << 30) /* Bit 30: Standard Transmit Buffer Interrupt Enable */ #define USIC_TBCTR_STBIEN (1 << 30) /* Bit 30: Standard Transmit Buffer Interrupt Enable */
@ -1058,12 +1054,7 @@
#define USIC_RBCTR_SIZE_SHIFT (24) /* Bits 24-26: Buffer Size */ #define USIC_RBCTR_SIZE_SHIFT (24) /* Bits 24-26: Buffer Size */
#define USIC_RBCTR_SIZE_MASK (7 << USIC_RBCTR_SIZE_SHIFT) #define USIC_RBCTR_SIZE_MASK (7 << USIC_RBCTR_SIZE_SHIFT)
# define USIC_RBCTR_SIZE_DISABLE (0 << USIC_RBCTR_SIZE_SHIFT) /* FIFO mechanism is disabled */ # define USIC_RBCTR_SIZE_DISABLE (0 << USIC_RBCTR_SIZE_SHIFT) /* FIFO mechanism is disabled */
# define USIC_RBCTR_SIZE_2 (1 << USIC_RBCTR_SIZE_SHIFT) /* FIFO buffer contains 2 entries */ # define USIC_RBCTR_SIZE(n) ((uint32_t)(LOG2_CEIL(n)) << USIC_RBCTR_SIZE_SHIFT)
# define USIC_RBCTR_SIZE_4 (2 << USIC_RBCTR_SIZE_SHIFT) /* FIFO buffer contains 4 entries */
# define USIC_RBCTR_SIZE_8 (3 << USIC_RBCTR_SIZE_SHIFT) /* FIFO buffer contains 8 entries */
# define USIC_RBCTR_SIZE_16 (4 << USIC_RBCTR_SIZE_SHIFT) /* FIFO buffer contains 16 entries */
# define USIC_RBCTR_SIZE_32 (5 << USIC_RBCTR_SIZE_SHIFT) /* FIFO buffer contains 32 entries */
# define USIC_RBCTR_SIZE_64 (6 << USIC_RBCTR_SIZE_SHIFT) /* FIFO buffer contains 64 entries */
#define USIC_RBCTR_RNM (1 << 27) /* Bit 27: Receiver Notification Mode */ #define USIC_RBCTR_RNM (1 << 27) /* Bit 27: Receiver Notification Mode */
#define USIC_RBCTR_LOF (1 << 28) /* Bit 28: Buffer Event on Limit Overflow */ #define USIC_RBCTR_LOF (1 << 28) /* Bit 28: Buffer Event on Limit Overflow */

View File

@ -23,6 +23,7 @@
****************************************************************************/ ****************************************************************************/
#include <nuttx/config.h> #include <nuttx/config.h>
#include <nuttx/lib/math32.h>
#include <stdint.h> #include <stdint.h>
#include <errno.h> #include <errno.h>
@ -109,6 +110,129 @@
#define UART_OVERSAMPLING 16 #define UART_OVERSAMPLING 16
#if defined(CONFIG_XMC4_USIC0_CHAN0_ISUART)
#if CONFIG_XMC4_USIC0_CHAN0_TX_BUFFER_SIZE < 2 \
|| CONFIG_XMC4_USIC0_CHAN0_TX_BUFFER_SIZE > 64 \
|| !IS_POWER_OF_2(CONFIG_XMC4_USIC0_CHAN0_TX_BUFFER_SIZE)
# error Tx Buffer Size should be a power of 2 between 2 and 64
#endif
#if CONFIG_XMC4_USIC0_CHAN0_RX_BUFFER_SIZE < 2 \
|| CONFIG_XMC4_USIC0_CHAN0_RX_BUFFER_SIZE > 64 \
|| !IS_POWER_OF_2(CONFIG_XMC4_USIC0_CHAN0_RX_BUFFER_SIZE)
# error Rx Buffer Size should be a power of 2 between 2 and 64
#endif
#endif
#if defined(CONFIG_XMC4_USIC0_CHAN1_ISUART)
#if CONFIG_XMC4_USIC0_CHAN1_TX_BUFFER_SIZE < 2 \
|| CONFIG_XMC4_USIC0_CHAN1_TX_BUFFER_SIZE > 64 \
|| !IS_POWER_OF_2(CONFIG_XMC4_USIC0_CHAN1_TX_BUFFER_SIZE)
# error Tx Buffer Size should be a power of 2 between 2 and 64
#endif
#if CONFIG_XMC4_USIC0_CHAN1_RX_BUFFER_SIZE < 2 \
|| CONFIG_XMC4_USIC0_CHAN1_RX_BUFFER_SIZE > 64 \
|| !IS_POWER_OF_2(CONFIG_XMC4_USIC0_CHAN1_RX_BUFFER_SIZE)
# error Rx Buffer Size should be a power of 2 between 2 and 64
#endif
#endif
#if defined(CONFIG_XMC4_USIC0_CHAN0_ISUART) && defined(CONFIG_XMC4_USIC0_CHAN1_ISUART)
#if CONFIG_XMC4_USIC0_CHAN0_TX_BUFFER_SIZE + CONFIG_XMC4_USIC0_CHAN0_RX_BUFFER_SIZE + \
CONFIG_XMC4_USIC0_CHAN1_TX_BUFFER_SIZE + CONFIG_XMC4_USIC0_CHAN1_RX_BUFFER_SIZE > 64
# error The sum of Rx and Tx Buffers sizes should be inferior to 64
#endif
#endif
#if defined(CONFIG_XMC4_USIC1_CHAN0_ISUART)
#if CONFIG_XMC4_USIC1_CHAN0_TX_BUFFER_SIZE < 2 \
|| CONFIG_XMC4_USIC1_CHAN0_TX_BUFFER_SIZE > 64 \
|| !IS_POWER_OF_2(CONFIG_XMC4_USIC1_CHAN0_TX_BUFFER_SIZE)
# error Tx Buffer Size should be a power of 2 between 2 and 64
#endif
#if CONFIG_XMC4_USIC1_CHAN0_RX_BUFFER_SIZE < 2 \
|| CONFIG_XMC4_USIC1_CHAN0_RX_BUFFER_SIZE > 64 \
|| !IS_POWER_OF_2(CONFIG_XMC4_USIC1_CHAN0_RX_BUFFER_SIZE)
# error Rx Buffer Size should be a power of 2 between 2 and 64
#endif
#if CONFIG_XMC4_USIC1_CHAN0_TX_BUFFER_SIZE + CONFIG_XMC4_USIC1_CHAN0_RX_BUFFER_SIZE > 64
# error The sum of Rx and Tx Buffer sizes should be inferior to 64
#endif
#endif
#if defined(CONFIG_XMC4_USIC1_CHAN1_ISUART)
#if CONFIG_XMC4_USIC1_CHAN1_TX_BUFFER_SIZE < 2 \
|| CONFIG_XMC4_USIC1_CHAN1_TX_BUFFER_SIZE > 64 \
|| !IS_POWER_OF_2(CONFIG_XMC4_USIC1_CHAN1_TX_BUFFER_SIZE)
# error Tx Buffer Size should be a power of 2 between 2 and 64
#endif
#if CONFIG_XMC4_USIC1_CHAN1_RX_BUFFER_SIZE < 2 \
|| CONFIG_XMC4_USIC1_CHAN1_RX_BUFFER_SIZE > 64 \
|| !IS_POWER_OF_2(CONFIG_XMC4_USIC1_CHAN1_RX_BUFFER_SIZE)
# error Rx Buffer Size should be a power of 2 between 2 and 64
#endif
#if CONFIG_XMC4_USIC1_CHAN1_TX_BUFFER_SIZE + CONFIG_XMC4_USIC1_CHAN1_RX_BUFFER_SIZE > 64
# error The sum of Rx and Tx Buffer sizes should be inferior to 64
#endif
#endif
#if defined(CONFIG_XMC4_USIC1_CHAN0_ISUART) && defined(CONFIG_XMC4_USIC1_CHAN1_ISUART)
#if CONFIG_XMC4_USIC1_CHAN0_TX_BUFFER_SIZE + CONFIG_XMC4_USIC1_CHAN0_RX_BUFFER_SIZE + \
CONFIG_XMC4_USIC1_CHAN1_TX_BUFFER_SIZE + CONFIG_XMC4_USIC1_CHAN1_RX_BUFFER_SIZE > 64
# error The sum of Rx and Tx Buffers sizes should be inferior to 64
#endif
#endif
#if defined(CONFIG_XMC4_USIC2_CHAN0_ISUART)
#if CONFIG_XMC4_USIC2_CHAN0_TX_BUFFER_SIZE < 2 \
|| CONFIG_XMC4_USIC2_CHAN0_TX_BUFFER_SIZE > 64 \
|| !IS_POWER_OF_2(CONFIG_XMC4_USIC2_CHAN0_TX_BUFFER_SIZE)
# error Tx Buffer Size should be a power of 2 between 2 and 64
#endif
#if CONFIG_XMC4_USIC2_CHAN0_RX_BUFFER_SIZE < 2 \
|| CONFIG_XMC4_USIC2_CHAN0_RX_BUFFER_SIZE > 64 \
|| !IS_POWER_OF_2(CONFIG_XMC4_USIC2_CHAN0_RX_BUFFER_SIZE)
# error Rx Buffer Size should be a power of 2 between 2 and 64
#endif
#if CONFIG_XMC4_USIC2_CHAN0_TX_BUFFER_SIZE + CONFIG_XMC4_USIC2_CHAN0_RX_BUFFER_SIZE > 64
# error The sum of Rx and Tx Buffer sizes should be inferior to 64
#endif
#endif
#if defined(CONFIG_XMC4_USIC2_CHAN1_ISUART)
#if CONFIG_XMC4_USIC2_CHAN1_TX_BUFFER_SIZE < 2 \
|| CONFIG_XMC4_USIC2_CHAN1_TX_BUFFER_SIZE > 64 \
|| !IS_POWER_OF_2(CONFIG_XMC4_USIC2_CHAN1_TX_BUFFER_SIZE)
# error Tx Buffer Size should be a power of 2 between 2 and 64
#endif
#if CONFIG_XMC4_USIC2_CHAN1_RX_BUFFER_SIZE < 2 \
|| CONFIG_XMC4_USIC2_CHAN1_RX_BUFFER_SIZE > 64 \
|| !IS_POWER_OF_2(CONFIG_XMC4_USIC2_CHAN1_RX_BUFFER_SIZE)
# error Rx Buffer Size should be a power of 2 between 2 and 64
#endif
#if CONFIG_XMC4_USIC2_CHAN1_TX_BUFFER_SIZE + CONFIG_XMC4_USIC2_CHAN1_RX_BUFFER_SIZE > 64
# error The sum of Rx and Tx Buffer sizes should be inferior to 64
#endif
#endif
#if defined(CONFIG_XMC4_USIC2_CHAN0_ISUART) && defined(CONFIG_XMC4_USIC2_CHAN1_ISUART)
#if CONFIG_XMC4_USIC2_CHAN0_TX_BUFFER_SIZE + CONFIG_XMC4_USIC2_CHAN0_RX_BUFFER_SIZE + \
CONFIG_XMC4_USIC2_CHAN1_TX_BUFFER_SIZE + CONFIG_XMC4_USIC2_CHAN1_RX_BUFFER_SIZE > 64
# error The sum of Rx and Tx Buffers sizes should be inferior to 64
#endif
#endif
/**************************************************************************** /****************************************************************************
* Private Data * Private Data
****************************************************************************/ ****************************************************************************/
@ -357,21 +481,21 @@ int xmc4_uart_configure(enum usic_channel_e channel,
/* Configure transmit FIFO /* Configure transmit FIFO
* *
* - DPTR = 16
* - LIMIT = 1 * - LIMIT = 1
* - STBTEN = 0, the trigger of the standard transmit buffer event is * - STBTEN = 0, the trigger of the standard transmit buffer event is
* based on the transition of the fill level from equal to below the * based on the transition of the fill level from equal to below the
* limit, not the fact being below * limit, not the fact being below
* - SIZE = 16
* - LOF = 0, A standard transmit buffer event occurs when the filling * - LOF = 0, A standard transmit buffer event occurs when the filling
* level equals the limit value and gets lower due to transmission of * level equals the limit value and gets lower due to transmission of
* a data word * a data word
*/ */
regval &= ~(USIC_TBCTR_DPTR_MASK | USIC_TBCTR_LIMIT_MASK | regval &= ~(USIC_TBCTR_DPTR_MASK | USIC_TBCTR_LIMIT_MASK |
USIC_TBCTR_STBTEN | USIC_TBCTR_SIZE_MASK | USIC_TBCTR_LOF); USIC_TBCTR_STBTEN | USIC_TBCTR_SIZE_MASK |
regval |= (USIC_TBCTR_DPTR(16) | USIC_TBCTR_LIMIT(1) | USIC_TBCTR_LOF);
USIC_TBCTR_SIZE_16); regval |= (USIC_TBCTR_DPTR(config->startbufferptr)) |
USIC_TBCTR_LIMIT(1) |
USIC_TBCTR_SIZE(config->txbuffersize);
putreg32(regval, base + XMC4_USIC_TBCTR_OFFSET); putreg32(regval, base + XMC4_USIC_TBCTR_OFFSET);
/* Disable the receive FIFO */ /* Disable the receive FIFO */
@ -382,9 +506,6 @@ int xmc4_uart_configure(enum usic_channel_e channel,
/* Configure receive FIFO. /* Configure receive FIFO.
* *
* - DPTR = 0
* - LIMIT = 16
* - SIZE = 15
* - LOF = 1, A standard receive buffer event occurs when the filling * - LOF = 1, A standard receive buffer event occurs when the filling
* level equals the limit value and gets bigger due to the reception * level equals the limit value and gets bigger due to the reception
* of a new data word * of a new data word
@ -392,7 +513,9 @@ int xmc4_uart_configure(enum usic_channel_e channel,
regval &= ~(USIC_RBCTR_DPTR_MASK | USIC_RBCTR_LIMIT_MASK | regval &= ~(USIC_RBCTR_DPTR_MASK | USIC_RBCTR_LIMIT_MASK |
USIC_RBCTR_SIZE_MASK); USIC_RBCTR_SIZE_MASK);
regval |= (USIC_RBCTR_DPTR(0) | USIC_RBCTR_LIMIT(15) | USIC_RBCTR_SIZE_16 | regval |= (USIC_RBCTR_DPTR(config->startbufferptr + config->txbuffersize) |
USIC_RBCTR_LIMIT(config->rxbuffersize) |
USIC_RBCTR_SIZE(config->rxbuffersize) |
USIC_RBCTR_LOF); USIC_RBCTR_LOF);
putreg32(regval, base + XMC4_USIC_RBCTR_OFFSET); putreg32(regval, base + XMC4_USIC_RBCTR_OFFSET);

View File

@ -41,11 +41,14 @@
struct uart_config_s struct uart_config_s
{ {
uint32_t baud; /* Desired BAUD rate */ uint32_t baud; /* Desired BAUD rate */
uint8_t dx; /* Input pin 0=DXA, 1=DXB, ... 6=DXG */ uint8_t dx; /* Input pin 0=DXA, 1=DXB, ... 6=DXG */
uint8_t parity; /* Parity selection: 0=none, 1=odd, 2=even */ uint8_t parity; /* Parity selection: 0=none, 1=odd, 2=even */
uint8_t nbits; /* Number of bits per word */ uint8_t nbits; /* Number of bits per word */
bool stop2; /* true=2 stop bits; false=1 stop bit */ bool stop2; /* true=2 stop bits; false=1 stop bit */
uint8_t startbufferptr; /* Hardware Tx buffer start pointer */
uint8_t txbuffersize; /* Hardware Tx Buffer Size */
uint8_t rxbuffersize; /* Hardware Rx Buffer Size */
}; };
/**************************************************************************** /****************************************************************************

View File

@ -310,16 +310,19 @@ static char g_uart5txbuffer[CONFIG_UART5_TXBUFSIZE];
#ifdef HAVE_UART0 #ifdef HAVE_UART0
static struct xmc4_dev_s g_uart0priv = static struct xmc4_dev_s g_uart0priv =
{ {
.uartbase = XMC4_USIC0_CH0_BASE, .uartbase = XMC4_USIC0_CH0_BASE,
.channel = (uint8_t)USIC0_CHAN0, .channel = (uint8_t)USIC0_CHAN0,
.irq = XMC4_IRQ_USIC0_SR0, .irq = XMC4_IRQ_USIC0_SR0,
.config = .config =
{ {
.baud = CONFIG_UART0_BAUD, .baud = CONFIG_UART0_BAUD,
.dx = BOARD_UART0_DX, .dx = BOARD_UART0_DX,
.parity = CONFIG_UART0_PARITY, .parity = CONFIG_UART0_PARITY,
.nbits = CONFIG_UART0_BITS, .nbits = CONFIG_UART0_BITS,
.stop2 = CONFIG_UART0_2STOP, .stop2 = CONFIG_UART0_2STOP,
.startbufferptr = 0,
.txbuffersize = CONFIG_XMC4_USIC0_CHAN0_TX_BUFFER_SIZE,
.rxbuffersize = CONFIG_XMC4_USIC0_CHAN0_RX_BUFFER_SIZE,
} }
}; };
@ -345,16 +348,20 @@ static uart_dev_t g_uart0port =
#ifdef HAVE_UART1 #ifdef HAVE_UART1
static struct xmc4_dev_s g_uart1priv = static struct xmc4_dev_s g_uart1priv =
{ {
.uartbase = XMC4_USIC0_CH1_BASE, .uartbase = XMC4_USIC0_CH1_BASE,
.channel = (uint8_t)USIC0_CHAN1, .channel = (uint8_t)USIC0_CHAN1,
.irq = XMC4_IRQ_USIC0_SR1, .irq = XMC4_IRQ_USIC0_SR1,
.config = .config =
{ {
.baud = CONFIG_UART1_BAUD, .baud = CONFIG_UART1_BAUD,
.dx = BOARD_UART1_DX, .dx = BOARD_UART1_DX,
.parity = CONFIG_UART1_PARITY, .parity = CONFIG_UART1_PARITY,
.nbits = CONFIG_UART1_BITS, .nbits = CONFIG_UART1_BITS,
.stop2 = CONFIG_UART1_2STOP, .stop2 = CONFIG_UART1_2STOP,
.startbufferptr = CONFIG_XMC4_USIC0_CHAN0_TX_BUFFER_SIZE
+ CONFIG_XMC4_USIC0_CHAN0_RX_BUFFER_SIZE,
.txbuffersize = CONFIG_XMC4_USIC0_CHAN1_TX_BUFFER_SIZE,
.rxbuffersize = CONFIG_XMC4_USIC0_CHAN1_RX_BUFFER_SIZE,
} }
}; };
@ -380,16 +387,19 @@ static uart_dev_t g_uart1port =
#ifdef HAVE_UART2 #ifdef HAVE_UART2
static struct xmc4_dev_s g_uart2priv = static struct xmc4_dev_s g_uart2priv =
{ {
.uartbase = XMC4_USIC1_CH0_BASE, .uartbase = XMC4_USIC1_CH0_BASE,
.channel = (uint8_t)USIC1_CHAN0, .channel = (uint8_t)USIC1_CHAN0,
.irq = XMC4_IRQ_USIC1_SR0, .irq = XMC4_IRQ_USIC1_SR0,
.config = .config =
{ {
.baud = CONFIG_UART2_BAUD, .baud = CONFIG_UART2_BAUD,
.dx = BOARD_UART2_DX, .dx = BOARD_UART2_DX,
.parity = CONFIG_UART2_PARITY, .parity = CONFIG_UART2_PARITY,
.nbits = CONFIG_UART2_BITS, .nbits = CONFIG_UART2_BITS,
.stop2 = CONFIG_UART2_2STOP, .stop2 = CONFIG_UART2_2STOP,
.startbufferptr = 0,
.txbuffersize = CONFIG_XMC4_USIC1_CHAN0_TX_BUFFER_SIZE,
.rxbuffersize = CONFIG_XMC4_USIC1_CHAN0_RX_BUFFER_SIZE,
} }
}; };
@ -415,16 +425,20 @@ static uart_dev_t g_uart2port =
#ifdef HAVE_UART3 #ifdef HAVE_UART3
static struct xmc4_dev_s g_uart3priv = static struct xmc4_dev_s g_uart3priv =
{ {
.uartbase = XMC4_USIC1_CH1_BASE, .uartbase = XMC4_USIC1_CH1_BASE,
.channel = (uint8_t)USIC1_CHAN1, .channel = (uint8_t)USIC1_CHAN1,
.irq = XMC4_IRQ_USIC1_SR1, .irq = XMC4_IRQ_USIC1_SR1,
.config = .config =
{ {
.baud = CONFIG_UART3_BAUD, .baud = CONFIG_UART3_BAUD,
.dx = BOARD_UART3_DX, .dx = BOARD_UART3_DX,
.parity = CONFIG_UART3_PARITY, .parity = CONFIG_UART3_PARITY,
.nbits = CONFIG_UART3_BITS, .nbits = CONFIG_UART3_BITS,
.stop2 = CONFIG_UART3_2STOP, .stop2 = CONFIG_UART3_2STOP,
.startbufferptr = CONFIG_XMC4_USIC1_CHAN0_TX_BUFFER_SIZE
+ CONFIG_XMC4_USIC1_CHAN0_RX_BUFFER_SIZE,
.txbuffersize = CONFIG_XMC4_USIC1_CHAN1_TX_BUFFER_SIZE,
.rxbuffersize = CONFIG_XMC4_USIC1_CHAN1_RX_BUFFER_SIZE,
} }
}; };
@ -450,16 +464,19 @@ static uart_dev_t g_uart3port =
#ifdef HAVE_UART4 #ifdef HAVE_UART4
static struct xmc4_dev_s g_uart4priv = static struct xmc4_dev_s g_uart4priv =
{ {
.uartbase = XMC4_USIC2_CH0_BASE, .uartbase = XMC4_USIC2_CH0_BASE,
.channel = (uint8_t)USIC2_CHAN0, .channel = (uint8_t)USIC2_CHAN0,
.irq = XMC4_IRQ_USIC2_SR0, .irq = XMC4_IRQ_USIC2_SR0,
.config = .config =
{ {
.baud = CONFIG_UART4_BAUD, .baud = CONFIG_UART4_BAUD,
.dx = BOARD_UART4_DX, .dx = BOARD_UART4_DX,
.parity = CONFIG_UART4_PARITY, .parity = CONFIG_UART4_PARITY,
.nbits = CONFIG_UART4_BITS, .nbits = CONFIG_UART4_BITS,
.stop2 = CONFIG_UART4_2STOP, .stop2 = CONFIG_UART4_2STOP,
.startbufferptr = 0,
.txbuffersize = CONFIG_XMC4_USIC2_CHAN0_TX_BUFFER_SIZE,
.rxbuffersize = CONFIG_XMC4_USIC2_CHAN0_RX_BUFFER_SIZE,
} }
}; };
@ -485,16 +502,20 @@ static uart_dev_t g_uart4port =
#ifdef HAVE_UART5 #ifdef HAVE_UART5
static struct xmc4_dev_s g_uart5priv = static struct xmc4_dev_s g_uart5priv =
{ {
.uartbase = XMC4_USIC2_CH1_BASE, .uartbase = XMC4_USIC2_CH1_BASE,
.channel = (uint8_t)USIC2_CHAN1, .channel = (uint8_t)USIC2_CHAN1,
.irq = XMC4_IRQ_USIC2_SR1, .irq = XMC4_IRQ_USIC2_SR1,
.config = .config =
{ {
.baud = CONFIG_UART5_BAUD, .baud = CONFIG_UART5_BAUD,
.dx = BOARD_UART5_DX, .dx = BOARD_UART5_DX,
.parity = CONFIG_UART5_PARITY, .parity = CONFIG_UART5_PARITY,
.nbits = CONFIG_UART5_BITS, .nbits = CONFIG_UART5_BITS,
.stop2 = CONFIG_UART5_2STOP, .stop2 = CONFIG_UART5_2STOP,
.startbufferptr = CONFIG_XMC4_USIC2_CHAN0_TX_BUFFER_SIZE
+ CONFIG_XMC4_USIC2_CHAN0_RX_BUFFER_SIZE,
.txbuffersize = CONFIG_XMC4_USIC2_CHAN1_TX_BUFFER_SIZE,
.rxbuffersize = CONFIG_XMC4_USIC2_CHAN1_RX_BUFFER_SIZE,
} }
}; };