1288 lines
37 KiB
Systemverilog
Executable File
1288 lines
37 KiB
Systemverilog
Executable File
`ifndef AXIDMA_FIFO_VH
|
|
`define AXIDMA_FIFO_VH
|
|
`include "xdma_axi4mm_axi_bridge.vh"
|
|
//-----------------------------------------------------------------------------
|
|
// $Id:
|
|
//-----------------------------------------------------------------------------
|
|
// axi_bridge.vh
|
|
//-----------------------------------------------------------------------------
|
|
// (c) Copyright 2010 - 2010 Xilinx, Inc. All rights reserved.
|
|
//
|
|
// This file contains confidential and proprietary information
|
|
// of Xilinx, Inc. and is protected under U.S. and
|
|
// international copyright and other intellectual property
|
|
// laws.
|
|
//
|
|
// DISCLAIMER
|
|
// This disclaimer is not a license and does not grant any
|
|
// rights to the materials distributed herewith. Except as
|
|
// otherwise provided in a valid license issued to you by
|
|
// Xilinx, and to the maximum extent permitted by applicable
|
|
// law: (1) THESE MATERIALS ARE MADE AVAILABLE "AS IS" AND
|
|
// WITH ALL FAULTS, AND XILINX HEREBY DISCLAIMS ALL WARRANTIES
|
|
// AND CONDITIONS, EXPRESS, IMPLIED, OR STATUTORY, INCLUDING
|
|
// BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, NON-
|
|
// INFRINGEMENT, OR FITNESS FOR ANY PARTICULAR PURPOSE; and
|
|
// (2) Xilinx shall not be liable (whether in contract or tort,
|
|
// including negligence, or under any other theory of
|
|
// liability) for any loss or damage of any kind or nature
|
|
// related to, arising under or in connection with these
|
|
// materials, including for any direct, or any indirect,
|
|
// special, incidental, or consequential loss or damage
|
|
// (including loss of data, profits, goodwill, or any type of
|
|
// loss or damage suffered as a result of any action brought
|
|
// by a third party) even if such damage or loss was
|
|
// reasonably foreseeable or Xilinx had been advised of the
|
|
// possibility of the same.
|
|
//
|
|
// CRITICAL APPLICATIONS
|
|
// Xilinx products are not designed or intended to be fail-
|
|
// safe, or for use in any application requiring fail-safe
|
|
// performance, such as life-support or safety devices or
|
|
// systems, Class III medical devices, nuclear facilities,
|
|
// applications related to the deployment of airbags, or any
|
|
// other applications that could lead to death, personal
|
|
// injury, or severe property or environmental damage
|
|
// (individually and collectively, "Critical
|
|
// Applications"). Customer assumes the sole risk and
|
|
// liability of any use of Xilinx products in Critical
|
|
// Applications, subject only to applicable laws and
|
|
// regulations governing limitations on product liability.
|
|
//
|
|
// THIS COPYRIGHT NOTICE AND DISCLAIMER MUST BE RETAINED AS
|
|
// PART OF THIS FILE AT ALL TIMES.
|
|
//-----------------------------------------------------------------------------
|
|
// Filename: axi_bridge.vh
|
|
//
|
|
// Description:
|
|
//
|
|
// This file needs to be included in all modules so that all the modules can commonly
|
|
// reference state_transitions
|
|
//
|
|
//
|
|
// VHDL-Standard: VHDL'93
|
|
//-----------------------------------------------------------------------------
|
|
// Structure:
|
|
// Include file
|
|
//
|
|
//-----------------------------------------------------------------------------
|
|
// Revision: v1.05.a
|
|
// Date: 06/28/12
|
|
//
|
|
//-----------------------------------------------------------------------------
|
|
|
|
|
|
|
|
//signal arid_dependencySM_cs : arid_dependencySM_STATES;
|
|
//signal arid_dependencySM_ns : arid_dependencySM_STATES;
|
|
module xdma_v4_1_20_BufferMem
|
|
#(
|
|
parameter TCQ = 1,
|
|
parameter BUF_DATAWIDTH = 256,
|
|
parameter BUF_WE = BUF_DATAWIDTH/8,
|
|
parameter BUF_DEPTH = 512,
|
|
parameter BUF_PTR = (BUF_DEPTH <=2) ? 1:
|
|
(BUF_DEPTH <=4) ? 2:
|
|
(BUF_DEPTH <=8) ? 3:
|
|
(BUF_DEPTH <=16) ? 4:
|
|
(BUF_DEPTH <=32) ? 5:
|
|
(BUF_DEPTH <=64) ? 6:
|
|
(BUF_DEPTH <=128) ? 7:
|
|
(BUF_DEPTH <=256) ? 8:
|
|
(BUF_DEPTH <=512) ? 9:
|
|
(BUF_DEPTH <=1024) ? 10 : -1,
|
|
parameter NO_OUTPUT_REG = 1
|
|
)
|
|
(
|
|
input clkin,
|
|
input reset_n,
|
|
input wrEn,
|
|
input [BUF_DATAWIDTH-1:0] DataIn,
|
|
input [BUF_DATAWIDTH/8-1:0] EccIn,
|
|
input [BUF_PTR-1:0] AddrIn,
|
|
input [BUF_PTR-1:0] AddrOut,
|
|
input rdEn,
|
|
output [BUF_DATAWIDTH-1:0] DataOut,
|
|
output [BUF_DATAWIDTH/8-1:0] EccOut
|
|
);
|
|
reg [BUF_DATAWIDTH-1:0] DataMem [BUF_DEPTH-1:0];
|
|
reg [BUF_DATAWIDTH/8-1:0] EccMem [BUF_DEPTH-1:0];
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
end
|
|
else if (wrEn) begin
|
|
DataMem[AddrIn] <= DataIn;
|
|
EccMem[AddrIn] <= EccIn;
|
|
end
|
|
end
|
|
//wire [BUF_DATAWIDTH-1:0] BuftoMem;
|
|
if(NO_OUTPUT_REG) begin: nooutput
|
|
assign DataOut = DataMem[AddrOut];
|
|
assign EccOut = EccMem[AddrOut];
|
|
end
|
|
else begin: outputStage
|
|
reg [BUF_DATAWIDTH-1:0] BufDout;
|
|
reg [BUF_DATAWIDTH/8-1:0] BufEccout;
|
|
`XSRREG_AXIMM(clkin, reset_n, BufDout, rdEn ?DataMem[AddrOut]: BufDout, {BUF_DATAWIDTH{1'b0}})
|
|
`XSRREG_AXIMM(clkin, reset_n, BufEccout, rdEn ?EccMem[AddrOut] : BufEccout, {(BUF_DATAWIDTH/8){1'b0}})
|
|
assign DataOut = BufDout;
|
|
assign EccOut = BufEccout;
|
|
|
|
end
|
|
|
|
endmodule // BufferMem
|
|
|
|
module xdma_v4_1_20_GenericFIFO1R2W
|
|
#(parameter BUF_DATAWIDTH = 256,
|
|
parameter BUF_WE = BUF_DATAWIDTH/8,
|
|
parameter BUF_DEPTH = 512,
|
|
parameter BUF_PTR = (BUF_DEPTH <=2) ? 1:
|
|
(BUF_DEPTH <=4) ? 2:
|
|
(BUF_DEPTH <=8) ? 3:
|
|
(BUF_DEPTH <=16) ? 4:
|
|
(BUF_DEPTH <=32) ? 5:
|
|
(BUF_DEPTH <=64) ? 6:
|
|
(BUF_DEPTH <=128) ? 7:
|
|
(BUF_DEPTH <=256) ? 8:
|
|
(BUF_DEPTH <=512) ? 9:
|
|
(BUF_DEPTH <=1024) ? 10 : -1,
|
|
parameter AE_THRESHOLD = BUF_DEPTH >> 2,
|
|
parameter AF_THRESHOLD = BUF_DEPTH - 2
|
|
)
|
|
(
|
|
input clkin,
|
|
input reset_n,
|
|
input sync_reset_n,
|
|
input WrEn0,
|
|
input WrEn1,
|
|
input [BUF_DATAWIDTH-1:0] DataIn0,
|
|
input [BUF_DATAWIDTH-1:0] DataIn1,
|
|
output [BUF_DATAWIDTH-1:0] DataOut,
|
|
input RdEn,
|
|
output almost_empty,
|
|
output almost_full,
|
|
output empty,
|
|
output full0,
|
|
output full1
|
|
);
|
|
(* ram_style = "DISTRIBUTED" *)
|
|
reg [BUF_DATAWIDTH-1:0] MemArray [BUF_DEPTH-1:0];
|
|
(* max_fanout = 128 *) reg [BUF_PTR-1:0] WrPtr;
|
|
(* max_fanout = 128 *) reg [BUF_PTR-1:0] WrPtrp1;
|
|
(* max_fanout = 128 *) reg [BUF_PTR-1:0] RdPtr;
|
|
reg [BUF_PTR:0] FifoCntr;
|
|
reg almost_empty_ff;
|
|
reg almost_full_ff;
|
|
reg empty_ff;
|
|
reg full_ff0;
|
|
reg full_ff1;
|
|
assign RdDeQ = RdEn;
|
|
assign DataOut = MemArray[RdPtr];
|
|
assign almost_empty = almost_empty_ff;
|
|
assign almost_full = almost_full_ff;
|
|
assign empty = empty_ff;
|
|
assign full0 = full_ff0;
|
|
assign full1 = full_ff1;
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n || ~sync_reset_n) begin
|
|
WrPtr <= 'd0;
|
|
WrPtrp1 <= 'd1;
|
|
end
|
|
else if (WrEn0 && WrEn1) begin
|
|
WrPtr <= WrPtr + 'd2;
|
|
WrPtrp1 <= WrPtr + 'd3;
|
|
end
|
|
else if (WrEn0 || WrEn1) begin
|
|
WrPtr <= WrPtr + 'd1;
|
|
WrPtrp1 <= WrPtr + 'd2;
|
|
end
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n || ~sync_reset_n) begin
|
|
RdPtr <= 'd0;
|
|
end
|
|
else if (RdEn) begin
|
|
RdPtr <= RdPtr + 'd1;
|
|
end
|
|
end
|
|
|
|
always @ (posedge clkin) begin
|
|
if (WrEn0 && WrEn1)
|
|
begin
|
|
MemArray[WrPtr] <= DataIn0;
|
|
MemArray[WrPtrp1] <= DataIn1;
|
|
end
|
|
else if (WrEn0)
|
|
MemArray[WrPtr] <= DataIn0;
|
|
else if (WrEn1)
|
|
MemArray[WrPtr] <= DataIn1;
|
|
end
|
|
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n || ~sync_reset_n)
|
|
FifoCntr <= 'd0;
|
|
else if (WrEn0 && WrEn1 && ~RdDeQ)
|
|
FifoCntr <= FifoCntr +'d2;
|
|
else if (((WrEn0 || WrEn1) && ~RdDeQ) ||
|
|
((WrEn0 && WrEn1) && RdDeQ))
|
|
FifoCntr <= FifoCntr +'d1;
|
|
else if (~(WrEn0 || WrEn1) && RdDeQ)
|
|
FifoCntr <= FifoCntr -'d1;
|
|
else
|
|
FifoCntr <= FifoCntr;
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n || ~sync_reset_n)
|
|
empty_ff <= 1'b1;
|
|
else if((FifoCntr==0) || ((FifoCntr==1) && RdEn))
|
|
empty_ff <= 1'b1;
|
|
else if(FifoCntr>0)
|
|
empty_ff <= 1'b0;
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n || ~sync_reset_n)
|
|
almost_empty_ff <= 1'b1;
|
|
else if(FifoCntr>(AE_THRESHOLD))
|
|
almost_empty_ff <= 1'b0;
|
|
else if(FifoCntr<=(AE_THRESHOLD))
|
|
almost_empty_ff <= 1'b1;
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n || ~sync_reset_n)
|
|
full_ff0 <= 1'b0;
|
|
else if ((FifoCntr==(BUF_DEPTH)) ||
|
|
((FifoCntr==(BUF_DEPTH-1)) && (WrEn0 || WrEn1)) ||
|
|
((FifoCntr==(BUF_DEPTH-2)) && (WrEn0 && WrEn1)))
|
|
full_ff0 <= 1'b1;
|
|
else if(FifoCntr<BUF_DEPTH)
|
|
full_ff0 <= 1'b0;
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n || ~sync_reset_n)
|
|
full_ff1 <= 1'b0;
|
|
else if ((FifoCntr==(BUF_DEPTH-1)) ||
|
|
((FifoCntr==(BUF_DEPTH-2)) && (WrEn0 || WrEn1)) ||
|
|
((FifoCntr==(BUF_DEPTH-3)) && (WrEn0 && WrEn1)))
|
|
full_ff1 <= 1'b1;
|
|
else if(FifoCntr<BUF_DEPTH-1)
|
|
full_ff1 <= 1'b0;
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n || ~sync_reset_n)
|
|
almost_full_ff <= 1'b0;
|
|
else if(FifoCntr>(AF_THRESHOLD))
|
|
almost_full_ff <= 1'b1;
|
|
else if(FifoCntr<=(AF_THRESHOLD))
|
|
almost_full_ff <= 1'b0;
|
|
end
|
|
endmodule
|
|
module xdma_v4_1_20_GenericFIFO
|
|
#(parameter BUF_DATAWIDTH = 256,
|
|
parameter BUF_WE = BUF_DATAWIDTH/8,
|
|
parameter BUF_DEPTH = 512,
|
|
parameter BUF_PTR = (BUF_DEPTH <=2) ? 1:
|
|
(BUF_DEPTH <=4) ? 2:
|
|
(BUF_DEPTH <=8) ? 3:
|
|
(BUF_DEPTH <=16) ? 4:
|
|
(BUF_DEPTH <=32) ? 5:
|
|
(BUF_DEPTH <=64) ? 6:
|
|
(BUF_DEPTH <=128) ? 7:
|
|
(BUF_DEPTH <=256) ? 8:
|
|
(BUF_DEPTH <=512) ? 9:
|
|
(BUF_DEPTH <=1024) ? 10 : -1,
|
|
parameter AE_THRESHOLD = BUF_DEPTH >> 2,
|
|
parameter AF_THRESHOLD = BUF_DEPTH - 2
|
|
)
|
|
(
|
|
input clkin,
|
|
input reset_n,
|
|
input sync_reset_n,
|
|
input [BUF_DATAWIDTH-1:0] DataIn,
|
|
output [BUF_DATAWIDTH-1:0] DataOut,
|
|
input WrEn,
|
|
input RdEn,
|
|
output almost_empty,
|
|
output almost_full,
|
|
output empty,
|
|
output full
|
|
);
|
|
(* ram_style = "DISTRIBUTED" *)
|
|
reg [BUF_DATAWIDTH-1:0] MemArray [BUF_DEPTH-1:0];
|
|
(* max_fanout = 128 *) reg [BUF_PTR-1:0] WrPtr;
|
|
(* max_fanout = 128 *) reg [BUF_PTR-1:0] RdPtr;
|
|
reg [BUF_PTR:0] FifoCntrWr;
|
|
reg [BUF_PTR:0] FifoCntrRd;
|
|
wire WriteQ, RdDeQ;
|
|
reg almost_empty_ff;
|
|
reg almost_full_ff;
|
|
reg empty_ff;
|
|
reg full_ff;
|
|
assign WriteQ = WrEn;
|
|
assign RdDeQ = RdEn;
|
|
assign DataOut = MemArray[RdPtr];
|
|
assign almost_empty = almost_empty_ff;
|
|
assign almost_full = almost_full_ff;
|
|
assign empty = empty_ff;
|
|
assign full = full_ff;
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n)
|
|
WrPtr <= 'd0;
|
|
else if (~sync_reset_n)
|
|
WrPtr <= 'd0;
|
|
else if (WrEn) begin
|
|
WrPtr <= WrPtr + 'd1;
|
|
end
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n)
|
|
RdPtr <= 'd0;
|
|
else if (~sync_reset_n)
|
|
RdPtr <= 'd0;
|
|
else if (RdEn) begin
|
|
RdPtr <= RdPtr + 'd1;
|
|
end
|
|
end
|
|
|
|
always @ (posedge clkin) begin
|
|
if (WrEn)
|
|
MemArray[WrPtr] <= DataIn;
|
|
end
|
|
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n)
|
|
FifoCntrWr <= 'd0;
|
|
else if (~sync_reset_n)
|
|
FifoCntrWr <= 'd0;
|
|
else if ((WrEn & RdDeQ) | (~WrEn & ~RdDeQ))begin
|
|
FifoCntrWr <= FifoCntrWr;
|
|
end
|
|
else if (WrEn) begin
|
|
FifoCntrWr <= FifoCntrWr +'d1;
|
|
end
|
|
else begin
|
|
FifoCntrWr <= FifoCntrWr -'d1;
|
|
end
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n)
|
|
FifoCntrRd <= 'd0;
|
|
else if (~sync_reset_n)
|
|
FifoCntrRd <= 'd0;
|
|
else if ((RdEn & WriteQ) | (~RdEn & ~WriteQ)) begin
|
|
FifoCntrRd <= FifoCntrRd;
|
|
end
|
|
else if (WriteQ) begin
|
|
FifoCntrRd <= FifoCntrRd +'d1;
|
|
end
|
|
else begin
|
|
FifoCntrRd <= FifoCntrRd -'d1;
|
|
end
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n)
|
|
empty_ff <= 1'b1;
|
|
else if (~sync_reset_n)
|
|
empty_ff <= 1'b1;
|
|
else if((FifoCntrRd==0) || ((FifoCntrRd==1) && RdEn))
|
|
empty_ff <= 1'b1;
|
|
else if(FifoCntrRd>0)
|
|
empty_ff <= 1'b0;
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n)
|
|
almost_empty_ff <= 1'b1;
|
|
else if (~sync_reset_n)
|
|
almost_empty_ff <= 1'b1;
|
|
else if(FifoCntrRd>(AE_THRESHOLD))
|
|
almost_empty_ff <= 1'b0;
|
|
else if(FifoCntrRd<=(AE_THRESHOLD))
|
|
almost_empty_ff <= 1'b1;
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n)
|
|
full_ff <= 1'b0;
|
|
else if (~sync_reset_n)
|
|
full_ff <= 1'b0;
|
|
else if((FifoCntrWr==(BUF_DEPTH)) || ((FifoCntrWr==(BUF_DEPTH-1)) && WriteQ))
|
|
full_ff <= 1'b1;
|
|
else if(FifoCntrWr<BUF_DEPTH)
|
|
full_ff <= 1'b0;
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n)
|
|
almost_full_ff <= 1'b0;
|
|
else if (~sync_reset_n)
|
|
almost_full_ff <= 1'b0;
|
|
else if(FifoCntrWr>(AF_THRESHOLD))
|
|
almost_full_ff <= 1'b1;
|
|
else if(FifoCntrWr<=(AF_THRESHOLD))
|
|
almost_full_ff <= 1'b0;
|
|
end
|
|
endmodule
|
|
|
|
module xdma_v4_1_20_GenericFIFOAsyncNoHead
|
|
#(parameter BUF_DATAWIDTH = 256,
|
|
parameter BUF_WE = BUF_DATAWIDTH/8,
|
|
parameter BUF_DEPTH = 512,
|
|
parameter BUF_PTR = (BUF_DEPTH <=2) ? 1:
|
|
(BUF_DEPTH <=4) ? 2:
|
|
(BUF_DEPTH <=8) ? 3:
|
|
(BUF_DEPTH <=16) ? 4:
|
|
(BUF_DEPTH <=32) ? 5:
|
|
(BUF_DEPTH <=64) ? 6:
|
|
(BUF_DEPTH <=128) ? 7:
|
|
(BUF_DEPTH <=256) ? 8:
|
|
(BUF_DEPTH <=512) ? 9:
|
|
(BUF_DEPTH <=1024) ? 10 : -1
|
|
)
|
|
(
|
|
input clkin,
|
|
input reset_n,
|
|
input clkout,
|
|
input reseto_n,
|
|
input [BUF_DATAWIDTH-1:0] DataIn,
|
|
output [BUF_DATAWIDTH-1:0] DataOut,
|
|
input WrEn,
|
|
input RdEn,
|
|
output almost_empty,
|
|
output almost_full,
|
|
output empty,
|
|
output full
|
|
);
|
|
(* ram_style = "DISTRIBUTED" *)
|
|
reg [BUF_DATAWIDTH-1:0] MemArray [BUF_DEPTH-1:0];
|
|
(* max_fanout = 128 *) reg [BUF_PTR-1:0] WrPtr;
|
|
(* max_fanout = 128 *) reg [BUF_PTR-1:0] RdPtr;
|
|
reg [BUF_PTR:0] FifoCntrWr;
|
|
reg [BUF_PTR:0] FifoCntrRd;
|
|
wire WriteQ, RdDeQ;
|
|
reg almost_empty_ff;
|
|
reg almost_full_ff;
|
|
reg empty_ff;
|
|
reg full_ff;
|
|
assign WriteQ = WrEn;
|
|
assign RdDeQ = RdEn;
|
|
|
|
assign DataOut = MemArray[RdPtr];
|
|
|
|
assign almost_empty = almost_empty_ff;
|
|
assign almost_full = almost_full_ff;
|
|
assign empty = empty_ff;
|
|
assign full = full_ff;
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
WrPtr <= 'd0;
|
|
end
|
|
else if (WrEn) begin
|
|
WrPtr <= WrPtr + 'd1;
|
|
end
|
|
end
|
|
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
RdPtr <= 'd0;
|
|
end else if (RdEn) begin
|
|
RdPtr <= RdPtr + 'd1;
|
|
end
|
|
end
|
|
|
|
always @ (posedge clkin) begin
|
|
if (WrEn)
|
|
MemArray[WrPtr] <= DataIn;
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
FifoCntrWr <= 'd0;
|
|
end
|
|
else if ((WrEn & RdDeQ) | (~WrEn & ~RdDeQ))begin
|
|
FifoCntrWr <= FifoCntrWr;
|
|
end
|
|
else if (WrEn) begin
|
|
FifoCntrWr <= FifoCntrWr +'d1;
|
|
end
|
|
else begin
|
|
FifoCntrWr <= FifoCntrWr -'d1;
|
|
end
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
FifoCntrRd <= 'd0;
|
|
end
|
|
else if ((RdEn & WriteQ) | (~RdEn & ~WriteQ)) begin
|
|
FifoCntrRd <= FifoCntrRd;
|
|
end
|
|
else if (WriteQ) begin
|
|
FifoCntrRd <= FifoCntrRd +'d1;
|
|
end
|
|
else begin
|
|
FifoCntrRd <= FifoCntrRd -'d1;
|
|
end
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
almost_empty_ff <= 1'b1;
|
|
empty_ff <= 1'b1;
|
|
end
|
|
else begin
|
|
if((FifoCntrRd==0) || ((FifoCntrRd==1) && RdEn)) begin
|
|
empty_ff <= 1'b1;
|
|
end
|
|
else if(FifoCntrRd>0) begin
|
|
empty_ff <= 1'b0;
|
|
end
|
|
|
|
if((FifoCntrRd==0) || ((FifoCntrRd==1) && RdEn)) begin
|
|
almost_empty_ff <= 1'b1;
|
|
end
|
|
else if(FifoCntrRd>(BUF_DEPTH>>2)) begin
|
|
almost_empty_ff <= 1'b0;
|
|
end
|
|
else if(FifoCntrRd<=(BUF_DEPTH>>2)) begin
|
|
almost_empty_ff <= 1'b1;
|
|
end
|
|
end
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
almost_full_ff <= 1'b0;
|
|
full_ff <= 1'b0;
|
|
end
|
|
else begin
|
|
if((FifoCntrWr==(BUF_DEPTH)) || ((FifoCntrWr==(BUF_DEPTH-1)) && WriteQ)) begin
|
|
full_ff <= 1'b1;
|
|
end
|
|
else if (FifoCntrWr<BUF_DEPTH) begin
|
|
full_ff <= 1'b0;
|
|
end
|
|
|
|
if((FifoCntrWr==(BUF_DEPTH)) || ((FifoCntrWr==(BUF_DEPTH-1)) && WriteQ)) begin
|
|
almost_full_ff <= 1'b1;
|
|
end
|
|
else if(FifoCntrWr>(BUF_DEPTH-2)) begin
|
|
almost_full_ff <= 1'b1;
|
|
end
|
|
else if(FifoCntrWr<=(BUF_DEPTH-2)) begin
|
|
almost_full_ff <= 1'b0;
|
|
end
|
|
end
|
|
end
|
|
endmodule
|
|
|
|
module xdma_v4_1_20_GenericFIFOAsync
|
|
#(parameter BUF_DATAWIDTH = 256,
|
|
parameter BUF_WE = BUF_DATAWIDTH/8,
|
|
parameter BUF_DEPTH = 512,
|
|
parameter BUF_PTR = (BUF_DEPTH <=2) ? 1:
|
|
(BUF_DEPTH <=4) ? 2:
|
|
(BUF_DEPTH <=8) ? 3:
|
|
(BUF_DEPTH <=16) ? 4:
|
|
(BUF_DEPTH <=32) ? 5:
|
|
(BUF_DEPTH <=64) ? 6:
|
|
(BUF_DEPTH <=128) ? 7:
|
|
(BUF_DEPTH <=256) ? 8:
|
|
(BUF_DEPTH <=512) ? 9:
|
|
(BUF_DEPTH <=1024) ? 10 : -1,
|
|
parameter AE_THRESHOLD = BUF_DEPTH >> 2,
|
|
parameter AF_THRESHOLD = BUF_DEPTH - 2
|
|
)
|
|
(
|
|
input clkin,
|
|
input reset_n,
|
|
input clkout,
|
|
input reseto_n,
|
|
input [BUF_DATAWIDTH-1:0] DataIn,
|
|
output [BUF_DATAWIDTH-1:0] DataOut,
|
|
input WrEn,
|
|
input RdEn,
|
|
output almost_empty,
|
|
output almost_full,
|
|
output empty,
|
|
output full
|
|
);
|
|
|
|
(* ram_style = "DISTRIBUTED" *)
|
|
reg [BUF_DATAWIDTH-1:0] MemArray [BUF_DEPTH-1:0];
|
|
(* max_fanout = 128 *) reg [BUF_PTR-1:0] WrPtr;
|
|
(* max_fanout = 128 *) reg [BUF_PTR-1:0] RdPtr;
|
|
reg [BUF_PTR:0] FifoCntrWr;
|
|
reg [BUF_PTR:0] FifoCntrRd;
|
|
wire WriteQ, RdDeQ;
|
|
reg almost_empty_ff;
|
|
reg almost_full_ff;
|
|
reg empty_ff;
|
|
reg full_ff;
|
|
assign WriteQ = WrEn;
|
|
assign RdDeQ = RdEn;
|
|
|
|
reg [BUF_DATAWIDTH-1:0] Head;
|
|
|
|
assign almost_empty = almost_empty_ff;
|
|
assign almost_full = almost_full_ff;
|
|
assign empty = empty_ff;
|
|
assign full = full_ff;
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
WrPtr <= 'd0;
|
|
end
|
|
else if (WrEn) begin
|
|
WrPtr <= WrPtr + 'd1;
|
|
end
|
|
end
|
|
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
RdPtr <= 'd0;
|
|
end
|
|
else if ((RdEn && (FifoCntrRd>1) ) ||
|
|
(WrEn && (FifoCntrRd==0) ) ||
|
|
(RdEn && WrEn && (FifoCntrRd==1)))begin
|
|
RdPtr <= RdPtr + 'd1;
|
|
end
|
|
end
|
|
|
|
always @(posedge clkin) begin
|
|
if (WrEn)
|
|
MemArray[WrPtr] <= DataIn;
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
FifoCntrWr <= 'd0;
|
|
end
|
|
else if ((WrEn & RdDeQ) | (~WrEn & ~RdDeQ))begin
|
|
FifoCntrWr <= FifoCntrWr;
|
|
end
|
|
else if (WrEn) begin
|
|
FifoCntrWr <= FifoCntrWr +'d1;
|
|
end
|
|
else begin
|
|
FifoCntrWr <= FifoCntrWr -'d1;
|
|
end
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
FifoCntrRd <= 'd0;
|
|
end
|
|
else if ((RdEn & WriteQ) | (~RdEn & ~WriteQ)) begin
|
|
FifoCntrRd <= FifoCntrRd;
|
|
end
|
|
else if (WriteQ) begin
|
|
FifoCntrRd <= FifoCntrRd +'d1;
|
|
end
|
|
else begin
|
|
FifoCntrRd <= FifoCntrRd -'d1;
|
|
end
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
almost_empty_ff <= 1'b1;
|
|
empty_ff <= 1'b1;
|
|
end
|
|
else begin
|
|
if((FifoCntrRd==0) || ((FifoCntrRd==1) && RdEn)) begin
|
|
empty_ff <= 1'b1;
|
|
end
|
|
else if(FifoCntrRd>0) begin
|
|
empty_ff <= 1'b0;
|
|
end
|
|
|
|
if((FifoCntrRd==0) || ((FifoCntrRd==1) && RdEn)) begin
|
|
almost_empty_ff <= 1'b1;
|
|
end
|
|
else if(FifoCntrRd>(AE_THRESHOLD)) begin
|
|
almost_empty_ff <= 1'b0;
|
|
end
|
|
else if(FifoCntrRd<=(AE_THRESHOLD)) begin
|
|
almost_empty_ff <= 1'b1;
|
|
end
|
|
end
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
almost_full_ff <= 1'b0;
|
|
full_ff <= 1'b0;
|
|
end
|
|
else begin
|
|
if((FifoCntrWr==(BUF_DEPTH)) || ((FifoCntrWr==(BUF_DEPTH-1)) && WriteQ)) begin
|
|
full_ff <= 1'b1;
|
|
end
|
|
else if (FifoCntrWr<BUF_DEPTH) begin
|
|
full_ff <= 1'b0;
|
|
end
|
|
|
|
if((FifoCntrWr==(BUF_DEPTH)) || ((FifoCntrWr==(BUF_DEPTH-1)) && WriteQ)) begin
|
|
almost_full_ff <= 1'b1;
|
|
end
|
|
else if(FifoCntrWr>(AF_THRESHOLD)) begin
|
|
almost_full_ff <= 1'b1;
|
|
end
|
|
else if(FifoCntrWr<=(AF_THRESHOLD)) begin
|
|
almost_full_ff <= 1'b0;
|
|
end
|
|
end
|
|
end
|
|
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
Head <= 1'b0;
|
|
end
|
|
else begin
|
|
if ((WrEn && (FifoCntrRd == 0)) || (WrEn && RdEn && (FifoCntrRd == 1)))
|
|
Head <= DataIn;
|
|
else if (RdEn || (FifoCntrRd == 0))
|
|
Head <= MemArray[RdPtr];
|
|
end
|
|
end
|
|
assign DataOut = Head;
|
|
|
|
endmodule
|
|
|
|
module xdma_v4_1_20_GenericFIFOHead
|
|
#(parameter BUF_DATAWIDTH = 256,
|
|
parameter BUF_WE = BUF_DATAWIDTH/8,
|
|
parameter BUF_DEPTH = 512,
|
|
parameter BUF_PTR = (BUF_DEPTH <=2) ? 1:
|
|
(BUF_DEPTH <=4) ? 2:
|
|
(BUF_DEPTH <=8) ? 3:
|
|
(BUF_DEPTH <=16) ? 4:
|
|
(BUF_DEPTH <=32) ? 5:
|
|
(BUF_DEPTH <=64) ? 6:
|
|
(BUF_DEPTH <=128) ? 7:
|
|
(BUF_DEPTH <=256) ? 8:
|
|
(BUF_DEPTH <=512) ? 9:
|
|
(BUF_DEPTH <=1024) ? 10 : -1,
|
|
parameter AE_THRESHOLD = BUF_DEPTH >> 2,
|
|
parameter AF_THRESHOLD = BUF_DEPTH - 2
|
|
)
|
|
(
|
|
input clkin,
|
|
input reset_n,
|
|
input sync_reset_n,
|
|
input [BUF_DATAWIDTH-1:0] DataIn,
|
|
output [BUF_DATAWIDTH-1:0] DataOut,
|
|
input WrEn,
|
|
input WrAlloc,
|
|
input RdEn,
|
|
output almost_empty,
|
|
output almost_full,
|
|
output empty,
|
|
output full
|
|
);
|
|
|
|
(* ram_style = "DISTRIBUTED" *)
|
|
reg [BUF_DATAWIDTH-1:0] MemArray [BUF_DEPTH-1:0];
|
|
(* max_fanout = 128 *) reg [BUF_PTR-1:0] WrPtr;
|
|
(* max_fanout = 128 *) reg [BUF_PTR-1:0] RdPtr;
|
|
reg [BUF_PTR:0] FifoCntrWr;
|
|
reg [BUF_PTR:0] FifoCntrRd;
|
|
wire WriteQ, RdDeQ;
|
|
reg almost_empty_ff;
|
|
reg almost_full_ff;
|
|
reg empty_ff;
|
|
reg full_ff;
|
|
assign WriteQ = WrEn;
|
|
assign RdDeQ = RdEn;
|
|
|
|
reg [BUF_DATAWIDTH-1:0] Head;
|
|
|
|
assign almost_empty = almost_empty_ff;
|
|
assign almost_full = almost_full_ff;
|
|
assign empty = empty_ff;
|
|
assign full = full_ff;
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
WrPtr <= 'd0;
|
|
end
|
|
else if (~sync_reset_n)
|
|
WrPtr <= 'd0;
|
|
else if (WrEn) begin
|
|
WrPtr <= WrPtr + 'd1;
|
|
end
|
|
end
|
|
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
RdPtr <= 'd0;
|
|
end
|
|
else if (~sync_reset_n)
|
|
RdPtr <= 'd0;
|
|
else if ((RdEn && (FifoCntrRd>1) ) ||
|
|
(WrEn && (FifoCntrRd==0) ) ||
|
|
(RdEn && WrEn && (FifoCntrRd==1)))begin
|
|
RdPtr <= RdPtr + 'd1;
|
|
end
|
|
end
|
|
|
|
always @(posedge clkin) begin
|
|
if (WrEn)
|
|
MemArray[WrPtr] <= DataIn;
|
|
end
|
|
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
FifoCntrWr <= 'd0;
|
|
end
|
|
else if (~sync_reset_n)
|
|
FifoCntrWr <= 'd0;
|
|
else if ((WrAlloc & RdDeQ) | (~WrAlloc & ~RdDeQ))begin
|
|
FifoCntrWr <= FifoCntrWr;
|
|
end
|
|
else if (WrAlloc) begin
|
|
FifoCntrWr <= FifoCntrWr +'d1;
|
|
end
|
|
else begin
|
|
FifoCntrWr <= FifoCntrWr -'d1;
|
|
end
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
FifoCntrRd <= 'd0;
|
|
end
|
|
else if (~sync_reset_n)
|
|
FifoCntrRd <= 'd0;
|
|
else if ((RdEn & WriteQ) | (~RdEn & ~WriteQ)) begin
|
|
FifoCntrRd <= FifoCntrRd;
|
|
end
|
|
else if (WriteQ) begin
|
|
FifoCntrRd <= FifoCntrRd +'d1;
|
|
end
|
|
else begin
|
|
FifoCntrRd <= FifoCntrRd -'d1;
|
|
end
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
almost_empty_ff <= 1'b1;
|
|
empty_ff <= 1'b1;
|
|
end
|
|
else if (~sync_reset_n) begin
|
|
almost_empty_ff <= 1'b1;
|
|
empty_ff <= 1'b1;
|
|
end
|
|
else begin
|
|
if((FifoCntrRd==0) || ((FifoCntrRd==1) && RdEn)) begin
|
|
empty_ff <= 1'b1;
|
|
end
|
|
else if(FifoCntrRd>0) begin
|
|
empty_ff <= 1'b0;
|
|
end
|
|
|
|
if((FifoCntrRd==0) || ((FifoCntrRd==1) && RdEn)) begin
|
|
almost_empty_ff <= 1'b1;
|
|
end
|
|
else if(FifoCntrRd>(AE_THRESHOLD)) begin
|
|
almost_empty_ff <= 1'b0;
|
|
end
|
|
else if(FifoCntrRd<=(AE_THRESHOLD)) begin
|
|
almost_empty_ff <= 1'b1;
|
|
end
|
|
end
|
|
end
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
almost_full_ff <= 1'b0;
|
|
full_ff <= 1'b0;
|
|
end
|
|
else if (~sync_reset_n) begin
|
|
almost_full_ff <= 1'b0;
|
|
full_ff <= 1'b0;
|
|
end
|
|
else begin
|
|
if((FifoCntrWr==(BUF_DEPTH)) || ((FifoCntrWr==(BUF_DEPTH-1)) && WriteQ)) begin
|
|
full_ff <= 1'b1;
|
|
end
|
|
else if (FifoCntrWr<BUF_DEPTH) begin
|
|
full_ff <= 1'b0;
|
|
end
|
|
|
|
if((FifoCntrWr==(BUF_DEPTH)) || ((FifoCntrWr==(BUF_DEPTH-1)) && WriteQ)) begin
|
|
almost_full_ff <= 1'b1;
|
|
end
|
|
else if((FifoCntrWr>AF_THRESHOLD) || ((FifoCntrWr == AF_THRESHOLD) && WriteQ)) begin
|
|
almost_full_ff <= 1'b1;
|
|
end
|
|
else if(FifoCntrWr<=(AF_THRESHOLD)) begin
|
|
almost_full_ff <= 1'b0;
|
|
end
|
|
end
|
|
end
|
|
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
Head <= 1'b0;
|
|
end
|
|
else if (~sync_reset_n) begin
|
|
Head <= 1'b0;
|
|
end
|
|
else begin
|
|
if ((WrEn && (FifoCntrRd == 0)) || (WrEn && RdEn && (FifoCntrRd == 1)))
|
|
Head <= DataIn;
|
|
else if (RdEn || (FifoCntrRd == 0))
|
|
Head <= MemArray[RdPtr];
|
|
end
|
|
end
|
|
assign DataOut = Head;
|
|
|
|
endmodule
|
|
|
|
module xdma_v4_1_20_GenericFIFOHead2
|
|
#(parameter BUF_DATAWIDTH = 256,
|
|
parameter BUF_WE = BUF_DATAWIDTH/8,
|
|
parameter BUF_DEPTH = 512,
|
|
parameter BUF_PTR = (BUF_DEPTH <=2) ? 1:
|
|
(BUF_DEPTH <=4) ? 2:
|
|
(BUF_DEPTH <=8) ? 3:
|
|
(BUF_DEPTH <=16) ? 4:
|
|
(BUF_DEPTH <=32) ? 5:
|
|
(BUF_DEPTH <=64) ? 6:
|
|
(BUF_DEPTH <=128) ? 7:
|
|
(BUF_DEPTH <=256) ? 8:
|
|
(BUF_DEPTH <=512) ? 9:
|
|
(BUF_DEPTH <=1024) ? 10 : -1,
|
|
parameter AE_THRESHOLD = BUF_DEPTH >> 2,
|
|
parameter AF_THRESHOLD = BUF_DEPTH - 2
|
|
)
|
|
(
|
|
input clkin,
|
|
input reset_n,
|
|
input sync_reset_n,
|
|
input [BUF_DATAWIDTH-1:0] DataIn,
|
|
output [BUF_DATAWIDTH-1:0] DataOut,
|
|
input WrEn,
|
|
input RdEn,
|
|
output almost_empty,
|
|
output almost_full,
|
|
output empty,
|
|
output full
|
|
);
|
|
|
|
(* ram_style = "DISTRIBUTED" *)
|
|
reg [BUF_DATAWIDTH-1:0] MemArray [BUF_DEPTH-1:0];
|
|
(* max_fanout = 128 *) reg [BUF_PTR-1:0] WrPtr;
|
|
(* max_fanout = 128 *) reg [BUF_PTR-1:0] RdPtr;
|
|
reg [BUF_PTR:0] FifoCntrWr;
|
|
reg [BUF_PTR:0] FifoCntrRd;
|
|
wire WriteQ, RdDeQ;
|
|
reg almost_empty_ff;
|
|
reg almost_full_ff;
|
|
reg empty_ff;
|
|
reg full_ff;
|
|
assign WriteQ = WrEn;
|
|
assign RdDeQ = RdEn;
|
|
|
|
reg [BUF_DATAWIDTH-1:0] Head;
|
|
|
|
assign almost_empty = almost_empty_ff;
|
|
assign almost_full = almost_full_ff;
|
|
assign empty = empty_ff;
|
|
assign full = full_ff;
|
|
|
|
`XLREG_XDMA (clkin, reset_n)
|
|
begin
|
|
if (~reset_n)
|
|
WrPtr <= 'd0;
|
|
else if (~sync_reset_n)
|
|
WrPtr <= 'd0;
|
|
else if (WrEn && (BUF_DEPTH > 1)) begin
|
|
WrPtr <= WrPtr + 'd1;
|
|
end
|
|
end
|
|
|
|
`XLREG_XDMA (clkin, reset_n)
|
|
begin
|
|
if (~reset_n)
|
|
RdPtr <= 'd0;
|
|
else if (~sync_reset_n) begin
|
|
RdPtr <= 'd0;
|
|
end
|
|
else if (BUF_DEPTH > 1)
|
|
begin
|
|
if ((RdEn && (FifoCntrRd>1) ) ||
|
|
(WrEn && (FifoCntrRd==0) ) ||
|
|
(RdEn && WrEn && (FifoCntrRd==1)))begin
|
|
RdPtr <= RdPtr + 'd1;
|
|
end
|
|
end
|
|
end
|
|
|
|
always @(posedge clkin) begin
|
|
if (WrEn)
|
|
MemArray[WrPtr] <= DataIn;
|
|
end
|
|
|
|
`XLREG_XDMA (clkin, reset_n)
|
|
begin
|
|
if (~reset_n)
|
|
FifoCntrWr <= 'd0;
|
|
else if (~sync_reset_n)
|
|
FifoCntrWr <= 'd0;
|
|
else if ((WrEn & RdDeQ) | (~WrEn & ~RdDeQ))begin
|
|
FifoCntrWr <= FifoCntrWr;
|
|
end
|
|
else if (WrEn) begin
|
|
FifoCntrWr <= FifoCntrWr +'d1;
|
|
end
|
|
else begin
|
|
FifoCntrWr <= FifoCntrWr -'d1;
|
|
end
|
|
end
|
|
`XLREG_XDMA (clkin, reset_n)
|
|
begin
|
|
if (~reset_n) begin
|
|
FifoCntrRd <= 'd0;
|
|
end
|
|
else if (~sync_reset_n) begin
|
|
FifoCntrRd <= 'd0;
|
|
end
|
|
else if ((RdEn & WriteQ) | (~RdEn & ~WriteQ)) begin
|
|
FifoCntrRd <= FifoCntrRd;
|
|
end
|
|
else if (WriteQ) begin
|
|
FifoCntrRd <= FifoCntrRd +'d1;
|
|
end
|
|
else begin
|
|
FifoCntrRd <= FifoCntrRd -'d1;
|
|
end
|
|
end
|
|
`XLREG_XDMA (clkin, reset_n)
|
|
begin
|
|
if (~reset_n) begin
|
|
almost_empty_ff <= 1'b1;
|
|
empty_ff <= 1'b1;
|
|
end
|
|
else if (~sync_reset_n) begin
|
|
almost_empty_ff <= 1'b1;
|
|
empty_ff <= 1'b1;
|
|
end
|
|
else begin
|
|
if(((FifoCntrRd==0) && ~WrEn) || ((FifoCntrRd==1) && RdEn && ~WrEn)) begin
|
|
empty_ff <= 1'b1;
|
|
end
|
|
else begin
|
|
empty_ff <= 1'b0;
|
|
end
|
|
|
|
if((FifoCntrRd==0) || ((FifoCntrRd==1) && RdEn && ~WrEn)) begin
|
|
almost_empty_ff <= 1'b1;
|
|
end
|
|
else if(FifoCntrRd>(AE_THRESHOLD)) begin
|
|
almost_empty_ff <= 1'b0;
|
|
end
|
|
else if(FifoCntrRd<=(AE_THRESHOLD)) begin
|
|
almost_empty_ff <= 1'b1;
|
|
end
|
|
end
|
|
end
|
|
|
|
`XLREG_XDMA (clkin, reset_n)
|
|
begin
|
|
if (~reset_n) begin
|
|
almost_full_ff <= 1'b0;
|
|
full_ff <= 1'b0;
|
|
end
|
|
else if (~sync_reset_n) begin
|
|
almost_full_ff <= 1'b0;
|
|
full_ff <= 1'b0;
|
|
end
|
|
else begin
|
|
if(((FifoCntrWr==(BUF_DEPTH+1)) && (~RdEn || WriteQ)) || ((FifoCntrWr==BUF_DEPTH) && WriteQ && ~RdEn)) begin
|
|
full_ff <= 1'b1;
|
|
end
|
|
else
|
|
begin
|
|
full_ff <= 1'b0;
|
|
end
|
|
|
|
if((FifoCntrWr>(BUF_DEPTH)) || ((FifoCntrWr==BUF_DEPTH) && WriteQ)) begin
|
|
almost_full_ff <= 1'b1;
|
|
end
|
|
else if((FifoCntrWr>AF_THRESHOLD) || ((FifoCntrWr == AF_THRESHOLD) && WriteQ)) begin
|
|
almost_full_ff <= 1'b1;
|
|
end
|
|
else if(FifoCntrWr<=(AF_THRESHOLD)) begin
|
|
almost_full_ff <= 1'b0;
|
|
end
|
|
end
|
|
end
|
|
|
|
`XLREG_XDMA(clkin, reset_n) begin
|
|
if (~reset_n) begin
|
|
Head <= 1'b0;
|
|
end
|
|
else if (~sync_reset_n) begin
|
|
Head <= 1'b0;
|
|
end
|
|
else begin
|
|
if ((WrEn && (FifoCntrRd == 0)) || (WrEn && RdEn && (FifoCntrRd == 1)))
|
|
Head <= DataIn;
|
|
else if (RdEn || (FifoCntrRd == 0))
|
|
Head <= MemArray[RdPtr];
|
|
end
|
|
end
|
|
assign DataOut = Head;
|
|
|
|
endmodule
|
|
|
|
/*
|
|
module xdma_v4_1_20_GenericBRAMFIFOHead #(
|
|
parameter TCQ = 0,
|
|
parameter BUF_DATAWIDTH = 256,
|
|
parameter BUF_WE = BUF_DATAWIDTH/8,
|
|
parameter BUF_DEPTH = 512,
|
|
parameter BUF_PTR = (BUF_DEPTH <=2) ? 1:
|
|
(BUF_DEPTH <=4) ? 2:
|
|
(BUF_DEPTH <=8) ? 3:
|
|
(BUF_DEPTH <=16) ? 4:
|
|
(BUF_DEPTH <=32) ? 5:
|
|
(BUF_DEPTH <=64) ? 6:
|
|
(BUF_DEPTH <=128) ? 7:
|
|
(BUF_DEPTH <=256) ? 8:
|
|
(BUF_DEPTH <=512) ? 9:
|
|
(BUF_DEPTH <=1024) ? 10 : -1,
|
|
parameter AE_THRESHOLD = BUF_DEPTH >> 2,
|
|
parameter AF_THRESHOLD = BUF_DEPTH - 2
|
|
)
|
|
(
|
|
input clk,
|
|
input rst,
|
|
input srst,
|
|
input [BUF_DATAWIDTH-1:0] DataIn,
|
|
output [BUF_DATAWIDTH-1:0] DataOut,
|
|
input WrEn,
|
|
input RdEn,
|
|
output almost_empty,
|
|
output almost_full,
|
|
output empty,
|
|
output full
|
|
);
|
|
|
|
(* ram_style = "BLOCK" *)
|
|
reg [BUF_DATAWIDTH-1:0] MemArray [BUF_DEPTH-1:0];
|
|
|
|
reg [BUF_PTR-1:0] WrPtr;
|
|
reg [BUF_PTR-1:0] WrPtr_nxt;
|
|
|
|
reg [BUF_PTR-1:0] RdPtr_nxt;
|
|
reg [BUF_PTR-1:0] RdPtr;
|
|
|
|
reg [BUF_PTR:0] FifoCntr_nxt;
|
|
reg [BUF_PTR:0] FifoCntr;
|
|
|
|
reg almost_empty_nxt;
|
|
reg almost_empty_ff;
|
|
reg almost_full_nxt;
|
|
reg almost_full_ff;
|
|
reg empty_nxt;
|
|
reg empty_ff;
|
|
reg full_nxt;
|
|
reg full_ff;
|
|
|
|
wire [BUF_DATAWIDTH-1:0] Head_nxt;
|
|
reg [BUF_DATAWIDTH-1:0] Head;
|
|
|
|
assign almost_empty = almost_empty_ff;
|
|
assign almost_full = almost_full_ff;
|
|
assign empty = empty_ff;
|
|
assign full = full_ff;
|
|
|
|
always @(*) begin
|
|
WrPtr_nxt = WrPtr;
|
|
if (srst)
|
|
WrPtr_nxt = 'h0;
|
|
else if (WrEn)
|
|
WrPtr_nxt = WrPtr + 'd1;
|
|
end
|
|
`XSRREG_XDMA(clk, ~rst, WrPtr, WrPtr_nxt, 'h0)
|
|
|
|
always @(*) begin
|
|
RdPtr_nxt = RdPtr;
|
|
if (srst) begin
|
|
RdPtr_nxt = 'h0;
|
|
end
|
|
else if ((RdEn && (FifoCntr > 1) ) ||
|
|
(WrEn && (FifoCntr == 0) ) ||
|
|
(RdEn && WrEn && (FifoCntr == 1)))begin
|
|
RdPtr_nxt = RdPtr + 'd1;
|
|
end
|
|
end
|
|
`XSRREG_XDMA(clk, ~rst, RdPtr, RdPtr_nxt, 'h0)
|
|
|
|
always @(posedge clk) begin
|
|
if (WrEn)
|
|
MemArray[WrPtr] <= DataIn;
|
|
end
|
|
|
|
always @(*) begin
|
|
FifoCntr_nxt = FifoCntr;
|
|
if (srst)
|
|
FifoCntr_nxt = 'd0;
|
|
else if ((RdEn & WrEn) | (~RdEn & ~WrEn))
|
|
FifoCntr_nxt = FifoCntr;
|
|
else if (WrEn)
|
|
FifoCntr_nxt = FifoCntr +'d1;
|
|
else
|
|
FifoCntr_nxt = FifoCntr -'d1;
|
|
end
|
|
`XSRREG_XDMA(clk, ~rst, FifoCntr, FifoCntr_nxt, 'h0)
|
|
|
|
always @(*) begin
|
|
almost_empty_nxt = almost_empty_ff;
|
|
empty_nxt = empty_ff;
|
|
|
|
if (srst) begin
|
|
almost_empty_nxt= 1'b1;
|
|
empty_nxt = 1'b1;
|
|
end
|
|
else begin
|
|
if((FifoCntr==0) || ((FifoCntr==1) && RdEn))
|
|
empty_nxt = 1'b1;
|
|
else if(FifoCntr > 0)
|
|
empty_nxt = 1'b0;
|
|
|
|
if((FifoCntr==0) || ((FifoCntr==1) && RdEn))
|
|
almost_empty_nxt = 1'b1;
|
|
else if(FifoCntr > AE_THRESHOLD)
|
|
almost_empty_nxt = 1'b0;
|
|
else if(FifoCntr <= AE_THRESHOLD)
|
|
almost_empty_nxt = 1'b1;
|
|
end
|
|
end
|
|
`XSRREG_XDMA(clk, ~rst, almost_empty_ff, almost_empty_nxt, 'h0)
|
|
`XSRREG_XDMA(clk, ~rst, empty_ff, empty_nxt, 'h0)
|
|
|
|
|
|
always @(*) begin
|
|
full_nxt = full_ff;
|
|
almost_full_nxt = almost_full_ff;
|
|
if (srst) begin
|
|
almost_full_nxt = 1'b0;
|
|
full_nxt = 1'b0;
|
|
end
|
|
else begin
|
|
if((FifoCntr==(BUF_DEPTH)) || ((FifoCntr==(BUF_DEPTH-1)) && WrEn))
|
|
full_nxt = 1'b1;
|
|
else if (FifoCntr<BUF_DEPTH)
|
|
full_nxt = 1'b0;
|
|
|
|
if((FifoCntr==(BUF_DEPTH)) || ((FifoCntr==(BUF_DEPTH-1)) && WrEn))
|
|
almost_full_nxt = 1'b1;
|
|
else if(FifoCntr > AF_THRESHOLD)
|
|
almost_full_nxt = 1'b1;
|
|
else if(FifoCntr <= AF_THRESHOLD)
|
|
almost_full_nxt = 1'b0;
|
|
end
|
|
end
|
|
`XSRREG_XDMA(clk, ~rst, almost_full_ff, almost_full_nxt, 'h0)
|
|
`XSRREG_XDMA(clk, ~rst, full_ff, full_nxt, 'h0)
|
|
|
|
assign Head_nxt = (srst) ? 'h0 :
|
|
((WrEn && (FifoCntr == 0)) || (WrEn && RdEn && (FifoCntr == 1))) ? DataIn :
|
|
(RdEn || (FifoCntr == 0)) ? MemArray[RdPtr] :
|
|
Head;
|
|
|
|
`XSRREG_XDMA(clk, ~rst, Head, Head_nxt, 'h0)
|
|
assign DataOut = Head;
|
|
|
|
endmodule
|
|
*/
|
|
`endif // AXI_BRIDGE_VH
|