sram.v

来自「这个是用可编程器件进行仿真CPU的程序」· Verilog 代码 · 共 102 行

V
102
字号
//**************************************************
//** Revision    :  0.1
//** File name   :  SRAM.v
//** Module name :  SRAM
//** Discription :  Discripte a 8-bit X16 RAM
//** Simulator   :  Quartus II V5.1 web edition
//** Synthesizer :  Quartus II V5.1 web edition
//** Author      :  IamFree
//** Last modified:    @ 2006///
//** Created date:  2006/03/23
//**************************************************

module SRAM(datao,datai,address,nWR,nCS,CLK);
//Parameter define
parameter width=8;

//Port define
output [width-1:0] datao;
input [width-1:0] datai;
input [3:0] address;    //Address bus
input nWR;              //RAM write signal,active low.
input nCS;              //RAM select signal,active low.
input CLK;

reg [width-1:0] datao;

//Register stack,as Quartus don't support register array
reg [width-1:0] byte0;
reg [width-1:0] byte1;
reg [width-1:0] byte2;
reg [width-1:0] byte3;
reg [width-1:0] byte4;

reg [width-1:0] byte5;
reg [width-1:0] byte6;
reg [width-1:0] byte7;
reg [width-1:0] byte8;
reg [width-1:0] byte9;
reg [width-1:0] byte10;
reg [width-1:0] byte11;
reg [width-1:0] byte12;
reg [width-1:0] byte13;
reg [width-1:0] byte14;
reg [width-1:0] byte15;

//Body
always @(posedge CLK)
if(!nCS & !nWR)
    case(address)  //synthesis parallel_case
     4'b0000:byte0<=datai;
     4'b0001:byte1<=datai;
     4'b0010:byte2<=datai;
     4'b0011:byte3<=datai;

     4'b0100:byte4<=datai;
     4'b0101:byte5<=datai;
     4'b0110:byte6<=datai;
     4'b0111:byte7<=datai;

     4'b1000:byte8<=datai;
     4'b1001:byte9<=datai;
     4'b1010:byte10<=datai;
     4'b1011:byte11<=datai;

     4'b1100:byte12<=datai;
     4'b1101:byte13<=datai;
     4'b1110:byte14<=datai;
     4'b1111:byte15<=datai;
    endcase

 always @(address or byte0 or byte1 or byte2 or byte3 or
          byte4 or byte5 or byte6 or byte7 or
          byte8 or byte9 or byte10 or byte11 or
          byte12 or byte13 or byte14 or byte15
         )//读寄存器
  begin
   case(address)  //synthesis parallel_case
     4'b0000:datao=byte0;
     4'b0001:datao=byte1;
     4'b0010:datao=byte2;
     4'b0011:datao=byte3;

     4'b0100:datao=byte4;
     4'b0101:datao=byte5;
     4'b0110:datao=byte6;
     4'b0111:datao=byte7;

     4'b1000:datao=byte8;
     4'b1001:datao=byte9;
     4'b1010:datao=byte10;
     4'b1011:datao=byte11;

     4'b1100:datao=byte12;
     4'b1101:datao=byte13;
     4'b1110:datao=byte14;
     4'b1111:datao=byte15;    
   endcase
  end

endmodule

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?