ram存储器的简单实现

1.单端口ram

读使能有效,输出数据,否则为高阻。

module ram(clk,wr_en,rd_en,addr,data);
	input clk;
	input wr_en,rd_en;
	
	inout [7:0] data;
	
	reg [7:0] mem [15:0] ;
	reg [7:0] temp;
	
	assign data = rd_en?temp:8'bz;
always @(posedge clk)begin
	if(rd_en)
		temp<=mem[addr];
	else if(wr_en)
		mem[addr]<= data;
	else 
		temp <= 8'bz;
end
endmodule 
2.双端口ram

与单端口ram相比,双端口的输入、输出数据总线是分开的,有时钟控制,且为同步控制。其有单独的读控制信号和读地址、写控制信号和写地址。

`define WIDTH 8
`define DEPTH 16
`define ADDR_SIZE 4

module double_ram(clk,rst_n,rd_en,wr_en,rdaddr,wraddr,data_in,data_out);
	input clk,rst_n;
	input rd_en,wr_en;
	input [`ADDR_SIZE-1:0] rdaddr,wraddr;
	input [`WIDTH-1:0] data_in;
	
	reg [`WIDTH-1:0]mem[`DEPTH-1:0];
	output [`WIDTH-1:0] data_out;
	reg [`WIDTH-1:0] data_out;
	

always @(posedge clk or negedge rst_n)begin
	if(rst_n)
		data_out<=0;
	else if(rd_en)
		data_out <= mem[rdaddr];
	else if(wr_en)
		mem[wraddr] <= data_in;	
end
endmodule

以上是简单的ram,对其读写地址没有控制。

下边介绍一下同步fifo的实现

3.同步fifo

fifo是一中先进先出的数据缓存器,他与普通存储器的区别是没有外部读写地址线,这样使用起来非常简单,但缺点就是只能顺序写入数据,和顺序读出数据,其数据地址由内部读写指针自动加1完成。不像上边的ram要指定读写地址。

其主要分为基于移位寄存器型和基于ram型,而ram型的又有单端口ram和双端口ram之分,目前基于双端口ram的fifo较为广泛。

fifo的原理就是对双端口ram进行操作。

module sfifo(clk,rst_n,rd_en,wr_en,data_in,data_out,empty,full);
	input clk,rst_n;
	input rd_en,wr_en;
	
	input [7:0] data_in;
	
	output [7:0] data_out;
	
	output empty,full;
	
	reg [7:0] data_out;
	reg [7:0]mem[15:0] ;
	reg [3:0] cnt;
	
assign empyt = (cnt==0)?1'b1:1'b0;
assign full = (cnt==15)?1'b1:1'b0;
	
always@(posedge clk or negedge rst_n)begin
	if(~rst_n)begin
		wrptr<=0;
		rdptr<=0;
	end
	else if(rd_en)
		rdptr <= rdptr+1'b1;
	else if(wr_en)
		wrptr <= rdptr+1'b1;
end

always@(posedge clk or negedge rst_n)begin
	if(~rst_n)
		cnt <= 4'b0;
	else if(rd_en)
		cnt <= cnt -1'b0;
	else if(wr_en)
		cnt <= cnt +1'b1;
end

always @(posedge clk or posedge rst_n)begin
	if(~rst_n)
		data_out < = 0;
	else if(wr_en)
		mem[wrptr] <= data_in;
	else if(rd_en)
		data_out <=  mem[rdptr];
	else 
		data_out <= data_out;
end
endmodule




  • 3
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【实验题目】 在RAM中执行程序代码 【实验目的】 掌握片外RAM扩展方法(重点是硬件接法,而程序操作很简单)。 弄清楚什么是“哈佛存储结构”和“冯·诺依曼存储结构”。 【硬件接法】 P1.2接交流蜂鸣器。 请认真参考硬件电路图中RAM的接法。RAM映射到地址“0x8000~0xBFFF”,共16KB。 【实验原理】 8051单片机本来是“哈佛存储结构”,程序ROM和片外数据RAM位于完全分开的存储空间。/WR和/RD信号用于访问片外数据RAM。当使用片外程序ROM时,/PSEN管脚负责读取程序代码或固定数表。通常ROM不可写,所以未安排ROM的写信号。ROM和RAM共用地址和数据总线,但读写选通信号是分开的,所以在逻辑上分属两个不同的64KB空间,总共128KB。另外片内数据RAM和SFR空间又与前两者有别,是独立编址的。在软件上,访问不同的存储空间采用不同的指令,如“MOVX A,@DPTR”、“MOVC A,@A+DPTR”、“MOV A,@Ri”等。 注意,/PSEN和/RD可以经过“与门”后再接到RAM的/OE。这样,代码和数据都位于相同的地址空间,在RAM中也可以跑程序,用“MOVC”和“MOVX”指令都能访问RAM的存储单元。如果把程序代码加载到片外RAM中,然后用“LJMP”指令跳转过去就能在RAM中执行程序代码。 【说明:片内Flash中的引导程序】 这是一个比较复杂的程序,其中还牵涉到了C51中嵌入汇编的用法。对大多数初学者来说,只要了解其工作过程即可,不必深究。如果您确实对其感兴趣,请自行仔细研究。 该引导程序位于片内Flash中,其作用是通过串行口加载HEX格式的程序文件,并自动转换成BIN格式,然后保存到片外RAM中,最后跳转过去执行。RAM起始地址为0x8000。引导完毕后,蜂鸣器鸣叫,并等待按下K4键。K4按下后,才开始执行。 【说明:在片外RAM中运行的程序】 编写在片外RAM中运行的程序与编写正常的A51或C51程序基本相同,但是需要做一些小的调整。正常的程序起始地址总是0x0000,但现在片外RAM的起始地址是0x8000,因此要在原有程序的基础上重新设置起始地址。 对于A51编程,找到ORG命令,修改复位地址和全部中断向量入口地址,使它们都偏移0x8000。例如复位地址为0x0000要改成0x8000,定时器T0中断入口地址0x000B要改成0x800B,等等。重新编译,生成HEX程序文件,备用。 而对于C51编程,设置的项目稍多一些,步骤如下: 第一,打开Keil C51安装目录“C:\Keil\C51\LIB”,找到文件“STARTUP.A51”,将其复制到您的工程文件夹下,然后右击项目管理窗口的“Source Group1”添加该文件。另一种方法是:在新建工程选择“CPU”后,当出现是否添加启动文件对话框时选择“是”,则文件“STARTUP.A51”会自动被加入。 第二,双击项目管理窗口里的“STARTUP.A51”,找到“CSEG AT 0”这一行,将起始地址“0”改成“0x8000”,保存。 第三,设置片外程序ROM的起始地址和大小。打开编译环境中设置(点击工具栏的那个绿色按钮进入该设置),在“Off-chip Code memory”Eprom(在这里,Eprom实际上已被RAM代替)栏第一行填入0x8000和0x3000(共12KB空间)。 第四,程序中有可能用到xdata数据,因此还要设置片外数据RAM的起始地址和大小。可以在“Off-chip Xdata memory”Ram栏第一行填入0xB000和0x1000,留足空间(有4KB呀!)。 第五,设置中断向量。打开“Options fo Target”设置里的“C51”选项页,找到“Interrupt vectors at...”项,修改为“0x8000”。 OK,所有设置都已完成,重新编译,生成HEX程序文件,备用。 【实验步骤】 1、ISP下载开关扳到“01”,用Flash Magic软件下载程序文件“HexLoader.hex”,暂时不要运行。 2、打开串行调试助手软件ZLGCOMView,操作如下: 勾中“HEX发送”(非常重要!); 通信口:选择实际的串行口(通常为COM1); 波特率:4800; 数据位:8; 停止位:1; 点击“打开文件”装入文件夹“在片外RAM中运行的程序”下的一个程序文件(HEX格式),在这些程序中,所有起始地址都已经预先设置好了; 按实验箱上单片机的RST键,会看到显示“Ready”; 点击“发送文件”,程序开始下载到片外RAM; 下载完毕,出现“OK, press K4...”,蜂鸣器同时鸣叫; 按一次实验箱上的K4键,程

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值