• 方案介绍
  • 附件下载
  • 相关推荐
申请入驻 产业图谱

一种数据通信系统设计Verilog代码Quartus仿真

07/03 16:07
532
加入交流群
扫码加入
获取工程师必备礼包
参与热点资讯讨论

2-24011G04200221.doc

共1个文件

名称:一种数据通信系统设计Verilog代码Quartus仿真

软件:Quartus

语言:Verilog

代码功能:

QQ图片20240117103925.png

要求:系统为同步设计。TX模块通过串行通道向RX模块发送串行数据,串行数据中包含有效数据和无效数据,串行通道仅有1位时钟和1位数据,RX应正确接收TX发来的有效数据,不接收无效数据。自定义标记有效数据和无效数据的方法。

FPGA代码Verilog/VHDL代码资源下载:www.hdlcode.com

演示视频:

设计文档:

1. 发送端代码文件

2. 接收端代码文件

3. 发送端testbench

4. 接收端testbench

5. 仿真图

发送端仿真

发送接收仿真

部分代码展示:

//发送端
module source(
    input      sys_clk,                  //系统时钟
    input         sys_rst_n,                //系统复位,低电平有效
    input         TS_en,                    //发送使能信号
    input  [7:0]  TS_data,                 //待发送数据
output  reg   clock,                   //串行通道发送时钟
    output  reg   data                     //串行通道发送端口
    );
    
//parameter define
parameter  CLK_FREQ = 50000000;             //系统时钟频率
parameter  BPS = 115200;                 //波特率
localparam BPS_CNT  = CLK_FREQ/BPS;    //为得到指定波特率,对系统时钟计数BPS_CNT次
//reg define
reg        TS_en_d0; 
reg        TS_en_d1;  
reg [15:0] clk_cnt;                         //系统时钟计数器
reg [ 3:0] tx_cnt;                          //发送数据计数器
reg        tx_flag;                         //发送过程标志信号
reg [ 7:0] tx_data;                         //寄存发送数据
//wire define
wire       en_flag;
//*****************************************************
//**                    main code
//*****************************************************                                         
//对发送使能信号TS_en延迟两个时钟周期
always @(posedge sys_clk or negedge sys_rst_n) begin         
    if (!sys_rst_n) begin
        TS_en_d0 <= 1'b0;                                  
        TS_en_d1 <= 1'b0;
    end                                                      
    else begin                                               
        TS_en_d0 <= TS_en;                               
        TS_en_d1 <= TS_en_d0;                            
    end
end
//捕获TS_en上升沿,得到一个时钟周期的脉冲信号
assign en_flag = (~TS_en_d1) & TS_en_d0;
//当脉冲信号en_flag到达时,寄存待发送的数据,并进入发送过程          
always @(posedge sys_clk or negedge sys_rst_n) begin         
    if (!sys_rst_n) begin                                  
        tx_flag <= 1'b0;
        tx_data <= 8'd0;
    end 
    else if (en_flag) begin                 //检测到发送使能上升沿                      
            tx_flag <= 1'b1;                //进入发送过程,标志位tx_flag拉高
            tx_data <= TS_data;            //寄存待发送的数据
        end
        else 
        if ((tx_cnt == 4'd9)&&(clk_cnt == BPS_CNT/2))
        begin                               //计数到停止位中间时,停止发送过程
            tx_flag <= 1'b0;                //发送过程结束,标志位tx_flag拉低
            tx_data <= 8'd0;
        end
        else begin
            tx_flag <= tx_flag;
            tx_data <= tx_data;
        end 
end
//进入发送过程后,启动系统时钟计数器与发送数据计数器
always @(posedge sys_clk or negedge sys_rst_n) begin         
    if (!sys_rst_n) begin                             
        clk_cnt <= 16'd0;                                  
        tx_cnt  <= 4'd0;
    end                                                      
    else if (tx_flag) begin                 //处于发送过程
        if (clk_cnt < BPS_CNT - 1) begin
            clk_cnt <= clk_cnt + 1'b1;
            tx_cnt  <= tx_cnt;
        end
        else begin
            clk_cnt <= 16'd0;               //对系统时钟计数达一个波特率周期后清零
            tx_cnt  <= tx_cnt + 1'b1;       //此时发送数据计数器加1
        end
    end
    else begin                              //发送过程结束
        clk_cnt <= 16'd0;
        tx_cnt  <= 4'd0;
    end
end
//根据clk_cnt计数器控制输出串行通道发送时钟
always @(posedge sys_clk or negedge sys_rst_n)  
if (!sys_rst_n)   
clock<=0;
else if (clk_cnt > BPS_CNT/2) 
clock<=1;//高电平
else
clock<=0;//低电平

点击链接获取代码文件:http://www.hdlcode.com/index.php?m=home&c=View&a=index&aid=588

  • 2-24011G04200221.doc
    下载

相关推荐