GD32VF103 User Manual
332
the transmission is ongoing.
After power on, the TBE bit is high by default. Data can be written to the USART_DATA when
the TBE bit of the USART_STAT register is asserted. The TBE bit is cleared by writing to the
USART_DATA register and it is set by hardware after the data is put into the transmit shift
register. If a data is written to the USART_DATA register while a transmission is ongoing, it
will be firstly stored in the transmit buffer, and transferred to the transmit shift register after
the current transmission is done. If a data is written to the USART_DATA register while no
transmission is ongoing, the TBE bit will be cleared and set soon, because the data will be
transferred to the transmit shift register immediately.
If a frame is transmitted and the TBE bit is asserted, the TC bit of the USART_STAT register
will be set. An interrupt will be generated if the corresponding interrupt enable bit (TCIE) is
set in the USART_CTL0 register.
The USART transmit procedure is shown in
Figure 16-3. USART transmit procedure
. The
software operating process is as follows:
1. Write the WL bit in USART_CTL0 to set the data bits length.
2. Set the STB[1:0] bits in USART_CTL1 to configure the number of stop bits.
3. Enable DMA (DENT bit) in USART_CTL2 if multibuffer communication is selected.
4. Set the baud rate in USART_BAUD.
5. Set the TEN bit in USART_CTL0.
6. Set the UEN bit in USART_CTL0 to enable the USART
7. Wait for the TBE to be asserted.
8. Write the data to the USART_DATA register.
9. Repeat step7-8 for each data, if DMA is not enabled.
10. Wait until TC=1 to finish.
Figure 16-3. USART transmit procedure
Write data0 to
USART_DATA by
DMA or software
set by hardware
Write data1 to
USART_DATA by
DMA or software
Write data2 to
USART_DATA by
DMA or software
set by hardware
set by hardware
USART_DAT
A
TBE
TEN
TX pin
idle frame
frame0
frame1
frame2
data0
data1
data2
set by hardware
cleared by
software
TC
It is necessary to wait for the TC bit to be asserted before disabling the USART or entering
the power saving mode. This bit can be cleared by a software sequence: reading the
USART_STAT register and then writing the USART_DATA register. If the multibuffer
communication is selected (DENT=1), this bit can also be cleared by writing 0 directly.