基于FPGA的ARQ功能的实现

停止等待ARQ部分功能的实现
1.代码
头文件+接收器+发送器+测试激励

/*发送装置,首先在存储器中写入八位数据,之后将数据经过并串转换传送*/
module transmit(rst,clk,datain,ack,dataout,state,wr_add);
input rst,clk,ack;
input [7:0]datain;
output dataout;
input state;//write or read
input [2:0]wr_add;
reg [7:0]mem[7:0];
reg ack1=0,ack2=0,ack3=0;
wire state;
reg [2:0]rd_add;
wire [2:0]wr_add;
reg jishu;
reg [7:0]dataout1;
wire sign;
assign sign=( (~ack3) & ack1)? 1:0;/*检测到ack是否为1,表明是否开始存储八位数据*/
/*存储datain*/
always@(posedge clk or negedge rst)
begin
  if(~rst)
   begin
    rd_add<=0;
   end
  else 
   begin 
    if(state)//choose state 1为读 0为写
     begin
       ack1<=ack;
       ack2<=ack1;  //检测ack(边沿检测)
       ack3<=ack2;
       dataout1<=mem[rd_add];
       if(sign)      
          jishu<=1;    
      end 
    else
       begin
         mem[wr_add]<=datain;//存储数据
       end
   end
end 
/*发送*/
reg dataout;
reg [10:0]dataout_temp;//起始位1,数据位8
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值