文章目录
前言
一、UART简介
1、基本概念
2、UART协议
3、波特率简介
二、UART串口回环实验
1、设计思路
2、程序代码
① 串口接收模块
② 串口发送模块
③ 串口顶层模块
④ 串口仿真模块
3、仿真验证
总结
前言
在我们进行FPGA设计时,常常会用到一些数据通信接口,这些通信接口都是有着特定的功能以及协议的,其中最常见的莫过于串口uart了,它对于每一个做硬件和嵌入式软件的人来说,几乎就是一个必备的工具,用来调试一个带MCU或者CPU的系统。
串口uart是一种非常通用的设备接口,可以实现不同硬件间的通信,对于FPGA开发来说,串口也同样可以实现FPGA开发板与电脑PC端的通信,下面我们就来简单介绍一下串口uart的基本协议及功能。
一、UART简介
1、基本概念
通用异步收发传输器,英文全称为Universal Asynchronous Receiver/Transmitter,简称UART,是一种异步收发传输器,在发送数据通过将并行数据转换成串行数据进行传输,在接收数据时将串行数据转换成并行数据。
串行通信分为同步串行通信和异步串行通信。同步串行通信即需要时钟的参与,通信双方需要在同一时钟的控制下,同步传输数据;异步串行通信则不需要时钟的干预,通信双方使用各种的时钟来控制数据的发送和接收。uart属于异步串行通信,即没有时钟信号来同步或验证从发送器发送并由接收器接收的数据,这就要求发送器和接收器必须事先就时序参数达成一致。
UART是通用异步收发器的简称,它包括了RS232、RS422、RS423、RS449以及RS485等接口标准和总线规范标准,UART是异步串行通信接口的总称。而RS323、RS422、RS423、RS449和RS485等是对应各种异步串行通信的接口标准和总线标准,它规定了通信接口的电器特性、传输速率以及接口的机械特性等内容。
2、UART协议
UART串口通信需要两根信号线来实现,一根用于串口发送数据,一根用于串口接收数据。UART串口传输的数据被组织成数据包,每个数据包包含了一个起始位,5至9个数据位,可选的奇偶校验位和1或者2个停止位,如下图所示。
UART串口协议规定,当总线处于空闲状态时信号线的状态为高电平,表示当前线路上没有数据传输。
起始位:开始进行数据传输时发送方要先发送一个低电平来表示传输字符的开始。
数据位:起始位之后就需要传输数据,数据位可以是5~9位,构成一个字符,一般是8位,先发送最低位后发送最高位。
奇偶校验位:奇偶校验位是用来检验数据在传输过程中是否出错。在奇校验时,发送方应使数据位中1的个数与校验位中1的个数为奇数,接收方在接收数据时,对1的个数进行检测,若1的个数不为奇数个,则说明数据在传输过程中存在差错。偶校验则相反。
停止位:数据结束标志,可以是1位或者2位的高电平。由于数据在传输线上是定时传输的,并且每一个设备有自己的时钟,很可能在通信中两台设备之间出现了小小的不同步,因此停止位不仅仅是表示数据传输的结束,并且提供计算机校正时钟的机会。停止位越多,数据传输月稳定,但是数据传输速度越慢。
3、波特率简介
在电子通信领域,波特(Baud)即调制速率,指的是有效数据讯号调制载波的速率,即单位时间内载波调制状态变化的次数。
波特率表示每秒钟传送码元符号的个数,它是对符号传输速率的一种度量,用单位时间内载波调制状态改变的次数来表示,1波特指每秒传输1个字符。
数据传输速率使用波特率来表示,单位bps(bits per second),常见的波特率有9600、19200、38400、57600、115200等。例如将串口波特率设置位115200bps,那么传输一个bit需要的时间是1/115200 ≈ 8.68us。
二、UART串口回环实验
1、设计思路
实验任务:通过电脑端的串口调试助手向FPGA发送数据,FPGA通过串口接收数据并将接受到的数据发送给上位机,实现串口回环功能。
接收模块(RX):通过检测起始位来表示数据传输的开始,在波特率中间时刻去采样总线上的数据,最后将数据进行串并转换。
发送模块(TX):将并行数据转换成串行数据,然后在串行数据帧头加上起始位,帧尾加上停止位,发送给上位机。
2、程序代码
本次程序设计中没有用到奇偶校验位,一帧数据为8bit,停止位为1位,波特率可供选择(代码为115200),FPGA的系统晶振时钟为50MHZ。
① 串口接收模块
/*===============================* filename : uart_rx.v description : 串口接收模块 time : 2022-12-22 author : 卡夫卡与海 *================================*/ module uart_rx( input clk ,//时钟 50MHZ input rst_n ,//复位 input uart_rx ,//rx数据线 input [2:0] baud_sel ,//波特率选择 output reg [7:0] po_data ,//接收的数据 output reg po_flag //数据使能 ); //参数定义 parameter SCLK = 50_000_000;//系统时钟 50MHZ //波特率选择 parameter BAUD_9600 = SCLK/9600 , BAUD_19200 = SCLK/19200 , BAUD_38400 = SCLK/38400 , BAUD_57600 = SCLK/57600 , BAUD_115200 = SCLK/115200; //信号定义 reg uart_rx_1 ;//同步、打拍 reg uart_rx_2 ; wire rx_nedge ;//下降沿检测 reg start_flag ;//起始标志 reg work_en ;//工作使能 reg [15:0] cnt_baud ;//波特率计数器 reg [15:0] BAUD_NUM ; reg bit_flag ;//接收数据使能 reg [3:0] cnt_bit ;//bit计数器 reg [7:0] rx_data ;//数据 reg rx_flag ;//数据标志 //同步、打拍 检测下降沿 always @(posedge clk or negedge rst_n)begin if(!rst_n)begin uart_rx_1