mirror of
https://github.com/aolofsson/oh.git
synced 2025-01-17 20:02:53 +08:00
Fixing brain-dead bug!
-I guess nobody has been using this fifo, because it was hoplessly broken. Fucking sad.
This commit is contained in:
parent
bee941aa61
commit
3c8be0c083
@ -7,6 +7,7 @@
|
|||||||
|
|
||||||
module oh_fifo_sync #(parameter DW = 104, //FIFO width
|
module oh_fifo_sync #(parameter DW = 104, //FIFO width
|
||||||
parameter DEPTH = 32, //FIFO depth
|
parameter DEPTH = 32, //FIFO depth
|
||||||
|
parameter REG = 1, //Register fifo output
|
||||||
parameter PROG_FULL = (DEPTH/2),//prog_full threshold
|
parameter PROG_FULL = (DEPTH/2),//prog_full threshold
|
||||||
parameter AW = $clog2(DEPTH) //rd_count width
|
parameter AW = $clog2(DEPTH) //rd_count width
|
||||||
)
|
)
|
||||||
@ -29,11 +30,13 @@ module oh_fifo_sync #(parameter DW = 104, //FIFO width
|
|||||||
wire fifo_read;
|
wire fifo_read;
|
||||||
wire fifo_write;
|
wire fifo_write;
|
||||||
|
|
||||||
assign empty = (rd_count[AW-1:0] == 0);
|
|
||||||
assign prog_full = (rd_count[AW-1:0] >= PROG_FULL);
|
|
||||||
assign full = (rd_count[AW-1:0] == (DEPTH-1));
|
|
||||||
assign fifo_read = rd_en & ~empty;
|
assign fifo_read = rd_en & ~empty;
|
||||||
assign fifo_write = wr_en & ~full;
|
assign fifo_write = wr_en & ~full;
|
||||||
|
assign prog_full = (rd_count[AW-1:0] >= PROG_FULL);
|
||||||
|
assign full = (rd_count[AW-1:0] == (DEPTH-1));
|
||||||
|
assign fifo_empty = (rd_count[AW-1:0] == 0);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
always @ (posedge clk or negedge nreset)
|
always @ (posedge clk or negedge nreset)
|
||||||
if(~nreset)
|
if(~nreset)
|
||||||
@ -64,10 +67,25 @@ module oh_fifo_sync #(parameter DW = 104, //FIFO width
|
|||||||
rd_count[AW-1:0]<= rd_count[AW-1:0] - 'd1;
|
rd_count[AW-1:0]<= rd_count[AW-1:0] - 'd1;
|
||||||
end
|
end
|
||||||
|
|
||||||
|
//Empty register to account for RAM output register
|
||||||
|
generate
|
||||||
|
if(REG)
|
||||||
|
begin
|
||||||
|
reg empty_reg;
|
||||||
|
always @ (posedge clk)
|
||||||
|
empty_reg <= fifo_empty;
|
||||||
|
assign empty= empty_reg;
|
||||||
|
end
|
||||||
|
else
|
||||||
|
assign empty= fifo_empty;
|
||||||
|
endgenerate
|
||||||
|
|
||||||
|
|
||||||
// GENERIC DUAL PORTED MEMORY
|
// GENERIC DUAL PORTED MEMORY
|
||||||
oh_memory_dp
|
oh_memory_dp
|
||||||
#(.DW(DW),
|
#(.DW(DW),
|
||||||
.DEPTH(DEPTH))
|
.DEPTH(DEPTH),
|
||||||
|
.REG(REG))
|
||||||
mem (// read port
|
mem (// read port
|
||||||
.rd_dout (dout[DW-1:0]),
|
.rd_dout (dout[DW-1:0]),
|
||||||
.rd_clk (clk),
|
.rd_clk (clk),
|
||||||
|
@ -9,6 +9,7 @@ module oh_memory_dp # (parameter DW = 104, //memory width
|
|||||||
parameter DEPTH = 32, //memory depth
|
parameter DEPTH = 32, //memory depth
|
||||||
parameter PROJ = "", //project name
|
parameter PROJ = "", //project name
|
||||||
parameter MCW = 8, //repair/config vector width
|
parameter MCW = 8, //repair/config vector width
|
||||||
|
parameter REG = 1, //register memory output
|
||||||
parameter AW = $clog2(DEPTH) // address bus width
|
parameter AW = $clog2(DEPTH) // address bus width
|
||||||
)
|
)
|
||||||
(// Memory interface (dual port)
|
(// Memory interface (dual port)
|
||||||
@ -37,8 +38,9 @@ module oh_memory_dp # (parameter DW = 104, //memory width
|
|||||||
`ifdef CFG_ASIC
|
`ifdef CFG_ASIC
|
||||||
|
|
||||||
oh_memory_ram #(.DW(DW),
|
oh_memory_ram #(.DW(DW),
|
||||||
.DEPTH(DEPTH))
|
.DEPTH(DEPTH),
|
||||||
memory_dp (//read port
|
.REG(REG))
|
||||||
|
macro (//read port
|
||||||
.rd_dout (rd_dout[DW-1:0]),
|
.rd_dout (rd_dout[DW-1:0]),
|
||||||
.rd_clk (rd_clk),
|
.rd_clk (rd_clk),
|
||||||
.rd_en (rd_en),
|
.rd_en (rd_en),
|
||||||
@ -51,8 +53,9 @@ module oh_memory_dp # (parameter DW = 104, //memory width
|
|||||||
.wr_din (wr_din[DW-1:0]));
|
.wr_din (wr_din[DW-1:0]));
|
||||||
`else
|
`else
|
||||||
oh_memory_ram #(.DW(DW),
|
oh_memory_ram #(.DW(DW),
|
||||||
.DEPTH(DEPTH))
|
.DEPTH(DEPTH),
|
||||||
memory_dp (//read port
|
.REG(REG))
|
||||||
|
macro (//read port
|
||||||
.rd_dout (rd_dout[DW-1:0]),
|
.rd_dout (rd_dout[DW-1:0]),
|
||||||
.rd_clk (rd_clk),
|
.rd_clk (rd_clk),
|
||||||
.rd_en (rd_en),
|
.rd_en (rd_en),
|
||||||
|
@ -5,15 +5,16 @@
|
|||||||
//# License: MIT (see LICENSE file in OH! repository) #
|
//# License: MIT (see LICENSE file in OH! repository) #
|
||||||
//#############################################################################
|
//#############################################################################
|
||||||
|
|
||||||
module oh_memory_ram # (parameter DW = 104, //memory width
|
module oh_memory_ram # (parameter DW = 104, // memory width
|
||||||
parameter DEPTH = 32, //memory depth
|
parameter DEPTH = 32, // memory depth
|
||||||
|
parameter REG = 1, // register output
|
||||||
parameter AW = $clog2(DEPTH) // address width
|
parameter AW = $clog2(DEPTH) // address width
|
||||||
)
|
)
|
||||||
(// read-port
|
(// read-port
|
||||||
input rd_clk,// rd clock
|
input rd_clk,// rd clock
|
||||||
input rd_en, // memory access
|
input rd_en, // memory access
|
||||||
input [AW-1:0] rd_addr, // address
|
input [AW-1:0] rd_addr, // address
|
||||||
output reg [DW-1:0] rd_dout, // data output
|
output [DW-1:0] rd_dout, // data output
|
||||||
// write-port
|
// write-port
|
||||||
input wr_clk,// wr clock
|
input wr_clk,// wr clock
|
||||||
input wr_en, // memory access
|
input wr_en, // memory access
|
||||||
@ -23,19 +24,40 @@ module oh_memory_ram # (parameter DW = 104, //memory width
|
|||||||
);
|
);
|
||||||
|
|
||||||
reg [DW-1:0] ram [DEPTH-1:0];
|
reg [DW-1:0] ram [DEPTH-1:0];
|
||||||
|
wire [DW-1:0] rdata;
|
||||||
integer i;
|
integer i;
|
||||||
|
|
||||||
//registered read port
|
//#########################################
|
||||||
always @ (posedge rd_clk)
|
//write port
|
||||||
if(rd_en)
|
//#########################################
|
||||||
rd_dout[DW-1:0] <= ram[rd_addr[AW-1:0]];
|
|
||||||
|
|
||||||
//write port with vector enable
|
|
||||||
always @(posedge wr_clk)
|
always @(posedge wr_clk)
|
||||||
for (i=0;i<DW;i=i+1)
|
for (i=0;i<DW;i=i+1)
|
||||||
if (wr_en & wr_wem[i])
|
if (wr_en & wr_wem[i])
|
||||||
ram[wr_addr[AW-1:0]][i] <= wr_din[i];
|
ram[wr_addr[AW-1:0]][i] <= wr_din[i];
|
||||||
|
|
||||||
|
//#########################################
|
||||||
|
//read port
|
||||||
|
//#########################################
|
||||||
|
|
||||||
|
//RAM read
|
||||||
|
assign rdata[DW-1:0] = ram[rd_addr[AW-1:0]];
|
||||||
|
|
||||||
|
//Configurable output register
|
||||||
|
generate
|
||||||
|
if(REG)
|
||||||
|
begin
|
||||||
|
reg [DW-1:0] rd_reg;
|
||||||
|
always @ (posedge rd_clk)
|
||||||
|
if(rd_en)
|
||||||
|
rd_reg[DW-1:0] <= rdata[DW-1:0];
|
||||||
|
assign rd_dout[DW-1:0] = rd_reg[DW-1:0];
|
||||||
|
end
|
||||||
|
else
|
||||||
|
begin
|
||||||
|
assign rd_dout[DW-1:0] = rdata[DW-1:0];
|
||||||
|
end
|
||||||
|
endgenerate
|
||||||
|
|
||||||
endmodule // oh_memory_ram
|
endmodule // oh_memory_ram
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user