题解 | #同步FIFO#

同步FIFO

https://www.nowcoder.com/practice/e5e86054a0ce4355b9dfc08238f25f5f

`timescale 1ns/1ns

/**********************************RAM************************************/
module dual_port_RAM #(parameter DEPTH = 16,
					   parameter WIDTH = 8)(
	 input wclk
	,input wenc
	,input [$clog2(DEPTH)-1:0] waddr  
	,input [WIDTH-1:0] wdata      	
	,input rclk
	,input renc
	,input [$clog2(DEPTH)-1:0] raddr  
	,output reg [WIDTH-1:0] rdata 		
);

reg [WIDTH-1:0] RAM_MEM [0:DEPTH-1];

always @(posedge wclk) begin
	if(wenc)
		RAM_MEM[waddr] <= wdata;
end 

always @(posedge rclk) begin
	if(renc)
		rdata <= RAM_MEM[raddr];
end 

endmodule  

/**********************************SFIFO************************************/
module sfifo#(
	parameter	WIDTH = 8,
	parameter 	DEPTH = 16
)(
	input 					clk		, 
	input 					rst_n	,
	input 					winc	,
	input 			 		rinc	,
	input 		[WIDTH-1:0]	wdata	,

	output reg				wfull	,
	output reg				rempty	,
	output wire [WIDTH-1:0]	rdata
);

wire	wenc,renc	;
reg	[$clog2(DEPTH):0]	waddr,raddr	;

assign	wenc = winc & !wfull;
assign	renc = rinc & !rempty;

always@(posedge clk or negedge rst_n)
    if(!rst_n)
        waddr   <=  0;
    else    if(wenc)
        waddr   <=  waddr + 1;
    else
        waddr   <=  waddr;

always@(posedge clk or negedge rst_n)
    if(!rst_n)
        raddr   <=  0;
    else    if(renc)
        raddr   <=  raddr + 1;
    else
        raddr   <=  raddr;

always@(posedge clk or negedge rst_n)
    if(!rst_n)
        wfull   <=  1'b0;
    else    if (waddr == {!raddr[$clog2(DEPTH)],raddr[$clog2(DEPTH)-1:0]})
        wfull   <=  1'b1;
    else
        wfull   <=  1'b0;

always@(posedge clk or negedge rst_n)
    if(!rst_n)
        rempty  <=  1'b0;
    else    if(raddr == waddr )
        rempty  <=  1'b1;
    else
        rempty  <=  1'b0;

dual_port_RAM 
#(
    .DEPTH(16),
    .WIDTH(8 )
)
u0
(
	. wclk(clk),
	. wenc(wenc),
	. waddr(waddr[$clog2(DEPTH)-1:0]),  
	. wdata(wdata),     	
	. rclk(clk),
	. renc(renc),
	. raddr(raddr[$clog2(DEPTH)-1:0]), 
	. rdata(rdata) 		
);

endmodule

全部评论

相关推荐

不愿透露姓名的神秘牛友
11-24 20:55
阿里国际 Java工程师 2.7k*16.0
程序员猪皮:没有超过3k的,不太好选。春招再看看
点赞 评论 收藏
分享
感性的干饭人在线蹲牛友:🐮 应该是在嘉定这边叭,禾赛大楼挺好看的
点赞 评论 收藏
分享
Noob1024:一笔传三代,人走笔还在
点赞 评论 收藏
分享
评论
点赞
收藏
分享
正在热议
# 25届秋招总结 #
439565次浏览 4481人参与
# 春招别灰心,我们一人来一句鼓励 #
41297次浏览 523人参与
# 阿里云管培生offer #
119522次浏览 2219人参与
# 地方国企笔面经互助 #
7904次浏览 18人参与
# 虾皮求职进展汇总 #
113037次浏览 878人参与
# 实习,投递多份简历没人回复怎么办 #
2453508次浏览 34845人参与
# 北方华创开奖 #
107186次浏览 598人参与
# 实习必须要去大厂吗? #
55545次浏览 959人参与
# 同bg的你秋招战况如何? #
74881次浏览 544人参与
# 提前批简历挂麻了怎么办 #
149742次浏览 1975人参与
# 投递实习岗位前的准备 #
1195546次浏览 18545人参与
# 你投递的公司有几家约面了? #
33162次浏览 188人参与
# 双非本科求职如何逆袭 #
661700次浏览 7392人参与
# 机械人春招想让哪家公司来捞你? #
157576次浏览 2267人参与
# 如果公司给你放一天假,你会怎么度过? #
4705次浏览 53人参与
# 如果你有一天可以担任公司的CEO,你会做哪三件事? #
11170次浏览 252人参与
# 发工资后,你做的第一件事是什么 #
12320次浏览 60人参与
# 工作中,努力重要还是选择重要? #
35479次浏览 384人参与
# 参加完秋招的机械人,还参加春招吗? #
20062次浏览 240人参与
# 实习想申请秋招offer,能不能argue薪资 #
39188次浏览 314人参与
# 我的上岸简历长这样 #
451841次浏览 8086人参与
# 非技术岗是怎么找实习的 #
155825次浏览 2120人参与
牛客网
牛客企业服务