1
0
mirror of https://github.com/aolofsson/oh.git synced 2025-01-17 20:02:53 +08:00

Fixing memory macro instantiation

- too many variations (polarity etc) on memory interface, stay with generics
(repair + config)
- hookup magic happens under the hood
This commit is contained in:
Andreas Olofsson 2016-04-05 22:43:29 -04:00
parent 1c1a4dae66
commit 8c224d6771
2 changed files with 12 additions and 16 deletions

View File

@ -2,14 +2,14 @@ module oh_memory_sp(/*AUTOARG*/
// Outputs // Outputs
dout, dout,
// Inputs // Inputs
clk, en, we, wem, addr, din, vdd, vddm, sleep, shutdown, repair, clk, en, we, wem, addr, din, vdd, vddm, memconfig, memrepair,
bist_en, bist_we, bist_wem, bist_addr, bist_din bist_en, bist_we, bist_wem, bist_addr, bist_din
); );
// parameters // parameters
parameter DW = 32; // memory width parameter DW = 32; // memory width
parameter DEPTH = 14; // memory depth parameter DEPTH = 14; // memory depth
parameter RW = 32; // repair vector width parameter MCW = 8; // repair/config vector width
parameter PROJ = ""; // project name (used for IP selection) parameter PROJ = ""; // project name (used for IP selection)
localparam AW = $clog2(DEPTH); // address bus width localparam AW = $clog2(DEPTH); // address bus width
@ -25,9 +25,8 @@ module oh_memory_sp(/*AUTOARG*/
// Power/repai interface (ASICs only) // Power/repai interface (ASICs only)
input vdd; // periphery power rail input vdd; // periphery power rail
input vddm; // array power rail input vddm; // array power rail
input sleep; // sleep (content retained) input [MCW-1:0] memconfig; // memory config
input shutdown; // shutdown (no retention) input [MCW-1:0] memrepair; // "wildcard" repair vector
input [RW-1:0] repair; // "wildcard" repair vector
// BIST interface (ASICs only) // BIST interface (ASICs only)
input bist_en; // bist enable input bist_en; // bist enable
@ -40,11 +39,10 @@ module oh_memory_sp(/*AUTOARG*/
//Actual IP hidden behind wrapper to protect the innocent //Actual IP hidden behind wrapper to protect the innocent
sram_sp #(.DW(DW). sram_sp #(.DW(DW),
.DEPTH(DEPTH), .DEPTH(DEPTH),
.PROJ(PROJ), .PROJ(PROJ),
.RW(RW)) .MCW(MCW))
sram_sp (// Outputs sram_sp (// Outputs
.dout (dout[DW-1:0]), .dout (dout[DW-1:0]),
// Inputs // Inputs
@ -56,9 +54,8 @@ module oh_memory_sp(/*AUTOARG*/
.din (din[DW-1:0]), .din (din[DW-1:0]),
.vdd (vdd), .vdd (vdd),
.vddm (vddm), .vddm (vddm),
.sleep (sleep), .memconfig (memconfig[MCW-1:0]),
.shutdown (shutdown), .memrepair (memrepair[MCW-1:0]),
.cfg_repair (cfg_repair[RW-1:0]),
.bist_en (bist_en), .bist_en (bist_en),
.bist_we (bist_we), .bist_we (bist_we),
.bist_wem (bist_wem[DW-1:0]), .bist_wem (bist_wem[DW-1:0]),
@ -77,13 +74,13 @@ module oh_memory_sp(/*AUTOARG*/
//read port (one cycle latency) //read port (one cycle latency)
always @ (posedge clk) always @ (posedge clk)
if(en & ~sleep & ~shutdown) if(en)
dout[DW-1:0] <= ram[addr[AW-1:0]]; dout[DW-1:0] <= ram[addr[AW-1:0]];
//write port //write port
always @ (posedge clk) always @ (posedge clk)
for(i=0;i<DW;i=i+1) for(i=0;i<DW;i=i+1)
if(en & wem[i] & we & ~sleep & ~shutdown) if(en & wem[i] & we)
ram[addr[AW-1:0]][i] <= din[i]; ram[addr[AW-1:0]][i] <= din[i];
`endif `endif

View File

@ -143,9 +143,8 @@ module ememory(/*AUTOARG*/
.dout (dout[63:0]), .dout (dout[63:0]),
.vdd (1'b1), .vdd (1'b1),
.vddm (1'b1), .vddm (1'b1),
.sleep (1'b0), .memrepair(8'b0),
.shutdown (1'b0), .memconfig(8'b0),
.repair (32'b0),
.bist_en (1'b0), .bist_en (1'b0),
.bist_we (1'b0), .bist_we (1'b0),
.bist_wem (64'b0), .bist_wem (64'b0),