1
0
mirror of https://github.com/corundum/corundum.git synced 2025-01-16 08:12:53 +08:00

Add TX underflow error signal

This commit is contained in:
Alex Forencich 2019-03-26 12:42:08 -07:00
parent b691a30760
commit 585ccefa15
47 changed files with 292 additions and 21 deletions

View File

@ -67,7 +67,8 @@ module axis_baser_tx_64 #
* Status
*/
output wire start_packet_0,
output wire start_packet_4
output wire start_packet_4,
output wire error_underflow
);
// bus width assertions
@ -211,6 +212,7 @@ reg [3:0] output_type_reg = OUTPUT_TYPE_IDLE, output_type_next;
reg start_packet_0_reg = 1'b0, start_packet_0_next;
reg start_packet_4_reg = 1'b0, start_packet_4_next;
reg error_underflow_reg = 1'b0, error_underflow_next;
assign s_axis_tready = s_axis_tready_reg;
@ -219,6 +221,7 @@ assign encoded_tx_hdr = encoded_tx_hdr_reg;
assign start_packet_0 = start_packet_0_reg;
assign start_packet_4 = start_packet_4_reg;
assign error_underflow = error_underflow_reg;
lfsr #(
.LFSR_WIDTH(32),
@ -474,6 +477,7 @@ always @* begin
start_packet_0_next = 1'b0;
start_packet_4_next = 1'b0;
error_underflow_next = 1'b0;
case (state_reg)
STATE_IDLE: begin
@ -554,10 +558,11 @@ always @* begin
state_next = STATE_PAYLOAD;
end
end else begin
// tvalid deassert, fail framec
// tvalid deassert, fail frame
output_type_next = OUTPUT_TYPE_ERROR;
frame_ptr_next = 16'd0;
ifg_count_next = 8'd8;
error_underflow_next = 1'b1;
state_next = STATE_WAIT_END;
end
end
@ -728,6 +733,7 @@ always @(posedge clk) begin
start_packet_0_reg <= 1'b0;
start_packet_4_reg <= 1'b0;
error_underflow_reg <= 1'b0;
crc_state <= 32'hFFFFFFFF;
@ -747,6 +753,7 @@ always @(posedge clk) begin
start_packet_0_reg <= start_packet_0_next;
start_packet_4_reg <= start_packet_4_next;
error_underflow_reg <= error_underflow_next;
delay_type_valid <= 1'b0;

View File

@ -68,7 +68,8 @@ module axis_gmii_tx #
/*
* Status
*/
output wire start_packet
output wire start_packet,
output wire error_underflow
);
localparam [7:0]
@ -105,6 +106,7 @@ reg gmii_tx_er_reg = 1'b0, gmii_tx_er_next;
reg s_axis_tready_reg = 1'b0, s_axis_tready_next;
reg start_packet_reg = 1'b0, start_packet_next;
reg error_underflow_reg = 1'b0, error_underflow_next;
reg [31:0] crc_state = 32'hFFFFFFFF;
wire [31:0] crc_next;
@ -116,6 +118,7 @@ assign gmii_tx_en = gmii_tx_en_reg;
assign gmii_tx_er = gmii_tx_er_reg;
assign start_packet = start_packet_reg;
assign error_underflow = error_underflow_reg;
lfsr #(
.LFSR_WIDTH(32),
@ -153,6 +156,7 @@ always @* begin
gmii_tx_er_next = 1'b0;
start_packet_next = 1'b0;
error_underflow_next = 1'b0;
if (!clk_enable) begin
// clock disabled - hold state and outputs
@ -243,6 +247,7 @@ always @* begin
// tvalid deassert, fail frame
gmii_tx_er_next = 1'b1;
frame_ptr_next = 16'd0;
error_underflow_next = 1'b1;
state_next = STATE_WAIT_END;
end
end
@ -364,6 +369,7 @@ always @(posedge clk) begin
gmii_tx_er_reg <= 1'b0;
start_packet_reg <= 1'b0;
error_underflow_reg <= 1'b0;
crc_state <= 32'hFFFFFFFF;
end else begin
@ -377,6 +383,7 @@ always @(posedge clk) begin
gmii_tx_er_reg <= gmii_tx_er_next;
start_packet_reg <= start_packet_next;
error_underflow_reg <= error_underflow_next;
// datapath
if (reset_crc) begin

View File

@ -63,7 +63,8 @@ module axis_xgmii_tx_32 #
/*
* Status
*/
output wire start_packet
output wire start_packet,
output wire error_underflow
);
localparam MIN_FL_NOCRC = MIN_FRAME_LENGTH-4;
@ -129,6 +130,7 @@ reg [31:0] xgmii_txd_reg = {4{XGMII_IDLE}}, xgmii_txd_next;
reg [3:0] xgmii_txc_reg = 4'b1111, xgmii_txc_next;
reg start_packet_reg = 1'b0, start_packet_next;
reg error_underflow_reg = 1'b0, error_underflow_next;
assign s_axis_tready = s_axis_tready_reg;
@ -136,6 +138,7 @@ assign xgmii_txd = xgmii_txd_reg;
assign xgmii_txc = xgmii_txc_reg;
assign start_packet = start_packet_reg;
assign error_underflow = error_underflow_reg;
lfsr #(
.LFSR_WIDTH(32),
@ -288,6 +291,7 @@ always @* begin
xgmii_txc_next = 4'b1111;
start_packet_next = 1'b0;
error_underflow_next = 1'b0;
case (state_reg)
STATE_IDLE: begin
@ -376,6 +380,7 @@ always @* begin
xgmii_txc_next = 4'b1111;
frame_ptr_next = 16'd0;
ifg_count_next = 8'd10;
error_underflow_next = 1'b1;
state_next = STATE_WAIT_END;
end
end
@ -536,6 +541,7 @@ always @(posedge clk) begin
xgmii_txc_reg <= 4'b1111;
start_packet_reg <= 1'b0;
error_underflow_reg <= 1'b0;
crc_state <= 32'hFFFFFFFF;
end else begin
@ -552,6 +558,7 @@ always @(posedge clk) begin
xgmii_txc_reg <= xgmii_txc_next;
start_packet_reg <= start_packet_next;
error_underflow_reg <= error_underflow_next;
// datapath
if (reset_crc) begin

View File

@ -64,7 +64,8 @@ module axis_xgmii_tx_64 #
* Status
*/
output wire start_packet_0,
output wire start_packet_4
output wire start_packet_4,
output wire error_underflow
);
localparam MIN_FL_NOCRC = MIN_FRAME_LENGTH-4;
@ -140,6 +141,7 @@ reg [7:0] xgmii_txc_reg = 8'b11111111, xgmii_txc_next;
reg start_packet_0_reg = 1'b0, start_packet_0_next;
reg start_packet_4_reg = 1'b0, start_packet_4_next;
reg error_underflow_reg = 1'b0, error_underflow_next;
assign s_axis_tready = s_axis_tready_reg;
@ -148,6 +150,7 @@ assign xgmii_txc = xgmii_txc_reg;
assign start_packet_0 = start_packet_0_reg;
assign start_packet_4 = start_packet_4_reg;
assign error_underflow = error_underflow_reg;
lfsr #(
.LFSR_WIDTH(32),
@ -404,6 +407,7 @@ always @* begin
start_packet_0_next = 1'b0;
start_packet_4_next = 1'b0;
error_underflow_next = 1'b0;
case (state_reg)
STATE_IDLE: begin
@ -491,6 +495,7 @@ always @* begin
xgmii_txc_next = 8'b11111111;
frame_ptr_next = 16'd0;
ifg_count_next = 8'd8;
error_underflow_next = 1'b1;
state_next = STATE_WAIT_END;
end
end
@ -658,6 +663,7 @@ always @(posedge clk) begin
start_packet_0_reg <= 1'b0;
start_packet_4_reg <= 1'b0;
error_underflow_reg <= 1'b0;
crc_state <= 32'hFFFFFFFF;
@ -674,6 +680,7 @@ always @(posedge clk) begin
start_packet_0_reg <= start_packet_0_next;
start_packet_4_reg <= start_packet_4_next;
error_underflow_reg <= error_underflow_next;
if (swap_lanes || (lanes_swapped && !unswap_lanes)) begin
lanes_swapped <= 1'b1;

View File

@ -76,6 +76,7 @@ module eth_mac_10g #
*/
output wire tx_start_packet_0,
output wire tx_start_packet_4,
output wire tx_error_underflow,
output wire rx_start_packet_0,
output wire rx_start_packet_4,
output wire rx_error_bad_frame,
@ -139,7 +140,8 @@ axis_xgmii_tx_inst (
.xgmii_txc(xgmii_txc),
.ifg_delay(ifg_delay),
.start_packet_0(tx_start_packet_0),
.start_packet_4(tx_start_packet_4)
.start_packet_4(tx_start_packet_4),
.error_underflow(tx_error_underflow)
);
end else begin

View File

@ -85,6 +85,7 @@ module eth_mac_10g_fifo #
/*
* Status
*/
output wire tx_error_underflow,
output wire tx_fifo_overflow,
output wire tx_fifo_bad_frame,
output wire tx_fifo_good_frame,
@ -114,6 +115,35 @@ wire rx_fifo_axis_tlast;
wire rx_fifo_axis_tuser;
// synchronize MAC status signals into logic clock domain
wire tx_error_underflow_int;
reg tx_sync_reg_1 = 1'b0;
reg tx_sync_reg_2 = 1'b0;
reg tx_sync_reg_3 = 1'b0;
reg tx_sync_reg_4 = 1'b0;
assign tx_error_underflow = tx_sync_reg_3 ^ tx_sync_reg_4;
always @(posedge tx_clk or posedge tx_rst) begin
if (tx_rst) begin
tx_sync_reg_1 <= 1'b0;
end else begin
tx_sync_reg_1 <= tx_sync_reg_1 ^ {tx_error_underflow_int};
end
end
always @(posedge logic_clk or posedge logic_rst) begin
if (logic_rst) begin
tx_sync_reg_2 <= 1'b0;
tx_sync_reg_3 <= 1'b0;
tx_sync_reg_4 <= 1'b0;
end else begin
tx_sync_reg_2 <= tx_sync_reg_1;
tx_sync_reg_3 <= tx_sync_reg_2;
tx_sync_reg_4 <= tx_sync_reg_3;
end
end
wire rx_error_bad_frame_int;
wire rx_error_bad_fcs_int;
@ -173,6 +203,7 @@ eth_mac_10g_inst (
.xgmii_rxc(xgmii_rxc),
.xgmii_txd(xgmii_txd),
.xgmii_txc(xgmii_txc),
.tx_error_underflow(tx_error_underflow_int),
.rx_error_bad_frame(rx_error_bad_frame_int),
.rx_error_bad_fcs(rx_error_bad_fcs_int),
.ifg_delay(ifg_delay)

View File

@ -79,6 +79,7 @@ module eth_mac_1g #
* Status
*/
output wire tx_start_packet,
output wire tx_error_underflow,
output wire rx_start_packet,
output wire rx_error_bad_frame,
output wire rx_error_bad_fcs,
@ -125,7 +126,8 @@ axis_gmii_tx_inst (
.clk_enable(tx_clk_enable),
.mii_select(tx_mii_select),
.ifg_delay(ifg_delay),
.start_packet(tx_start_packet)
.start_packet(tx_start_packet),
.error_underflow(tx_error_underflow)
);
endmodule

View File

@ -89,6 +89,7 @@ module eth_mac_1g_fifo #
/*
* Status
*/
output wire tx_error_underflow,
output wire tx_fifo_overflow,
output wire tx_fifo_bad_frame,
output wire tx_fifo_good_frame,
@ -116,6 +117,35 @@ wire rx_fifo_axis_tlast;
wire rx_fifo_axis_tuser;
// synchronize MAC status signals into logic clock domain
wire tx_error_underflow_int;
reg tx_sync_reg_1 = 1'b0;
reg tx_sync_reg_2 = 1'b0;
reg tx_sync_reg_3 = 1'b0;
reg tx_sync_reg_4 = 1'b0;
assign tx_error_underflow = tx_sync_reg_3 ^ tx_sync_reg_4;
always @(posedge tx_clk or posedge tx_rst) begin
if (tx_rst) begin
tx_sync_reg_1 <= 1'b0;
end else begin
tx_sync_reg_1 <= tx_sync_reg_1 ^ {tx_error_underflow_int};
end
end
always @(posedge logic_clk or posedge logic_rst) begin
if (logic_rst) begin
tx_sync_reg_2 <= 1'b0;
tx_sync_reg_3 <= 1'b0;
tx_sync_reg_4 <= 1'b0;
end else begin
tx_sync_reg_2 <= tx_sync_reg_1;
tx_sync_reg_3 <= tx_sync_reg_2;
tx_sync_reg_4 <= tx_sync_reg_3;
end
end
wire rx_error_bad_frame_int;
wire rx_error_bad_fcs_int;

View File

@ -86,6 +86,7 @@ module eth_mac_1g_gmii #
/*
* Status
*/
output wire tx_error_underflow,
output wire rx_error_bad_frame,
output wire rx_error_bad_fcs,
output wire [1:0] speed,
@ -244,6 +245,7 @@ eth_mac_1g_inst (
.tx_clk_enable(1'b1),
.rx_mii_select(rx_mii_select_3),
.tx_mii_select(tx_mii_select_3),
.tx_error_underflow(tx_error_underflow),
.rx_error_bad_frame(rx_error_bad_frame),
.rx_error_bad_fcs(rx_error_bad_fcs),
.ifg_delay(ifg_delay)

View File

@ -93,6 +93,7 @@ module eth_mac_1g_gmii_fifo #
/*
* Status
*/
output wire tx_error_underflow,
output wire tx_fifo_overflow,
output wire tx_fifo_bad_frame,
output wire tx_fifo_good_frame,
@ -126,6 +127,35 @@ wire rx_fifo_axis_tlast;
wire rx_fifo_axis_tuser;
// synchronize MAC status signals into logic clock domain
wire tx_error_underflow_int;
reg tx_sync_reg_1 = 1'b0;
reg tx_sync_reg_2 = 1'b0;
reg tx_sync_reg_3 = 1'b0;
reg tx_sync_reg_4 = 1'b0;
assign tx_error_underflow = tx_sync_reg_3 ^ tx_sync_reg_4;
always @(posedge tx_clk or posedge tx_rst) begin
if (tx_rst) begin
tx_sync_reg_1 <= 1'b0;
end else begin
tx_sync_reg_1 <= tx_sync_reg_1 ^ {tx_error_underflow_int};
end
end
always @(posedge logic_clk or posedge logic_rst) begin
if (logic_rst) begin
tx_sync_reg_2 <= 1'b0;
tx_sync_reg_3 <= 1'b0;
tx_sync_reg_4 <= 1'b0;
end else begin
tx_sync_reg_2 <= tx_sync_reg_1;
tx_sync_reg_3 <= tx_sync_reg_2;
tx_sync_reg_4 <= tx_sync_reg_3;
end
end
wire rx_error_bad_frame_int;
wire rx_error_bad_fcs_int;

View File

@ -86,6 +86,7 @@ module eth_mac_1g_rgmii #
/*
* Status
*/
output wire tx_error_underflow,
output wire rx_error_bad_frame,
output wire rx_error_bad_fcs,
output wire [1:0] speed,
@ -245,6 +246,7 @@ eth_mac_1g_inst (
.tx_clk_enable(mac_gmii_tx_clk_en),
.rx_mii_select(rx_mii_select_3),
.tx_mii_select(tx_mii_select_3),
.tx_error_underflow(tx_error_underflow),
.rx_error_bad_frame(rx_error_bad_frame),
.rx_error_bad_fcs(rx_error_bad_fcs),
.ifg_delay(ifg_delay)

View File

@ -93,6 +93,7 @@ module eth_mac_1g_rgmii_fifo #
/*
* Status
*/
output wire tx_error_underflow,
output wire tx_fifo_overflow,
output wire tx_fifo_bad_frame,
output wire tx_fifo_good_frame,
@ -126,6 +127,35 @@ wire rx_fifo_axis_tlast;
wire rx_fifo_axis_tuser;
// synchronize MAC status signals into logic clock domain
wire tx_error_underflow_int;
reg tx_sync_reg_1 = 1'b0;
reg tx_sync_reg_2 = 1'b0;
reg tx_sync_reg_3 = 1'b0;
reg tx_sync_reg_4 = 1'b0;
assign tx_error_underflow = tx_sync_reg_3 ^ tx_sync_reg_4;
always @(posedge tx_clk or posedge tx_rst) begin
if (tx_rst) begin
tx_sync_reg_1 <= 1'b0;
end else begin
tx_sync_reg_1 <= tx_sync_reg_1 ^ {tx_error_underflow_int};
end
end
always @(posedge logic_clk or posedge logic_rst) begin
if (logic_rst) begin
tx_sync_reg_2 <= 1'b0;
tx_sync_reg_3 <= 1'b0;
tx_sync_reg_4 <= 1'b0;
end else begin
tx_sync_reg_2 <= tx_sync_reg_1;
tx_sync_reg_3 <= tx_sync_reg_2;
tx_sync_reg_4 <= tx_sync_reg_3;
end
end
wire rx_error_bad_frame_int;
wire rx_error_bad_fcs_int;

View File

@ -82,6 +82,7 @@ module eth_mac_phy_10g #
*/
output wire tx_start_packet_0,
output wire tx_start_packet_4,
output wire tx_error_underflow,
output wire rx_start_packet_0,
output wire rx_start_packet_4,
output wire rx_error_bad_frame,
@ -148,7 +149,8 @@ eth_mac_phy_10g_tx_inst (
.serdes_tx_hdr(serdes_tx_hdr),
.ifg_delay(ifg_delay),
.tx_start_packet_0(tx_start_packet_0),
.tx_start_packet_4(tx_start_packet_4)
.tx_start_packet_4(tx_start_packet_4),
.tx_error_underflow(tx_error_underflow)
);
endmodule

View File

@ -91,6 +91,7 @@ module eth_mac_phy_10g_fifo #
/*
* Status
*/
output wire tx_error_underflow,
output wire tx_fifo_overflow,
output wire tx_fifo_bad_frame,
output wire tx_fifo_good_frame,
@ -122,6 +123,35 @@ wire rx_fifo_axis_tlast;
wire rx_fifo_axis_tuser;
// synchronize MAC status signals into logic clock domain
wire tx_error_underflow_int;
reg tx_sync_reg_1 = 1'b0;
reg tx_sync_reg_2 = 1'b0;
reg tx_sync_reg_3 = 1'b0;
reg tx_sync_reg_4 = 1'b0;
assign tx_error_underflow = tx_sync_reg_3 ^ tx_sync_reg_4;
always @(posedge tx_clk or posedge tx_rst) begin
if (tx_rst) begin
tx_sync_reg_1 <= 1'b0;
end else begin
tx_sync_reg_1 <= tx_sync_reg_1 ^ {tx_error_underflow_int};
end
end
always @(posedge logic_clk or posedge logic_rst) begin
if (logic_rst) begin
tx_sync_reg_2 <= 1'b0;
tx_sync_reg_3 <= 1'b0;
tx_sync_reg_4 <= 1'b0;
end else begin
tx_sync_reg_2 <= tx_sync_reg_1;
tx_sync_reg_3 <= tx_sync_reg_2;
tx_sync_reg_4 <= tx_sync_reg_3;
end
end
wire rx_error_bad_frame_int;
wire rx_error_bad_fcs_int;

View File

@ -70,7 +70,8 @@ module eth_mac_phy_10g_tx #
* Status
*/
output wire tx_start_packet_0,
output wire tx_start_packet_4
output wire tx_start_packet_4,
output wire tx_error_underflow
);
// bus width assertions
@ -115,7 +116,8 @@ axis_baser_tx_inst (
.encoded_tx_hdr(encoded_tx_hdr),
.ifg_delay(ifg_delay),
.start_packet_0(tx_start_packet_0),
.start_packet_4(tx_start_packet_4)
.start_packet_4(tx_start_packet_4),
.error_underflow(tx_error_underflow)
);
reg [57:0] tx_scrambler_state_reg = {58{1'b1}};

View File

@ -71,6 +71,7 @@ def bench():
encoded_tx_hdr = Signal(intbv(1)[HDR_WIDTH:])
start_packet_0 = Signal(bool(0))
start_packet_4 = Signal(bool(0))
error_underflow = Signal(bool(0))
# sources and sinks
source_pause = Signal(bool(0))
@ -120,6 +121,7 @@ def bench():
ifg_delay=ifg_delay,
start_packet_0=start_packet_0,
start_packet_4=start_packet_4,
error_underflow=error_underflow
)
@always(delay(4))

View File

@ -57,6 +57,7 @@ wire [DATA_WIDTH-1:0] encoded_tx_data;
wire [HDR_WIDTH-1:0] encoded_tx_hdr;
wire start_packet_0;
wire start_packet_4;
wire error_underflow;
initial begin
// myhdl integration
@ -76,7 +77,8 @@ initial begin
encoded_tx_data,
encoded_tx_hdr,
start_packet_0,
start_packet_4
start_packet_4,
error_underflow
);
// dump file
@ -105,7 +107,8 @@ UUT (
.encoded_tx_hdr(encoded_tx_hdr),
.ifg_delay(ifg_delay),
.start_packet_0(start_packet_0),
.start_packet_4(start_packet_4)
.start_packet_4(start_packet_4),
.error_underflow(error_underflow)
);
endmodule

View File

@ -68,6 +68,7 @@ def bench():
gmii_tx_en = Signal(bool(0))
gmii_tx_er = Signal(bool(0))
start_packet = Signal(bool(0))
error_underflow = Signal(bool(0))
# sources and sinks
source_pause = Signal(bool(0))
@ -124,7 +125,8 @@ def bench():
ifg_delay=ifg_delay,
start_packet=start_packet
start_packet=start_packet,
error_underflow=error_underflow
)
@always(delay(4))

View File

@ -54,6 +54,7 @@ wire [7:0] gmii_txd;
wire gmii_tx_en;
wire gmii_tx_er;
wire start_packet;
wire error_underflow;
initial begin
// myhdl integration
@ -74,7 +75,8 @@ initial begin
gmii_txd,
gmii_tx_en,
gmii_tx_er,
start_packet
start_packet,
error_underflow
);
// dump file
@ -100,7 +102,8 @@ UUT (
.clk_enable(clk_enable),
.mii_select(mii_select),
.ifg_delay(ifg_delay),
.start_packet(start_packet)
.start_packet(start_packet),
.error_underflow(error_underflow)
);
endmodule

View File

@ -66,6 +66,7 @@ def bench():
xgmii_txd = Signal(intbv(0x07070707)[32:])
xgmii_txc = Signal(intbv(0xf)[4:])
start_packet = Signal(bool(0))
error_underflow = Signal(bool(0))
# sources and sinks
source_pause = Signal(bool(0))
@ -117,7 +118,8 @@ def bench():
ifg_delay=ifg_delay,
start_packet=start_packet
start_packet=start_packet,
error_underflow=error_underflow
)
@always(delay(4))

View File

@ -52,6 +52,7 @@ wire s_axis_tready;
wire [31:0] xgmii_txd;
wire [3:0] xgmii_txc;
wire start_packet;
wire error_underflow;
initial begin
// myhdl integration
@ -70,7 +71,8 @@ initial begin
s_axis_tready,
xgmii_txd,
xgmii_txc,
start_packet
start_packet,
error_underflow
);
// dump file
@ -94,7 +96,8 @@ UUT (
.xgmii_txd(xgmii_txd),
.xgmii_txc(xgmii_txc),
.ifg_delay(ifg_delay),
.start_packet(start_packet)
.start_packet(start_packet),
.error_underflow(error_underflow)
);
endmodule

View File

@ -67,6 +67,7 @@ def bench():
xgmii_txc = Signal(intbv(0xff)[8:])
start_packet_0 = Signal(bool(0))
start_packet_4 = Signal(bool(0))
error_underflow = Signal(bool(0))
# sources and sinks
source_pause = Signal(bool(0))
@ -119,7 +120,8 @@ def bench():
ifg_delay=ifg_delay,
start_packet_0=start_packet_0,
start_packet_4=start_packet_4
start_packet_4=start_packet_4,
error_underflow=error_underflow
)
@always(delay(4))

View File

@ -53,6 +53,7 @@ wire [63:0] xgmii_txd;
wire [7:0] xgmii_txc;
wire start_packet_0;
wire start_packet_4;
wire error_underflow;
initial begin
// myhdl integration
@ -72,7 +73,8 @@ initial begin
xgmii_txd,
xgmii_txc,
start_packet_0,
start_packet_4
start_packet_4,
error_underflow
);
// dump file
@ -97,7 +99,8 @@ UUT (
.xgmii_txc(xgmii_txc),
.ifg_delay(ifg_delay),
.start_packet_0(start_packet_0),
.start_packet_4(start_packet_4)
.start_packet_4(start_packet_4),
.error_underflow(error_underflow)
);
endmodule

View File

@ -84,6 +84,7 @@ def bench():
xgmii_txc = Signal(intbv(0xff)[CTRL_WIDTH:])
tx_start_packet_0 = Signal(bool(0))
tx_start_packet_4 = Signal(bool(0))
tx_error_underflow = Signal(bool(0))
rx_start_packet_0 = Signal(bool(0))
rx_start_packet_4 = Signal(bool(0))
rx_error_bad_frame = Signal(bool(0))
@ -176,6 +177,7 @@ def bench():
tx_start_packet_0=tx_start_packet_0,
tx_start_packet_4=tx_start_packet_4,
tx_error_underflow=tx_error_underflow,
rx_start_packet_0=rx_start_packet_0,
rx_start_packet_4=rx_start_packet_4,
rx_error_bad_frame=rx_error_bad_frame,

View File

@ -68,6 +68,7 @@ wire [DATA_WIDTH-1:0] xgmii_txd;
wire [CTRL_WIDTH-1:0] xgmii_txc;
wire tx_start_packet_0;
wire tx_start_packet_4;
wire tx_error_underflow;
wire rx_start_packet_0;
wire rx_start_packet_4;
wire rx_error_bad_frame;
@ -103,6 +104,7 @@ initial begin
xgmii_txc,
tx_start_packet_0,
tx_start_packet_4,
tx_error_underflow,
rx_start_packet_0,
rx_start_packet_4,
rx_error_bad_frame,
@ -144,6 +146,7 @@ UUT (
.xgmii_txc(xgmii_txc),
.tx_start_packet_0(tx_start_packet_0),
.tx_start_packet_4(tx_start_packet_4),
.tx_error_underflow(tx_error_underflow),
.rx_start_packet_0(rx_start_packet_0),
.rx_start_packet_4(rx_start_packet_4),
.rx_error_bad_frame(rx_error_bad_frame),

View File

@ -84,6 +84,7 @@ def bench():
xgmii_txc = Signal(intbv(0xff)[CTRL_WIDTH:])
tx_start_packet_0 = Signal(bool(0))
tx_start_packet_4 = Signal(bool(0))
tx_error_underflow = Signal(bool(0))
rx_start_packet_0 = Signal(bool(0))
rx_start_packet_4 = Signal(bool(0))
rx_error_bad_frame = Signal(bool(0))
@ -176,6 +177,7 @@ def bench():
tx_start_packet_0=tx_start_packet_0,
tx_start_packet_4=tx_start_packet_4,
tx_error_underflow=tx_error_underflow,
rx_start_packet_0=rx_start_packet_0,
rx_start_packet_4=rx_start_packet_4,
rx_error_bad_frame=rx_error_bad_frame,

View File

@ -68,6 +68,7 @@ wire [DATA_WIDTH-1:0] xgmii_txd;
wire [CTRL_WIDTH-1:0] xgmii_txc;
wire tx_start_packet_0;
wire tx_start_packet_4;
wire tx_error_underflow;
wire rx_start_packet_0;
wire rx_start_packet_4;
wire rx_error_bad_frame;
@ -103,6 +104,7 @@ initial begin
xgmii_txc,
tx_start_packet_0,
tx_start_packet_4,
tx_error_underflow,
rx_start_packet_0,
rx_start_packet_4,
rx_error_bad_frame,
@ -144,6 +146,7 @@ UUT (
.xgmii_txc(xgmii_txc),
.tx_start_packet_0(tx_start_packet_0),
.tx_start_packet_4(tx_start_packet_4),
.tx_error_underflow(tx_error_underflow),
.rx_start_packet_0(rx_start_packet_0),
.rx_start_packet_4(rx_start_packet_4),
.rx_error_bad_frame(rx_error_bad_frame),

View File

@ -89,6 +89,7 @@ def bench():
rx_axis_tuser = Signal(bool(0))
xgmii_txd = Signal(intbv(0x0707070707070707)[DATA_WIDTH:])
xgmii_txc = Signal(intbv(0xff)[CTRL_WIDTH:])
tx_error_underflow = Signal(bool(0))
tx_fifo_overflow = Signal(bool(0))
tx_fifo_bad_frame = Signal(bool(0))
tx_fifo_good_frame = Signal(bool(0))
@ -189,6 +190,7 @@ def bench():
xgmii_txd=xgmii_txd,
xgmii_txc=xgmii_txc,
tx_error_underflow=tx_error_underflow,
tx_fifo_overflow=tx_fifo_overflow,
tx_fifo_bad_frame=tx_fifo_bad_frame,
tx_fifo_good_frame=tx_fifo_good_frame,

View File

@ -71,6 +71,7 @@ wire rx_axis_tlast;
wire rx_axis_tuser;
wire [DATA_WIDTH-1:0] xgmii_txd;
wire [CTRL_WIDTH-1:0] xgmii_txc;
wire tx_error_underflow;
wire tx_fifo_overflow;
wire tx_fifo_bad_frame;
wire tx_fifo_good_frame;
@ -111,6 +112,7 @@ initial begin
rx_axis_tuser,
xgmii_txd,
xgmii_txc,
tx_error_underflow,
tx_fifo_overflow,
tx_fifo_bad_frame,
tx_fifo_good_frame,
@ -159,6 +161,7 @@ UUT (
.xgmii_rxc(xgmii_rxc),
.xgmii_txd(xgmii_txd),
.xgmii_txc(xgmii_txc),
.tx_error_underflow(tx_error_underflow),
.tx_fifo_overflow(tx_fifo_overflow),
.tx_fifo_bad_frame(tx_fifo_bad_frame),
.tx_fifo_good_frame(tx_fifo_good_frame),

View File

@ -89,6 +89,7 @@ def bench():
rx_axis_tuser = Signal(bool(0))
xgmii_txd = Signal(intbv(0x0707070707070707)[DATA_WIDTH:])
xgmii_txc = Signal(intbv(0xff)[CTRL_WIDTH:])
tx_error_underflow = Signal(bool(0))
tx_fifo_overflow = Signal(bool(0))
tx_fifo_bad_frame = Signal(bool(0))
tx_fifo_good_frame = Signal(bool(0))
@ -189,6 +190,7 @@ def bench():
xgmii_txd=xgmii_txd,
xgmii_txc=xgmii_txc,
tx_error_underflow=tx_error_underflow,
tx_fifo_overflow=tx_fifo_overflow,
tx_fifo_bad_frame=tx_fifo_bad_frame,
tx_fifo_good_frame=tx_fifo_good_frame,

View File

@ -71,6 +71,7 @@ wire rx_axis_tlast;
wire rx_axis_tuser;
wire [DATA_WIDTH-1:0] xgmii_txd;
wire [CTRL_WIDTH-1:0] xgmii_txc;
wire tx_error_underflow;
wire tx_fifo_overflow;
wire tx_fifo_bad_frame;
wire tx_fifo_good_frame;
@ -111,6 +112,7 @@ initial begin
rx_axis_tuser,
xgmii_txd,
xgmii_txc,
tx_error_underflow,
tx_fifo_overflow,
tx_fifo_bad_frame,
tx_fifo_good_frame,
@ -159,6 +161,7 @@ UUT (
.xgmii_rxc(xgmii_rxc),
.xgmii_txd(xgmii_txd),
.xgmii_txc(xgmii_txc),
.tx_error_underflow(tx_error_underflow),
.tx_fifo_overflow(tx_fifo_overflow),
.tx_fifo_bad_frame(tx_fifo_bad_frame),
.tx_fifo_good_frame(tx_fifo_good_frame),

View File

@ -83,6 +83,7 @@ def bench():
gmii_tx_en = Signal(bool(0))
gmii_tx_er = Signal(bool(0))
tx_start_packet = Signal(bool(0))
tx_error_underflow = Signal(bool(0))
rx_start_packet = Signal(bool(0))
rx_error_bad_frame = Signal(bool(0))
rx_error_bad_fcs = Signal(bool(0))
@ -183,6 +184,7 @@ def bench():
tx_mii_select=tx_mii_select,
tx_start_packet=tx_start_packet,
tx_error_underflow=tx_error_underflow,
rx_start_packet=rx_start_packet,
rx_error_bad_frame=rx_error_bad_frame,
rx_error_bad_fcs=rx_error_bad_fcs,

View File

@ -67,6 +67,7 @@ wire [7:0] gmii_txd;
wire gmii_tx_en;
wire gmii_tx_er;
wire tx_start_packet;
wire tx_error_underflow;
wire rx_start_packet;
wire rx_error_bad_frame;
wire rx_error_bad_fcs;
@ -104,6 +105,7 @@ initial begin
gmii_tx_en,
gmii_tx_er,
tx_start_packet,
tx_error_underflow,
rx_start_packet,
rx_error_bad_frame,
rx_error_bad_fcs
@ -143,6 +145,7 @@ UUT (
.rx_mii_select(rx_mii_select),
.tx_mii_select(tx_mii_select),
.tx_start_packet(tx_start_packet),
.tx_error_underflow(tx_error_underflow),
.rx_start_packet(rx_start_packet),
.rx_error_bad_frame(rx_error_bad_frame),
.rx_error_bad_fcs(rx_error_bad_fcs),

View File

@ -89,6 +89,7 @@ def bench():
gmii_txd = Signal(intbv(0)[8:])
gmii_tx_en = Signal(bool(0))
gmii_tx_er = Signal(bool(0))
tx_error_underflow = Signal(bool(0))
tx_fifo_overflow = Signal(bool(0))
tx_fifo_bad_frame = Signal(bool(0))
tx_fifo_good_frame = Signal(bool(0))
@ -199,6 +200,7 @@ def bench():
rx_mii_select=rx_mii_select,
tx_mii_select=tx_mii_select,
tx_error_underflow=tx_error_underflow,
tx_fifo_overflow=tx_fifo_overflow,
tx_fifo_bad_frame=tx_fifo_bad_frame,
tx_fifo_good_frame=tx_fifo_good_frame,

View File

@ -71,6 +71,7 @@ wire rx_axis_tuser;
wire [7:0] gmii_txd;
wire gmii_tx_en;
wire gmii_tx_er;
wire tx_error_underflow;
wire tx_fifo_overflow;
wire tx_fifo_bad_frame;
wire tx_fifo_good_frame;
@ -115,6 +116,7 @@ initial begin
gmii_txd,
gmii_tx_en,
gmii_tx_er,
tx_error_underflow,
tx_fifo_overflow,
tx_fifo_bad_frame,
tx_fifo_good_frame,
@ -163,6 +165,7 @@ UUT (
.tx_clk_enable(tx_clk_enable),
.rx_mii_select(rx_mii_select),
.tx_mii_select(tx_mii_select),
.tx_error_underflow(tx_error_underflow),
.tx_fifo_overflow(tx_fifo_overflow),
.tx_fifo_bad_frame(tx_fifo_bad_frame),
.tx_fifo_good_frame(tx_fifo_good_frame),

View File

@ -91,6 +91,7 @@ def bench():
gmii_txd = Signal(intbv(0)[8:])
gmii_tx_en = Signal(bool(0))
gmii_tx_er = Signal(bool(0))
tx_error_underflow = Signal(bool(0))
rx_error_bad_frame = Signal(bool(0))
rx_error_bad_fcs = Signal(bool(0))
speed = Signal(intbv(0)[2:])
@ -190,6 +191,7 @@ def bench():
gmii_tx_en=gmii_tx_en,
gmii_tx_er=gmii_tx_er,
tx_error_underflow=tx_error_underflow,
rx_error_bad_frame=rx_error_bad_frame,
rx_error_bad_fcs=rx_error_bad_fcs,
speed=speed,

View File

@ -70,6 +70,7 @@ wire gmii_tx_clk;
wire [7:0] gmii_txd;
wire gmii_tx_en;
wire gmii_tx_er;
wire tx_error_underflow;
wire rx_error_bad_frame;
wire rx_error_bad_fcs;
wire [1:0] speed;
@ -107,6 +108,7 @@ initial begin
gmii_txd,
gmii_tx_en,
gmii_tx_er,
tx_error_underflow,
rx_error_bad_frame,
rx_error_bad_fcs,
speed
@ -149,6 +151,7 @@ UUT (
.gmii_txd(gmii_txd),
.gmii_tx_en(gmii_tx_en),
.gmii_tx_er(gmii_tx_er),
.tx_error_underflow(tx_error_underflow),
.rx_error_bad_frame(rx_error_bad_frame),
.rx_error_bad_fcs(rx_error_bad_fcs),
.speed(speed),

View File

@ -94,6 +94,7 @@ def bench():
gmii_txd = Signal(intbv(0)[8:])
gmii_tx_en = Signal(bool(0))
gmii_tx_er = Signal(bool(0))
tx_error_underflow = Signal(bool(0))
tx_fifo_overflow = Signal(bool(0))
tx_fifo_bad_frame = Signal(bool(0))
tx_fifo_good_frame = Signal(bool(0))
@ -200,6 +201,7 @@ def bench():
gmii_tx_en=gmii_tx_en,
gmii_tx_er=gmii_tx_er,
tx_error_underflow=tx_error_underflow,
tx_fifo_overflow=tx_fifo_overflow,
tx_fifo_bad_frame=tx_fifo_bad_frame,
tx_fifo_good_frame=tx_fifo_good_frame,

View File

@ -71,6 +71,7 @@ wire gmii_tx_clk;
wire [7:0] gmii_txd;
wire gmii_tx_en;
wire gmii_tx_er;
wire tx_error_underflow;
wire tx_fifo_overflow;
wire tx_fifo_bad_frame;
wire tx_fifo_good_frame;
@ -113,6 +114,7 @@ initial begin
gmii_txd,
gmii_tx_en,
gmii_tx_er,
tx_error_underflow,
tx_fifo_overflow,
tx_fifo_bad_frame,
tx_fifo_good_frame,
@ -162,6 +164,7 @@ UUT (
.gmii_txd(gmii_txd),
.gmii_tx_en(gmii_tx_en),
.gmii_tx_er(gmii_tx_er),
.tx_error_underflow(tx_error_underflow),
.tx_fifo_overflow(tx_fifo_overflow),
.tx_fifo_bad_frame(tx_fifo_bad_frame),
.tx_fifo_good_frame(tx_fifo_good_frame),

View File

@ -91,6 +91,7 @@ def bench():
rgmii_tx_clk = Signal(bool(0))
rgmii_txd = Signal(intbv(0)[4:])
rgmii_tx_ctl = Signal(bool(0))
tx_error_underflow = Signal(bool(0))
rx_error_bad_frame = Signal(bool(0))
rx_error_bad_fcs = Signal(bool(0))
speed = Signal(intbv(0)[2:])
@ -186,6 +187,7 @@ def bench():
rgmii_txd=rgmii_txd,
rgmii_tx_ctl=rgmii_tx_ctl,
tx_error_underflow=tx_error_underflow,
rx_error_bad_frame=rx_error_bad_frame,
rx_error_bad_fcs=rx_error_bad_fcs,
speed=speed,

View File

@ -69,6 +69,7 @@ wire rx_axis_tuser;
wire rgmii_tx_clk;
wire [3:0] rgmii_txd;
wire rgmii_tx_ctl;
wire tx_error_underflow;
wire rx_error_bad_frame;
wire rx_error_bad_fcs;
wire [1:0] speed;
@ -104,6 +105,7 @@ initial begin
rgmii_tx_clk,
rgmii_txd,
rgmii_tx_ctl,
tx_error_underflow,
rx_error_bad_frame,
rx_error_bad_fcs,
speed
@ -145,6 +147,7 @@ UUT (
.rgmii_tx_clk(rgmii_tx_clk),
.rgmii_txd(rgmii_txd),
.rgmii_tx_ctl(rgmii_tx_ctl),
.tx_error_underflow(tx_error_underflow),
.rx_error_bad_frame(rx_error_bad_frame),
.rx_error_bad_fcs(rx_error_bad_fcs),
.speed(speed),

View File

@ -92,6 +92,7 @@ def bench():
rgmii_tx_clk = Signal(bool(0))
rgmii_txd = Signal(intbv(0)[4:])
rgmii_tx_ctl = Signal(bool(0))
tx_error_underflow = Signal(bool(0))
tx_fifo_overflow = Signal(bool(0))
tx_fifo_bad_frame = Signal(bool(0))
tx_fifo_good_frame = Signal(bool(0))
@ -194,6 +195,7 @@ def bench():
rgmii_txd=rgmii_txd,
rgmii_tx_ctl=rgmii_tx_ctl,
tx_error_underflow=tx_error_underflow,
tx_fifo_overflow=tx_fifo_overflow,
tx_fifo_bad_frame=tx_fifo_bad_frame,
tx_fifo_good_frame=tx_fifo_good_frame,

View File

@ -70,6 +70,7 @@ wire rx_axis_tuser;
wire rgmii_tx_clk;
wire [3:0] rgmii_txd;
wire rgmii_tx_ctl;
wire tx_error_underflow;
wire tx_fifo_overflow;
wire tx_fifo_bad_frame;
wire tx_fifo_good_frame;
@ -110,6 +111,7 @@ initial begin
rgmii_tx_clk,
rgmii_txd,
rgmii_tx_ctl,
tx_error_underflow,
tx_fifo_overflow,
tx_fifo_bad_frame,
tx_fifo_good_frame,
@ -158,6 +160,7 @@ UUT (
.rgmii_tx_clk(rgmii_tx_clk),
.rgmii_txd(rgmii_txd),
.rgmii_tx_ctl(rgmii_tx_ctl),
.tx_error_underflow(tx_error_underflow),
.tx_fifo_overflow(tx_fifo_overflow),
.tx_fifo_bad_frame(tx_fifo_bad_frame),
.tx_fifo_good_frame(tx_fifo_good_frame),

View File

@ -98,6 +98,7 @@ def bench():
serdes_rx_bitslip = Signal(bool(0))
tx_start_packet_0 = Signal(bool(0))
tx_start_packet_4 = Signal(bool(0))
tx_error_underflow = Signal(bool(0))
rx_start_packet_0 = Signal(bool(0))
rx_start_packet_4 = Signal(bool(0))
rx_error_bad_frame = Signal(bool(0))
@ -185,6 +186,7 @@ def bench():
serdes_rx_bitslip=serdes_rx_bitslip,
tx_start_packet_0=tx_start_packet_0,
tx_start_packet_4=tx_start_packet_4,
tx_error_underflow=tx_error_underflow,
rx_start_packet_0=rx_start_packet_0,
rx_start_packet_4=rx_start_packet_4,
rx_error_bad_frame=rx_error_bad_frame,

View File

@ -74,6 +74,7 @@ wire [HDR_WIDTH-1:0] serdes_tx_hdr;
wire serdes_rx_bitslip;
wire tx_start_packet_0;
wire tx_start_packet_4;
wire tx_error_underflow;
wire rx_start_packet_0;
wire rx_start_packet_4;
wire rx_error_bad_frame;
@ -112,6 +113,7 @@ initial begin
serdes_rx_bitslip,
tx_start_packet_0,
tx_start_packet_4,
tx_error_underflow,
rx_start_packet_0,
rx_start_packet_4,
rx_error_bad_frame,
@ -161,6 +163,7 @@ UUT (
.serdes_rx_bitslip(serdes_rx_bitslip),
.tx_start_packet_0(tx_start_packet_0),
.tx_start_packet_4(tx_start_packet_4),
.tx_error_underflow(tx_error_underflow),
.rx_start_packet_0(rx_start_packet_0),
.rx_start_packet_4(rx_start_packet_4),
.rx_error_bad_frame(rx_error_bad_frame),

View File

@ -109,6 +109,7 @@ def bench():
serdes_tx_data = Signal(intbv(0)[DATA_WIDTH:])
serdes_tx_hdr = Signal(intbv(1)[HDR_WIDTH:])
serdes_rx_bitslip = Signal(bool(0))
tx_error_underflow = Signal(bool(0))
tx_fifo_overflow = Signal(bool(0))
tx_fifo_bad_frame = Signal(bool(0))
tx_fifo_good_frame = Signal(bool(0))
@ -202,6 +203,7 @@ def bench():
serdes_rx_data=serdes_rx_data,
serdes_rx_hdr=serdes_rx_hdr,
serdes_rx_bitslip=serdes_rx_bitslip,
tx_error_underflow=tx_error_underflow,
tx_fifo_overflow=tx_fifo_overflow,
tx_fifo_bad_frame=tx_fifo_bad_frame,
tx_fifo_good_frame=tx_fifo_good_frame,

View File

@ -83,6 +83,7 @@ wire rx_axis_tuser;
wire [DATA_WIDTH-1:0] serdes_tx_data;
wire [HDR_WIDTH-1:0] serdes_tx_hdr;
wire serdes_rx_bitslip;
wire tx_error_underflow;
wire tx_fifo_overflow;
wire tx_fifo_bad_frame;
wire tx_fifo_good_frame;
@ -126,6 +127,7 @@ initial begin
serdes_tx_data,
serdes_tx_hdr,
serdes_rx_bitslip,
tx_error_underflow,
tx_fifo_overflow,
tx_fifo_bad_frame,
tx_fifo_good_frame,
@ -188,6 +190,7 @@ UUT (
.serdes_rx_data(serdes_rx_data),
.serdes_rx_hdr(serdes_rx_hdr),
.serdes_rx_bitslip(serdes_rx_bitslip),
.tx_error_underflow(tx_error_underflow),
.tx_fifo_overflow(tx_fifo_overflow),
.tx_fifo_bad_frame(tx_fifo_bad_frame),
.tx_fifo_good_frame(tx_fifo_good_frame),