mirror of https://github.com/VLSIDA/OpenRAM.git
Merge branch 'multibank' of github.com:VLSIDA/PrivateRAM into multibank
This commit is contained in:
commit
289f48c3f3
|
|
@ -0,0 +1,191 @@
|
||||||
|
// OpenRAM SRAM model
|
||||||
|
// Words: #$WORDS$#
|
||||||
|
// Word size: #$WORD_SIZE$#
|
||||||
|
#<WRITE_SIZE_CMT
|
||||||
|
// Write size: #$WRITE_SIZE$#
|
||||||
|
#>WRITE_SIZE_CMT
|
||||||
|
|
||||||
|
module #$MODULE_NAME$# (
|
||||||
|
#<PORTS
|
||||||
|
`ifdef USE_POWER_PINS
|
||||||
|
#$VDD$#,
|
||||||
|
#$GND$#,
|
||||||
|
`endif
|
||||||
|
#<WRITE_MASK
|
||||||
|
wmask#$PORT_NUM$#,
|
||||||
|
#>WRITE_MASK
|
||||||
|
#<SPARE_WEN
|
||||||
|
spare_wen#$PORT_NUM$#,
|
||||||
|
#<SPARE_WEN
|
||||||
|
#<RW_PORT
|
||||||
|
// Port #$PORT_NUM$#: RW
|
||||||
|
clk#$PORT_NUM#$,csb#$PORT_NUM$#,web$#PORT_NUM$#,addr#$PORT_NUM$#,din#$PORT_NUM$#,dout#$PORT_NUM$#
|
||||||
|
#>RW_PORT
|
||||||
|
#<R_PORT
|
||||||
|
// Port #$PORT_NUM$#: R
|
||||||
|
clk#$PORT_NUM#$,csb#$PORT_NUM$#,addr#PORT_NUM$#,dout#PORT_NUM$#
|
||||||
|
#>RW_PORT
|
||||||
|
#<W_PORT
|
||||||
|
// Port #$PORT_NUM$#: W
|
||||||
|
clk#$PORT_NUM#$,csb#$PORT_NUM$#,web$#PORT_NUM$#,addr#PORT_NUM$#,din#PORT_NUM$#
|
||||||
|
#>W_PORT
|
||||||
|
#>PORTS
|
||||||
|
);
|
||||||
|
#<WMASK_PAR
|
||||||
|
parameter NUM_WMASK = #$NUM_WMASK#$ ;
|
||||||
|
#>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
|
||||||
|
input [NUM_WMASK-1:0] wmask#$PORT_NUM$#;
|
||||||
|
#>WRITE_MASK
|
||||||
|
#<SPARE_WEN_SINGLE
|
||||||
|
input spare_wen#$PORT_NUM$#;
|
||||||
|
#<SPARE_WEN_SINGLE
|
||||||
|
#<SPARE_WEN_MULT
|
||||||
|
input [#$NUM_SPARE_COL$#-1:0] spare_wen;
|
||||||
|
#<SPARE_WEN_MULT
|
||||||
|
#<RW_PORT
|
||||||
|
input clk#$PORT_NUM#$;
|
||||||
|
input csb#$PORT_NUM$#;
|
||||||
|
input web#$PORT_NUM$#;
|
||||||
|
input [ADDR_WIDTH-1:0] addr#$PORT_NUM$#;
|
||||||
|
input [DATA_WIDTH-1:0] din#$PORT_NUM$#;
|
||||||
|
output [DATA_WIDTH-1:0] dout#$PORT_NUM$#;
|
||||||
|
#>RW_PORT
|
||||||
|
#<R_PORT
|
||||||
|
input clk#$PORT_NUM#$;
|
||||||
|
input csb#$PORT_NUM$#;
|
||||||
|
input [ADDR_WIDTH-1:0] addr#$PORT_NUM$#;
|
||||||
|
output [DATA_WIDTH-1:0] dout#$PORT_NUM$#;
|
||||||
|
#>RW_PORT
|
||||||
|
#<W_PORT
|
||||||
|
// Port 0: RW
|
||||||
|
input clk#$PORT_NUM#$;
|
||||||
|
input csb#$PORT_NUM$#;
|
||||||
|
input web#$PORT_NUM$#;
|
||||||
|
input [ADDR_WIDTH-1:0] addr#$PORT_NUM$#;
|
||||||
|
input [DATA_WIDTH-1:0] din#$PORT_NUM$#;
|
||||||
|
output [DATA_WIDTH-1:0] dout#$PORT_NUM$#;
|
||||||
|
clk#$PORT_NUM#$,csb#$PORT_NUM$#,web$#PORT_NUM$#,addr#PORT_NUM$#,din#PORT_NUM$#,dout#PORT_NUM$#
|
||||||
|
#>W_PORT
|
||||||
|
|
||||||
|
reg [DATA_WIDTH-1:0] mem [0:RAM_DEPTH-1];
|
||||||
|
|
||||||
|
#<REGS
|
||||||
|
reg csb#$PORT_NUM$#_reg;
|
||||||
|
reg web#$PORT_NUM$#_reg;
|
||||||
|
reg [NUM_WMASK-1:0] wmask#$PORT_NUM$#_reg;
|
||||||
|
reg spare_wen#$PORT_NUM$#_reg;
|
||||||
|
reg [#$SPARE_COLS$#-1:0] spare_wen#$PORT_NUM$#_reg;
|
||||||
|
reg [ADDR_WIDTH-1:0] addr#$PORT_NUM$#_reg;
|
||||||
|
reg [DATA_WIDTH-1:0] din#$PORT_NUM$#_reg;
|
||||||
|
reg [DATA_WIDTH-1:0] dout#$PORT_NUM$#;
|
||||||
|
#<REGS
|
||||||
|
#<FLOPS
|
||||||
|
// All inputs are registers
|
||||||
|
always @(posedge clk#$PORT_NUM$#)
|
||||||
|
begin
|
||||||
|
csb#$PORT_NUM$#_reg = csb#$PORT_NUM$#;
|
||||||
|
#<WEB_FLOP
|
||||||
|
web#$PORT_NUM$#_reg = web#$PORT_NUM$#;
|
||||||
|
#>WEB_FLOP
|
||||||
|
#<W_MASK_FLOP
|
||||||
|
w_mask#$PORT_NUM$#_reg = w_mask#$PORT_NUM$#;
|
||||||
|
#>W_MASK_FLOP
|
||||||
|
#<SPARE_WEN_FLOP
|
||||||
|
spare_wen#$PORT_NUM$#_reg = spare_wen#$PORT_NUM$#;
|
||||||
|
#>SPARE_WEN_FLOP
|
||||||
|
addr#$PORT_NUM$#_reg = addr#$PORT_NUM$#;
|
||||||
|
#<RW_CHECKS
|
||||||
|
if (#$WPORT_CONTROL$# && #$RPORT_CONTROL$# && (addr#$WPORT$# == addr#$RPORT$#))
|
||||||
|
$display($time," WARNING: Writing and reading addr#$WPORT$#=%b and addr#$RPORT$#=%b simultaneously!",addr#$WPORT$#,addr#$RPORT$#);
|
||||||
|
#>RW_CHECKS
|
||||||
|
#<DIN_FLOP
|
||||||
|
din#$PORT_NUM$#_reg = din#$PORT_NUM$#;
|
||||||
|
#>DIN_FLOP
|
||||||
|
#<DOUT_FLOP
|
||||||
|
#(T_HOLD) dout#$PORT_NUM$# = #$WORD_SIZE$#'bx;
|
||||||
|
#>DOUT_FLOP
|
||||||
|
#<RW_VERBOSE
|
||||||
|
if ( !csb#$PORT_NUM$#_reg && web#$PORT_NUM$#_reg && VERBOSE )
|
||||||
|
$display($time," Reading %m addr#$PORT_NUM$#=%b dout#$PORT_NUM$#=%b",addr#$PORT_NUM$#_reg,mem[addr#$PORT_NUM$#_reg]);
|
||||||
|
if ( !csb#$PORT_NUM$#_reg && !web#$PORT_NUM$#_reg && VERBOSE )
|
||||||
|
#<RW_WMASK
|
||||||
|
$display($time," Writing %m addr#$PORT_NUM$#=%b din#$PORT_NUM$#=%b wmask#$PORT_NUM$#=%b",addr#$PORT_NUM$#_reg,din#$PORT_NUM$#_reg,wmask#$PORT_NUM$#_reg);
|
||||||
|
#>RW_WMASK
|
||||||
|
#<RW_NO_WMASK
|
||||||
|
$display($time," Writing %m addr#$PORT_NUM$#=%b din#$PORT_NUM$#=%b",addr#$PORT_NUM$#_reg,din#$PORT_NUM$#_reg);
|
||||||
|
#>RW_NO_WMASK
|
||||||
|
#>RW_VERBOSE
|
||||||
|
#<R_VERBOSE
|
||||||
|
if ( !csb#$PORT_NUM$#_reg && VERBOSE )
|
||||||
|
$display($time," Reading %m addr#$PORT_NUM$#=%b dout#$PORT_NUM$#=%b",addr#$PORT_NUM$#_reg,mem[addr#$PORT_NUM$#_reg]);
|
||||||
|
#>R_VERBOSE
|
||||||
|
#<W_VERBOSE
|
||||||
|
if ( !csb#$PORT_NUM$#_reg && VERBOSE )
|
||||||
|
#<W_WMASK
|
||||||
|
$display($time," Writing %m addr#$PORT_NUM$#=%b din#$PORT_NUM$#=%b wmask#$PORT_NUM$#=%b",addr#$PORT_NUM$#_reg,din#$PORT_NUM$#_reg,wmask#$PORT_NUM$#_reg);
|
||||||
|
#>W_WMASK
|
||||||
|
#<W_NO_WMASK
|
||||||
|
$display($time," Writing %m addr#$PORT_NUM$#=%b din#$PORT_NUM$#=%b",addr#$PORT_NUM$#_reg,din#$PORT_NUM$#_reg);
|
||||||
|
#>W_NO_WMASK
|
||||||
|
#>W_VERBOSE
|
||||||
|
end
|
||||||
|
#>FLOPS
|
||||||
|
#<W_BLOCK
|
||||||
|
// Memory Write Block Port #$PORT_NUM$#
|
||||||
|
// Write Operation : When web#$PORT_NUM$# = #$PORT_NUM$#, csb#$PORT_NUM$# = #$PORT_NUM$#
|
||||||
|
always @ (negedge clk#$PORT_NUM$#)
|
||||||
|
begin : MEM_WRITE#$PORT_NUM$#
|
||||||
|
#<READ
|
||||||
|
if ( !csb#$PORT_NUM$#_reg && !web#$PORT_NUM$#_reg ) begin
|
||||||
|
#>READ
|
||||||
|
#<NO_READ
|
||||||
|
if ( !csb#$PORT_NUM$#_reg ) begin
|
||||||
|
#>NO_READ
|
||||||
|
#<W_MASK
|
||||||
|
if (wmask#$PORT_NUM$#_reg[#$MASK$#])
|
||||||
|
mem[addr#$PORT_NUM$#_reg][#$UPPER$#:#$LOWER$#] = din#$PORT_NUM$#_reg[#$UPPER$#:#$LOWER$#];
|
||||||
|
#>W_MASK
|
||||||
|
#<NO_W_MASK
|
||||||
|
mem[addr#$PORT_NUM$#_reg][1:#$PORT_NUM$#] = din#$PORT_NUM$#_reg[1:#$PORT_NUM$#];
|
||||||
|
#<NO_WMASK
|
||||||
|
#<ONE_SPARE_COL
|
||||||
|
if (spare_wen#$PORT_NUM$#_reg)
|
||||||
|
mem[addr#$PORT_NUM$#_reg][#$WORD_SIZE$#] = din#$PORT_NUM$#_reg[#$WORD_SIZE$#];
|
||||||
|
#>ONE_SPARE_COL
|
||||||
|
#!NUM!0#
|
||||||
|
#<SPARE_COLS
|
||||||
|
if (spare_wen#$PORT_NUM$#_reg[#$NUM$#])
|
||||||
|
mem[addr#$PORT_NUM$#_reg][#$NUM$# + #$WORD_SIZE$#] = din#$PORT_NUM$#_reg[#$NUM$#];
|
||||||
|
#>SPARE_COLS
|
||||||
|
end
|
||||||
|
end
|
||||||
|
#>W_BLOCK
|
||||||
|
#<R_BLOCK
|
||||||
|
// Memory Read Block Port #$PORT_NUM$#
|
||||||
|
// Read Operation : When web#$PORT_NUM$# = 1, csb#$PORT_NUM$# = #$PORT_NUM$#
|
||||||
|
always @ (negedge clk#$PORT_NUM$#)
|
||||||
|
begin : MEM_READ#$PORT_NUM$#
|
||||||
|
#<WRITE
|
||||||
|
if (!csb#$PORT_NUM$#_reg && web#$PORT_NUM$#_reg)
|
||||||
|
#>WRITE
|
||||||
|
#<NO_WRITE
|
||||||
|
if (!csb#$PORT_NUM$#_reg)
|
||||||
|
#>NO_WRITE
|
||||||
|
dout#$PORT_NUM$# <= #(DELAY) mem[addr#$PORT_NUM$#_reg];
|
||||||
|
end
|
||||||
|
#>R_BLOCK
|
||||||
|
endmodule
|
||||||
|
|
@ -121,7 +121,8 @@ class sram_config:
|
||||||
self.row_addr_size = ceil(log(self.num_rows, 2))
|
self.row_addr_size = ceil(log(self.num_rows, 2))
|
||||||
self.col_addr_size = int(log(self.words_per_row, 2))
|
self.col_addr_size = int(log(self.words_per_row, 2))
|
||||||
self.bank_addr_size = self.col_addr_size + self.row_addr_size
|
self.bank_addr_size = self.col_addr_size + self.row_addr_size
|
||||||
self.addr_size = self.bank_addr_size + int(log(self.num_banks, 2))
|
#self.addr_size = self.bank_addr_size + int(log(self.num_banks, 2))
|
||||||
|
self.addr_size = self.bank_addr_size
|
||||||
debug.info(1, "Row addr size: {}".format(self.row_addr_size)
|
debug.info(1, "Row addr size: {}".format(self.row_addr_size)
|
||||||
+ " Col addr size: {}".format(self.col_addr_size)
|
+ " Col addr size: {}".format(self.col_addr_size)
|
||||||
+ " Bank addr size: {}".format(self.bank_addr_size))
|
+ " Bank addr size: {}".format(self.bank_addr_size))
|
||||||
|
|
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue