同步时钟 必要性

`timescale 1ns/1ns

//`define clock_period 41  //系统时钟24M,所以周期为41ns

`define clock_period 8//这里因为要120M,所以8ns

module test1_tb;

reg clk100M,locked,rst_n;

reg    rst_nr1, rst_nr2;

 

         initialclk100M=1'b1;

         initiallocked=1'b1;

         always#(`clock_period/2)clk100M=~clk100M;

         initial

         repeat(10)

         begin

                   rst_n= 1'b0;

                   #(`clock_period*200);

                   rst_n= 1'b1;

                   #(`clock_period*20);       

         End

 

always @(posedge clk100M)

begin

         if(!rst_n)

                   begin

                   rst_nr1<= 1'b0;

                   rst_nr2<= 1'b0;

                   end

         else

                   begin

                   rst_nr1<= 1'b1;

                   rst_nr2<= rst_nr1;

                   end

end

assign       sys_rst_n= rst_nr2 & locked;

 

endmodule

 

 

`timescale 1ns/1ns

//`define clock_period 41  //系统时钟24M,所以周期为41ns

`define clock_period 8//这里因为要120M,所以8ns

module test1_tb;

reg clk100M,locked,rst_n;

reg [1:0]rst_nr;

 

         initialclk100M=1'b1;

         initiallocked=1'b1;

         always#(`clock_period/2)clk100M=~clk100M;

         initial

         repeat(10)

         begin

                   rst_n= 1'b0;

                   #(`clock_period*200);

                   rst_n= 1'b1;

                   #(`clock_period*20);       

         end

        

        

always @(posedge clk100M)

begin

         if(!rst_n)

                   rst_nr<=0;

         else

                   rst_nr={rst_nr[0],1'b1};

end

assign       sys_rst_n= rst_nr[1] & locked;      

 

endmodule

 

 

 

异步时钟同步化:

这里模拟的是刚好在clk100M上升沿来一个复位信号,实际中肯定没有这么走运,复位时钟是随机的,因此需要在复位信号产生的后一个时钟上升沿把复位信号传出去,这样复位信号就与时钟同步。

 

以上两种方法都验证可靠,第一种较容易理解,第二种简单,常用

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值