/**
* @file xmc_usic.h
* @date 2019-07-01
*
* @cond
*********************************************************************************************************************
* XMClib v2.1.24 - XMC Peripheral Driver Library
*
* Copyright (c) 2015-2019, Infineon Technologies AG
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification,are permitted provided that the
* following conditions are met:
*
* Redistributions of source code must retain the above copyright notice, this list of conditions and the following
* disclaimer.
*
* Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following
* disclaimer in the documentation and/or other materials provided with the distribution.
*
* Neither the name of the copyright holders nor the names of its contributors may be used to endorse or promote
* products derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY,OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* To improve the quality of the software, users are encouraged to share modifications, enhancements or bug fixes with
* Infineon Technologies AG dave@infineon.com).
*********************************************************************************************************************
*
* Change History
* --------------
*
* 2015-02-20:
* - Initial draft
* - Documentation improved
*
* 2015-05-08:
* - Added XMC_USIC_CH_SetInputTriggerCombinationMode() and XMC_USIC_CH_SetTransmitBufferStatus()
*
* 2015-06-20:
* - Removed version macros and declaration of GetDriverVersion API
*
* 2015-08-17:
* - Bug fixed in XMC_USIC_CH_SetTransmitBufferStatus API. OR operator removed.
*
* 2015-08-24:
* - Added APIs for enabling/disabling delay compensation XMC_USIC_CH_DisableDelayCompensation() and
* XMC_USIC_CH_DisableDelayCompensation()
*
* 2015-08-25:
* - Added APIs for defining if the data shift unit input is derived
* from the input data path DXn or from the selected protocol pre-processors: XMC_USIC_CH_ConnectInputDataShiftToPPP()
* and XMC_USIC_CH_ConnectInputDataShiftToDataInput()
*
* 2015-08-27:
* - Fixed bug in XMC_USIC_CH_BRG_CLOCK_SOURCE_DX1T value.
* - Added APIs for direct TBUF access: XMC_USIC_CH_WriteToTBUF() and XMC_USIC_CH_WriteToTBUFTCI()
* - Added APIs for external input for BRG configuration:XMC_USIC_CH_ConfigExternalInputSignalToBRG() and XMC_USIC_CH_SetBRGInputClockSource()
*
* 2015-08-28:
* - Added API for enabling the transfer trigger unit to set bit TCSR.TE if the trigger signal DX2T becomes active. Feature used for RS-232
* Clear to Send (CTS) signal: XMC_USIC_CH_EnableTBUFDataValidTrigger() and XMC_USIC_CH_DisableTBUFDataValidTrigger().
*
* 2016-03-09:
* - Optimization of write only registers
*
* 2016-04-10:
* - Added an API to put the data into FIFO when hardware port control is enabled: XMC_USIC_CH_TXFIFO_PutDataHPCMode()
*
* 2017-02-10:
* - Added XMC_USIC_CH_SetShiftDirection() to allow selection of shift direction of the data words for transmision and reception
* - Added XMC_USIC_CH_GetCaptureTimerValue() and XMC_USIC_CH_SetFractionalDivider()
*
* 2017-09-08:
* - Fixed value of macro XMC_USIC_CH_SHIFT_DIRECTION_MSB_FIRST used in XMC_USIC_CH_SetShiftDirection()
*
* 2018-09-29:
* - Added XMC_USIC_CH_SetBaudrateEx which uses the integer divider instead of the fractional divider
*
* 2019-05-07:
* - Added XMC_USIC_CH_GetBaudrate(), XMC_USIC_CH_GetSCLKFrequency() and XMC_USIC_CH_GetMCLKFrequency()
*
* 2019-07-01:
* - Changed XMC_USIC_CH_SetBaudrateEx() input parameter types
*
* @endcond
*
*/
#ifndef XMC_USIC_H
#define XMC_USIC_H
/*******************************************************************************
* HEADER FILES
*******************************************************************************/
#include "xmc_common.h"
/**
* @addtogroup XMClib XMC Peripheral Library
* @{
*/
/**
* @addtogroup USIC
* @brief Universal Serial Interface Channel(USIC) driver for serial communication.
*
* The Universal Serial Interface Channel(USIC) module is a flexible interface module
* covering several serial communication protocols. A USIC module contains two
* independent communication channels named USICx_CH0 and USICx_CH1, with x
* being the number of the USIC module. The user can program, during run-time, which protocol will be handled
* by each communication channel and which pins are used.
* The driver provides APIs, configuration structures and enumerations to configure common features of multiple serial
* communication protocols.
*
* USIC driver features:
* -# Allows configuration of FIFO for transmit and receive functions.
* -# Provides a structure type XMC_USIC_CH_t to represent the USIC channel registers in a programmer
friendly format.
* -# Allows configuration of automatic update for frame length, word length, slave select or slave address.
* -# Allows transmission of data to FIFO using XMC_USIC_CH_TXFIFO_PutData() and XMC_USIC_CH_TXFIFO_PutDataFLEMode()
* -# Allows reading of received data in FIFO using XMC_USIC_CH_RXFIFO_GetData()
* -# Allows configuration of baudrate using XMC_USIC_CH_SetBaudrate()
* -# Provides API to trigger interrupts using XMC_USIC_CH_TriggerServiceRequest()
* @{
*/
/*******************************************************************************
* MACROS
*******************************************************************************/
#define XMC_USIC0 ((XMC_USIC_t *)USIC0_BASE) /**< USIC0 module base address */
#define XMC_USIC0_CH0 ((XMC_USIC_CH_t *)USIC0_CH0_BASE) /**< USIC0 channel 0 base address */
#define XMC_USIC0_CH1 ((XMC_USIC_CH_t *)USIC0_CH1_BASE) /**< USIC0 channel 1 base address */
#if defined(USIC1)
#define XMC_USIC1 ((XMC_USIC_t *)USIC1_BASE) /**< USIC1 module base address */
#define XMC_USIC1_CH0 ((XMC_USIC_CH_t *)USIC1_CH0_BASE) /**< USIC1 channel 0 base address */
#define XMC_USIC1_CH1 ((XMC_USIC_CH_t *)USIC1_CH1_BASE) /**< USIC1 channel 1 base address */
#endif
#if defined(USIC2)
#define XMC_USIC2 ((XMC_USIC_t *)USIC2_BASE) /**< USIC2 module base address */
#define XMC_USIC2_CH0 ((XMC_USIC_CH_t *)USIC2_CH0_BASE) /**< USIC2 channel 0 base address */
#define XMC_USIC2_CH1 ((XMC_USIC_CH_t *)USIC2_CH1_BASE) /**< USIC2 channel 1 base address */
#endif
#define USIC_CH_DXCR_DSEL_Msk USIC_CH_DX0CR_DSEL_Msk /**< Common mask for DSEL bitfield mask in DXnCR register */
#define USIC_CH_DXCR_DSEL_Pos USIC_CH_DX0CR_DSEL_Pos /**< Common mask for DSEL bitfield position in DXnCR register */
#define USIC_CH_DXCR_SFSEL_Pos USIC_CH_DX0CR_SFSEL_Pos /**< Common mask for SFSEL bitfield position in DXnCR register */
#define USIC_CH_DXCR_SFSEL_Msk USIC_CH_DX0CR_SFSEL_Msk /**< Common mask for SFSEL bitfield mask in DXnCR register */
#define USIC_CH_DXCR_DPOL_Msk USIC_CH_DX0CR_DPOL_Msk /**< Common mask for DPOL bitfield mask in DXnCR register */
#define USIC_CH_DXCR_DFEN_Msk USIC_CH_DX0CR_DFEN_Msk /**< Common mask for DFEN bitfield mask in DXnCR register */
#define USIC_CH_DXCR_DSEN_Msk USIC_CH_DX0CR_DSEN_Msk /**< Common mask for DSEN bitfield mask in DXnCR register */
#define USIC_CH_DXCR_CM_Pos USIC_CH_DX0CR_CM_Pos /**< Common mask for CM bitfield position in DXnCR register */
#define USIC_CH_DXCR_CM_Msk USIC_CH_DX0CR_CM_Msk /**< Common mask for CM bitfield mask in DXnCR register */
#define USIC_CH_DXCR_INSW_Msk USIC_CH_DX0CR_INSW_Msk /**< Common mask for INSW bitfield mask in DXnCR register */
#define USIC_CH_DXCR_INSW_pos USIC_CH_DX0CR_INSW_Pos /**< Common mask for INSW bitfield position in DXnCR register */
#if UC_FAMILY == XMC1
#include "xmc1_usic_map.h"
#endif
#if UC_FAMILY == XMC4
#include "xmc4_usic_map.h"
#endif
/*******************************************************************************
* ENUMS
*******************************************************************************/
/**
* USIC channel driver status
*/
typedef enum XMC_USIC_CH_STATUS
{
XMC_USIC_CH_STATUS_OK, /**< USIC driver status : OK */
XMC_USIC_CH_STATUS_ERROR, /**< USIC driver status : ERROR */
XMC_USIC_CH_STATUS_BUSY /**< USIC driver status : BUSY */
} XMC_USIC_CH_STATUS_t;
/**
* USIC channel kernel mode
*/
typedef enum XMC_USIC_CH_KERNEL_MODE
{
XMC_USIC_CH_KERNEL_MODE_RUN_0 = 0x0UL, /**< Run mode 0 (transmission and reception possible)*/
XMC_USIC_CH_KERNEL_MODE_RUN_1 = 0x1UL << USIC_CH_KSCFG_NOMCFG_Pos, /**< Run mode 1 (transmission and reception possible)*/
XMC_USIC_CH_KERNEL_MODE_STOP_0 = 0x2UL << USIC_CH_KSCFG_NOMCFG_Pos, /**< Stop mode 0 (no transmission, but reception possible)*/
XMC_USIC_CH_KERNEL_MODE_STOP_1 = 0x3UL << USIC_CH_KSCFG_NOMCFG_Pos /**< Stop mode 1 (both transmission and reception not possible)*/
} XMC_USIC_CH_KERNEL_MODE_t;
/**
* USIC channel operating mode
*/
typedef enum XMC_USIC_CH_OPERATING_MODE
{
XMC_USIC_CH_OPERATING_MODE_IDLE = 0x0UL, /**< USIC channel idle */
XMC_USIC_CH_OPERATING_MODE_SPI = 0x1UL << USIC_CH_CCR_MODE_Pos, /**< SPI mode */
XMC_USIC_CH_OPERATING_MODE_UART = 0x2UL << USIC_CH_CCR_MODE_Pos, /**< UART mode */
XMC_USIC_CH_OPERATING_MODE_I2S = 0x3UL << USIC_CH_CCR_MODE_Pos, /**< I2S mode */
XMC_USIC_CH_OPERATING_MODE_I2C = 0x4UL << USIC_CH_CCR_MODE_Pos /**< I2C mode */
} XMC_USIC_CH_OPERATING_MODE_t;
/**
* USIC channel inputs
*/
typedef enum XMC_USIC_CH_INPUT
{
XMC_USIC_CH_INPUT_DX0, /**< DX0 input */
XMC_USIC_CH_INPUT_DX1, /**< DX1 input */
XMC_USIC_CH_INPUT_DX2, /**< DX2 input */
XMC_USIC_CH_INPUT_DX3, /**< DX3 input */
XMC_USIC_CH_INPUT_DX4, /**< DX4 input */
XMC_USIC_CH_INPUT_DX5 /**< DX5 input */
} XMC_USIC_CH_INPUT_t;
/**
* USIC channel input source sampling frequency
*/
typedef enum XMC_USIC_CH_INPUT_SAMPLING_FREQ
{
XMC_USIC_CH_INPUT_SAMPLING_FREQ_FPERIPH = 0x0UL, /**< Use fperiph frequency for input source sampling*/
XMC_USIC_CH_INPUT_SAMPLING_FREQ_FRACTIONAL_DIVIDER = 0x1UL << USIC_CH_DXCR_SFSEL_Pos /**< Use fFD(fractional divider) frequency for input source sampling*/
} XMC_USIC_CH_INPUT_SAMPLING_FREQ_t;
/**
* USIC channel input combination mode
*/
typedef enum XMC_USIC_CH_INPUT_COMBINATION_MODE
{
XMC_USIC_CH_INPUT_COMBINATION_MODE_TRIGGER_DISABLED = 0x0UL, /**< The trigger activation is disabled.*/
XMC_USIC_CH_INPUT_COMBINATION_MODE_RISING_EDGE = 0x1UL, /**< A rising edge activates DXnT*/
XMC_USIC_CH_INPUT_COMBINATION_MODE_FALLING_EDGE = 0x2UL, /**< A falling edge activates DXnT*/
XMC_USIC_CH_INPUT_COMBINATION_MODE_BOTH_EDGES = 0x3UL, /**< Both edges activate DXnT*/
} XMC_USIC_CH_INPUT_COMBINATION_MODE_t;
/**
* USIC channel data transmission start modes.
* Data shifted out of the transmit pin depends on the value configured for the
* TDEN bitfield of the TCSR register. Following enum values are used for configuring
* the TCSR->TDEN bitfield.
*/
typedef enum XMC_USIC_CH_START_TRANSMISION_MODE
{
XMC_USIC_CH_START_TRANSMISION_DISABLED = 0x0U, /**< Passive data level is sent out on transmission. */
XMC_USIC_CH_START_TRANSMISION_ON_TDV = 0x1UL << USIC_CH_TCSR_TDEN_Pos, /**< Transmission of the data word in TBUF can be started if TDV = 1 */
XMC_USIC_CH_START_TRANSMISION_ON_TDV_DX2S_0 = 0x2UL << USIC_CH_TCSR_TDEN_Pos, /**< Transmission of the data word in TBUF can be started if TDV = 1 while DX2S_0 */
XMC_USIC_CH_START_TRANSMISION_ON_TDV_DX2S_1 = 0x3UL << USIC_CH_TCSR_TDEN_Pos /**< Transmission of the data word in TBUF can be started if TDV = 1 while DX2S_1 */
} XMC_USIC_CH_START_TRANSMISION_MODE_t;
/**
* USIC channel interrupt node pointers
*/
typedef enum XMC_USIC_CH_INTERRUPT_NODE_POINTER
{
XMC_USIC_CH_INTERRUPT_NODE_POINTER_TRANSMIT_SHIFT = USIC_CH_INPR_TSINP_Pos, /**< Node pointer for transmit shift interrupt */
XMC_USIC_CH_INTERRUPT_NODE_POINTER_TRANSMIT_BUFFER = USIC_CH_INPR_TBINP_Pos, /**< Node pointer for transmit buffer interrupt */
XMC_USIC_CH_INTERRUPT_NODE_POINTER_RECEIVE = USIC_CH_INPR_RINP_Pos, /**< Node pointer for receive interrupt */
XMC_USIC_CH_INTERRUPT_NODE_POINTER_ALTERNATE_RECEIVE = USIC_CH_INPR_AINP_Pos, /**< Node pointer for alternate receive interrupt */
XMC_USIC_CH_INTERRUPT_NODE_POINTER_PROTOCOL = USIC_CH_INPR_PINP_Pos /**< Node pointer for protocol related interrupts */
} XMC_USIC_CH_INTERRUPT_NODE_POINTER_t;
/**
* USIC channel events
*/
typedef enum XMC_USIC_CH_EVENT
{
XMC_USIC_CH_EVENT_RECEIVE_START = USIC_CH_CCR_RSIEN_Msk, /**< Receive start event */
XMC_USIC_CH_EVENT_DATA_LOST = USIC_CH_CCR_DLIEN_Msk, /**< Data lost event */
XMC_USIC_CH_EVENT_TRANSMIT_SHIFT = USIC_CH_CCR_TSIEN_Msk, /**< Transmit shift event */
XMC_USIC_CH_EVENT_TRANSMIT_BUFFER = USIC_CH_CCR_TBIEN_Msk, /**< Transmit buffer event */
XMC_USIC_CH_EVENT_STANDARD_RECEIVE = USIC_CH_CCR_RIEN_Msk, /**< Receive event */
XMC_USIC_CH_EVENT_ALTERNATIVE_RECEIVE = USIC_CH_CCR_AIEN_Msk, /**< Alternate receive event */
XMC_USIC_CH_EVENT_BAUD_RATE_GENERATOR = USIC_CH_CCR_BRGIEN_Msk /**< Baudrate generator event */
} XMC_USIC_CH_EVENT_t;
/**
* USIC channel parity mode
*/
typedef enum XMC_USIC_CH_PARITY_MODE
{
XMC_USIC_CH_PARITY_MODE_NONE = 0x0UL, /**< Disable parity mode */
XMC_USIC_CH_PARITY_MODE_EVEN = 0x2UL << USIC_CH_CCR_PM_Pos, /**< Enable even parity mode */
XMC_USIC_CH_PARITY_MODE_ODD = 0x3UL << USIC_CH_CCR_PM_Pos /**< Enable odd parity mode */
} XMC_USIC_CH_PARITY_MODE_t;
/**
* USIC channel data output mode
*/
typedef enum XMC_USIC_CH_DATA_OUTPUT_MODE
{
XMC_USIC_CH_DATA_OUTPUT_MODE_NORMAL = 0x0UL, /**< Data output normal mode */
XMC_USIC_CH_DATA_OUTPUT_MODE_INVERTED = 0x1UL << USIC_CH_SCTR_DOCFG_Pos /**< Data output inverted mode */
} XMC_USIC_CH_DATA_OUTPUT_MODE_t;
/**
* USIC channel data transmit buffer status
*/
typedef enum XMC_USIC_CH_TBUF_STATUS
{
XMC_USIC_CH_TBUF_STATUS_IDLE = 0x0UL, /**< Transfer buffer is currently idle*/
XMC_USIC_CH_TBUF_STATUS_BUSY = USIC_CH_TCSR_TDV_Msk /**< Transfer buffer is currently busy*/
} XMC_USIC_CH_TBUF_STATUS_t;
/**
* USIC channel data transmit buffer status modification
*/
typedef enum XMC_USIC_CH_TBUF_STATUS_SET
{
XMC_USIC_CH_TBUF_STATUS_SET_BUSY = 0x1UL, /**< Set Transfer buffer status to busy*/
XMC_USIC_CH_TBUF_STATUS_SET_IDLE = 0x2UL /**< Set Transfer buffer status to idle*/
} XMC_USIC_CH_TBUF_STATUS_SET_t;
/**
* USIC channel receive buffer status
*/
typedef enum XMC_USIC_CH_RBUF_STATUS
{
XMC_USIC_CH_RBUF_STATUS_DATA_VALID0 = USIC_CH_RBUFSR_RDV0_Msk, /**< RBUF0 data has not yet been read out*/
XMC_USIC_CH_RBUF_STATUS_DATA_VALID1 = USIC_CH_RBUFSR_RDV1_Msk /**< RBUF1 data has not yet been read out*/
} XMC_USIC_CH_RBUF_STATUS_t;
/**
* USIC channel output signal passive data level
*/
typedef enum XMC_USCI_CH_PASSIVE_DATA_LEVEL
{
XMC_USIC_CH_PASSIVE_DATA_LEVEL0 = 0x0UL, /**< Passive level(idle mode signal level) 0 */
XMC_USIC_CH_PASSIVE_DATA_LEVEL1 = 0x1UL << USIC_CH_SCTR_PDL_Pos /**< Passive level(idle mode signal level) 1 */
} XMC_USIC_CH_PASSIVE_DATA_LEVEL_t;
/**
* USIC channel receive FIFO size
*/
typedef enum XMC_USIC_CH_FIFO_SIZE
{
XMC_USIC_CH_FIFO_DISABLED = 0x0U, /**< FIFO Disabled */
XMC_USIC_CH_FIFO_SIZE_2WORDS = 0x1U, /**< FIFO size: 2 words */
XMC_USIC_CH_FIFO_SIZE_4WORDS = 0x2U, /**< FIFO size: 4 words */
XMC_USIC_CH_FIFO_SIZE_8WORDS = 0x3U, /**< FIFO size: 8 words */
XMC_USIC_CH_FIFO_SIZE_16WORDS = 0x4U, /**< FIFO size: 16 words */
XMC_USIC_CH_FIFO_SIZE_32WORDS = 0x5U, /**< FIFO size: 32 words */
XMC_USIC_CH_FIFO_SIZE_64WORDS = 0x6U /**< FIFO size: 64 words */
} XMC_USIC_CH_FIFO_SIZE_t;
/**
* USIC channel transmit FIFO interrupt node pointers
*/
typedef enum XMC_USIC_CH_TXFIFO_INTERRUPT_NODE_POINTER
{
XMC_USIC_CH_TXFIFO_INTERRUPT_NODE_POINTER_STANDARD = USIC_CH_TBCTR_STBINP_Pos, /**< Node pointer for FIFO standard transmit interrupt */
XMC_USIC_CH_TXFIFO_INTERRUPT_NODE_POINTER_ALTERNATE = USIC_CH_TBCTR_ATBINP_Pos /**< Node pointer for transmit FIFO error interrupt */
} XMC_USIC_CH_TXFIFO_INTERRUPT_NODE_POINTER_t;
/**
* USIC channel transmit FIFO event configuration
*/
typedef enum XMC_USIC_CH_TXFIFO_EVENT_CONF
{
XMC_USIC_CH_TXFIFO_EVENT_CONF_STANDARD = USIC_CH_TBCTR_STBIEN_Msk, /**< Enable FIFO standard transmit interrupt */
XMC_USIC_CH_TXFIFO_EVENT_CONF_ERROR = (int32_t)USIC_CH_TBCTR_TBERIEN_Msk /**< Enable transmit FIFO error interrupt */
} XMC_USIC_CH_TXFIFO_EVENT_CONF_t;
/**
* USIC channel transmit FIFO status
*/
typedef enum XMC_USIC_CH_TXFIFO_EVENT
{
XMC_USIC_CH_TXFIFO_EVENT_STANDARD = USIC_CH_TRBSR_STBI_Msk, /**< Transmit FIFO status: Standard event */
XMC_USIC_CH_TXFIFO_EVENT_ERROR = USIC_CH_TRBSR_TBERI_Msk /**< Transmit FIFO status: Error event */
} XMC_USIC_CH_TXFIFO_EVENT_t;
/**
* USIC channel receive FIFO interrupt node pointers
*/
typedef enum XMC_USIC_CH_RXFIFO_INTERRUPT_NODE_POINTER
{
XMC_USIC_CH_RXFIFO_INTERRUPT_NODE_POINTER_STANDARD = USIC_CH_RBCTR_SRBINP_Pos, /**< Node pointer for FIFO standard receive interrupt */
XMC_USIC_CH_RXFIFO_INTERRUPT_NODE_POINTER_ALTERNATE = USIC_CH_RBCTR_ARBINP_Pos /**< Node pointer for FIFO alternative receive interrupt */
} XMC_USIC_CH_RXFIFO_INTERRUPT_NODE_POINTER_t;
/**
* USIC channel receive FIFO event configuration
*/
typedef enum XMC_USIC_CH_RXFIFO_EVENT_CONF
{
XMC_USIC_CH_RXFIFO_EVENT_CONF_STANDARD = USIC_CH_RBCTR_SRBIEN_Msk, /**< Enable FIFO standard receive interrupt */
XMC_USIC_CH_RXFIFO_EVENT_CONF_ERROR = (int32_t)USIC_CH_RBCTR_RBERIEN_Msk, /**< Enable receive FIFO error interrupt */
XMC_USIC_CH_RXFIFO_EVENT_CONF_ALTERNATE = USIC_CH_RBCTR_ARBIEN_Msk /**< Enable FIFO alternative receive interrupt */
} XMC_USIC_CH_RXFIFO_EVENT_CONF_t;
/**
* USIC channel receive FIFO status
*/
typedef enum XMC_USIC_CH_RXFIFO_EVENT
{
XMC_USIC_CH_RXFIFO_EVENT_STANDARD = USIC_CH_TRBSR_SRBI_Msk, /**< Receive FIFO status: Standard event */
XMC_USIC_CH_RXFIFO_EVENT_ERROR = USIC_CH_TRBSR_RBERI_Msk, /**< Receive FIFO status: Error event */
XMC_USIC_CH_RXFIFO_EVENT_ALTERNATE = USIC_CH_TRBSR_ARBI_Msk /**< Receive FIFO status: Alternative event */
} XMC_USIC_CH_RXFIFO_EVENT_t;
/**
* USIC channel baudrate generator clock source
*/
typedef enum XMC_USIC_CH_BRG_CLOCK_SOURCE
{
XMC_USIC_CH_BRG_CLOCK_SOURCE_DIVIDER = 0x0UL, /**< Baudrate generator clock source : Source divider. (Internal clock source)*/
XMC_USIC_CH_BRG_CLOCK_SOURCE_DX1T = 0x2UL << USIC_CH_BRG_CLKSEL_Pos /**< Baudrate generator clock source : DX1T. (External clock source) */
} XMC_USIC_CH_BRG_CLOCK_SOURCE_t;
/**
* USIC channel baudrate generator divider mode
*/
typedef enum XMC_USIC_CH_BRG_CLOCK_DIVIDER_MODE
{
XMC_USIC_CH_BRG_CLOCK_DIVIDER_MODE_DISABLED = 0x0UL, /**< Baudrate generator clock divider: Disabled */
XMC_USIC_CH_BRG_CLOCK_DIVIDER_MODE_NORMAL = 0x1UL << USIC_CH_FDR_DM_Pos, /**< Baudrate generator clock divider: Normal mode */
XMC_USIC_CH_BRG_CLOCK_DIVIDER_MODE_FRACTIONAL = 0x2UL << USIC_CH_FDR_DM_Pos /**< Baudrate generator clock divider: Fractional mode */
} XMC_USIC_CH_BRG_CLOCK_DIVIDER_MODE_t;
/**
* USIC channel baudrate generator master clock passive level
*/
typedef enum XMC_USIC_CH_BRG_MASTER_CLOCK_PASSIVE_LEVEL
{
XMC_USIC_CH_BRG_MASTER_CLOCK_PASSIVE_LEVEL_0 = 0x0UL, /**< Baudrate generator master clock passive level(idle mode signal level) 0*/
XMC_USIC_CH_BRG_MASTER_CLOCK_PASSIVE_LEVEL_1 = 0x1UL << USIC_CH_BRG_MCLKCFG_Pos /**< Baudrate generator master clock passive level((idle mode signal level)) 1*/
} XMC_USIC_CH_BRG_MASTER_CLOCK_PASSIVE_LEVEL_t;
/**
* USIC channel baudrate generator shift clock passive level
*/
typedef enum XMC_USIC_CH_BRG_SHIFT_CLOCK_PASSIVE_LEVEL
{
XMC_USIC_CH_BRG_SHIFT_CLOCK_PASSIVE_LEVEL_0_DELAY_DISABLED = 0x0UL, /**< Shift clock passive level 0, delay disabled */
XMC_USIC_CH_BRG_SHIFT_CLOCK_PASSIVE_LEVEL_1_DELAY_DISABLED = 0x1UL << USIC_CH_BRG_SCLKCFG_Pos, /**< Shift clock passive level 1, delay disabled */
XMC_USIC_CH_BRG_SHIFT_CLOCK_PASSIVE_LEVEL_0_DELAY_ENABLED = (int32_t)(0x2UL << USIC_CH_BRG_SCLKCFG_Pos), /**< Shift clock passive level 0, delay enabled */
XMC_USIC_CH_BRG_SHIFT_CLOCK_PASSIVE_LEVEL_1_DELAY_ENABLED = (int32_t)(0x3UL << USIC_CH_BRG_SCLKCFG_Pos) /**< Shift clock passive level 1, delay enabled */
} XMC_USIC_CH_BRG_SHIFT_CLOCK_PASSIVE_LEVEL_t;
/**
* USIC channel baudrate generator shift clock output
*/
typedef enum XMC_USIC_CH_BRG_SHIFT_CLOCK_OUTPUT
{
XMC_USIC_CH_BRG_SHIFT_CLOCK_OUTPUT_SCLK = 0x0UL, /**< Baudrate generator shift clock output: SCL.(Internally generated shift clock)*/
XMC_USIC_CH_BRG_SHIFT_CLOCK_OUTPUT_DX1 = 0x1UL << USIC_CH_BRG_SCLKOSEL_Pos /**< Baudrate generator shift clock output: DX1. (External input shift clock)*/
} XMC_USIC_CH_BRG_SHIFT_CLOCK_OUTPUT_t;
/**
* USIC channel shift direction.
* Defines the shift direction of the data words for transmission and reception
*/
typedef enum XMC_USIC_CH_SHIFT_DIRECTION
{
XMC_USIC_CH_SHIFT_DIRECTION_LSB_FIRST = 0x0UL, /**< Shift LSB first. The first data bit of a data word is located at bit position 0. */
XMC_USIC_CH_SHIFT_DIRECTION_MSB_FIRST = 0x1UL << USIC_CH_SCTR_SDIR_Pos /**< Shift MSB first. The first data bit of a data word is located at the bit position given by the configured word length. */
} XMC_USIC_CH_SHIFT_DIRECTION_t;
/*******************************************************************************
* DATA STRUCTURES
*******************************************************************************/
/*Anonymous structure/union guard start*/
#if defined(__CC_ARM)
#pragma push
#pragma anon_unions
#elif defined(__TASKING__)
#pragma warning 586
#endif
/**
* USIC module structure
*/
typedef USIC_GLOBAL_TypeDef XMC_USIC_t;
/**
* USIC channel structure.
The members of the structure are same as in the device header file,
* except for some registers.
* DX0CR, DX1CR, DX2CR, DX3CR, DX4CR and DX5CR are replaced with the array DXCR[6].
* TBUF0 to TBUF31 are replaced with TBUF[32].
* IN0 to IN31 are replaced with IN[32].
*/
typedef struct XMC_USIC_CH
{
__I uint32_t RESERVED0;
__I uint32_t CCFG; /**< Channel configuration register*/
__I uint32_t RESERVED1;
__IO uint32_t KSCFG; /**< Kernel state configuration register*/
__IO uint32_t FDR; /**< Fractional divider configuration register*/
__IO uint32_t BRG; /**< Baud rate generator register*/
__IO uint32_t INPR; /**< Interrupt node pointer register*/
__IO uint32_t DXCR[6]; /**< Input control registers DX0 to DX5.*/
__IO uint32_t SCTR; /**< Shift control register*/
__IO uint32_t TCSR;
union {
__IO uint32_t PCR_IICMode; /**< I2C protocol configuration register*/
__IO uint32_t PCR_IISMode; /**< I2S protocol configuration register*/
__IO uint32_t PCR_SSCMode; /**< SPI protocol configuration register*/
__IO uint32_t PCR; /**< Protocol configuration register*/
__IO uint32_t PCR_ASCMode; /**< UART protocol configuration register*/
};
__IO uint32_t CCR; /**< Channel control register*/
__IO uint32_t CMTR; /**< Capture mode timer register*/
union {
__IO uint32_t PSR_IICMode; /**< I2C protocol status register*/
__IO uint32_t PSR_IISMode; /**< I2S protocol status register*/
__IO uint32_t PSR_SSCMode; /**< SPI protocol status register*/
__IO uint32_t PSR; /**< Protocol status register*/
__IO uint32_t PSR_ASCMode; /**< UART protocol status register*/
};
__O uint32_t PSCR; /**< Protocol status clear register*/
__I uint32_t RBUFSR; /**< Receive buffer status register*/
__I uint32_t RBUF; /**< Receive buffer register*/
__I uint32_t RBUFD; /**< Debug mode receive buffer register*/
__I uint32_t RBUF0; /**< Receive buffer 0*/
__I uint32_t RBUF1; /**< Receive buffer 1*/
__I uint32_t RBUF01SR; /**< Receive buffer status register*/
__O uint32_t FMR; /**< Flag modification register*/
__I uint32_t RESERVED2[5];
__IO uint32_t TBUF[32]; /**< Tranmsit buffer registers*/
__IO uint32_t BYP; /**< FIFO bypass register*/
__IO uint32_t BYPCR; /**< FIFO bypass control register*/
__IO uint32_t TBCTR; /**< Transmit FIFO control register*/
__IO uint32_t RBCTR; /**< Receive FIFO control register*/
__I uint32_t TRBPTR; /**< Transmit/recive buffer pointer register*/
__IO uint32_t TRBSR; /**< Transmit/receive buffer status register*/
__O uint32_t TRBSCR; /**< Transmit/receive buffer status clear register*/
__I uint32_t OUTR; /**< Receive FIFO output register*/
__I uint32_t OUTDR; /**< Receive FIFO debug output register*/
__I uint32_t RESERVED3[23];
__O uint32_t IN[32]; /**< Transmit FIFO input register*/
} XMC_USIC_CH_t;
/*Anonymous structure/union guard end*/
#if defined(__CC_ARM)
#pragma pop
#elif defined(__TASKING__)
#pragma warning restore
#endif
/*******************************************************************************
* API PROTOTYPES
******************************************************************************/
#ifdef __cplusplus
extern "C" {
#endif
__STATIC_INLINE bool XMC_USIC_IsModuleValid(const XMC_USIC_t *const module)
{
bool tmp;
tmp = (module == XMC_USIC0);
#if defined(XMC_USIC1)
tmp = tmp || (module == XMC_USIC1);
#endif
#if defined(XMC_USIC2)
tmp = tmp || (module == XMC_USIC2);
#endif
return tmp;
}
__STATIC_INLINE bool XMC_USIC_IsChannelValid(const XMC_USIC_CH_t *const channel)
{
bool tmp;
tmp = ((channel == XMC_USIC0_CH0) || (channel == XMC_USIC0_CH1));
#if defined(XMC_USIC1)
tmp = tmp || ((channel == XMC_USIC1_CH0) || (channel == XMC_USIC1_CH1));
#endif
#if defined(XMC_USIC2)
tmp = tmp || ((channel == XMC_USIC2_CH0) || (channel == XMC_USIC2_CH1));
#endif
return tmp;
}
/* Common APIs */
/**
* @param usic Pointer to USIC module handler of type @ref XMC_USIC_t.\n
* \b Range: @ref XMC_USIC0 to @ref XMC_USIC2 based on device support.
* @return None
*
* \parDescription
* Enables the USIC module.\n\n
* Enables the clock for the USIC module by following the
* clock enabling sequence for the selected device.
*
* \parRelated APIs:
* XMC_USIC_CH_Enable(), XMC_USIC_Disable() \n\n\n
*/
void XMC_USIC_Enable(XMC_USIC_t *const usic);
/**
* @param usic Pointer to USIC module handler of type @ref XMC_USIC_t.\n
* \b Range: @ref XMC_USIC0 to @ref XMC_USIC2 based on device support.
* @return None
*
* \parDescription
* Disables the USIC module.\n\n
* Disables the clock for the USIC module by following the clock
* disabling sequence for the selected device.
*
* \parRelated APIs:
* XMC_USIC_CH_Disable(), XMC_USIC_Enable() \n\n\n
*/
void XMC_USIC_Disable(XMC_USIC_t *const usic);
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return None
*
* \parDescription
* Enables the USIC channel. \n\n
* USIC channel is enabled by setting the module enable bit in KSCFG register bitfield MODEN.
* On enabling, the channel is set to idle mode.
*
* \parRelated APIs:
* XMC_USIC_CH_Disable(), XMC_USIC_Enable() \n\n\n
*/
void XMC_USIC_CH_Enable(XMC_USIC_CH_t *const channel);
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return None
*
* \parDescription
* Disables the USIC channel.\n\n
* USIC channel is disabled by setting the module enable bit(MDEN) to 0 in the register KSCFG.
*
* \parRelated APIs:
* XMC_USIC_CH_Enable(), XMC_USIC_Disable() \n\n\n
*/
void XMC_USIC_CH_Disable(XMC_USIC_CH_t *const channel);
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param rate Desired baudrate. \b Range: minimum value = 100, maximum value depends on the peripheral clock frequency \n
* and \a oversampling. Maximum baudrate can be derived using the formula: (fperiph * 1023)/(1024 * oversampling)
* @param oversampling Required oversampling. The value indicates the number of time quanta for one symbol of data. \n
* This can be related to the number of samples for each logic state of the data signal. \n
* \b Range: 1 to 32. Value should be chosen based on the protocol used.
* @return Status indicating the baudrate configuration.\n
* \b Range: @ref XMC_USIC_CH_STATUS_OK if baudrate is successfully configured,
* @ref XMC_USIC_CH_STATUS_ERROR if desired baudrate or oversampling is invalid.
*
* \parDescription
* Configures the baudrate of the USIC channel. \n\n
* Baudrate is configured by considering the peripheral frequency and the desired baudrate.
* Optimum values of FDR->STEP and BRG->PDIV are calulated and used for generating the desired
* baudrate.
*
* \parRelated APIs:
* XMC_USIC_CH_SetStartTransmisionMode(), XMC_USIC_CH_SetInputSource() \n\n\n
*/
XMC_USIC_CH_STATUS_t XMC_USIC_CH_SetBaudrate(XMC_USIC_CH_t *const channel, uint32_t rate, uint32_t oversampling);
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param rate Desired baudrate. Only integer dividers of peripheral clock are achievable
* @param oversampling Required oversampling. The value indicates the number of time quanta for one symbol of data. \n
* This can be related to the number of samples for each logic state of the data signal. \n
* \b Range: 1 to 32. Value should be chosen based on the protocol used.
* @return Status indicating the baudrate configuration.\n
* \b Range: @ref XMC_USIC_CH_STATUS_OK if baudrate is successfully configured,
* @ref XMC_USIC_CH_STATUS_ERROR if desired baudrate or oversampling is invalid.
*
* \parDescription
* Configures the baudrate of the USIC channel using the integer divider which restrics the achievable baudrate but decreses jitter. \n\n
* Baudrate is configured by considering the peripheral frequency and the desired baudrate.
* Optimum values of FDR->STEP and BRG->PDIV are calulated and used for generating the desired
* baudrate.
*
* \parRelated APIs:
* XMC_USIC_CH_SetStartTransmisionMode(), XMC_USIC_CH_SetInputSource() \n\n\n
*/
XMC_USIC_CH_STATUS_t XMC_USIC_CH_SetBaudrateEx(XMC_USIC_CH_t *const channel, int32_t rate, int32_t oversampling);
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return baudrate currently used by USIC channel for .\n
*
* \parDescription
* Calculates the current used baudrate (fCTQIN) of a USIC channel. \n\n
* @image html ../images/usic_brg.png
* @image latex ../images/usic_brg.png
*
* \parRelated APIs:
* XMC_USIC_CH_SetBaudrateMode(), XMC_USIC_CH_SetBaudrate(), XMC_USIC_CH_SetBaudrateEx() \n\n\n
*/
uint32_t XMC_USIC_CH_GetBaudrate(XMC_USIC_CH_t *const channel);
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return baudrate currently used by USIC channel.\n
*
* \parDescription
* Calculates the current used SCLK frequency of a USIC channel. \n\n
* @image html ../images/usic_brg.png
* @image latex ../images/usic_brg.png
*
* \parRelated APIs:
* XMC_USIC_CH_SetBaudrateMode(), XMC_USIC_CH_SetBaudrate(), XMC_USIC_CH_SetBaudrateEx() \n\n\n
*/
uint32_t XMC_USIC_CH_GetSCLKFrequency(XMC_USIC_CH_t *const channel);
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return baudrate currently used by USIC channel.\n
*
* \parDescription
* Calculates the current used MCLK frequency of a USIC channel. \n\n
* @image html ../images/usic_brg.png
* @image latex ../images/usic_brg.png
*
* \parRelated APIs:
* XMC_USIC_CH_SetBaudrateMode(), XMC_USIC_CH_SetBaudrate(), XMC_USIC_CH_SetBaudrateEx() \n\n\n
*/
uint32_t XMC_USIC_CH_GetMCLKFrequency(XMC_USIC_CH_t *const channel);
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param pdiv Desired divider for the external frequency input. \b Range: minimum value = 1, maximum value = 1024 \n
* @param oversampling Required oversampling. The value indicates the number of time quanta for one symbol of data. \n
* This can be related to the number of samples for each logic state of the data signal. \n
* \b Range: 1 to 32. Value should be chosen based on the protocol used.
* @param combination_mode Selects which edge of the synchronized(and optionally filtered) signal DXnS actives the trigger
* output DXnT of the input stage.
*
* @return None
*
* \parDescription
* Enables the external frequency input for the Baudrate Generator and configures the divider, oversampling and
* the combination mode of the USIC channel. \n\n
*
* \parRelated APIs:
* XMC_USIC_CH_SetBRGInputClockSource(), XMC_USIC_CH_SetInputTriggerCombinationMode() \n\n\n
*/
void XMC_USIC_CH_ConfigExternalInputSignalToBRG(XMC_USIC_CH_t *const channel,
const uint16_t pdiv,
const uint32_t oversampling,
const XMC_USIC_CH_INPUT_COMBINATION_MODE_t combination_mode);
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param input USIC channel input stage of type @ref XMC_USIC_CH_INPUT_t. \n
* \b Range: @ref XMC_USIC_CH_INPUT_DX0 to @ref XMC_USIC_CH_INPUT_DX5
* @param source Input source select for the input stage. The table below maps the enum value with the input channel.
*
0 | DXnA |
1 | DXnB |
2 | DXnC |
3 | DXnD |
* 4 | DXnE |
5 | DXnF |
6 | DXnG |
7 | Always 1 |
*
* @return None
*
* \parDescription
* Selects the data source for USIC input stage.\n\n
* Selects the input data signal source among DXnA, DXnB.. DXnG for the input stage. The API can be used for all the input stages
* like DX0CR, DX1CR etc.
*
* \parRelated APIs:
* XMC_USIC_CH_EnableInputInversion(), XMC_USIC_CH_EnableInputDigitalFilter(), XMC_USIC_CH_EnableInputSync(),
* XMC_USIC_CH_SetInputSamplingFreq()\n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_SetInputSource(XMC_USIC_CH_t *const channel, const XMC_USIC_CH_INPUT_t input, const uint8_t source)
{
channel->DXCR[input] = (uint32_t)((channel->DXCR[input] & (uint32_t)(~USIC_CH_DXCR_DSEL_Msk)) |
((uint32_t)source << USIC_CH_DXCR_DSEL_Pos));
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param input USIC channel input stage of type @ref XMC_USIC_CH_INPUT_t. \n
* \b Range: @ref XMC_USIC_CH_INPUT_DX0 to @ref XMC_USIC_CH_INPUT_DX5
* @return None
*
* \parDescription
* The input of the data shift unit is controlled by the
* protocol pre-processor. \n\n
*
* \parRelated APIs:
* XMC_USIC_CH_ConnectInputDataShiftToDataInput()\n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_ConnectInputDataShiftToPPP(XMC_USIC_CH_t *const channel, const XMC_USIC_CH_INPUT_t input)
{
channel->DXCR[input] &=(uint32_t)~USIC_CH_DXCR_INSW_Msk;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param input USIC channel input stage of type @ref XMC_USIC_CH_INPUT_t. \n
* \b Range: @ref XMC_USIC_CH_INPUT_DX0 to @ref XMC_USIC_CH_INPUT_DX5
* @return None
*
* \parDescription
* The input of the data shift unit is connected to
* the selected data input line. \n\n
*
* This setting is used
* if the signals are directly derived from an input
* pin without treatment by the protocol preprocessor.
* \parRelated APIs:
* XMC_USIC_CH_ConnectInputDataShiftToPPP()\n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_ConnectInputDataShiftToDataInput(XMC_USIC_CH_t *const channel, const XMC_USIC_CH_INPUT_t input)
{
channel->DXCR[input] |= USIC_CH_DXCR_INSW_Msk;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param input USIC channel input stage of type @ref XMC_USIC_CH_INPUT_t. \n
* \b Range: @ref XMC_USIC_CH_INPUT_DX0 to @ref XMC_USIC_CH_INPUT_DX5
* @return None
*
* \parDescription
* Enables input inversion for USIC channel input data signal. \n\n
*
* Polarity of the input source can be changed to provide inverted data input.
* \parRelated APIs:
* XMC_USIC_CH_DisableInputInversion()\n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_EnableInputInversion(XMC_USIC_CH_t *const channel, const XMC_USIC_CH_INPUT_t input)
{
channel->DXCR[input] |= USIC_CH_DXCR_DPOL_Msk;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param input USIC channel input stage of type @ref XMC_USIC_CH_INPUT_t. \n
* \b Range: @ref XMC_USIC_CH_INPUT_DX0 to @ref XMC_USIC_CH_INPUT_DX5
* @return None
*
* \parDescription
* Disables input inversion for USIC channel. \n\n
*
* Resets the input data polarity for the USIC channel input data signal.
* \parRelated APIs:
* XMC_USIC_CH_EnableInputInversion()\n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_DisableInputInversion(XMC_USIC_CH_t *const channel, const XMC_USIC_CH_INPUT_t input)
{
channel->DXCR[input] &=(uint32_t)~USIC_CH_DXCR_DPOL_Msk;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return None
*
* \parDescription
* Enables delay compensation. \n\n
*
* Delay compensation can be applied to the receive path.
* \parRelated APIs:
* XMC_USIC_CH_DisableDelayCompensation()\n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_EnableDelayCompensation(XMC_USIC_CH_t *const channel)
{
channel->DXCR[1U] |= USIC_CH_DX1CR_DCEN_Msk;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return None
*
* \parDescription
* Disables delay compensation.. \n\n
*
* \parRelated APIs:
* XMC_USIC_CH_EnableDelayCompensation()\n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_DisableDelayCompensation(XMC_USIC_CH_t *const channel)
{
channel->DXCR[1U] &=(uint32_t)~USIC_CH_DX1CR_DCEN_Msk;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param input USIC channel input stage of type @ref XMC_USIC_CH_INPUT_t. \n
* \b Range: @ref XMC_USIC_CH_INPUT_DX0 to @ref XMC_USIC_CH_INPUT_DX5
* @return None
*
* \parDescription
* Enables the input digital filter for USIC channel input data signal. \n\n
* Input data signal from the selected multiplexer will be digitally filtered.
*
* \parRelated APIs:
* XMC_USIC_CH_DisableInputDigitalFilter()\n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_EnableInputDigitalFilter(XMC_USIC_CH_t *const channel, const XMC_USIC_CH_INPUT_t input)
{
channel->DXCR[input] |= (uint32_t)USIC_CH_DXCR_DFEN_Msk;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param input USIC channel input stage of type @ref XMC_USIC_CH_INPUT_t. \n
* \b Range: @ref XMC_USIC_CH_INPUT_DX0 to @ref XMC_USIC_CH_INPUT_DX5
* @return None
*
* \parDescription
* Disables the input digital filter for USIC channel input data signal. \n\n
* Input data signal from the selected multiplexer will not be digitally filtered.
*
* \parRelated APIs:
* XMC_USIC_CH_EnableInputDigitalFilter()\n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_DisableInputDigitalFilter(XMC_USIC_CH_t *const channel, const XMC_USIC_CH_INPUT_t input)
{
channel->DXCR[input] &=(uint32_t)~USIC_CH_DXCR_DFEN_Msk;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param input USIC channel input stage of type @ref XMC_USIC_CH_INPUT_t. \n
* \b Range: @ref XMC_USIC_CH_INPUT_DX0 to @ref XMC_USIC_CH_INPUT_DX5
* @return None
*
* \parDescription
* Enables input synchronization for the USIC channel input data signal. \n\n
* Input data signal from the selected multiplexer will be synchronized with fPERIPH.
* A noisy signal can be synchronized and filtered by enabling the digital filter.
*
* \parRelated APIs:
* XMC_USIC_CH_DisableInputSync(), XMC_USIC_CH_EnableInputDigitalFilter()\n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_EnableInputSync(XMC_USIC_CH_t *const channel, const XMC_USIC_CH_INPUT_t input)
{
channel->DXCR[input] |=(uint32_t)USIC_CH_DXCR_DSEN_Msk;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param input USIC channel input stage of type @ref XMC_USIC_CH_INPUT_t. \n
* \b Range: @ref XMC_USIC_CH_INPUT_DX0 to @ref XMC_USIC_CH_INPUT_DX5
* @return None
*
* \parDescription
* Disables input synchronization for the USIC channel input data signal. \n\n
* Input data signal from the selected multiplexer will not be synchronized.
*
* \parRelated APIs:
* XMC_USIC_CH_EnableInputSync(), XMC_USIC_CH_DisableInputDigitalFilter() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_DisableInputSync(XMC_USIC_CH_t *const channel, const XMC_USIC_CH_INPUT_t input)
{
channel->DXCR[input] &=(uint32_t)~USIC_CH_DXCR_DSEN_Msk;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support..
* @param input USIC channel input stage of type @ref XMC_USIC_CH_INPUT_t. \n
* \b Range: @ref XMC_USIC_CH_INPUT_DX0 to @ref XMC_USIC_CH_INPUT_DX5
* @param sampling_freq Sampling frequency value of type \a XMC_USIC_CH_INPUT_SAMPLING_FREQ_t.
* @return None
*
* \parDescription
* Sets sampling frequency for USIC channel input data signal. \n\n
*
* \parRelated APIs:
* XMC_USIC_CH_SetInputSource(), XMC_USIC_CH_EnableInputSync(), XMC_USIC_CH_EnableInputDigitalFilter() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_SetInputSamplingFreq(XMC_USIC_CH_t *const channel,
const XMC_USIC_CH_INPUT_t input,
const XMC_USIC_CH_INPUT_SAMPLING_FREQ_t sampling_freq)
{
channel->DXCR[input] = (uint32_t)(channel->DXCR[input] & (~USIC_CH_DXCR_SFSEL_Msk)) |
((uint32_t)sampling_freq);
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support..
* @param input USIC channel input stage of type @ref XMC_USIC_CH_INPUT_t. \n
* \b Range: @ref XMC_USIC_CH_INPUT_DX0 to @ref XMC_USIC_CH_INPUT_DX5
* @param combination_mode Combination mode value of type \a XMC_USIC_CH_INPUT_COMBINATION_MODE_t.
* @return None
*
* \parDescription
* Selects which edge of the synchronized signal DXnS activates the trigger output DXnT of the input stage. \n\n
*
* \parRelated APIs:
* XMC_USIC_CH_SetInputSource(), XMC_USIC_CH_EnableInputSync(), XMC_USIC_CH_EnableInputDigitalFilter() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_SetInputTriggerCombinationMode(XMC_USIC_CH_t *const channel,
const XMC_USIC_CH_INPUT_t input,
const XMC_USIC_CH_INPUT_COMBINATION_MODE_t combination_mode)
{
channel->DXCR[input] = (uint32_t)(channel->DXCR[input] & (~USIC_CH_DXCR_CM_Msk)) |
((uint32_t)combination_mode << USIC_CH_DXCR_CM_Pos);
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param clock_source clock source for the BRG.
* @return None
*
* \parDescription
* Sets the clock source for the BRG. \n\n
*
* \parRelated APIs:
* XMC_USIC_CH_SetInputTriggerCombinationMode(), XMC_USIC_CH_SetExternalClockBRGDivider()\n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_SetBRGInputClockSource(XMC_USIC_CH_t *const channel, const XMC_USIC_CH_BRG_CLOCK_SOURCE_t clock_source)
{
channel->BRG = (uint32_t)(channel->BRG & (~USIC_CH_BRG_CLKSEL_Msk)) | (uint32_t)(clock_source);
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param data Data to be transmitted. \n
* \b Range: 16bit unsigned data. minimum= 0, maximum= 65535
* @return None
*
* \parDescription
* Writes data into the transmit buffer. \n\n
* The data provided is placed in TBUF[0U].
*
*
* \parRelated APIs:
* XMC_USIC_CH_WriteToTBUFTCI() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_WriteToTBUF(XMC_USIC_CH_t *const channel, const uint16_t data)
{
channel->TBUF[0U] = data;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param data Data to be transmitted.
* @param transmit_control_information transmit control information to be configured while transmitting the data. \n
* \b Range: minimum= 0, maximum= 31.
* @return None
*
* \parDescription
* Writes data to the transmit buffer in a control mode. \n\n
* When the respective control mode is enabled , this API can be used.
*
*
* \parRelated APIs:
* XMC_USIC_CH_WriteToTBUF() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_WriteToTBUFTCI(XMC_USIC_CH_t *const channel,
const uint16_t data,
const uint32_t transmit_control_information)
{
channel->TBUF[transmit_control_information] = data;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param word_length Number of bits to be configured for a data word. \n
* \b Range: minimum= 1, maximum= 16. \n
* e.g: For word length of 8, \a word_length should be provided as 8.
* @return None
*
* \parDescription
* Sets the data word length in number of bits. \n\n
* Sets the number of bits to represent a data word. Frame length should be a multiple of word length.
*
* \parRelated APIs:
* XMC_USIC_CH_SetFrameLength()\n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_SetWordLength(XMC_USIC_CH_t *const channel, const uint8_t word_length)
{
channel->SCTR = (uint32_t)(channel->SCTR & (~USIC_CH_SCTR_WLE_Msk)) |
(uint32_t)(((uint32_t)word_length - 1UL) << USIC_CH_SCTR_WLE_Pos);
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param word_length Number of bits to be configured for a data word. \n
* \b Range: minimum= 1, maximum= 16. \n
* e.g: For word length of 8, \a word_length should be provided as 8.
* @return None
*
* \parDescription
* Sets the data word length in number of bits. \n\n
* Sets the number of bits to represent a data word. Frame length should be a multiple of word length.
*
* \parRelated APIs:
* XMC_USIC_CH_SetFrameLength()\n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_SetShiftDirection(XMC_USIC_CH_t *const channel, const XMC_USIC_CH_SHIFT_DIRECTION_t shift_direction)
{
channel->SCTR = (uint32_t)(channel->SCTR & (~USIC_CH_SCTR_SDIR_Msk)) | (uint32_t)shift_direction;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return Captured counter value
*
*
* \parDescription
* The value of the counter is captured if one of the trigger signals DX0T or DX1T are activated by the corresponding input stage.
*/
__STATIC_INLINE uint32_t XMC_USIC_CH_GetCaptureTimerValue(const XMC_USIC_CH_t *const channel)
{
return channel->CMTR;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param mode divider mode ::XMC_USIC_CH_BRG_CLOCK_DIVIDER_MODE_t \n
* @param step divider \n
* \b XMC_USIC_CH_BRG_CLOCK_DIVIDER_MODE_NORMAL resulting divider = 1023 - step \n
* \b XMC_USIC_CH_BRG_CLOCK_DIVIDER_MODE_FRACTIONAL resulting divider = 1023 / step \n
*
* @return None
*
* \parDescription
* The fractional divider generates its output frequency fFD by either dividing the input frequency fPERIPH by an integer factor n or by multiplication of n/1024.
*
*/
__STATIC_INLINE void XMC_USIC_CH_SetFractionalDivider(XMC_USIC_CH_t *const channel, const XMC_USIC_CH_BRG_CLOCK_DIVIDER_MODE_t mode, const uint16_t step)
{
channel->FDR = mode | step;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param frame_length Number of bits in a frame. \n
* \b Range: minimum= 1, maximum= 0x3f. The maximum value for fixed frame size is 0x3f. \n
* e.g: For a frame length of 16, \a frame_length should be provided as 16.
* @return None
*
* \parDescription
* Define the data frame length.\n\n
* Set the number of bits to be serially transmitted in a frame.
* The frame length should be multiples of word length. If the value is set to 0x40, the frame length
* has to be controlled explicitly.
*
* \parRelated APIs:
* XMC_USIC_CH_SetWordLength(), XMC_USIC_CH_EnableFrameLengthControl() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_SetFrameLength(XMC_USIC_CH_t *const channel, const uint8_t frame_length)
{
channel->SCTR = (uint32_t)(channel->SCTR & (~USIC_CH_SCTR_FLE_Msk)) |
(((uint32_t)frame_length - 0x1U) << USIC_CH_SCTR_FLE_Pos);
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param event Bit mask of the channel events to be enabled. Use @ref XMC_USIC_CH_EVENT_t for the bit masks. \n
* \b Range: @ref XMC_USIC_CH_EVENT_RECEIVE_START, @ref XMC_USIC_CH_EVENT_DATA_LOST etc. Multiple events
* can be combined using \a OR operation.
* @return None
*
* \parDescription
* Enable the channel interrupt events.\n\n
* Common channel events related to serial communication can be configured using this API.
* Multiple events can be combined using the bitwise OR operation and configured in one function call.
* XMC_USIC_CH_EVENT_t enumerates multiple protocol event bitmasks. These enumerations can be used as input to the API.
*
* \parRelated APIs:
* XMC_USIC_CH_DisableEvent(), XMC_USIC_CH_SetInterruptNodePointer() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_EnableEvent(XMC_USIC_CH_t *const channel, const uint32_t event)
{
channel->CCR |= event;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param event Bit mask of the channel events to be disabled. Use @ref XMC_USIC_CH_EVENT_t for the bit masks. \n
* \b Range: @ref XMC_USIC_CH_EVENT_RECEIVE_START, @ref XMC_USIC_CH_EVENT_DATA_LOST etc. Multiple events
* can be combined using \a OR operation.
* @return None
*
* \parDescription
* Disable the channel interrupt events. \n\n
* Multiple events can be combined using the bitwise OR operation and configured in one function call.
* XMC_USIC_CH_EVENT_t enumerates multiple protocol event bitmasks. These enumerations can be used as input to the API.
*
* \parRelated APIs:
* XMC_USIC_CH_EnableEvent(), XMC_USIC_CH_SetInterruptNodePointer() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_DisableEvent(XMC_USIC_CH_t *const channel, const uint32_t event)
{
channel->CCR &= (uint32_t)~event;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param interrupt_node Interrupt node pointer to be configured. \n
* \b Range: @ref XMC_USIC_CH_INTERRUPT_NODE_POINTER_TRANSMIT_SHIFT,
* @ref XMC_USIC_CH_INTERRUPT_NODE_POINTER_TRANSMIT_BUFFER etc.
* @param service_request Service request number.\n
* \b Range: 0 to 5.
* @return None
*
* \parDescription
* Sets the interrupt node for USIC channel events. \n\n
* For an event to generate interrupt, node pointer should be configured with service request(SR0, SR1..SR5).
* The NVIC node gets linked to the interrupt event by doing so.
* Note: NVIC node should be separately enabled to generate the interrupt.
*
* \parRelated APIs:
* XMC_USIC_CH_EnableEvent() \n\n\n
*/
void XMC_USIC_CH_SetInterruptNodePointer(XMC_USIC_CH_t *const channel,
const XMC_USIC_CH_INTERRUPT_NODE_POINTER_t interrupt_node,
const uint32_t service_request);
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return Stataus @ref XMC_USIC_CH_TBUF_STATUS_IDLE if transmit buffer is free,
* @ref XMC_USIC_CH_TBUF_STATUS_BUSY if transmit buffer is busy.
*
* \parDescription
* Gets transmit buffer status. \n\n
* Status indicates whether the transmit buffer is free, or busy transmitting data.
* The status depends on the value of TDV flag in TCSR register.
* This status can be used while transmitting data. Transmit data when the transmit buffer
* status is @ref XMC_USIC_CH_TBUF_STATUS_IDLE.
*
* \parRelated APIs:
* XMC_USIC_CH_SetDataOutputMode() \n\n\n
*/
__STATIC_INLINE XMC_USIC_CH_TBUF_STATUS_t XMC_USIC_CH_GetTransmitBufferStatus(XMC_USIC_CH_t *const channel)
{
return (XMC_USIC_CH_TBUF_STATUS_t)(channel->TCSR & USIC_CH_TCSR_TDV_Msk);
}
/**
* @brief API to get receive buffer status
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return Status of data validity check for RBUF0 and RBUF1. \n
* Returned value should be masked with RDV0 and RDV1 bits to know the status. \n
* \b Range: @ref XMC_USIC_CH_RBUF_STATUS_DATA_VALID0, @ref XMC_USIC_CH_RBUF_STATUS_DATA_VALID1.
*
* \parDescription
* Checks if RBUF0 and RBUF1 have valid unread data. \n\n
* It checks the bits RDV0 and RDV1 of the RBUFSR register.
* Returns the value of RBUFSR masked with bitmasks of RDV0 and RDV1.
* It can be used to decide whether 2bytes has to be read from RBUF or 1 byte.
* If both bitmasks XMC_USIC_CH_RBUF_STATUS_DATA_VALID0 and XMC_USIC_CH_RBUF_STATUS_DATA_VALID1
* are set, then 2 bytes can be read from RBUF. If only either of them is set, then only one byte
* can be read from RBUF.
* \parRelated APIs:
* XMC_USIC_CH_GetTransmitBufferStatus() \n\n\n
*/
__STATIC_INLINE uint32_t XMC_USIC_CH_GetReceiveBufferStatus(XMC_USIC_CH_t *const channel)
{
return ((uint32_t) (channel->RBUFSR & (USIC_CH_RBUFSR_RDV0_Msk | USIC_CH_RBUFSR_RDV1_Msk)));
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param start_transmision_mode Transmission mode to be enabled. \n
* \b Range: @ref XMC_USIC_CH_START_TRANSMISION_DISABLED,
* @ref XMC_USIC_CH_START_TRANSMISION_ON_TDV, @ref XMC_USIC_CH_START_TRANSMISION_ON_TDV_DX2S_0,
* @ref XMC_USIC_CH_START_TRANSMISION_ON_TDV_DX2S_1
*
* @return None
*
* \parDescription
* Configures data transmission. \n\n
* The configuration affects the data shifted on the DOUT0 pin.
*
* \parRelated APIs:
* XMC_USIC_CH_GetTransmitBufferStatus(), XMC_USIC_CH_SetDataOutputMode() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_SetStartTransmisionMode(XMC_USIC_CH_t *const channel,
const XMC_USIC_CH_START_TRANSMISION_MODE_t start_transmision_mode)
{
channel->TCSR = (uint32_t)(channel->TCSR & (~USIC_CH_TCSR_TDEN_Msk)) | (uint32_t)start_transmision_mode;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param data_output_mode Data output mode. \n
* \b Range: @ref XMC_USIC_CH_DATA_OUTPUT_MODE_NORMAL, @ref XMC_USIC_CH_DATA_OUTPUT_MODE_INVERTED
* @return None
*
* \parDescription
* Configures the mode for data output. \n\n
* USIC channel can be configured to shift inverted data or direct data based on the input to the API.
*
* \parRelated APIs:
* XMC_USIC_CH_SetStartTransmisionMode() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_SetDataOutputMode(XMC_USIC_CH_t *const channel,
const XMC_USIC_CH_DATA_OUTPUT_MODE_t data_output_mode)
{
channel->SCTR = (uint32_t)(channel->SCTR & (~USIC_CH_SCTR_DOCFG_Msk)) | (uint32_t)data_output_mode;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return None
*
* \parDescription
* Enables automatic update of frame length. \n\n
* When the automatic update of frame length is enabled, frame length is configured based on the
* index of the TBUF[]/IN[] register array. When the data is written to TBUF[x], frame length is configured
* with the mask value of \a x at the last 5 bit positions. Same logic is applicable if data is written to
* IN[x] register.
*
* \parRelated APIs:
* XMC_USIC_CH_DisableFrameLengthControl(), XMC_USIC_CH_TXFIFO_PutDataFLEMode() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_EnableFrameLengthControl(XMC_USIC_CH_t *const channel)
{
channel->TCSR = (uint32_t)(channel->TCSR & (~(USIC_CH_TCSR_WLEMD_Msk |
USIC_CH_TCSR_SELMD_Msk |
USIC_CH_TCSR_WAMD_Msk |
USIC_CH_TCSR_HPCMD_Msk))) |
(uint32_t)USIC_CH_TCSR_FLEMD_Msk;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return None
*
* \parDescription
* Disables automatic update of frame length. \n\n
* When automatic update of frame length is disabled, frame length has to configured explicitly.
* Frame length remains fixed until it is changed again.
*
* \parRelated APIs:
* XMC_USIC_CH_DisableFrameLengthControl(), XMC_USIC_CH_SetFrameLength() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_DisableFrameLengthControl(XMC_USIC_CH_t *const channel)
{
channel->TCSR &= (uint32_t)~USIC_CH_TCSR_FLEMD_Msk;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return None
*
* \parDescription
* Bit TCSR.TE is set if DX2T becomes active while TDV = 1. \n\n
* Enables the transfer trigger unit to set bit TCSR.TE if the trigger signal DX2T becomes active
* for event driven transfer starts.
*
* \parRelated APIs:
* XMC_USIC_CH_DisableTBUFDataValidTrigger()\n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_EnableTBUFDataValidTrigger(XMC_USIC_CH_t *const channel)
{
channel->TCSR |= (uint32_t)USIC_CH_TCSR_TDVTR_Msk;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return None
*
* \parDescription
* Disables the trigger of TDV depending on DX2T signal. \n\n
* Bit TCSR.TE is permanently set.
*
* \parRelated APIs:
* XMC_USIC_CH_EnableTBUFDataValidTrigger() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_DisableTBUFDataValidTrigger(XMC_USIC_CH_t *const channel)
{
channel->TCSR &= (uint32_t)~USIC_CH_TCSR_TDVTR_Msk;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param service_request_line service request number of the event to be triggered. \n
* \b Range: 0 to 5.
* @return None
*
* \parDescription
* Trigger a USIC interrupt service request.\n\n
* When the USIC service request is triggered, the NVIC interrupt associated with it will be
* generated if enabled.
*
* \parRelated APIs:
* XMC_USIC_CH_SetInterruptNodePointer() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_TriggerServiceRequest(XMC_USIC_CH_t *const channel, const uint32_t service_request_line)
{
channel->FMR = (uint32_t)(USIC_CH_FMR_SIO0_Msk << service_request_line);
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param transmit_buffer_status clearing or setting the TDV flag. \n
*
* @return None
*
* \parDescription
* Modify TCSR.TDV and TCSR.TE to control the start of a data word transmission by software.
*
* \parRelated APIs:
* XMC_USIC_CH_GetTransmitBufferStatus() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_SetTransmitBufferStatus(XMC_USIC_CH_t *const channel,
const XMC_USIC_CH_TBUF_STATUS_SET_t transmit_buffer_status)
{
channel->FMR = (uint32_t)transmit_buffer_status;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param passive_level Value of passive level for the channel. \n
* \b Range: @ref XMC_USIC_CH_PASSIVE_DATA_LEVEL0, @ref XMC_USIC_CH_PASSIVE_DATA_LEVEL1
* @return None
*
* \parDescription
* Set the passive data level of the output signal. \n\n
* When the USIC channel transmit stage is idle, the output signal level stays at the
* configured passive level.
*
* \parRelated APIs:
* XMC_USIC_CH_GetTransmitBufferStatus(), XMC_USIC_CH_SetStartTransmisionMode() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_SetPassiveDataLevel(XMC_USIC_CH_t *const channel,
const XMC_USIC_CH_PASSIVE_DATA_LEVEL_t passive_level)
{
channel->SCTR &= (~USIC_CH_SCTR_PDL_Msk);
channel->SCTR |= (uint32_t)passive_level;
}
/* TX FIFO APIs */
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param data_pointer Start position inside the FIFO buffer. \n
* \b Range: 0 to 63.
* @param size Required size of the transmit FIFO. \n
* \b Range: @ref XMC_USIC_CH_FIFO_DISABLED, @ref XMC_USIC_CH_FIFO_SIZE_2WORDS.. @ref XMC_USIC_CH_FIFO_SIZE_64WORDS
* @param limit Threshold of transmit FIFO filling level to be considered for generating events. \n
* \b Range: 0 to \a size -1.
* @return None
*
* \parDescription
* Initializes the transmit FIFO. \n\n
* Transmit FIFO is a subset of a common FIFO sized 64 words. This FIFO is shared between 2 channels of the USIC module.
* Each channel can share the FIFO for transmission and reception. \a data_pointer represents the start index in the common FIFO,
* from where transmit data can be put, for the selected USIC channel. \a size represents the size of transmit FIFO as a multiple of
* 2. Since the FIFO is shared between 2 USIC channels, FIFO size should be carefully selected. A FIFO standard transmit buffer
* event is generated when the FIFO filling level falls below the \a limit value.
*
* \parRelated APIs:
* XMC_USIC_CH_TXFIFO_EnableEvent(), XMC_USIC_CH_TXFIFO_SetInterruptNodePointer() \n\n\n
*/
void XMC_USIC_CH_TXFIFO_Configure(XMC_USIC_CH_t *const channel,
const uint32_t data_pointer,
const XMC_USIC_CH_FIFO_SIZE_t size,
const uint32_t limit);
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param size Required size of the transmit FIFO. \n
* \b Range: @ref XMC_USIC_CH_FIFO_DISABLED, @ref XMC_USIC_CH_FIFO_SIZE_2WORDS.. @ref XMC_USIC_CH_FIFO_SIZE_64WORDS
* @param limit Threshold for transmit FIFO filling level to be considered for generating events. \n
* \b Range: 0 to \a size -1.
* @return None
*
* \parDescription
* Sets the size and trigger limit for the transmit FIFO. \n\n
* The API is not to be called for initializing the transmit FIFO. The API shall be used for the
* runtime change of transmit FIFO trigger limit. FIFO start position will not be affected on execution.
*
* \parRelated APIs:
* XMC_USIC_CH_RXFIFO_SetSizeTriggerLimit() \n\n\n
*/
void XMC_USIC_CH_TXFIFO_SetSizeTriggerLimit(XMC_USIC_CH_t *const channel,
const XMC_USIC_CH_FIFO_SIZE_t size,
const uint32_t limit);
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param event Events to be enabled. Multiple events can be bitwise OR combined. @ref XMC_USIC_CH_TXFIFO_EVENT_CONF_t \n
* @return None
*
* \parDescription
* Enables the interrupt events related to transmit FIFO. \n\n
* Event bitmasks can be constructed using the enumeration @ref XMC_USIC_CH_TXFIFO_EVENT_CONF_t.
* Multiple events can be enabled by providing multiple events in a single call. For providing
* multiple events, combine the events using bitwise OR operation. Events are configured in the TBCTR register.
*
* Note: API only enables the events. For interrupt generation, interrupt node must be configured and NVIC node
* must be enabled.
*
* \parRelated APIs:
* XMC_USIC_CH_TXFIFO_SetInterruptNodePointer() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_TXFIFO_EnableEvent(XMC_USIC_CH_t *const channel, const uint32_t event)
{
channel->TBCTR |= event;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param event Events to be disabled. @ref XMC_USIC_CH_TXFIFO_EVENT_CONF_t \n
* @return None
*
* \parDescription
* Disables the interrupt events related to transmit FIFO. \n\n
* By disabling the interrupt events, generation of interrupt is stopped. User can poll the event
* flags from the status register using the API XMC_USIC_CH_TXFIFO_GetEvent().
* Event bitmasks can be constructed using the enumeration @ref XMC_USIC_CH_TXFIFO_EVENT_CONF_t. For providing
* multiple events, combine the events using bitwise OR operation.
*
* \parRelated APIs:
* XMC_USIC_CH_TXFIFO_GetEvent(), XMC_USIC_CH_TXFIFO_EnableEvent() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_TXFIFO_DisableEvent(XMC_USIC_CH_t *const channel, const uint32_t event)
{
channel->TBCTR &= (uint32_t)~event;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param interrupt_node Node pointer representing the transmit FIFO events. \n
* \b Range: @ref XMC_USIC_CH_TXFIFO_INTERRUPT_NODE_POINTER_STANDARD,
* @ref XMC_USIC_CH_TXFIFO_INTERRUPT_NODE_POINTER_ALTERNATE
* @param service_request The service request to be used for interrupt generation. \n
* \b Range: 0 to 5.
* @return None
*
* \parDescription
* Sets an interrupt node for the transmit FIFO events.\n\n
* A node pointer represents one or more interrupt events. Service request represents the interrupt node to be used
* among the 6 interrupt nodes available for USIC module.
* API configures the service request to be used for interrupt generation for the events selected.
* A transmit FIFO event can generate an interrupt only if the interrupt node is configured for the event and
* the interrupt generation is enabled for the event. For example, transmit FIFO standard transmit buffer
* interrupt is generated if the interrupt node for the same is set and interrupt is enabled.
*
* Note: NVIC node should be explicitly enabled for the interrupt generation.
*
* \parRelated APIs:
* XMC_USIC_CH_TXFIFO_EnableEvent() \n\n\n
*/
void XMC_USIC_CH_TXFIFO_SetInterruptNodePointer(XMC_USIC_CH_t *const channel,
const XMC_USIC_CH_TXFIFO_INTERRUPT_NODE_POINTER_t interrupt_node,
const uint32_t service_request);
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param data Data to be transmitted. \n
* \b Range: 16bit unsigned data. minimum= 0, maximum= 65535
* @return None
*
* \parDescription
* Writes data into the transmit FIFO. \n\n
* The data provided is placed in the transmit FIFO.
* The transmit FIFO should be configured before calling this API.
*
* \parRelated APIs:
* XMC_USIC_CH_TXFIFO_EnableEvent() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_TXFIFO_PutData(XMC_USIC_CH_t *const channel, const uint16_t data)
{
channel->IN[0] = data;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param data Data to be transmitted.
* @param frame_length Frame length to be configured while transmitting the data. \n
* \b Range: minimum= 0, maximum= 31. e.g: For a frame length of 16, set \a frame_length as 15.
* @return None
*
* \parDescription
* Writes data to the transmit FIFO in frame length control mode. \n\n
* When frame length control is enabled for dynamic update of frame length, this API can be used.
* \a frame_length represents the frame length to be updated by the peripheral.
* \a frame_length is used as index for the IN[] register array.
*
* \parRelated APIs:
* XMC_USIC_CH_EnableFrameLengthControl() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_TXFIFO_PutDataFLEMode(XMC_USIC_CH_t *const channel,
const uint16_t data,
const uint32_t frame_length)
{
channel->IN[frame_length] = data;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param data Data to be transmitted.
* @param frame_length Frame length to be configured while transmitting the data. \n
* \b Range: minimum= 0, maximum= 31. e.g: For a frame length of 16, set \a frame_length as 15.
* @return None
*
* \parDescription
* Writes data to the transmit FIFO in hardware port control mode. \n\n
* When hardware port control is enabled for dynamic update of frame length, this API can be used.
* \a frame_length represents the frame length to be updated by the peripheral.
* \a frame_length is used as index for the IN[] register array.
*
* \parRelated APIs:
* XMC_USIC_CH_EnableFrameLengthControl() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_TXFIFO_PutDataHPCMode(XMC_USIC_CH_t *const channel,
const uint16_t data,
const uint32_t frame_length)
{
channel->IN[frame_length] = data;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return None
*
* \parDescription
* Clears the contents of transmit FIFO. \n\n
* Transmit FIFO contents will be cleared and the filling level will be reset to 0.
*
* \parRelated APIs:
* XMC_USIC_CH_TXFIFO_GetLevel() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_TXFIFO_Flush(XMC_USIC_CH_t *const channel)
{
channel->TRBSCR = (uint32_t)USIC_CH_TRBSCR_FLUSHTB_Msk;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return Status \a true if transmit FIFO is full
* \a false if transmit FIFO is not full.
*
* \parDescription
* Checks if transmit FIFO is full. \n\n
* When the transmit FIFO filling level reaches the configured size, FIFO full flag is set.
* User should not write to the FIFO when the transmit FIFO is full.
*
* \parRelated APIs:
* XMC_USIC_CH_TXFIFO_IsEmpty(), XMC_USIC_CH_TXFIFO_Flush() \n\n\n
*/
__STATIC_INLINE bool XMC_USIC_CH_TXFIFO_IsFull(XMC_USIC_CH_t *const channel)
{
return (bool)(channel->TRBSR & USIC_CH_TRBSR_TFULL_Msk);
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return Status \a true if transmit FIFO is empty
* \a false if transmit FIFO has some data.
*
* \parDescription
* Checks if transmit FIFO is empty. \n\n
* When the transmit FIFO is empty, data can be written to FIFO.
* When the last written word to the transmit FIFO is transmitted out of the FIFO,
* FIFO empty flag is set.
*
* \parRelated APIs:
* XMC_USIC_CH_TXFIFO_Flush(), XMC_USIC_CH_TXFIFO_PutData() \n\n\n
*/
__STATIC_INLINE bool XMC_USIC_CH_TXFIFO_IsEmpty(XMC_USIC_CH_t *const channel)
{
return (bool)(channel->TRBSR & USIC_CH_TRBSR_TEMPTY_Msk);
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return Transmit FIFO filling level. \n
* \b Range: minimum= 0(FIFO empty), maximum= transmit FIFO size.
*
* \parDescription
* Gets the transmit FIFO filling level. \n\n
* For every word written to the FIFO, filling level is updated. The API gives the value
* of this filling level.
*
* \parRelated APIs:
* XMC_USIC_CH_TXFIFO_Flush(), XMC_USIC_CH_TXFIFO_PutData() \n\n\n
*/
__STATIC_INLINE uint32_t XMC_USIC_CH_TXFIFO_GetLevel(XMC_USIC_CH_t *const channel)
{
return ((uint32_t)(channel->TRBSR & USIC_CH_TRBSR_TBFLVL_Msk) >> USIC_CH_TRBSR_TBFLVL_Pos);
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return Status of standard transmit and transmit buffer error events. @ref XMC_USIC_CH_TXFIFO_EVENT_t \n
*
* \parDescription
* Gets the transmit FIFO event status. \n\n
* Gives the status of transmit FIFO standard transmit buffer event and transmit buffer error event.
* The status bits are located at their bit positions in the TRBSR register in the returned value.
* User can make use of the @ref XMC_USIC_CH_TXFIFO_EVENT_t enumeration for checking the status of return value.
* The status can be found by using the bitwise AND operation on the returned value with the enumerated value.
*
* Note: Event status flags should be cleared by the user explicitly.
*
* \parRelated APIs:
* XMC_USIC_CH_TXFIFO_ClearEvent() \n\n\n
*/
__STATIC_INLINE uint32_t XMC_USIC_CH_TXFIFO_GetEvent(XMC_USIC_CH_t *const channel)
{
return (uint32_t)((channel->TRBSR) & (USIC_CH_TRBSR_STBI_Msk |
USIC_CH_TRBSR_TBERI_Msk));
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param event Transmit FIFO events to be cleared. \n
* \b Range: @ref XMC_USIC_CH_TXFIFO_EVENT_STANDARD, @ref XMC_USIC_CH_TXFIFO_EVENT_ERROR.
* @return None
*
* \parDescription
* Clears the transmit FIFO event flags in the status register. \n\n
* USIC channel peripheral does not clear the event flags after they are read.
* This API clears the events provided in the \a mask value.
* XMC_USIC_CH_TXFIFO_EVENT enumeration can be used as input. Multiple events
* can be cleared by providing a mask value obtained by bitwise OR operation of
* multiple event enumerations.
*
* \parRelated APIs:
* XMC_USIC_CH_TXFIFO_GetEvent() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_TXFIFO_ClearEvent(XMC_USIC_CH_t *const channel,
const uint32_t event)
{
channel->TRBSCR = event;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param data_pointer Start position inside the FIFO buffer. \n
* \b Range: 0 to 63.
* @param size Required size of the receive FIFO. \n
* \b Range: @ref XMC_USIC_CH_FIFO_DISABLED, @ref XMC_USIC_CH_FIFO_SIZE_2WORDS.. @ref XMC_USIC_CH_FIFO_SIZE_64WORDS
* @param limit Threshold of receive FIFO filling level to be considered for generating events. \n
* \b Range: 0 to \a size -1.
* @return None
*
* \parDescription
* Configures the receive FIFO. \n\n
* Receive FIFO is the subset of a common FIFO sized 64 words. This FIFO is shared between 2 channels of the USIC module.
* Each channel can share the FIFO for transmission and reception. \a data_pointer represents the start index in the common FIFO,
* from where received data can be put. \a size represents the size of receive FIFO as a multiple of 2.
* Since the FIFO is shared between 2 USIC channels, FIFO size should be carefully selected. A FIFO standard receive buffer
* event or alternative receive buffer event is generated when the FIFO filling level exceeds the \a limit value.
*
* \parRelated APIs:
* XMC_USIC_CH_RXFIFO_EnableEvent(), XMC_USIC_CH_RXFIFO_SetInterruptNodePointer() \n\n\n
*/
void XMC_USIC_CH_RXFIFO_Configure(XMC_USIC_CH_t *const channel,
const uint32_t data_pointer,
const XMC_USIC_CH_FIFO_SIZE_t size,
const uint32_t limit);
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param size Required size of the receive FIFO. \n
* \b Range: @ref XMC_USIC_CH_FIFO_DISABLED, @ref XMC_USIC_CH_FIFO_SIZE_2WORDS.. @ref XMC_USIC_CH_FIFO_SIZE_64WORDS
* @param limit Threshold for receive FIFO filling level to be considered for generating events. \n
* \b Range: 0 to \a size -1.
* @return None
*
* \parDescription
* Sets the size and trigger limit for the receive FIFO. \n\n
* The API is not to be called for initializing the receive FIFO. The API shall be used for the
* runtime change of receive FIFO trigger limit. FIFO start position will not be affected on execution.
*
* \parRelated APIs:
* XMC_USIC_CH_TXFIFO_SetSizeTriggerLimit()\ n\n\n
*/
void XMC_USIC_CH_RXFIFO_SetSizeTriggerLimit(XMC_USIC_CH_t *const channel,
const XMC_USIC_CH_FIFO_SIZE_t size,
const uint32_t limit);
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param event Events to be enabled. Multiple events can be bitwise OR combined. @ref XMC_USIC_CH_RXFIFO_EVENT_CONF_t\n
* @return None
*
* \parDescription
* Enables the interrupt events related to transmit FIFO. \n\n
* Event bitmasks can be constructed using the enumeration @ref XMC_USIC_CH_RXFIFO_EVENT_CONF_t.
* Multiple events can be enabled by providing multiple events in a single call. For providing
* multiple events, combine the events using bitwise OR operation.
*
* Note: API only enables the events. For interrupt generation, interrupt node must be configured and NVIC node
* must be enabled.
*
* \parRelated APIs:
* XMC_USIC_CH_RXFIFO_SetInterruptNodePointer() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_RXFIFO_EnableEvent(XMC_USIC_CH_t *const channel, const uint32_t event)
{
channel->RBCTR |= event;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param event Events to be disabled. \n
* \b Range: @ref XMC_USIC_CH_RXFIFO_EVENT_CONF_STANDARD, @ref XMC_USIC_CH_RXFIFO_EVENT_CONF_ERROR,
* @ref XMC_USIC_CH_RXFIFO_EVENT_CONF_ALTERNATE.
* @return None
*
* \parDescription
* Disables the selected interrupt events related to receive FIFO. \n\n
* By disabling the interrupt events, generation of interrupt is stopped. User can poll the event
* flags from the status register using the API XMC_USIC_CH_RXFIFO_GetEvent().
* Event bitmasks can be constructed using the enumeration \a XMC_USIC_CH_RXFIFO_EVENT_CONF. For providing
* multiple events, combine the events using bitwise OR operation.
*
* \parRelated APIs:
* XMC_USIC_CH_RXFIFO_GetEvent(), XMC_USIC_CH_RXFIFO_EnableEvent() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_RXFIFO_DisableEvent(XMC_USIC_CH_t *const channel, const uint32_t event)
{
channel->RBCTR &= (uint32_t)~event;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param interrupt_node Node pointer representing the receive FIFO events. \n
* \b Range: @ref XMC_USIC_CH_RXFIFO_INTERRUPT_NODE_POINTER_STANDARD,
* @ref XMC_USIC_CH_RXFIFO_INTERRUPT_NODE_POINTER_ALTERNATE
* @param service_request The service request to be used for interrupt generation.\n
* \b Range: 0 to 5.
* @return None
*
* \parDescription
* Sets an interrupt node for the receive FIFO events. \n\n
* A node pointer represents one or more interrupt events. Service request represents the interrupt node to be used
* among the 6 interrupt nodes available for USIC module.
* API configures the service request to be used for interrupt generation for the events selected.
* A receive FIFO event can generate an interrupt only if the interrupt node is configured for the event and
* the interrupt generation is enabled for the event. For example, transmit FIFO standard transmit buffer
* interrupt is generated if the interrupt node for the same is set and interrupt is enabled.
*
* Note: NVIC node should be explicitly enabled for the interrupt generation.
*
* \parRelated APIs:
* XMC_USIC_CH_RXFIFO_EnableEvent() \n\n\n
*/
void XMC_USIC_CH_RXFIFO_SetInterruptNodePointer(XMC_USIC_CH_t *const channel,
const XMC_USIC_CH_RXFIFO_INTERRUPT_NODE_POINTER_t interrupt_node,
const uint32_t service_request);
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return Value read from the receive FIFO. \n
* \b Range: 16bit data. Length of data depends on the word length configuration.
*
* \parDescription
* Gets data from the receive FIFO. \n\n
* Receive FIFO should be read only if data is availble in the FIFO. This can be checked using
* the API XMC_USIC_CH_RXFIFO_IsEmpty(). Receive FIFO error flag will be set if an attempt is made
* to read from an empty receive FIFO. To read all the received data, user should keep reading data
* until receive FIFO is empty.
*
* \parRelated APIs:
* XMC_USIC_CH_RXFIFO_ClearEvent() \n\n\n
*/
__STATIC_INLINE uint16_t XMC_USIC_CH_RXFIFO_GetData(XMC_USIC_CH_t *const channel)
{
return (uint16_t)(channel->OUTR);
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return None
*
* \parDescription
* Clears the contents of receive FIFO. \n\n
* Receive FIFO contents will be cleared and the filling level will be reset to 0.
*
* \parRelated APIs:
* XMC_USIC_CH_RXFIFO_GetLevel() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_RXFIFO_Flush(XMC_USIC_CH_t *const channel)
{
channel->TRBSCR = (uint32_t)USIC_CH_TRBSCR_FLUSHRB_Msk;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return Status \a true if receive FIFO is full
* \a false if receive FIFO is not full.
*
* \parDescription
* Checks if receive FIFO is full. \n\n
* When the receive FIFO filling level reaches the configured size, FIFO full flag is set.
* Any data received when the receive FIFO is full, is lost.
*
* \parRelated APIs:
* XMC_USIC_CH_RXFIFO_IsEmpty(), XMC_USIC_CH_RXFIFO_Flush() \n\n\n
*/
__STATIC_INLINE bool XMC_USIC_CH_RXFIFO_IsFull(XMC_USIC_CH_t *const channel)
{
return (bool)(channel->TRBSR & USIC_CH_TRBSR_RFULL_Msk);
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return Status \a true if receive FIFO is empty,
* \a false if receive FIFO has some data.
*
* \parDescription
* Checks if receive FIFO is empty. \n\n
* When the receive FIFO is empty, received data will be put in receive FIFO.
* When the last received word in the FIFO is read, FIFO empty flag is set. Any attempt
* to read from an empty receive FIFO will set the receive FIFO error flag.
*
* \parRelated APIs:
* XMC_USIC_CH_RXFIFO_Flush(), XMC_USIC_CH_RXFIFO_PutData() \n\n\n
*/
__STATIC_INLINE bool XMC_USIC_CH_RXFIFO_IsEmpty(XMC_USIC_CH_t *const channel)
{
return (bool)(channel->TRBSR & USIC_CH_TRBSR_REMPTY_Msk);
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return uint32_t Receive FIFO filling level. \n
* \b Range: minimum= 0(FIFO empty), maximum= receive FIFO size.
*
* \parDescription
* Gets the receive FIFO filling level. \n\n
* For every word received, the filling level is incremented. The API gives the value
* of this filling level. The filling level is decremented when the data is read out of the
* receive FIFO.
*
* \parRelated APIs:
* XMC_USIC_CH_RXFIFO_Flush(), XMC_USIC_CH_RXFIFO_PutData() \n\n\n
*/
__STATIC_INLINE uint32_t XMC_USIC_CH_RXFIFO_GetLevel(XMC_USIC_CH_t *const channel)
{
return ((uint32_t)(channel->TRBSR & USIC_CH_TRBSR_RBFLVL_Msk) >> USIC_CH_TRBSR_RBFLVL_Pos);
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return Status of standard receive buffer, alternative receive buffer and receive buffer error events. \n
* \b Range: @ref XMC_USIC_CH_RXFIFO_EVENT_STANDARD, @ref XMC_USIC_CH_RXFIFO_EVENT_ERROR,
* @ref XMC_USIC_CH_RXFIFO_EVENT_ALTERNATE.
*
* \parDescription
* Gets the receive FIFO events' status. \n\n
* Gives the status of receive FIFO standard receive buffer event, alternative receive buffer event and receive buffer error event.
* The status bits are located at their bitpositions in the TRBSR register in the returned value.
* User can make use of the XMC_USIC_CH_RXFIFO_EVENT enumeration for checking the status of return value.
* The status can be found by using the bitwise AND operation on the returned value with the enumerated value.
*
* Note: Event status flags should be cleared by the user explicitly.
*
* \parRelated APIs:
* XMC_USIC_CH_RXFIFO_ClearEvent()\n\n\n
*/
__STATIC_INLINE uint32_t XMC_USIC_CH_RXFIFO_GetEvent(XMC_USIC_CH_t *const channel)
{
return (uint32_t)((channel->TRBSR) & (USIC_CH_TRBSR_SRBI_Msk |
USIC_CH_TRBSR_RBERI_Msk |
USIC_CH_TRBSR_ARBI_Msk));
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param event Receive FIFO events to be cleared. \n
* \b Range: @ref XMC_USIC_CH_RXFIFO_EVENT_STANDARD, @ref XMC_USIC_CH_RXFIFO_EVENT_ERROR,
* @ref XMC_USIC_CH_RXFIFO_EVENT_ALTERNATE.
* @return None
*
* \parDescription
* Clears the receive FIFO event flags in the status register. \n\n
* USIC channel peripheral does not clear the event flags after they are read.
* This API clears the events provided in the \a mask value.
* XMC_USIC_CH_RXFIFO_EVENT enumeration can be used as input. Multiple events
* can be cleared by providing a mask value obtained by bitwise OR operation of
* multiple event enumerations.
*
* \parRelated APIs:
* XMC_USIC_CH_RXFIFO_GetEvent() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_RXFIFO_ClearEvent(XMC_USIC_CH_t *const channel,
const uint32_t event)
{
channel->TRBSCR = event;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return None
*
* \parDescription
* Enables time measurement using the capture mode timer. \n\n
* Time measurement is enabled by setting the timer enable flag in BRG register.
*
* \parRelated APIs:
* XMC_USIC_CH_DisableTimeMeasurement() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_EnableTimeMeasurement(XMC_USIC_CH_t *const channel)
{
channel->BRG |= (uint32_t)USIC_CH_BRG_TMEN_Msk;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @return None
*
* \parDescription
* Disables time measurement using the capture mode timer. \n\n
* Time measurement is disabled by clearing the timer enable flag in BRG register.
*
* \parRelated APIs:
* XMC_USIC_CH_EnableTimeMeasurement() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_DisableTimeMeasurement(XMC_USIC_CH_t *const channel)
{
channel->BRG &= (uint32_t)~USIC_CH_BRG_TMEN_Msk;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param passive_level Passive level for the master clock output. \n
* \b Range: @ref XMC_USIC_CH_BRG_MASTER_CLOCK_PASSIVE_LEVEL_0, @ref XMC_USIC_CH_BRG_MASTER_CLOCK_PASSIVE_LEVEL_1.
* @return None
*
* \parDescription
* Sets the idle mode pin level for the master clock output. \n
*/
__STATIC_INLINE void XMC_USIC_CH_SetMclkOutputPassiveLevel(XMC_USIC_CH_t *const channel,
const XMC_USIC_CH_BRG_MASTER_CLOCK_PASSIVE_LEVEL_t passive_level)
{
channel->BRG = (uint32_t)(channel->BRG & (~USIC_CH_BRG_MCLKCFG_Msk)) | (uint32_t)passive_level;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param passive_level Passive level for the clock output. \n
* \b Range: @ref XMC_USIC_CH_BRG_SHIFT_CLOCK_PASSIVE_LEVEL_0_DELAY_DISABLED,
* @ref XMC_USIC_CH_BRG_SHIFT_CLOCK_PASSIVE_LEVEL_0_DELAY_ENABLED,
* @ref XMC_USIC_CH_BRG_SHIFT_CLOCK_PASSIVE_LEVEL_1_DELAY_DISABLED,
* @ref XMC_USIC_CH_BRG_SHIFT_CLOCK_PASSIVE_LEVEL_1_DELAY_ENABLED,
* @param clock_output Shift clock source selection. \n
* \b Range: Use @ref XMC_USIC_CH_BRG_SHIFT_CLOCK_OUTPUT_SCLK,
* @ref XMC_USIC_CH_BRG_SHIFT_CLOCK_OUTPUT_DX1
* @return None
*
* \parDescription
* Sets the idle mode shift clock output level and selects the shift clock source. \n\n
* Shift clock idle mode output level can be set to logic high or low. Shift clock output can be configured to have a
* delay of half shift clock period. Both the configurations are available as enumeration values defined with type
* @ref XMC_USIC_CH_BRG_SHIFT_CLOCK_PASSIVE_LEVEL_t.
* This value should be configured based on the slave device requirement.
* Shift clock source can be selected between internal clock(master) and external input(slave).
*
*/
__STATIC_INLINE void XMC_USIC_CH_ConfigureShiftClockOutput(XMC_USIC_CH_t *const channel,
const XMC_USIC_CH_BRG_SHIFT_CLOCK_PASSIVE_LEVEL_t passive_level,
const XMC_USIC_CH_BRG_SHIFT_CLOCK_OUTPUT_t clock_output)
{
channel->BRG = (uint32_t)(channel->BRG & (~(USIC_CH_BRG_SCLKCFG_Msk |
USIC_CH_BRG_SCLKOSEL_Msk))) |
(uint32_t)passive_level |
(uint32_t)clock_output;
}
/**
* @param channel Pointer to USIC channel handler of type @ref XMC_USIC_CH_t \n
* \b Range: @ref XMC_USIC0_CH0, @ref XMC_USIC0_CH1 to @ref XMC_USIC2_CH1 based on device support.
* @param mode USIC channel operation mode. \n
* \b Range: @ref XMC_USIC_CH_OPERATING_MODE_IDLE, @ref XMC_USIC_CH_OPERATING_MODE_SPI,
* @ref XMC_USIC_CH_OPERATING_MODE_UART, @ref XMC_USIC_CH_OPERATING_MODE_I2S,
* @ref XMC_USIC_CH_OPERATING_MODE_I2C.
* @return None
*
* \parDescription
* Sets the USIC channel operation mode.\n\n
* A USIC channel can support multiple serial communication protocols like UART, SPI, I2C and I2S.
* The API sets the input operation mode to the USIC channel.
*
* \parRelated APIs:
* XMC_USIC_Enable(), XMC_USIC_CH_Enable() \n\n\n
*/
__STATIC_INLINE void XMC_USIC_CH_SetMode(XMC_USIC_CH_t *const channel, const XMC_USIC_CH_OPERATING_MODE_t mode)
{
channel->CCR = (uint32_t)(channel->CCR & (~(USIC_CH_CCR_MODE_Msk))) | (uint32_t)mode;
}
#ifdef __cplusplus
}
#endif
/**
* @}
*/
/**
* @}
*/
#endif