2.45.4 FLEXCOMx_USART_Read Function
C
/* x = FLEXCOM instance number */ /* Blocking and non-blocking mode */ bool FLEXCOMx_USART_Read( void *buffer, const size_t size ) /* Ring buffer mode */ size_t FLEXCOMx_USART_Read(uint8_t* buffer, const size_t size)
Summary
Blocking and non-blocking mode
Submits a read buffer to the given USART peripheral to process
Ring buffer mode
Read the requested data from the receive buffer into the application buffer
Description
Blocking mode
In blocking mode, the API blocks until the requested number of bytes have been received. The return value is true if the requested number of bytes have been read successfully. If not, call the FLEXCOMx_USART_ErrorGet API to check the error. The FLEXCOMx_USART_ReadCountGet function can be called to know the number of bytes that were received till the error occurred.
Non-blocking mode
This function submits a read buffer to the USART peripheral to process. A call to this function submits the buffer and the size to the peripheral library and returns immediately. The transfer completion status can either be checked through the callback mechanism or by calling the FLEXCOMx_USART_ReadIsBusy function. The success of the operation can be obtained by calling the FLEXCOMx_USART_ErrorGet function. If the FLEXCOMx_USART_ErrorGet function returns no error, then this means that the requested number of bytes have been processed. If the function returns some error, the FLEXCOMx_USART_ReadCountGet function can be called to know the number of bytes that were received till the error occurred.
Ring buffer mode
The API copies the number of bytes available in the receive buffer and returns the number of bytes actually copied. If the number of bytes copied is less than the requested size, the application must try reading after some time. If notifications are enabled and a callback is registered, a callback is given when the receive threshold condition is met. This lets the application to get notified when the data is available in the receive buffer.
Precondition
FLEXCOMx_USART_Initialize must have been called for the associated USART instance.
Parameters
Param | Description |
---|---|
buffer | Pointer to the user buffer where received data will be placed. |
size | Number of bytes to be received. If 9-bit mode is enabled, then the size is specified in terms of number of 9 bit data. For example, if 5 9-bit data are being received, then the size must be specified as 5. |
Returns
Blocking and non-blocking mode
true - if the Read transaction is successful or if the requested size is 0.
false - if the arguments are not valid or if the device is busy or if an error occurred while receiving data.
Ring buffer mode
The API returns the number of bytes actually read into the user buffer. Application must retry by calling this API again if the return value is less than the number of bytes requested. Application can use the FLEXCOMx_USART_ReadCountGet API to determine the number of unread bytes available in the receive buffer. Application can also choose to register for event notification to get notified when data is available in the receive buffer (set by the FLEXCOMx_USART_ReadThresholdSet API). If 9-bit mode is enabled, then the return value indicates the number of 9-bit data copied to the application buffer.
Example
Blocking mode
uint8_t rxBuffer[100]; //The below call blocks until the requested bytes have been read FLEXCOM0_USART_Read(rxBuffer, 100);
Non-blocking mode
uint8_t rxBuffer[100]; //The below call submits the request and returns immediately. Transfer status can be checked either by calling the FLEXCOMx_USART_ReadIsBusy API or by registering a callback and getting notified. FLEXCOM0_USART_Read(rxBuffer, 100); if (FLEXCOM0_USART_ReadIsBusy() == false) { // Transfer has completed. }
Ring buffer mode
uint8_t rxBuffer[100]; uint32_t nBytesRead = 0; nBytesRead = FLEXCOM0_USART_Read((uint8_t*)rxBuffer, 100); if (nBytesRead < 100) { // Receive buffer does not have more data, try after some time // Application can even enable notification to get notified when the // data becomes available in the receive buffer }
Remarks
None