题解 | #多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
全部评论

相关推荐

不愿透露姓名的神秘牛友
05-28 11:22
点赞 评论 收藏
分享
努力的小明a:项目看着很眼熟,施磊老师吧,我也学的这个😋我当时是把rpc框架做成了一个分布式网盘,这是一个项目,然后muduo库做成集群即时通讯,又用QT做了个交互的客户端,这样又一个项目,然后一个轻量redis,一个CAD,总共四个项目,投了三个月就今天2月份一个小厂Qt offer,然后后面想开了,Qt啥的都能干,这个月get了个北京大厂的offer,做java后端,人生就是这么魔幻,现在就在去北京入职的路上
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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