UART串口通讯

先简单说说串口通信(UART),我做的这个实验只针对RS232标准,在fpga与上位机给出的rs232口之间通过电平转换电路(最上面图中的Max232芯片) 实现TTL电平与RS232电平之间的转换。

UART串口通讯_第1张图片

UART串口通讯_第2张图片

我们只关心RS232_TX和RS232_RX两个信号,RS232_TX是数据发送端口,RS232-RX是数据接受端口,简单的串口帧格式如图所示。

UART串口通讯_第3张图片

帧格式为:1bit起始位,8bit数据,无校验位,1bit停止位。

fpga实时检测RS232_RX是否有数据,如果收到数据,则把接收到的数据通过RS232_TX发回给对方。上位机用的是串口调试助手。

代码设计中,我们设置波特率可以选择,9600bps,19200bps.....,115200bps,这部分代码由speed_select来选择。

RTL如下图所示:

UART串口通讯_第4张图片

my_uart模块主要是完成数据的接收,speed_select模块主要响应my_uart_rx模块发出的使能信号进行波特率计数,并且回送一个采样使能信号,my_uart_tx模块在my_uart_rx模块接收好一个完整的数据帧后启动,将收到的数据返回给对方,my_uart_tx的波特率控制是由speed_select(speed_tx)模块产生的。

代码链接:https://download.csdn.net/download/dongdongnihao_/10625649

你可能感兴趣的:(FPGA)