// OpenRAM SRAM model // Words: #$WORDS$# // Word size: #$WORD_SIZE$# #WRITE_SIZE_CMT module #$MODULE_NAME$# ( #WRITE_MASK #RW_PORT #RW_PORT #W_PORT #>PORTS ); #WMASK_PAR parameter DATA_WIDTH = #$DATA_WIDTH$# ; parameter ADDR_WIDTH = #$ADD_WIDTH$# ; parameter RAM_DEPTH = 1 << ADDR_WIDTH; // FIXME: This delay is arbitrary. parameter DELAY = 3 ; parameter VERBOSE = 1 ; //Set to 0 to only display warnings parameter T_HOLD = 1 ; //Delay to hold dout value after posedge. Value is arbitrary `ifdef USE_POWER_PINS inout #$VDD$#; inout #$GND$#; `endif #WRITE_MASK #RW_PORT #RW_PORT #W_PORT reg [DATA_WIDTH-1:0] mem [0:RAM_DEPTH-1]; #WEB_FLOP #W_MASK_FLOP #SPARE_WEN_FLOP addr#$PORT_NUM$#_reg = addr#$PORT_NUM$#; #RW_CHECKS #DIN_FLOP #DOUT_FLOP #RW_WMASK #RW_NO_WMASK #>RW_VERBOSE #R_VERBOSE #W_WMASK #W_NO_WMASK #>W_VERBOSE end #>FLOPS #READ #NO_READ #W_MASK #ONE_SPARE_COL #!NUM!0# #SPARE_COLS end end #>W_BLOCK #WRITE #NO_WRITE dout#$PORT_NUM$# <= #(DELAY) mem[addr#$PORT_NUM$#_reg]; end #>R_BLOCK endmodule