mirror of
https://github.com/qmk/qmk_firmware.git
synced 2025-07-17 13:12:08 +00:00
Add Serial_IsSendReady() and Serial_IsSendComplete() serial driver API functions.
This commit is contained in:
parent
0c00c2aaa3
commit
3d818fbb86
@ -10,6 +10,7 @@
|
|||||||
* <b>New:</b>
|
* <b>New:</b>
|
||||||
* - Core:
|
* - Core:
|
||||||
* - Updated the BUILD build system module to add a new COMPILER_PATH optional variable
|
* - Updated the BUILD build system module to add a new COMPILER_PATH optional variable
|
||||||
|
* - Added Serial_IsSendReady() and Serial_IsSendComplete() functions to the Serial hardware peripheral driver
|
||||||
*
|
*
|
||||||
* <b>Fixed:</b>
|
* <b>Fixed:</b>
|
||||||
* - Core:
|
* - Core:
|
||||||
|
@ -210,14 +210,39 @@
|
|||||||
return ((UCSR1A & (1 << RXC1)) ? true : false);
|
return ((UCSR1A & (1 << RXC1)) ? true : false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Indicates whether there is hardware buffer space for a new transmit on the USART. This
|
||||||
|
* function can be used to determine if a call to \ref Serial_SendByte() will block in advance.
|
||||||
|
*
|
||||||
|
* \return Boolean \c true if a character can be queued for transmission immediately, \c false otherwise.
|
||||||
|
*/
|
||||||
|
static inline bool Serial_IsSendReady(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
|
||||||
|
static inline bool Serial_IsSendReady(void)
|
||||||
|
{
|
||||||
|
return ((UCSR1A & (1 << UDRE1)) ? true : false);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Indicates whether the hardware USART transmit buffer is completely empty, indicating all
|
||||||
|
* pending transmissions have completed.
|
||||||
|
*
|
||||||
|
* \return Boolean \c true if no characters are buffered for transmission, \c false otherwise.
|
||||||
|
*/
|
||||||
|
static inline bool Serial_IsSendComplete(void) ATTR_WARN_UNUSED_RESULT ATTR_ALWAYS_INLINE;
|
||||||
|
static inline bool Serial_IsSendComplete(void)
|
||||||
|
{
|
||||||
|
return ((UCSR1A & (1 << TXC1)) ? true : false);
|
||||||
|
}
|
||||||
|
|
||||||
/** Transmits a given byte through the USART.
|
/** Transmits a given byte through the USART.
|
||||||
|
*
|
||||||
|
* \note If no buffer space is available in the hardware USART, this function will block. To check if
|
||||||
|
* space is available before calling this function, see \ref Serial_IsSendReady().
|
||||||
*
|
*
|
||||||
* \param[in] DataByte Byte to transmit through the USART.
|
* \param[in] DataByte Byte to transmit through the USART.
|
||||||
*/
|
*/
|
||||||
static inline void Serial_SendByte(const char DataByte) ATTR_ALWAYS_INLINE;
|
static inline void Serial_SendByte(const char DataByte) ATTR_ALWAYS_INLINE;
|
||||||
static inline void Serial_SendByte(const char DataByte)
|
static inline void Serial_SendByte(const char DataByte)
|
||||||
{
|
{
|
||||||
while (!(UCSR1A & (1 << UDRE1)));
|
while (!(Serial_IsSendReady()));
|
||||||
UDR1 = DataByte;
|
UDR1 = DataByte;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -216,7 +216,36 @@
|
|||||||
return ((USART->STATUS & USART_RXCIF_bm) ? true : false);
|
return ((USART->STATUS & USART_RXCIF_bm) ? true : false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Indicates whether there is hardware buffer space for a new transmit on the USART. This
|
||||||
|
* function can be used to determine if a call to \ref Serial_SendByte() will block in advance.
|
||||||
|
*
|
||||||
|
* \param[in,out] USART Pointer to the base of the USART peripheral within the device.
|
||||||
|
*
|
||||||
|
* \return Boolean \c true if a character can be queued for transmission immediately, \c false otherwise.
|
||||||
|
*/
|
||||||
|
static inline bool Serial_IsSendReady(USART_t* const USART) ATTR_ALWAYS_INLINE ATTR_WARN_UNUSED_RESULT ATTR_NON_NULL_PTR_ARG(1);
|
||||||
|
static inline bool Serial_IsSendReady(USART_t* const USART)
|
||||||
|
{
|
||||||
|
return (USART->STATUS & USART_DREIF_bm) ? true : false);
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Indicates whether the hardware USART transmit buffer is completely empty, indicating all
|
||||||
|
* pending transmissions have completed.
|
||||||
|
*
|
||||||
|
* \param[in,out] USART Pointer to the base of the USART peripheral within the device.
|
||||||
|
*
|
||||||
|
* \return Boolean \c true if no characters are buffered for transmission, \c false otherwise.
|
||||||
|
*/
|
||||||
|
static inline bool Serial_IsSendComplete(USART_t* const USART) ATTR_ALWAYS_INLINE ATTR_WARN_UNUSED_RESULT ATTR_NON_NULL_PTR_ARG(1);
|
||||||
|
static inline bool Serial_IsSendComplete(USART_t* const USART)
|
||||||
|
{
|
||||||
|
return (USART->STATUS & USART_TCXIF_bm) ? true : false);
|
||||||
|
}
|
||||||
|
|
||||||
/** Transmits a given byte through the USART.
|
/** Transmits a given byte through the USART.
|
||||||
|
*
|
||||||
|
* \note If no buffer space is available in the hardware USART, this function will block. To check if
|
||||||
|
* space is available before calling this function, see \ref Serial_IsSendReady().
|
||||||
*
|
*
|
||||||
* \param[in,out] USART Pointer to the base of the USART peripheral within the device.
|
* \param[in,out] USART Pointer to the base of the USART peripheral within the device.
|
||||||
* \param[in] DataByte Byte to transmit through the USART.
|
* \param[in] DataByte Byte to transmit through the USART.
|
||||||
@ -226,7 +255,7 @@
|
|||||||
static inline void Serial_SendByte(USART_t* const USART,
|
static inline void Serial_SendByte(USART_t* const USART,
|
||||||
const char DataByte)
|
const char DataByte)
|
||||||
{
|
{
|
||||||
while (!(USART->STATUS & USART_DREIF_bm));
|
while (!(Serial_IsSendReady(USART));
|
||||||
USART->DATA = DataByte;
|
USART->DATA = DataByte;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user