spr16x2b.v

来自「简单的8位CPU」· Verilog 代码 · 共 79 行

V
79
字号
`resetall
`timescale 1 ns / 1 ps

`celldefine

module SPR16X2B ( DI0, DI1, AD0, AD1, AD2, AD3, WRE, CK, DO0, DO1);
 
  input AD0, AD1, AD2, AD3, DI0, DI1, CK, WRE;
  output DO0, DO1;

  //parameter [31:0] initval = 32'h00000000;
  parameter [63:0] initval = 64'h0000000000000000;

  integer i,j;
  reg wre_reg;
  reg [1:0] din_reg;
  reg [3:0] wadr_reg;
  reg [3:0] radr_reg;
  reg [31:0] MEM;
  reg [1:0] DOb;

  buf  (AD0b, AD0);
  buf  (AD1b, AD1);
  buf  (AD2b, AD2);
  buf  (AD3b, AD3);
  buf  (DI0b, DI0);
  buf  (DI1b, DI1);
  buf  (CKb, CK);
  buf  (WREb, WRE);

  buf  (DO0, DOb[0]);
  buf  (DO1, DOb[1]);

  initial
  begin

	for ( i = 0 ; i < 16; i = i + 1)
        begin
	for ( j = 0; j < 2; j = j + 1)
		begin	
		 //MEM[i*2+j] = initval[i*2+j];  for 32 bits initval		
		 MEM[i*2+j] = initval[i*4+j];
		end
        end
  end

   // Latch the address and data in for writing
   // Registers are rising edge enabled
  always @ (posedge CKb) begin
       wre_reg = WREb;
       din_reg = {DI1b, DI0b};
       wadr_reg = {AD3b, AD2b, AD1b, AD0b};
  end

// always @ (posedge CKb) begin
 always @ (din_reg,wadr_reg,wre_reg) begin
     if (wre_reg === 1'b1) begin
         for (i = 0; i < 2; i = i + 1)
          begin
          MEM[2*wadr_reg+i] = din_reg[i];
          end
     end
   end

  always @ (AD3b or AD2b or AD1b or AD0b) begin
     radr_reg = {AD3b, AD2b, AD1b, AD0b};
  end

  always @ (radr_reg or MEM)
  begin
         for (i = 0; i < 2; i = i + 1)
            DOb[i] = MEM[2*radr_reg+i];
  end

endmodule

`endcelldefine

⌨️ 快捷键说明

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