1
0
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:
Andreas.Olofsson 2020-03-13 12:24:35 -04:00
parent bee941aa61
commit 3c8be0c083
3 changed files with 71 additions and 28 deletions

View File

@ -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),

View File

@ -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),

View File

@ -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