- 1、本文档共7页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
FPGA模拟串口自收发-Verilog
实现功能,FPGA里实现从PC串口接收数据,接着把接收到的数据发回去。波特率可选9600bps,可调 1bit起始位,8bit数据,1bit停止位,无校验位。
参考《VHDL硬件描述语言与和数字逻辑电路设计》
模块介绍如下
一、串口数据接收模块:特别注意一个数据位占4个clk_bps_4时钟周期。
串口数据接收控制
当数据接收端rxd出现起始位低电平,启动接收控制计数器rx_cnt,置位为8’b0111_00(28),
即rx_cnt[5:2]== 4’b0111(7),rx_cnt[1:0] == 2b00(0);一个计数周期开始,伴随clk_bps_4, rx_cnt加1(每一个数据位加4)
串口接收数据移位控制(关键采样点的选取)
每当rx_cnt[1:0] == 2b01,为了保证在rxd一位数据靠近中间位置采样;每4个clk_bps_4, rx_cnt[5:2]加1当rx_cnt[5:2] == 8,9,10….15,完成8位的数据采样,串并变换
置位标志位rxdF数据接收标志
rxd出现起始位低电平, rxdF置1,表示数据接收开始;当rx_cnt计数到8’b1111_11(63),数据接收完成, rxdF置0
置位标志位rdFULL;//接收锁存器满标志
空闲时rdFULL置0,当数据接收完成,数据锁存到do_latch,同时 rdFULL置1,向上层模块表示数据以准备OK,可以来读取;rd置0,表示上层模块开始读取数据,rdFULL置0,表示数据已读走
二、串口数据发送模块:数据发送依赖于wr(低电平有效)
空闲时wr置1,数据发送时wr产生低电平脉冲,wr上升沿将数据锁存到din_latch;
串口数据发送控制:
wr由0跳变为1后,启动发送控制计数器tx_cnt,置位为8’b0111_00(28),
即tx_cnt[5:2]== 4’b0111(7), tx_cnt[1:0] == 2b00(0);一个计数周期开始,伴随clk_bps_4, tx_cnt加1(每一个数据位加4)
串口发送数据移位控制
每4个clk_bps_4, tx_cnt[5:2]加1当tx_cnt[5:2] ==7,8,9,10….15,完成一位起始位,8位的数据位发送,随后txd置1(停止位),完成并串转换
置位标志位txdF,tdEMPTY //发送完成标志
当写数据到发送寄存器din_latch时,txdF,tdEMPTY置0; 当tx_cnt计数到8’b1111_11(63),数据发送完成,txdF,tdEMPTY置1;
三、串口数据自收发控制模块
当rdFULL == 1 tdEMPTY == 1(rdFULL == 1表示数据准备OK,tdEMPTY == 1表示上次发送已完成) ,rd,wr产生低脉冲,rd置0,数据读取到DATA,wr置0使能发送数据控制,低脉冲将DATA锁存到din_latch
四、波特率发生模块:
针对9600bps,生成4倍于波特率38.4KHz的时钟信号,用于采样
代码如下:串口数据自收发控制模块
module UART(clk, rst_n, rxd, txd, LED1 );
input clk; //时钟周期50MHz
input rst_n; //低电平复位
input rxd; //串口引脚输入--接收--PC
output txd; //串口引脚输出--发送--PC
output reg LED1;//lED测试用
/****************************************/
wire tdEMPTY;//发送寄存器空标志
reg wr;//发送使能信号
reg [7:0]DATA;
wire clk_bps_4;//4倍于波特率时钟信号
reg[1:0] wr_cnt;//wr低电平计数
reg rd;//读接收锁存器信号
wire[7:0] do_latch;//接收数据锁存
wire rdFULL;//接收锁存器满标志
reg[1:0] rd_cnt;//rd低电平计数
/*当rdFULL == 1 tdEMPTY == 1(rdFULL == 1表示接收锁锁存器数据准备OK,tdEMPTY == 1表示上次发送已完成),
rd,wr产生低脉冲,rd置0,do_latch数据读取到DATA,wr置0用于使能发送数据控制,低脉冲将DATA锁存到din_latch*/
always@(posedge clk_bps_4 or negedge rst_n)
begin
if(!rst_n)
begin
rd = 1;
wr = 1;
wr_cnt = 0;
rd_cnt = 0
您可能关注的文档
- E+H雷达液位计现场调试及运用.doc
- D江水利枢纽毕业设计.doc
- e-learning平台建设方案.docx
- eaoron:避开涂眼霜的3大误区,不然你的眼霜就浪费了.docx
- EBER检测试剂盒(原位杂交).doc
- EB-5投资移民 主申请人有变动应如何处理.doc
- ECharts 中的事 件和行为.doc
- EDA简易洗衣机设计.doc
- EDA设计实验_序列检测器.doc
- EDTA测定水的硬度.doc
- 2024-2025学年高一上学期期末模拟政治试卷(四)(解析版).docx
- 四川省安宁河高中振兴联盟2024-2025学年高二上学期11月期中考试语文试题(解析版).docx
- 山东省名校考试联盟2024-2025学年高一上学期11月期中考试语文试题(解析版).docx
- 福建省泉州市四校联盟2024-2025学年高二上学期11月期中联考政治试题(解析版).docx
- 广东省部分学校2024-2025学年高二上学期期中联考政治试题(解析版).docx
- 2024-2025学年高二上学期期末模拟政治试卷(三)(解析版).docx
- 湖北省部分高中联考协作体2024-2025学年高一上学期期中联考政治试题(解析版).docx
- 黑龙江省牡丹江市部分学校2024-2025学年高三上学期期中考试政治试题(解析版).docx
- 北京市2024-2025学年高二上学期期末模拟政治试卷(解析版).docx
- 广东省茂名市电白区2024-2025学年高一上学期期中考试政治试卷(解析版).docx
文档评论(0)