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

Making almost full programmable in oh_fifo_sync

This commit is contained in:
Andreas.Olofsson 2020-12-07 16:58:47 -05:00
parent 401d1c2e93
commit 3e49fa499f

View File

@ -10,6 +10,7 @@ module oh_fifo_sync
parameter DEPTH = 32, // FIFO depth
parameter REG = 1, // Register fifo output
parameter AW = $clog2(DEPTH),// rd_count width (derived)
parameter PROGFULL = DEPTH-1, // programmable almost full level
parameter TYPE = "soft", // hard=hard macro,soft=synthesizable
parameter CONFIG = "default", // hard macro user config pass through
parameter SHAPE = "square" // hard macro shape (square, tall, wide)
@ -24,7 +25,7 @@ module oh_fifo_sync
input [DW-1:0] din, // data to write
input wr_en, // write fifo
output full, // fifo full
output prog_full, // fifo is almost full
output almost_full, //progfull level reached
//read port
input rd_en, // read fifo
output [DW-1:0] dout, // output data (next cycle)
@ -56,7 +57,7 @@ module oh_fifo_sync
//############################
assign fifo_read = rd_en & ~empty;
assign fifo_write = wr_en & ~full;
assign prog_full = (rd_count[AW-1:0] == (DEPTH-1));
assign almost_full = (rd_count[AW-1:0] == PROGFULL);
assign ptr_match = (wr_addr[AW-1:0] == rd_addr[AW-1:0]);
assign full = ptr_match & (wr_addr[AW]==!rd_addr[AW]);
assign fifo_empty = ptr_match & (wr_addr[AW]==rd_addr[AW]);