题解 | #多bit MUX同步器#

多bit MUX同步器

http://www.nowcoder.com/practice/30e355a04a454e16811112cb82af591e

用计数器来做 当data_en=1时开始计数,当计数3次时,将输入数据data_in在clk_a时钟域内传递给临时存储器data,然后再clk_b的时钟域内将临时存储器data的值传递给输出dataout

`timescale 1ns/1ns

module mux(
	input 				clk_a	, 
	input 				clk_b	,   
	input 				arstn	,
	input				brstn   ,
	input		[3:0]	data_in	,
	input               data_en ,

	output reg  [3:0] 	dataout
);
    reg [2:0] cnt;
    reg [3:0] data;
    
    always@(posedge clk_b or negedge brstn)
        if(!brstn) cnt<=0;
        else if(data_en) 
            begin
                if(cnt==2) cnt<=0;
                else cnt<=cnt+1;
            end
        else cnt<=0;
    
    always@(posedge clk_a or negedge arstn)
        if(!arstn) data<=0;
    else if(cnt==2 && data_en) 
            begin
               data<=data_in;
            end
        else data<=data;
    
        always@(posedge clk_b or negedge brstn)
        if(!brstn) dataout<=0;
        else dataout<=data;
endmodule
全部评论

相关推荐

不愿透露姓名的神秘牛友
07-03 16:22
点赞 评论 收藏
分享
07-03 16:02
门头沟学院 Java
今天面试,非常紧张,面试官问我springboot有哪些核心模块都答不上来了,真的对自己无语了!
程序员小白条:28届我勒个去,很多人面试都没机会
查看1道真题和解析
点赞 评论 收藏
分享
废物一个0offer:认真的吗二本本科找人工智能岗位
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-01 13:54
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务