打印

Verilog实现serial到serial数据转换

[复制链接]
1410|0
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
lxAPP|  楼主 | 2012-10-8 22:18 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
serial到serial的转并没有太大的实际意义,实际上相当于将数据延迟输入。以下是serial到serial转换的代码:
module  s2s(clk,rstn,si,so);
  input  clk;
  input  rstn;
  input  si;
  output so;
  
  reg[8:0] r;
  
  
always@(posedge clk or negedge rstn)
     if(!rstn)
        r  <= 9'h0;
     else
        r  <= {r,si};
  assign  so  = r[8];   // 这里相当于将数据如数据延时8个时钟后,遇到时钟上升沿时,将数据输出
endmodule

testbench 内容如下
module s2s_tb;
  reg clk;
  reg rstn;
  reg si;
  wire so;
  s2s  ut  (clk,rstn ,si,so);
  initial clk = 0;
  always #5 clk = ~clk;
  initial begin
     rstn  = 0;
     #5;
     rstn  = 1;
  end
  initial begin
     si  = 0 ;
     #10;
     si  = 1 ;
     #10;
     si  = 0;
     #10;
     si  = 1;
     #10;
     si  = 1;
     #10;
     si  = 0;
  end
endmodule

相关帖子

发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

58

主题

483

帖子

2

粉丝