七夜浮生

FPGA 内部双口块RAM 读写实现

2
阅读(5754)

FPGA 内部块RAM 的读时序如下图:

blob.png

   可知,块RAM的读延时为两个时钟周期。

FPGA 内部块RAM 的写时序如下图:

blob.png

 可知,块RAM 的写延时为0,但是RAM 中的内容是在写的下一个时钟改变。

ISE下实现对FPGA内部块RAM 的读写代码:

1.   module TOP(  

2.   input USER_CLK  

3.       );  

4.     

5.   `define DLY #1  

6.   reg FPGA_Enable=0;  

7.   reg[3:0] FPGA_Write_Enable=4'h0;  

8.   reg[31:0] FPGA_Address=0;  

9.   reg[31:0] FPGA_Write_Data=0;  

10. reg[31:0] FPGA_Read_Data_reg=0;  

11. wire[31:0] FPGA_Read_Data;  

12.   

13. reg[10:0] count=0;  

14. always @ (posedge USER_CLK)  

15. begin  

16.     count <= count + 1;  

17.     if(count<=100)  

18.     begin  

19.         FPGA_Enable <= 0;  

20.         FPGA_Write_Enable <= 4'h0;  

21.     end  

22.     else if((count <= 105)&&(count >100))  

23.     begin  

24.         FPGA_Enable <= 1;  

25.         FPGA_Write_Enable <= 4'hf;  

26.         FPGA_Address <= FPGA_Address + 4;  

27.         FPGA_Write_Data <= FPGA_Write_Data + 1;  

28.     end  

29.     else if((count <= 110)&&(count >105))  

30.     begin  

31.         FPGA_Enable <= 0;  

32.         FPGA_Write_Enable <= 4'h0;  

33.         FPGA_Address <= 0;  

34.         FPGA_Write_Data <= 0;  

35.     end  

36.     else if((count <= 117)&&(count >110))  

37.     begin  

38.         FPGA_Enable <= 1;  

39.         FPGA_Write_Enable <= 4'h0;  

40.         FPGA_Read_Data_reg <= FPGA_Read_Data;  

41.         FPGA_Address <= FPGA_Address + 4;  

42.     end  

43.     else if(count == 118)  

44.     begin  

45.         FPGA_Enable <= 0;  

46.         count <= count;  

47.           

48.     end  

49. end  

50.   

51. BBBB your_instance_name (  

52.   .clka(USER_CLK), // input clka  

53.   .ena(FPGA_Enable), // input ena  

54.   .wea(FPGA_Write_Enable), // input [3 : 0] wea  

55.   .addra(FPGA_Address), // input [31 : 0] addra  

56.   .dina(FPGA_Write_Data), // input [31 : 0] dina  

57.   .douta(FPGA_Read_Data), // output [31 : 0] douta  

58.     

59.     

60.   .clkb(clkb), // input clkb  

61.   .enb(enb), // input enb  

62.   .web(web), // input [3 : 0] web  

63.   .addrb(addrb), // input [31 : 0] addrb  

64.   .dinb(dinb), // input [31 : 0] dinb  

65.   .doutb(doutb) // output [31 : 0] doutb  

66. );  

67. endmodule  


效果图:

blob.png

从上图可以看出,在地址4~20里面写入了1-5的数,数据读出的时候对应地址的数据都延时了两个时钟周期才输出。