题解 | #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
);

reg [3:0] ram [0:7];
integer i;

always@(posedge clk,negedge rst_n)
    begin
        if(rst_n==1'b0) begin
            for(i=0;i<=7;i=i+1)
                ram[i] <= 0;
        end
        else if(write_en == 1'b1) ram[write_addr] <= write_data;
    end


always@(*)
    begin
        if(rst_n==1'b0) begin
			read_data = 4'd0;
        end
		else if(read_en == 1'b1)  read_data = ram[read_addr];
    end
	
endmodule

全部评论

相关推荐

头像 会员标识
08-20 18:46
门头沟学院 C++
投递华为技术有限公司等公司10个岗位
点赞 评论 收藏
分享
Sigma429:极兔啊,薪资开的巨低,还在上海,索性不做笔试了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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