题解 | #RAM的简单实现#

RAM的简单实现

https://www.nowcoder.com/practice/2c17c36120d0425289cfac0855c28796

`timescale 1ns/1ns
module ram_mod(
	input clk,
	input rst_n,
	
	input write_en,
	input [7:0]write_addr,
	input [3:0]write_data,
	
	input read_en,
	input [7:0]read_addr,
	output reg [3:0]read_data
);

parameter ram_num = $pow(2,7);
reg [3:0] buff[0 : ram_num-1];
always@(posedge clk or negedge rst_n)  begin
	if(write_en)
		buff[write_addr] <= write_data;
	else
		buff[write_addr] <= 'd0;
end

always @(posedge clk or negedge rst_n)  begin
	if(!rst_n)
		read_data <= 'd0;
	else if(read_en)
		read_data <= buff[read_addr];
end	
endmodule

全部评论

相关推荐

牛客刘北:如果暑期实习是27届的话,你要晚一年才会毕业,企业为什么会等你呢?要搞清时间逻辑呀!27届现在实习只能是在暑假实习,这是日常实习,不是暑期实习。所以多去投日常实习吧,暑期实习肯定不会要你的
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-11 15:37
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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