Compare commits
9 Commits
dev/genera
...
100feb0ea1
| Author | SHA1 | Date | |
|---|---|---|---|
| 100feb0ea1 | |||
| 1310555b55 | |||
| c75443d170 | |||
| 3a58119960 | |||
| 0b9fb64193 | |||
| a1386fc8a4 | |||
| 7fedc36562 | |||
| 0dd0006e47 | |||
| ded2afc0db |
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
||||
**build**
|
||||
177
rtl/ethernet-udp/src/eth/arbi/gmii_arbi.v
Normal file
177
rtl/ethernet-udp/src/eth/arbi/gmii_arbi.v
Normal file
@ -0,0 +1,177 @@
|
||||
`timescale 1ns / 1ps
|
||||
//////////////////////////////////////////////////////////////////////////////////
|
||||
// Module Name: ethernet_test
|
||||
//////////////////////////////////////////////////////////////////////////////////
|
||||
module gmii_arbi
|
||||
(
|
||||
input clk,
|
||||
input rst_n,
|
||||
input [1:0] speed,
|
||||
input link,
|
||||
(* MARK_DEBUG="true" *)input gmii_rx_dv,
|
||||
(* MARK_DEBUG="true" *)input [7:0] gmii_rxd,
|
||||
(* MARK_DEBUG="true" *)input gmii_tx_en,
|
||||
(* MARK_DEBUG="true" *)input [7:0] gmii_txd,
|
||||
output reg [31:0] pack_total_len, //delay time
|
||||
output e_rst_n,
|
||||
(* MARK_DEBUG="true" *)output reg e_rx_dv,
|
||||
(* MARK_DEBUG="true" *)output reg [7:0] e_rxd,
|
||||
(* MARK_DEBUG="true" *)output reg e_tx_en,
|
||||
(* MARK_DEBUG="true" *)output reg [7:0] e_txd
|
||||
);
|
||||
|
||||
reg eth_1000m_en ;
|
||||
wire eth_10_100m_en ;
|
||||
reg eth_100m_en ;
|
||||
reg eth_10m_en ;
|
||||
reg [1:0] speed_d0 ;
|
||||
reg [1:0] speed_d1 ;
|
||||
reg [1:0] speed_d2 ;
|
||||
reg link_d0 ;
|
||||
reg link_d1 ;
|
||||
reg link_d2 ;
|
||||
|
||||
wire e10_100_tx_en ;
|
||||
wire [7:0] e10_100_txd ;
|
||||
wire e10_100_rx_dv ;
|
||||
wire [7:0] e10_100_rxd ;
|
||||
|
||||
reg e_rst_en ;
|
||||
reg [7:0] e_rst_cnt ;
|
||||
|
||||
assign e_rst_n = link_d2 & e_rst_en ;
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
begin
|
||||
speed_d0 <= 2'b00 ;
|
||||
speed_d1 <= 2'b00 ;
|
||||
speed_d2 <= 2'b00 ;
|
||||
link_d0 <= 1'b0 ;
|
||||
link_d1 <= 1'b0 ;
|
||||
link_d2 <= 1'b0 ;
|
||||
end
|
||||
else
|
||||
begin
|
||||
speed_d0 <= speed ;
|
||||
speed_d1 <= speed_d0 ;
|
||||
speed_d2 <= speed_d1 ;
|
||||
link_d0 <= link ;
|
||||
link_d1 <= link_d0 ;
|
||||
link_d2 <= link_d1 ;
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
begin
|
||||
eth_1000m_en <= 1'b0 ;
|
||||
eth_100m_en <= 1'b0 ;
|
||||
eth_10m_en <= 1'b0 ;
|
||||
pack_total_len <= 32'd2500000 ;
|
||||
end
|
||||
else if (speed_d2 == 2'b10) //1000M
|
||||
begin
|
||||
eth_1000m_en <= 1'b1 ;
|
||||
eth_100m_en <= 1'b0 ;
|
||||
eth_10m_en <= 1'b0 ;
|
||||
pack_total_len <= 32'd125000000 ; //1s
|
||||
end
|
||||
else if (speed_d2 == 2'b01) //100M
|
||||
begin
|
||||
eth_1000m_en <= 1'b0 ;
|
||||
eth_100m_en <= 1'b1 ;
|
||||
eth_10m_en <= 1'b0 ;
|
||||
pack_total_len <= 32'd25000000 ; //1s
|
||||
end
|
||||
else if (speed_d2 == 2'b00) //10M
|
||||
begin
|
||||
eth_1000m_en <= 1'b0 ;
|
||||
eth_100m_en <= 1'b0 ;
|
||||
eth_10m_en <= 1'b1 ;
|
||||
pack_total_len <= 32'd2500000 ; //1s
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
begin
|
||||
e_rx_dv <= 1'b0 ;
|
||||
e_rxd <= 8'd0 ;
|
||||
e_tx_en <= 1'b0 ;
|
||||
e_txd <= 8'd0 ;
|
||||
end
|
||||
else if (eth_1000m_en)
|
||||
begin
|
||||
e_rx_dv <= gmii_rx_dv ;
|
||||
e_rxd <= gmii_rxd ;
|
||||
e_tx_en <= gmii_tx_en ;
|
||||
e_txd <= gmii_txd ;
|
||||
end
|
||||
else if (eth_100m_en | eth_10m_en)
|
||||
begin
|
||||
e_rx_dv <= e10_100_rx_dv ;
|
||||
e_rxd <= e10_100_rxd ;
|
||||
e_tx_en <= e10_100_tx_en ;
|
||||
e_txd <= e10_100_txd ;
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
e_rst_en <= 1'b1 ;
|
||||
else if (speed_d2 != speed_d1)
|
||||
e_rst_en <= 1'b0 ;
|
||||
else if (e_rst_cnt == 8'd200)
|
||||
e_rst_en <= 1'b1 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
e_rst_cnt <= 8'd0 ;
|
||||
else if (~e_rst_en)
|
||||
e_rst_cnt <= e_rst_cnt + 1'b1 ;
|
||||
else
|
||||
e_rst_cnt <= 8'd0 ;
|
||||
end
|
||||
|
||||
assign eth_10_100m_en = eth_100m_en | eth_10m_en ;
|
||||
|
||||
gmii_tx_buffer tx_buffer_inst
|
||||
(
|
||||
.clk (clk ),
|
||||
.rst_n (e_rst_n ),
|
||||
.eth_10_100m_en (eth_10_100m_en ),
|
||||
.link (e_rst_n ),
|
||||
.gmii_tx_en (gmii_tx_en ),
|
||||
.gmii_txd (gmii_txd ),
|
||||
.e10_100_tx_en (e10_100_tx_en ),
|
||||
.e10_100_txd (e10_100_txd )
|
||||
);
|
||||
|
||||
|
||||
gmii_rx_buffer rx_buffer_inst
|
||||
(
|
||||
.clk (clk ),
|
||||
.rst_n (e_rst_n ),
|
||||
.link (e_rst_n ),
|
||||
.eth_100m_en (eth_100m_en ),
|
||||
.eth_10m_en (eth_10m_en ),
|
||||
.gmii_rx_dv (gmii_rx_dv ),
|
||||
.gmii_rxd (gmii_rxd ),
|
||||
.e10_100_rx_dv (e10_100_rx_dv ),
|
||||
.e10_100_rxd (e10_100_rxd )
|
||||
|
||||
);
|
||||
|
||||
endmodule
|
||||
305
rtl/ethernet-udp/src/eth/arbi/gmii_rx_buffer.v
Normal file
305
rtl/ethernet-udp/src/eth/arbi/gmii_rx_buffer.v
Normal file
@ -0,0 +1,305 @@
|
||||
`timescale 1ns / 1ps
|
||||
//////////////////////////////////////////////////////////////////////////////////
|
||||
// Module Name: ethernet_test
|
||||
//////////////////////////////////////////////////////////////////////////////////
|
||||
module gmii_rx_buffer
|
||||
(
|
||||
input clk,
|
||||
input rst_n,
|
||||
input eth_100m_en, //ethernet 100M enable
|
||||
input eth_10m_en, //ethernet 100M enable
|
||||
input link, //ethernet link signal
|
||||
input gmii_rx_dv, //gmii rx dv
|
||||
input [7:0] gmii_rxd, //gmii rxd
|
||||
|
||||
(* MARK_DEBUG="true" *)output reg e10_100_rx_dv, //ethernet 10/100 rx_dv
|
||||
(* MARK_DEBUG="true" *)output [7:0] e10_100_rxd //ethernet 10/100 rxd
|
||||
|
||||
);
|
||||
|
||||
|
||||
reg [15:0] rx_cnt ; //write fifo counter
|
||||
reg rx_wren ; //write fifo wren
|
||||
reg [7:0] rx_wdata ; //write fifo data
|
||||
reg [15:0] rx_data_cnt ; //read fifo counter
|
||||
reg rx_rden ; //read fifo rden
|
||||
wire [7:0] rx_rdata ; //read fifo data
|
||||
reg [3:0] rxd_high ; //rxd high 4 bit
|
||||
reg [3:0] rxd_low ; //rxd low 4 bit
|
||||
|
||||
(* MARK_DEBUG="true" *)reg gmii_rx_dv_d0 ;
|
||||
(* MARK_DEBUG="true" *)reg gmii_rx_dv_d1 ;
|
||||
reg gmii_rx_dv_d2 ;
|
||||
|
||||
reg [15:0] pack_len ; //package length
|
||||
reg [1:0] len_cnt ; //length latch counter
|
||||
wire [4:0] pack_num ; //length fifo usedw
|
||||
reg rx_len_wren ; //length wren
|
||||
reg [15:0] rx_len_wdata ; //length write data
|
||||
reg rx_len_rden ; //length rden
|
||||
wire [15:0] rx_len ; //legnth read data
|
||||
|
||||
|
||||
localparam IDLE = 4'd0 ;
|
||||
localparam CHECK_FIFO = 4'd1 ;
|
||||
localparam LEN_LATCH = 4'd2 ;
|
||||
localparam REC_WAIT = 4'd3 ;
|
||||
localparam READ_FIFO = 4'd4 ;
|
||||
localparam REC_END = 4'd5 ;
|
||||
|
||||
reg [3:0] state ;
|
||||
reg [3:0] next_state ;
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
state <= IDLE ;
|
||||
else
|
||||
state <= next_state ;
|
||||
end
|
||||
|
||||
always @(*)
|
||||
begin
|
||||
case(state)
|
||||
IDLE :
|
||||
begin
|
||||
next_state <= CHECK_FIFO ;
|
||||
end
|
||||
CHECK_FIFO :
|
||||
begin
|
||||
if (pack_num > 5'd0) // if length fifo usedw > 0, means there is package in data fifo
|
||||
next_state <= LEN_LATCH ;
|
||||
else
|
||||
next_state <= CHECK_FIFO ;
|
||||
end
|
||||
LEN_LATCH:
|
||||
begin
|
||||
if (len_cnt == 2'd3) // delay some clock
|
||||
next_state <= REC_WAIT ;
|
||||
else
|
||||
next_state <= LEN_LATCH ;
|
||||
end
|
||||
REC_WAIT :
|
||||
next_state <= READ_FIFO ;
|
||||
READ_FIFO :
|
||||
begin
|
||||
if (rx_data_cnt == pack_len - 1) // when reach package length read end
|
||||
next_state <= REC_END ;
|
||||
else
|
||||
next_state <= READ_FIFO ;
|
||||
end
|
||||
REC_END :
|
||||
next_state <= IDLE ;
|
||||
default :
|
||||
next_state <= IDLE ;
|
||||
endcase
|
||||
end
|
||||
|
||||
|
||||
|
||||
|
||||
/*************************************************
|
||||
write length to fifo
|
||||
*************************************************/
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
begin
|
||||
gmii_rx_dv_d0 <= 1'b0 ;
|
||||
gmii_rx_dv_d1 <= 1'b0 ;
|
||||
gmii_rx_dv_d2 <= 1'b0 ;
|
||||
end
|
||||
else
|
||||
begin
|
||||
gmii_rx_dv_d0 <= gmii_rx_dv ;
|
||||
gmii_rx_dv_d1 <= gmii_rx_dv_d0 ;
|
||||
gmii_rx_dv_d2 <= gmii_rx_dv_d1 ;
|
||||
end
|
||||
end
|
||||
//write rx length wren to fifo when gmii_rx_dv negedge
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
rx_len_wren <= 1'b0 ;
|
||||
else if (gmii_rx_dv == 1'b0 && gmii_rx_dv_d0 == 1'b1)
|
||||
rx_len_wren <= eth_100m_en | eth_10m_en ;
|
||||
else
|
||||
rx_len_wren <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
rx_cnt <= 16'd0 ;
|
||||
//else if (eth_10m_en & (gmii_rx_dv_d0 | gmii_rx_dv_d1)) //when 10M mode, there is one unnecessary 4 bits data need to be take out
|
||||
else if (eth_10m_en & (gmii_rx_dv | gmii_rx_dv_d0)) //when 10M mode, there is one unnecessary 4 bits data need to be take out
|
||||
rx_cnt <= rx_cnt + 1'b1 ;
|
||||
else if (eth_100m_en & (gmii_rx_dv | gmii_rx_dv_d1))
|
||||
rx_cnt <= rx_cnt + 1'b1 ;
|
||||
else if (state == REC_WAIT)
|
||||
rx_cnt <= 16'd0 ;
|
||||
end
|
||||
|
||||
//write length to fifo
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
rx_len_wdata <= 16'd0 ;
|
||||
else
|
||||
rx_len_wdata <= rx_cnt ;
|
||||
end
|
||||
|
||||
|
||||
|
||||
/*************************************************
|
||||
write data to fifo
|
||||
*************************************************/
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
begin
|
||||
rxd_high <= 4'd0 ;
|
||||
rxd_low <= 4'd0 ;
|
||||
end
|
||||
else if (gmii_rx_dv | gmii_rx_dv_d1)
|
||||
begin
|
||||
if (rx_cnt[0])
|
||||
begin
|
||||
rxd_high <= gmii_rxd[3:0] ;
|
||||
end
|
||||
else
|
||||
begin
|
||||
rxd_low <= gmii_rxd[3:0] ;
|
||||
end
|
||||
end
|
||||
else
|
||||
begin
|
||||
rxd_high <= 4'd0 ;
|
||||
rxd_low <= 4'd0 ;
|
||||
end
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
begin
|
||||
rx_wren <= 1'b0 ;
|
||||
rx_wdata <= 8'd0 ;
|
||||
end
|
||||
else if (gmii_rx_dv_d1)
|
||||
begin
|
||||
if (rx_cnt[0])
|
||||
begin
|
||||
rx_wren <= 1'b0 ;
|
||||
end
|
||||
else
|
||||
begin
|
||||
rx_wdata <= {rxd_high,rxd_low} ;
|
||||
rx_wren <= eth_100m_en | eth_10m_en ;
|
||||
end
|
||||
end
|
||||
else
|
||||
begin
|
||||
rx_wren <= 1'b0 ;
|
||||
rx_wdata <= 8'd0 ;
|
||||
end
|
||||
end
|
||||
|
||||
/*************************************************
|
||||
read length from fifo
|
||||
*************************************************/
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
rx_len_rden <= 1'b0 ;
|
||||
else if (state == LEN_LATCH && len_cnt == 2'd0)
|
||||
rx_len_rden <= eth_100m_en | eth_10m_en ;
|
||||
else
|
||||
rx_len_rden <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
len_cnt <= 2'd0 ;
|
||||
else if (state == LEN_LATCH)
|
||||
len_cnt <= len_cnt + 1'b1 ;
|
||||
else
|
||||
len_cnt <= 2'd0 ;
|
||||
end
|
||||
//package total length
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
pack_len <= 16'd0 ;
|
||||
else if (state == REC_WAIT)
|
||||
pack_len <= rx_len/2 ;
|
||||
end
|
||||
|
||||
|
||||
/*************************************************
|
||||
read data from fifo
|
||||
*************************************************/
|
||||
|
||||
|
||||
//read data counter
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
rx_data_cnt <= 16'd0 ;
|
||||
else if (state == READ_FIFO)
|
||||
rx_data_cnt <= rx_data_cnt + 1'b1 ;
|
||||
else
|
||||
rx_data_cnt <= 16'd0 ;
|
||||
end
|
||||
|
||||
|
||||
//read enable
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
rx_rden <= 1'b0 ;
|
||||
else if (state == READ_FIFO)
|
||||
rx_rden <= eth_100m_en | eth_10m_en ;
|
||||
else
|
||||
rx_rden <= 1'b0 ;
|
||||
end
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
e10_100_rx_dv <= 1'b0 ;
|
||||
else
|
||||
e10_100_rx_dv <= rx_rden ;
|
||||
end
|
||||
|
||||
assign e10_100_rxd = rx_rdata ;
|
||||
|
||||
|
||||
eth_data_fifo rx_fifo
|
||||
(
|
||||
.clk (clk ), // input wire clk
|
||||
.rst (~link ), // input wire rst
|
||||
.din (rx_wdata ), // input wire [7 : 0] din
|
||||
.wr_en (rx_wren ), // input wire wr_en
|
||||
.rd_en (rx_rden ), // input wire rd_en
|
||||
.dout (rx_rdata ), // output wire [7 : 0] dout
|
||||
.full ( ), // output wire full
|
||||
.empty ( ), // output wire empty
|
||||
.data_count ( ) // output wire [11 : 0] data_count
|
||||
);
|
||||
|
||||
len_fifo rx_len_fifo
|
||||
(
|
||||
.clk (clk ), // input wire clk
|
||||
.rst (~link ), // input wire rst
|
||||
.din (rx_len_wdata ), // input wire [7 : 0] din
|
||||
.wr_en (rx_len_wren ), // input wire wr_en
|
||||
.rd_en (rx_len_rden ), // input wire rd_en
|
||||
.dout (rx_len ), // output wire [7 : 0] dout
|
||||
.full ( ), // output wire full
|
||||
.empty ( ), // output wire empty
|
||||
.data_count (pack_num ) // output wire [11 : 0] data_count
|
||||
);
|
||||
endmodule
|
||||
298
rtl/ethernet-udp/src/eth/arbi/gmii_tx_buffer.v
Normal file
298
rtl/ethernet-udp/src/eth/arbi/gmii_tx_buffer.v
Normal file
@ -0,0 +1,298 @@
|
||||
`timescale 1ns / 1ps
|
||||
//////////////////////////////////////////////////////////////////////////////////
|
||||
// Module Name: ethernet_test
|
||||
//////////////////////////////////////////////////////////////////////////////////
|
||||
module gmii_tx_buffer
|
||||
(
|
||||
input clk,
|
||||
input rst_n,
|
||||
input eth_10_100m_en, //ethernet 10M/100M enable
|
||||
input link, //ethernet link signal
|
||||
input gmii_tx_en, //gmii tx enable
|
||||
input [7:0] gmii_txd, //gmii txd
|
||||
output reg e10_100_tx_en, //ethernet 10/100M tx enable
|
||||
output reg [7:0] e10_100_txd //ethernet 10/100M txd
|
||||
|
||||
|
||||
);
|
||||
|
||||
(* MARK_DEBUG="true" *)reg [7:0] tx_wdata ; //tx data fifo write data
|
||||
(* MARK_DEBUG="true" *)reg tx_wren ; //tx data fifo write enable
|
||||
(* MARK_DEBUG="true" *)reg tx_rden ; //tx data fifo read enable
|
||||
(* MARK_DEBUG="true" *)reg [15:0] tx_data_cnt ; //tx data counter
|
||||
(* MARK_DEBUG="true" *)wire [7:0] tx_rdata ; //tx fifo read data
|
||||
|
||||
|
||||
reg [16:0] pack_len ; //package length
|
||||
reg tx_en ; //tx enable
|
||||
reg [3:0] txd_high ; //high 4 bits
|
||||
reg [3:0] txd_low ; //low 4 bits
|
||||
|
||||
reg tx_en_d0 ;
|
||||
reg tx_en_d1 ;
|
||||
|
||||
reg [15:0] tx_len_cnt ; //tx length counter
|
||||
reg gmii_tx_en_d0 ;
|
||||
reg [1:0] len_cnt ; //length latch counter
|
||||
wire [4:0] pack_num ; //length fifo usedw
|
||||
reg tx_len_wren ; //length fifo wren
|
||||
reg tx_len_rden ; //length fifo rden
|
||||
wire [15:0] tx_len_wdata ; //length fifo write data
|
||||
wire [15:0] tx_len ; //length fifo read data
|
||||
|
||||
|
||||
|
||||
localparam IDLE = 4'd0 ;
|
||||
localparam CHECK_FIFO = 4'd1 ;
|
||||
localparam LEN_LATCH = 4'd2 ;
|
||||
localparam SEND_WAIT = 4'd3 ;
|
||||
localparam SEND = 4'd4 ;
|
||||
localparam SEND_WAIT_1 = 4'd5 ;
|
||||
localparam SEND_END = 4'd6 ;
|
||||
|
||||
|
||||
reg [3:0] state ;
|
||||
reg [3:0] next_state ;
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
state <= IDLE ;
|
||||
else
|
||||
state <= next_state ;
|
||||
end
|
||||
|
||||
|
||||
|
||||
always @(*)
|
||||
begin
|
||||
case(state)
|
||||
IDLE :
|
||||
begin
|
||||
next_state <= CHECK_FIFO ;
|
||||
end
|
||||
CHECK_FIFO :
|
||||
begin
|
||||
if (pack_num > 5'd0) //check length fifo, if usedw > 0 ,there is a package in data fifo
|
||||
next_state <= LEN_LATCH ;
|
||||
else
|
||||
next_state <= CHECK_FIFO ;
|
||||
end
|
||||
LEN_LATCH:
|
||||
begin
|
||||
if (len_cnt == 2'd3) //wait for read length fifo data
|
||||
next_state <= SEND_WAIT ;
|
||||
else
|
||||
next_state <= LEN_LATCH ;
|
||||
end
|
||||
SEND_WAIT :
|
||||
next_state <= SEND ;
|
||||
SEND :
|
||||
begin
|
||||
if (tx_data_cnt == pack_len - 1) //read data fifo and send out
|
||||
next_state <= SEND_WAIT_1 ;
|
||||
else
|
||||
next_state <= SEND ;
|
||||
end
|
||||
SEND_WAIT_1 :
|
||||
begin
|
||||
if (tx_data_cnt == pack_len + 1) //wait some clock for data latch
|
||||
next_state <= SEND_END ;
|
||||
else
|
||||
next_state <= SEND_WAIT_1 ;
|
||||
end
|
||||
SEND_END :
|
||||
next_state <= IDLE ;
|
||||
default :
|
||||
next_state <= IDLE ;
|
||||
endcase
|
||||
end
|
||||
/*************************************************
|
||||
write length to tx_len_fifo
|
||||
*************************************************/
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
gmii_tx_en_d0 <= 1'b0 ;
|
||||
else
|
||||
gmii_tx_en_d0 <= gmii_tx_en ;
|
||||
end
|
||||
//write tx length to fifo when gmii_tx_en negedge
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
tx_len_wren <= 1'b0 ;
|
||||
else if (gmii_tx_en == 1'b0 && gmii_tx_en_d0 == 1'b1)
|
||||
tx_len_wren <= eth_10_100m_en ;
|
||||
else
|
||||
tx_len_wren <= 1'b0 ;
|
||||
end
|
||||
//calculate tx length
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
tx_len_cnt <= 16'd0 ;
|
||||
else if (gmii_tx_en)
|
||||
tx_len_cnt <= tx_len_cnt + 1'b1 ;
|
||||
else if (tx_len_wren)
|
||||
tx_len_cnt <= 16'd0 ;
|
||||
end
|
||||
|
||||
assign tx_len_wdata = tx_len_cnt ; //write length data
|
||||
|
||||
/*************************************************
|
||||
read length from tx_len_fifo
|
||||
*************************************************/
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
tx_len_rden <= 1'b0 ;
|
||||
else if (state == LEN_LATCH && len_cnt == 2'd0)
|
||||
tx_len_rden <= eth_10_100m_en ;
|
||||
else
|
||||
tx_len_rden <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
len_cnt <= 2'd0 ;
|
||||
else if (state == LEN_LATCH)
|
||||
len_cnt <= len_cnt + 1'b1 ;
|
||||
else
|
||||
len_cnt <= 2'd0 ;
|
||||
end
|
||||
//package total length
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
pack_len <= 17'd0 ;
|
||||
else if (state == SEND_WAIT)
|
||||
pack_len <= 2*(tx_len) ;
|
||||
end
|
||||
//write data to tx_fifo
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
begin
|
||||
tx_wren <= 1'b0 ;
|
||||
tx_wdata <= 8'd0 ;
|
||||
end
|
||||
else
|
||||
begin
|
||||
tx_wren <= gmii_tx_en & eth_10_100m_en ;
|
||||
tx_wdata <= gmii_txd ;
|
||||
end
|
||||
end
|
||||
|
||||
/*************************************************
|
||||
read tx_fifo
|
||||
*************************************************/
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
tx_data_cnt <= 16'd0 ;
|
||||
else if (state == SEND || state == SEND_WAIT_1)
|
||||
tx_data_cnt <= tx_data_cnt + 1'b1 ;
|
||||
else
|
||||
tx_data_cnt <= 16'd0 ;
|
||||
end
|
||||
//read data enable
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
tx_rden <= 1'b0 ;
|
||||
else if (state == SEND)
|
||||
tx_rden <= ~tx_data_cnt[0] & eth_10_100m_en ;
|
||||
else
|
||||
tx_rden <= 1'b0 ;
|
||||
end
|
||||
//gmii tx enable
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
tx_en <= 1'b0 ;
|
||||
else if (state == SEND)
|
||||
tx_en <= 1'b1 ;
|
||||
else
|
||||
tx_en <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
begin
|
||||
tx_en_d0 <= 1'b0 ;
|
||||
tx_en_d1 <= 1'b0 ;
|
||||
end
|
||||
else
|
||||
begin
|
||||
tx_en_d0 <= tx_en ;
|
||||
tx_en_d1 <= tx_en_d0 ;
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
begin
|
||||
txd_high <= 4'd0 ;
|
||||
txd_low <= 4'd0 ;
|
||||
end
|
||||
else
|
||||
begin
|
||||
if (tx_data_cnt[0])
|
||||
txd_high <= tx_rdata[7:4] ;
|
||||
else
|
||||
txd_low <= tx_rdata[3:0] ;
|
||||
end
|
||||
end
|
||||
|
||||
//ethernet 10/100M tx enable
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
e10_100_tx_en <= 1'b0 ;
|
||||
else
|
||||
e10_100_tx_en <= tx_en_d1 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
e10_100_txd <= 8'd0 ;
|
||||
else if (tx_data_cnt[0])
|
||||
e10_100_txd <= {txd_low[3:0],txd_low[3:0]} ;
|
||||
else
|
||||
e10_100_txd <= {txd_high[3:0],txd_high[3:0]} ;
|
||||
end
|
||||
|
||||
|
||||
eth_data_fifo tx_fifo
|
||||
(
|
||||
.clk (clk ), // input wire clk
|
||||
.rst (~link ), // input wire rst
|
||||
.din (tx_wdata ), // input wire [7 : 0] din
|
||||
.wr_en (tx_wren ), // input wire wr_en
|
||||
.rd_en (tx_rden ), // input wire rd_en
|
||||
.dout (tx_rdata ), // output wire [7 : 0] dout
|
||||
.full ( ), // output wire full
|
||||
.empty ( ), // output wire empty
|
||||
.data_count ( ) // output wire [11 : 0] data_count
|
||||
);
|
||||
|
||||
len_fifo tx_len_fifo
|
||||
(
|
||||
.clk (clk ), // input wire clk
|
||||
.rst (~link ), // input wire rst
|
||||
.din (tx_len_wdata ), // input wire [7 : 0] din
|
||||
.wr_en (tx_len_wren ), // input wire wr_en
|
||||
.rd_en (tx_len_rden ), // input wire rd_en
|
||||
.dout (tx_len ), // output wire [7 : 0] dout
|
||||
.full ( ), // output wire full
|
||||
.empty ( ), // output wire empty
|
||||
.data_count (pack_num ) // output wire [11 : 0] data_count
|
||||
);
|
||||
|
||||
endmodule
|
||||
248
rtl/ethernet-udp/src/eth/axis_mac.sv
Normal file
248
rtl/ethernet-udp/src/eth/axis_mac.sv
Normal file
@ -0,0 +1,248 @@
|
||||
`timescale 1 ns / 1 ns
|
||||
|
||||
module axis_mac
|
||||
(
|
||||
input rst_n,
|
||||
input gmii_tx_clk,
|
||||
input gmii_rx_clk,
|
||||
input gmii_rx_dv,
|
||||
input [7:0] gmii_rxd,
|
||||
|
||||
output reg gmii_tx_en,
|
||||
output reg [7:0] gmii_txd,
|
||||
|
||||
// AXI-stream RX output (clock domain = gmii_rx_clk)
|
||||
(* MARK_DEBUG="true" *)output reg [7:0] m_axis_rx_tdata,
|
||||
(* MARK_DEBUG="true" *)output reg m_axis_rx_tvalid,
|
||||
input wire m_axis_rx_tready,
|
||||
(* MARK_DEBUG="true" *)output reg m_axis_rx_tlast
|
||||
);
|
||||
|
||||
// ----------------------------------------------------------------
|
||||
// GMII RX input registering
|
||||
// ----------------------------------------------------------------
|
||||
reg gmii_rx_dv_d0;
|
||||
reg [7:0] gmii_rxd_d0;
|
||||
|
||||
always @(posedge gmii_rx_clk or negedge rst_n) begin
|
||||
if (!rst_n) begin
|
||||
gmii_rx_dv_d0 <= 1'b0;
|
||||
gmii_rxd_d0 <= 8'd0;
|
||||
end else begin
|
||||
gmii_rx_dv_d0 <= gmii_rx_dv;
|
||||
gmii_rxd_d0 <= gmii_rxd;
|
||||
end
|
||||
end
|
||||
|
||||
// ----------------------------------------------------------------
|
||||
// TX path from mac_top
|
||||
// ----------------------------------------------------------------
|
||||
wire gmii_tx_en_tmp;
|
||||
wire [7:0] gmii_txd_tmp;
|
||||
|
||||
always @(posedge gmii_tx_clk or negedge rst_n) begin
|
||||
if (!rst_n) begin
|
||||
gmii_tx_en <= 1'b0;
|
||||
gmii_txd <= 8'd0;
|
||||
end else begin
|
||||
gmii_tx_en <= gmii_tx_en_tmp;
|
||||
gmii_txd <= gmii_txd_tmp;
|
||||
end
|
||||
end
|
||||
|
||||
// ----------------------------------------------------------------
|
||||
// Unused user TX path into mac_top
|
||||
// We disable user UDP TX for now.
|
||||
// ARP replies and ICMP replies inside mac_top still work.
|
||||
// ----------------------------------------------------------------
|
||||
wire udp_ram_data_req;
|
||||
wire udp_tx_end;
|
||||
wire almost_full;
|
||||
wire mac_send_end;
|
||||
wire arp_found;
|
||||
wire mac_not_exist;
|
||||
|
||||
wire [7:0] udp_rec_ram_rdata;
|
||||
reg [10:0] udp_rec_ram_read_addr;
|
||||
wire [15:0] udp_rec_data_length;
|
||||
wire udp_rec_data_valid;
|
||||
|
||||
wire [7:0] tx_ram_wr_data = 8'd0;
|
||||
wire tx_ram_wr_en = 1'b0;
|
||||
wire [15:0] udp_send_data_length = 16'd0;
|
||||
wire udp_tx_req = 1'b0;
|
||||
wire arp_request_req = 1'b0;
|
||||
|
||||
mac_top mac_top0 (
|
||||
.gmii_tx_clk (gmii_tx_clk),
|
||||
.gmii_rx_clk (gmii_rx_clk),
|
||||
.rst_n (rst_n),
|
||||
|
||||
.source_mac_addr (48'h00_0a_35_01_fe_c0),
|
||||
.TTL (8'h80),
|
||||
.source_ip_addr (32'hc0a80002), // 192.168.0.2
|
||||
.destination_ip_addr (32'hc0a80003), // 192.168.0.3 (не используется для user TX пока)
|
||||
.udp_send_source_port (16'h1f90), // 8080
|
||||
.udp_send_destination_port (16'h1f90), // 8080
|
||||
|
||||
.ram_wr_data (tx_ram_wr_data),
|
||||
.ram_wr_en (tx_ram_wr_en),
|
||||
.udp_ram_data_req (udp_ram_data_req),
|
||||
.udp_send_data_length (udp_send_data_length),
|
||||
.udp_tx_end (udp_tx_end),
|
||||
.almost_full (almost_full),
|
||||
|
||||
.udp_tx_req (udp_tx_req),
|
||||
.arp_request_req (arp_request_req),
|
||||
|
||||
.mac_send_end (mac_send_end),
|
||||
.mac_data_valid (gmii_tx_en_tmp),
|
||||
.mac_tx_data (gmii_txd_tmp),
|
||||
|
||||
.rx_dv (gmii_rx_dv_d0),
|
||||
.mac_rx_datain (gmii_rxd_d0),
|
||||
|
||||
.udp_rec_ram_rdata (udp_rec_ram_rdata),
|
||||
.udp_rec_ram_read_addr (udp_rec_ram_read_addr),
|
||||
.udp_rec_data_length (udp_rec_data_length),
|
||||
.udp_rec_data_valid (udp_rec_data_valid),
|
||||
|
||||
.arp_found (arp_found),
|
||||
.mac_not_exist (mac_not_exist)
|
||||
);
|
||||
|
||||
// ----------------------------------------------------------------
|
||||
// Detect "new packet ready" on udp_rec_data_valid rising edge
|
||||
// ----------------------------------------------------------------
|
||||
reg udp_rec_data_valid_d0;
|
||||
|
||||
always @(posedge gmii_rx_clk or negedge rst_n) begin
|
||||
if (!rst_n)
|
||||
udp_rec_data_valid_d0 <= 1'b0;
|
||||
else
|
||||
udp_rec_data_valid_d0 <= udp_rec_data_valid;
|
||||
end
|
||||
|
||||
wire udp_pkt_done = udp_rec_data_valid & ~udp_rec_data_valid_d0;
|
||||
|
||||
// ----------------------------------------------------------------
|
||||
// RX RAM -> AXI-stream bridge
|
||||
//
|
||||
// Assumption:
|
||||
// udp_rec_data_length includes 8-byte UDP header,
|
||||
// so payload length = udp_rec_data_length - 8
|
||||
//
|
||||
// This implementation is simple and safe:
|
||||
// - start on udp_pkt_done
|
||||
// - read bytes 0 .. payload_len-1 from RX RAM
|
||||
// - output them on AXIS
|
||||
//
|
||||
// Because the BRAM read port is synchronous, this bridge may insert
|
||||
// bubbles between bytes. For first bring-up this is fine.
|
||||
// ----------------------------------------------------------------
|
||||
localparam RX_IDLE = 2'd0;
|
||||
localparam RX_NOTREADY = 2'd1;
|
||||
localparam RX_START = 2'd2;
|
||||
localparam RX_DATA = 2'd3;
|
||||
|
||||
(* MARK_DEBUG="true" *) reg [1:0] rx_state;
|
||||
(* MARK_DEBUG="true" *) reg [15:0] rx_payload_len;
|
||||
(* MARK_DEBUG="true" *) reg [15:0] rx_index;
|
||||
|
||||
always @(posedge gmii_rx_clk or negedge rst_n) begin
|
||||
if (!rst_n) begin
|
||||
rx_state <= RX_IDLE;
|
||||
rx_payload_len <= 16'd0;
|
||||
rx_index <= 16'd0;
|
||||
udp_rec_ram_read_addr <= 11'd0;
|
||||
|
||||
m_axis_rx_tdata <= 8'd0;
|
||||
m_axis_rx_tvalid <= 1'b0;
|
||||
m_axis_rx_tlast <= 1'b0;
|
||||
|
||||
end else begin
|
||||
case (rx_state)
|
||||
RX_IDLE: begin
|
||||
m_axis_rx_tvalid <= 1'b0;
|
||||
m_axis_rx_tlast <= 1'b0;
|
||||
rx_index <= 16'd0;
|
||||
udp_rec_ram_read_addr <= 11'd0;
|
||||
|
||||
if (udp_pkt_done) begin
|
||||
// protect against pathological short values
|
||||
if (udp_rec_data_length > 16'd8) begin
|
||||
rx_payload_len <= udp_rec_data_length - 16'd8;
|
||||
udp_rec_ram_read_addr <= 11'd0; // issue read for byte 0
|
||||
rx_state <= RX_NOTREADY;
|
||||
end else begin
|
||||
rx_payload_len <= 16'd0;
|
||||
rx_state <= RX_IDLE;
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
// one cycle for synchronous BRAM read latency
|
||||
RX_NOTREADY: begin
|
||||
m_axis_rx_tvalid <= 1'b0;
|
||||
m_axis_rx_tlast <= 1'b0;
|
||||
|
||||
if (m_axis_rx_tready)
|
||||
rx_state <= RX_START;
|
||||
end
|
||||
|
||||
RX_START: begin
|
||||
if (m_axis_rx_tready) begin
|
||||
// put current data
|
||||
// end of data?
|
||||
if (rx_index == (rx_payload_len - 1)) begin
|
||||
rx_state <= RX_IDLE;
|
||||
end else begin
|
||||
rx_state <= RX_DATA;
|
||||
end
|
||||
|
||||
// always increment pointer
|
||||
rx_index <= rx_index + 1'b1;
|
||||
udp_rec_ram_read_addr <= rx_index + 1'b1; // next byte
|
||||
end else begin
|
||||
rx_state <= RX_NOTREADY;
|
||||
|
||||
end
|
||||
end
|
||||
|
||||
RX_DATA: begin
|
||||
// hold valid until accepted
|
||||
if (!m_axis_rx_tready) begin
|
||||
// take a break while not ready
|
||||
m_axis_rx_tvalid <= m_axis_rx_tvalid;
|
||||
m_axis_rx_tlast <= m_axis_rx_tlast;
|
||||
rx_state <= RX_NOTREADY;
|
||||
// reset increment
|
||||
rx_index <= rx_index - 1'b1;
|
||||
udp_rec_ram_read_addr <= rx_index - 1'b1;
|
||||
end else begin
|
||||
// present current byte from RAM
|
||||
m_axis_rx_tdata <= udp_rec_ram_rdata;
|
||||
m_axis_rx_tvalid <= 1'b1;
|
||||
m_axis_rx_tlast <= (rx_index == (rx_payload_len));
|
||||
if (rx_index == (rx_payload_len)) begin
|
||||
// last byte accepted immediately if ready=1,
|
||||
// otherwise valid/last remain asserted until ready
|
||||
rx_state <= RX_IDLE;
|
||||
end
|
||||
|
||||
|
||||
rx_index <= rx_index + 1'b1;
|
||||
udp_rec_ram_read_addr <= rx_index + 1'b1; // next byte
|
||||
end
|
||||
end
|
||||
|
||||
default: begin
|
||||
rx_state <= RX_IDLE;
|
||||
m_axis_rx_tvalid <= 1'b0;
|
||||
m_axis_rx_tlast <= 1'b0;
|
||||
end
|
||||
endcase
|
||||
end
|
||||
end
|
||||
|
||||
endmodule
|
||||
51
rtl/ethernet-udp/src/eth/mac/arp_cache.v
Normal file
51
rtl/ethernet-udp/src/eth/mac/arp_cache.v
Normal file
@ -0,0 +1,51 @@
|
||||
module arp_cache
|
||||
(
|
||||
input clk ,
|
||||
input rst_n ,
|
||||
|
||||
input arp_found,
|
||||
input [31:0] arp_rec_source_ip_addr,
|
||||
input [47:0] arp_rec_source_mac_addr,
|
||||
|
||||
input [31:0] destination_ip_addr,
|
||||
output reg [47:0] destination_mac_addr,
|
||||
|
||||
output reg mac_not_exist
|
||||
) ;
|
||||
|
||||
reg [79:0] arp_cache ;
|
||||
|
||||
//init arp cache
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
arp_cache <= 80'h00_00_00_00_ff_ff_ff_ff_ff_ff ;
|
||||
else if (arp_found)
|
||||
arp_cache <= {arp_rec_source_ip_addr, arp_rec_source_mac_addr} ;
|
||||
else
|
||||
arp_cache <= arp_cache ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
destination_mac_addr <= 48'hff_ff_ff_ff_ff_ff ;
|
||||
else if (destination_ip_addr == arp_cache[79:48])
|
||||
destination_mac_addr <= arp_cache[47:0] ;
|
||||
else
|
||||
destination_mac_addr <= 48'hff_ff_ff_ff_ff_ff ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
mac_not_exist <= 1'b0 ;
|
||||
else if (destination_ip_addr != arp_cache[79:48])
|
||||
mac_not_exist <= 1'b1 ;
|
||||
else if (destination_ip_addr == arp_cache[79:48] && arp_cache[47:0] == 48'hff_ff_ff_ff_ff_ff)
|
||||
mac_not_exist <= 1'b1 ;
|
||||
else
|
||||
mac_not_exist <= 1'b0 ;
|
||||
end
|
||||
|
||||
endmodule
|
||||
66
rtl/ethernet-udp/src/eth/mac/crc.v
Normal file
66
rtl/ethernet-udp/src/eth/mac/crc.v
Normal file
@ -0,0 +1,66 @@
|
||||
`timescale 1ns / 1ps
|
||||
/****************************************/
|
||||
// CRC32数据校验模块 //
|
||||
/****************************************/
|
||||
module crc (Clk, Reset, Data_in, Enable, Crc,CrcNext);
|
||||
|
||||
|
||||
parameter Tp = 1;
|
||||
|
||||
input Clk;
|
||||
input Reset;
|
||||
input [7:0] Data_in;
|
||||
input Enable;
|
||||
|
||||
output [31:0] Crc;
|
||||
reg [31:0] Crc;
|
||||
|
||||
output [31:0] CrcNext;
|
||||
|
||||
wire [7:0] Data;
|
||||
|
||||
assign Data={Data_in[0],Data_in[1],Data_in[2],Data_in[3],Data_in[4],Data_in[5],Data_in[6],Data_in[7]};
|
||||
|
||||
|
||||
assign CrcNext[0] = Crc[24] ^ Crc[30] ^ Data[0] ^ Data[6];
|
||||
assign CrcNext[1] = Crc[24] ^ Crc[25] ^ Crc[30] ^ Crc[31] ^ Data[0] ^ Data[1] ^ Data[6] ^ Data[7];
|
||||
assign CrcNext[2] = Crc[24] ^ Crc[25] ^ Crc[26] ^ Crc[30] ^ Crc[31] ^ Data[0] ^ Data[1] ^ Data[2] ^ Data[6] ^ Data[7];
|
||||
assign CrcNext[3] = Crc[25] ^ Crc[26] ^ Crc[27] ^ Crc[31] ^ Data[1] ^ Data[2] ^ Data[3] ^ Data[7];
|
||||
assign CrcNext[4] = Crc[24] ^ Crc[26] ^ Crc[27] ^ Crc[28] ^ Crc[30] ^ Data[0] ^ Data[2] ^ Data[3] ^ Data[4] ^ Data[6];
|
||||
assign CrcNext[5] = Crc[24] ^ Crc[25] ^ Crc[27] ^ Crc[28] ^ Crc[29] ^ Crc[30] ^ Crc[31] ^ Data[0] ^ Data[1] ^ Data[3] ^ Data[4] ^ Data[5] ^ Data[6] ^ Data[7];
|
||||
assign CrcNext[6] = Crc[25] ^ Crc[26] ^ Crc[28] ^ Crc[29] ^ Crc[30] ^ Crc[31] ^ Data[1] ^ Data[2] ^ Data[4] ^ Data[5] ^ Data[6] ^ Data[7];
|
||||
assign CrcNext[7] = Crc[24] ^ Crc[26] ^ Crc[27] ^ Crc[29] ^ Crc[31] ^ Data[0] ^ Data[2] ^ Data[3] ^ Data[5] ^ Data[7];
|
||||
assign CrcNext[8] = Crc[0] ^ Crc[24] ^ Crc[25] ^ Crc[27] ^ Crc[28] ^ Data[0] ^ Data[1] ^ Data[3] ^ Data[4];
|
||||
assign CrcNext[9] = Crc[1] ^ Crc[25] ^ Crc[26] ^ Crc[28] ^ Crc[29] ^ Data[1] ^ Data[2] ^ Data[4] ^ Data[5];
|
||||
assign CrcNext[10] = Crc[2] ^ Crc[24] ^ Crc[26] ^ Crc[27] ^ Crc[29] ^ Data[0] ^ Data[2] ^ Data[3] ^ Data[5];
|
||||
assign CrcNext[11] = Crc[3] ^ Crc[24] ^ Crc[25] ^ Crc[27] ^ Crc[28] ^ Data[0] ^ Data[1] ^ Data[3] ^ Data[4];
|
||||
assign CrcNext[12] = Crc[4] ^ Crc[24] ^ Crc[25] ^ Crc[26] ^ Crc[28] ^ Crc[29] ^ Crc[30] ^ Data[0] ^ Data[1] ^ Data[2] ^ Data[4] ^ Data[5] ^ Data[6];
|
||||
assign CrcNext[13] = Crc[5] ^ Crc[25] ^ Crc[26] ^ Crc[27] ^ Crc[29] ^ Crc[30] ^ Crc[31] ^ Data[1] ^ Data[2] ^ Data[3] ^ Data[5] ^ Data[6] ^ Data[7];
|
||||
assign CrcNext[14] = Crc[6] ^ Crc[26] ^ Crc[27] ^ Crc[28] ^ Crc[30] ^ Crc[31] ^ Data[2] ^ Data[3] ^ Data[4] ^ Data[6] ^ Data[7];
|
||||
assign CrcNext[15] = Crc[7] ^ Crc[27] ^ Crc[28] ^ Crc[29] ^ Crc[31] ^ Data[3] ^ Data[4] ^ Data[5] ^ Data[7];
|
||||
assign CrcNext[16] = Crc[8] ^ Crc[24] ^ Crc[28] ^ Crc[29] ^ Data[0] ^ Data[4] ^ Data[5];
|
||||
assign CrcNext[17] = Crc[9] ^ Crc[25] ^ Crc[29] ^ Crc[30] ^ Data[1] ^ Data[5] ^ Data[6];
|
||||
assign CrcNext[18] = Crc[10] ^ Crc[26] ^ Crc[30] ^ Crc[31] ^ Data[2] ^ Data[6] ^ Data[7];
|
||||
assign CrcNext[19] = Crc[11] ^ Crc[27] ^ Crc[31] ^ Data[3] ^ Data[7];
|
||||
assign CrcNext[20] = Crc[12] ^ Crc[28] ^ Data[4];
|
||||
assign CrcNext[21] = Crc[13] ^ Crc[29] ^ Data[5];
|
||||
assign CrcNext[22] = Crc[14] ^ Crc[24] ^ Data[0];
|
||||
assign CrcNext[23] = Crc[15] ^ Crc[24] ^ Crc[25] ^ Crc[30] ^ Data[0] ^ Data[1] ^ Data[6];
|
||||
assign CrcNext[24] = Crc[16] ^ Crc[25] ^ Crc[26] ^ Crc[31] ^ Data[1] ^ Data[2] ^ Data[7];
|
||||
assign CrcNext[25] = Crc[17] ^ Crc[26] ^ Crc[27] ^ Data[2] ^ Data[3];
|
||||
assign CrcNext[26] = Crc[18] ^ Crc[24] ^ Crc[27] ^ Crc[28] ^ Crc[30] ^ Data[0] ^ Data[3] ^ Data[4] ^ Data[6];
|
||||
assign CrcNext[27] = Crc[19] ^ Crc[25] ^ Crc[28] ^ Crc[29] ^ Crc[31] ^ Data[1] ^ Data[4] ^ Data[5] ^ Data[7];
|
||||
assign CrcNext[28] = Crc[20] ^ Crc[26] ^ Crc[29] ^ Crc[30] ^ Data[2] ^ Data[5] ^ Data[6];
|
||||
assign CrcNext[29] = Crc[21] ^ Crc[27] ^ Crc[30] ^ Crc[31] ^ Data[3] ^ Data[6] ^ Data[7];
|
||||
assign CrcNext[30] = Crc[22] ^ Crc[28] ^ Crc[31] ^ Data[4] ^ Data[7];
|
||||
assign CrcNext[31] = Crc[23] ^ Crc[29] ^ Data[5];
|
||||
|
||||
always @ (posedge Clk, posedge Reset)
|
||||
begin
|
||||
if (Reset) begin
|
||||
Crc <={32{1'b1}};
|
||||
end
|
||||
else if (Enable)
|
||||
Crc <=CrcNext;
|
||||
end
|
||||
endmodule
|
||||
558
rtl/ethernet-udp/src/eth/mac/icmp_reply.v
Normal file
558
rtl/ethernet-udp/src/eth/mac/icmp_reply.v
Normal file
@ -0,0 +1,558 @@
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
//Module Name : icmp_reply
|
||||
//Description : This module is used to receive icmp and reply
|
||||
//
|
||||
|
||||
module icmp_reply
|
||||
(
|
||||
input clk,
|
||||
input rst_n,
|
||||
|
||||
input mac_send_end,
|
||||
input ip_tx_ack,
|
||||
input [7:0] icmp_rx_data, //received data
|
||||
input icmp_rx_req, //receive request
|
||||
input icmp_rev_error, //receive error from MAC or IP
|
||||
input [15:0] upper_layer_data_length, //data length received from IP layer
|
||||
|
||||
input icmp_data_req, //IP layer request data
|
||||
output reg icmp_tx_ready, //icmp reply data ready
|
||||
output reg [7:0] icmp_tx_data, //icmp reply data
|
||||
output icmp_tx_end, //icmp reply end
|
||||
output reg icmp_tx_req //icmp reply request
|
||||
|
||||
);
|
||||
|
||||
localparam ECHO_REQUEST = 8'h08 ;
|
||||
localparam ECHO_REPLY = 8'h00 ;
|
||||
|
||||
reg [15:0] icmp_rx_cnt ;
|
||||
|
||||
reg icmp_rx_end ;
|
||||
reg icmp_checksum_error ; //icmp receive checksum error
|
||||
reg icmp_type_error ; //if icmp type is not 8'h08, do not reply
|
||||
reg [15:0] icmp_data_length ; //data length register
|
||||
reg [15:0] icmp_data_length_d0 ;
|
||||
reg [10:0] icmp_rec_ram_read_addr ; //icmp ram read address
|
||||
wire [7:0] icmp_rec_ram_rdata ; //icmp ram read data
|
||||
reg [7:0] icmp_code ; //icmp code
|
||||
reg [15:0] icmp_id ; //icmp id
|
||||
reg [15:0] icmp_seq ; //icmp seq
|
||||
reg checksum_finish ; //icmp reply checksum generated finish
|
||||
|
||||
reg [10:0] ram_write_addr ; //icmp ram write address, when receive icmp, write ram
|
||||
reg ram_wr_en ; //icmp ram write enable
|
||||
reg icmp_rev_error_d0 ;
|
||||
|
||||
reg [15:0] timeout ; //timeout counter
|
||||
reg [7:0] icmp_rx_data_d0 ; //register for receive data
|
||||
|
||||
reg mac_send_end_d0 ;
|
||||
|
||||
//receive and reply FSM
|
||||
parameter IDLE = 12'b00000_0000_001 ;
|
||||
parameter REC_DATA = 12'b00000_0000_010 ;
|
||||
parameter REC_ODD_DATA = 12'b00000_0000_100 ;
|
||||
parameter VERIFY_CHECKSUM = 12'b00000_0001_000 ;
|
||||
parameter REC_ERROR = 12'b00000_0010_000 ;
|
||||
parameter REC_END_WAIT = 12'b00000_0100_000 ;
|
||||
parameter GEN_CHECKSUM = 12'b00000_1000_000 ;
|
||||
parameter SEND_WAIT_0 = 12'b00001_0000_000 ;
|
||||
parameter SEND_WAIT_1 = 12'b00010_0000_000 ;
|
||||
parameter SEND = 12'b00100_0000_000 ;
|
||||
parameter REC_END = 12'b01000_0000_000 ;
|
||||
parameter SEND_END = 12'b10000_0000_000 ;
|
||||
|
||||
|
||||
|
||||
reg [11:0] state ;
|
||||
reg [11:0] next_state ;
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
state <= IDLE ;
|
||||
else
|
||||
state <= next_state ;
|
||||
end
|
||||
|
||||
always @(*)
|
||||
begin
|
||||
case(state)
|
||||
IDLE :
|
||||
begin
|
||||
if (icmp_rx_req == 1'b1)
|
||||
next_state <= REC_DATA ;
|
||||
else
|
||||
next_state <= IDLE ;
|
||||
end
|
||||
REC_DATA :
|
||||
begin
|
||||
if (icmp_rev_error_d0 || icmp_type_error)
|
||||
next_state <= REC_ERROR ;
|
||||
else if (icmp_data_length[0] == 1'b0 && icmp_rx_cnt == icmp_data_length - 1)
|
||||
next_state <= VERIFY_CHECKSUM ;
|
||||
else if (icmp_data_length[0] == 1'b1 && icmp_rx_cnt == icmp_data_length - 2)
|
||||
next_state <= REC_ODD_DATA ;
|
||||
else if (icmp_rx_cnt == 16'hffff)
|
||||
next_state <= IDLE ;
|
||||
else
|
||||
next_state <= REC_DATA ;
|
||||
end
|
||||
REC_ODD_DATA :
|
||||
begin
|
||||
if (icmp_rev_error_d0 || icmp_type_error)
|
||||
next_state <= REC_ERROR ;
|
||||
else if (icmp_rx_cnt == icmp_data_length - 1)
|
||||
next_state <= VERIFY_CHECKSUM ;
|
||||
else
|
||||
next_state <= REC_ODD_DATA ;
|
||||
end
|
||||
VERIFY_CHECKSUM:
|
||||
begin
|
||||
if (icmp_checksum_error)
|
||||
next_state <= REC_ERROR ;
|
||||
else if (icmp_rx_end && checksum_finish)
|
||||
next_state <= REC_END_WAIT ;
|
||||
else if (icmp_rx_cnt == 16'hffff)
|
||||
next_state <= IDLE ;
|
||||
else
|
||||
next_state <= VERIFY_CHECKSUM ;
|
||||
end
|
||||
REC_ERROR :
|
||||
next_state <= IDLE ;
|
||||
REC_END_WAIT :
|
||||
begin
|
||||
if (icmp_rx_cnt == 16'd63)
|
||||
next_state <= REC_END ;
|
||||
else
|
||||
next_state <= REC_END_WAIT ;
|
||||
end
|
||||
SEND_WAIT_0 :
|
||||
begin
|
||||
if (ip_tx_ack)
|
||||
next_state <= SEND_WAIT_1 ;
|
||||
else
|
||||
next_state <= SEND_WAIT_0 ;
|
||||
end
|
||||
SEND_WAIT_1 :
|
||||
begin
|
||||
if (icmp_data_req)
|
||||
next_state <= SEND ;
|
||||
else if (timeout == 16'hffff)
|
||||
next_state <= IDLE ;
|
||||
else
|
||||
next_state <= SEND_WAIT_1 ;
|
||||
end
|
||||
SEND :
|
||||
begin
|
||||
if (icmp_rx_cnt == icmp_data_length)
|
||||
next_state <= SEND_END ;
|
||||
else if (icmp_rx_cnt == 16'hffff)
|
||||
next_state <= IDLE ;
|
||||
else
|
||||
next_state <= SEND ;
|
||||
end
|
||||
REC_END :
|
||||
next_state <= SEND_WAIT_0 ;
|
||||
SEND_END :
|
||||
begin
|
||||
if (mac_send_end_d0)
|
||||
next_state <= IDLE ;
|
||||
else
|
||||
next_state <= SEND_END ;
|
||||
end
|
||||
default :
|
||||
next_state <= IDLE ;
|
||||
endcase
|
||||
end
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
mac_send_end_d0 <= 1'b0 ;
|
||||
else
|
||||
mac_send_end_d0 <= mac_send_end ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
icmp_tx_req <= 1'b0 ;
|
||||
else if (state == SEND_WAIT_1)
|
||||
icmp_tx_req <= 1'b0 ;
|
||||
else if (state == REC_END)
|
||||
icmp_tx_req <= 1'b1 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
icmp_tx_ready <= 1'b0 ;
|
||||
else if (state == SEND_WAIT_1)
|
||||
icmp_tx_ready <= 1'b1 ;
|
||||
else
|
||||
icmp_tx_ready <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ram_wr_en <= 1'b0 ;
|
||||
else if (state == REC_DATA || state == REC_ODD_DATA)
|
||||
begin
|
||||
if (icmp_rx_cnt < icmp_data_length && icmp_rx_cnt > 16'd7)
|
||||
ram_wr_en <= 1'b1 ;
|
||||
else
|
||||
ram_wr_en <= 1'b0 ;
|
||||
end
|
||||
else
|
||||
ram_wr_en <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ram_write_addr <= 11'b0 ;
|
||||
else if (state == REC_DATA || state == REC_ODD_DATA)
|
||||
ram_write_addr <= icmp_rx_cnt - 8 ;
|
||||
else
|
||||
ram_write_addr <= 11'b0 ;
|
||||
end
|
||||
|
||||
//timeout counter
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
timeout <= 16'd0 ;
|
||||
else if (state == SEND_WAIT_1)
|
||||
timeout <= timeout + 1'b1 ;
|
||||
else
|
||||
timeout <= 16'd0 ;
|
||||
end
|
||||
//received data register
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
icmp_rx_data_d0 <= 8'd0 ;
|
||||
else
|
||||
icmp_rx_data_d0 <= icmp_rx_data ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
icmp_rev_error_d0 <= 1'b0 ;
|
||||
else
|
||||
icmp_rev_error_d0 <= icmp_rev_error ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
icmp_data_length <= 16'd0 ;
|
||||
else if (state == IDLE)
|
||||
icmp_data_length <= upper_layer_data_length ;
|
||||
end
|
||||
|
||||
|
||||
//icmp receive and reply counter
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
icmp_rx_cnt <= 16'd0 ;
|
||||
else if (state == REC_DATA || state == REC_END_WAIT || state == SEND)
|
||||
icmp_rx_cnt <= icmp_rx_cnt + 1'b1 ;
|
||||
else
|
||||
icmp_rx_cnt <= 16'd0 ;
|
||||
end
|
||||
|
||||
|
||||
//icmp type is not request
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
icmp_type_error <= 1'b0 ;
|
||||
else if (state == REC_DATA && icmp_rx_cnt == 16'd0 && icmp_rx_data != ECHO_REQUEST)
|
||||
icmp_type_error <= 1'b1 ;
|
||||
else
|
||||
icmp_type_error <= 1'b0 ;
|
||||
end
|
||||
|
||||
//icmp code
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
icmp_code <= 8'd0 ;
|
||||
else if (state == REC_DATA && icmp_rx_cnt == 16'd1)
|
||||
icmp_code <= icmp_rx_data ;
|
||||
end
|
||||
|
||||
//icmp id
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
icmp_id <= 16'd0 ;
|
||||
else if (state == REC_DATA && icmp_rx_cnt == 16'd4)
|
||||
icmp_id[15:8] <= icmp_rx_data ;
|
||||
else if (state == REC_DATA && icmp_rx_cnt == 16'd5)
|
||||
icmp_id[7:0] <= icmp_rx_data ;
|
||||
end
|
||||
|
||||
//icmp seq
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
icmp_seq <= 16'd0 ;
|
||||
else if (state == REC_DATA && icmp_rx_cnt == 16'd6)
|
||||
icmp_seq[15:8] <= icmp_rx_data ;
|
||||
else if (state == REC_DATA && icmp_rx_cnt == 16'd7)
|
||||
icmp_seq[7:0] <= icmp_rx_data ;
|
||||
end
|
||||
|
||||
|
||||
//read ram address when reply
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
icmp_rec_ram_read_addr <= 11'd0 ;
|
||||
else if (state == SEND && icmp_rx_cnt > 5)
|
||||
icmp_rec_ram_read_addr <= icmp_rx_cnt - 6 ;
|
||||
else
|
||||
icmp_rec_ram_read_addr <= 11'd0 ;
|
||||
end
|
||||
//received ram: depth 256 width 8
|
||||
icmp_rx_ram_8_256 icmp_receive_ram
|
||||
(
|
||||
.clka(clk), // input wire clka
|
||||
.wea(ram_wr_en), // input wire [0 : 0] wea
|
||||
.addra(ram_write_addr), // input wire [7 : 0] addra
|
||||
.dina(icmp_rx_data_d0), // input wire [7 : 0] dina
|
||||
.clkb(clk), // input wire clkb
|
||||
.addrb(icmp_rec_ram_read_addr), // input wire [7 : 0] addrb
|
||||
.doutb(icmp_rec_ram_rdata) // output wire [7 : 0] doutb
|
||||
);
|
||||
|
||||
|
||||
//***************************************************************************//
|
||||
//verify checksum 32 bit adder, in the end, add itself until high 16 bit is 0
|
||||
//** ************************************************************************//
|
||||
reg [31:0] checksum_tmp ;
|
||||
reg [31:0] checksum_buf ;
|
||||
reg [31:0] check_out ;
|
||||
reg [31:0] checkout_buf ;
|
||||
wire [15:0] checksum ;
|
||||
reg [2:0] checksum_cnt ;
|
||||
|
||||
//checksum function
|
||||
function [31:0] checksum_adder
|
||||
(
|
||||
input [31:0] dataina,
|
||||
input [31:0] datainb
|
||||
);
|
||||
begin
|
||||
checksum_adder = dataina + datainb;
|
||||
end
|
||||
endfunction
|
||||
|
||||
function [31:0] checksum_out
|
||||
(
|
||||
input [31:0] dataina
|
||||
);
|
||||
begin
|
||||
checksum_out = dataina[15:0]+dataina[31:16];
|
||||
end
|
||||
endfunction
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
checksum_tmp <= 32'd0;
|
||||
else if (state == REC_DATA)
|
||||
begin
|
||||
if(icmp_rx_cnt[0] == 1'b1)
|
||||
checksum_tmp <= checksum_adder({icmp_rx_data_d0,icmp_rx_data},checksum_buf);
|
||||
end
|
||||
else if (state == REC_ODD_DATA)
|
||||
checksum_tmp <= checksum_adder({icmp_rx_data,8'h00},checksum_tmp); //if udp data length is odd, fill with one byte 8'h00
|
||||
else if (state == IDLE)
|
||||
checksum_tmp <= 32'd0;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
checksum_cnt <= 3'd0 ;
|
||||
else if (state == VERIFY_CHECKSUM)
|
||||
checksum_cnt <= checksum_cnt + 1'b1 ;
|
||||
else
|
||||
checksum_cnt <= 3'd0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
check_out <= 32'd0;
|
||||
else if (state == VERIFY_CHECKSUM)
|
||||
begin
|
||||
if (checksum_cnt == 3'd0)
|
||||
check_out <= checksum_out(checksum_tmp) ;
|
||||
else if (checksum_cnt == 3'd1)
|
||||
check_out <= checksum_out(check_out) ;
|
||||
end
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
checksum_buf <= 32'd0 ;
|
||||
else if (state == REC_DATA)
|
||||
checksum_buf <= checksum_tmp ;
|
||||
else
|
||||
checksum_buf <= 32'd0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
checkout_buf <= 32'd0 ;
|
||||
else
|
||||
checkout_buf <= check_out ;
|
||||
end
|
||||
|
||||
assign checksum = ~checkout_buf[15:0] ;
|
||||
|
||||
//generate checksum error signal and rx end signal
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
begin
|
||||
icmp_checksum_error <= 1'b0 ;
|
||||
icmp_rx_end <= 1'b0 ;
|
||||
end
|
||||
else if (state == VERIFY_CHECKSUM && checksum_cnt == 3'd3)
|
||||
begin
|
||||
if (checksum == 16'd0)
|
||||
begin
|
||||
icmp_checksum_error <= 1'b0 ;
|
||||
icmp_rx_end <= 1'b1 ;
|
||||
end
|
||||
else
|
||||
begin
|
||||
icmp_checksum_error <= 1'b1 ;
|
||||
icmp_rx_end <= 1'b0 ;
|
||||
end
|
||||
end
|
||||
else
|
||||
begin
|
||||
icmp_checksum_error <= 1'b0 ;
|
||||
icmp_rx_end <= 1'b0 ;
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
|
||||
//*******************************************************************//
|
||||
//reply checksum
|
||||
//*******************************************************************//
|
||||
reg [31:0] reply_checksum_tmp ;
|
||||
reg [31:0] reply_checksum_buf ;
|
||||
reg [31:0] reply_check_out ;
|
||||
reg [31:0] reply_checkout_buf ;
|
||||
wire [15:0] reply_checksum ;
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
reply_checksum_tmp <= 32'd0;
|
||||
else if (state == REC_DATA)
|
||||
begin
|
||||
if (icmp_rx_cnt == 16'd1)
|
||||
reply_checksum_tmp <= checksum_adder({8'h00,icmp_rx_data}, 16'h0000); //source ip address
|
||||
else if (icmp_rx_cnt == 16'd3)
|
||||
reply_checksum_tmp <= reply_checksum_tmp ; //source ip address
|
||||
else
|
||||
begin
|
||||
if(icmp_rx_cnt[0] == 1'b1)
|
||||
reply_checksum_tmp <= checksum_adder({icmp_rx_data_d0,icmp_rx_data},reply_checksum_buf);
|
||||
end
|
||||
end
|
||||
else if (state == REC_ODD_DATA)
|
||||
reply_checksum_tmp <= checksum_adder({icmp_rx_data,8'h00},reply_checksum_tmp); //if udp data length is odd, fill with one byte 8'h00
|
||||
else if (state == IDLE)
|
||||
reply_checksum_tmp <= 32'd0;
|
||||
end
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
reply_check_out <= 32'd0;
|
||||
else if (state == VERIFY_CHECKSUM)
|
||||
begin
|
||||
if (checksum_cnt == 3'd0)
|
||||
reply_check_out <= checksum_out(reply_checksum_tmp) ;
|
||||
else if (checksum_cnt == 3'd1)
|
||||
reply_check_out <= checksum_out(reply_check_out) ;
|
||||
end
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
reply_checksum_buf <= 32'd0 ;
|
||||
else if (state == REC_DATA)
|
||||
reply_checksum_buf <= reply_checksum_tmp ;
|
||||
else
|
||||
reply_checksum_buf <= 32'd0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
reply_checkout_buf <= 32'd0 ;
|
||||
else if (state == VERIFY_CHECKSUM)
|
||||
reply_checkout_buf <= reply_check_out ;
|
||||
end
|
||||
|
||||
assign reply_checksum = ~reply_checkout_buf[15:0] ;
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
checksum_finish <= 1'b0 ;
|
||||
else if (state == VERIFY_CHECKSUM && checksum_cnt == 3'd3)
|
||||
checksum_finish <= 1'b1 ;
|
||||
else
|
||||
checksum_finish <= 1'b0 ;
|
||||
end
|
||||
|
||||
|
||||
//*****************************************************************************************//
|
||||
//send icmp data
|
||||
//*****************************************************************************************//
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
icmp_tx_data <= 8'h00 ;
|
||||
else if (state == SEND)
|
||||
begin
|
||||
case(icmp_rx_cnt)
|
||||
16'd0 : icmp_tx_data <= ECHO_REPLY ;
|
||||
16'd1 : icmp_tx_data <= icmp_code ;
|
||||
16'd2 : icmp_tx_data <= reply_checksum[15:8];
|
||||
16'd3 : icmp_tx_data <= reply_checksum[7:0] ;
|
||||
16'd4 : icmp_tx_data <= icmp_id[15:8] ;
|
||||
16'd5 : icmp_tx_data <= icmp_id[7:0] ;
|
||||
16'd6 : icmp_tx_data <= icmp_seq[15:8] ;
|
||||
16'd7 : icmp_tx_data <= icmp_seq[7:0] ;
|
||||
default : icmp_tx_data <= icmp_rec_ram_rdata ;
|
||||
endcase
|
||||
end
|
||||
else
|
||||
icmp_tx_data <= 8'h00 ;
|
||||
end
|
||||
|
||||
endmodule
|
||||
435
rtl/ethernet-udp/src/eth/mac/mac_test.v
Normal file
435
rtl/ethernet-udp/src/eth/mac/mac_test.v
Normal file
@ -0,0 +1,435 @@
|
||||
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
//Module Name : mac_top
|
||||
//Description :
|
||||
//
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
//`define TEST_SPEED
|
||||
`timescale 1 ns/1 ns
|
||||
module mac_test
|
||||
(
|
||||
input rst_n ,
|
||||
input [31:0] pack_total_len,
|
||||
input gmii_tx_clk ,
|
||||
input gmii_rx_clk ,
|
||||
input gmii_rx_dv,
|
||||
input [7:0] gmii_rxd,
|
||||
output reg gmii_tx_en,
|
||||
output reg [7:0] gmii_txd
|
||||
);
|
||||
|
||||
localparam UDP_WIDTH = 32 ;
|
||||
localparam UDP_DEPTH = 5 ;
|
||||
|
||||
|
||||
reg gmii_rx_dv_d0 ;
|
||||
reg [7:0] gmii_rxd_d0 ;
|
||||
wire gmii_tx_en_tmp ;
|
||||
wire [7:0] gmii_txd_tmp ;
|
||||
|
||||
reg [7:0] ram_wr_data ;
|
||||
reg ram_wr_en ;
|
||||
wire udp_ram_data_req ;
|
||||
reg [15:0] udp_send_data_length ;
|
||||
|
||||
wire [7:0] tx_ram_wr_data ;
|
||||
wire tx_ram_wr_en ;
|
||||
wire udp_tx_req ;
|
||||
wire arp_request_req ;
|
||||
wire mac_send_end ;
|
||||
reg write_end ;
|
||||
|
||||
wire [7:0] udp_rec_ram_rdata ;
|
||||
reg [10:0] udp_rec_ram_read_addr ;
|
||||
wire [15:0] udp_rec_data_length ;
|
||||
wire udp_rec_data_valid ;
|
||||
|
||||
wire udp_tx_end ;
|
||||
wire almost_full ;
|
||||
|
||||
reg udp_ram_wr_en ;
|
||||
reg udp_write_end ;
|
||||
wire write_ram_end ;
|
||||
reg [31:0] wait_cnt ;
|
||||
reg [UDP_WIDTH-1:0] udp_data [UDP_DEPTH-1:0];
|
||||
|
||||
reg [4:0] i;
|
||||
reg [1:0] j ;
|
||||
|
||||
reg write_sel ;
|
||||
|
||||
wire button_negedge ;
|
||||
|
||||
wire mac_not_exist ;
|
||||
wire arp_found ;
|
||||
|
||||
parameter IDLE = 9'b000_000_001 ;
|
||||
parameter ARP_REQ = 9'b000_000_010 ;
|
||||
parameter ARP_SEND = 9'b000_000_100 ;
|
||||
parameter ARP_WAIT = 9'b000_001_000 ;
|
||||
parameter GEN_REQ = 9'b000_010_000 ;
|
||||
parameter WRITE_RAM = 9'b000_100_000 ;
|
||||
parameter SEND = 9'b001_000_000 ;
|
||||
parameter WAIT = 9'b010_000_000 ;
|
||||
parameter CHECK_ARP = 9'b100_000_000 ;
|
||||
|
||||
|
||||
reg [8:0] state ;
|
||||
reg [8:0] next_state ;
|
||||
reg [15:0] ram_cnt ;
|
||||
reg almost_full_d0 ;
|
||||
reg almost_full_d1 ;
|
||||
always @(posedge gmii_tx_clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
state <= IDLE ;
|
||||
else
|
||||
state <= next_state ;
|
||||
end
|
||||
|
||||
always @(*)
|
||||
begin
|
||||
case(state)
|
||||
IDLE :
|
||||
begin
|
||||
if (wait_cnt == pack_total_len)
|
||||
next_state <= ARP_REQ ;
|
||||
else
|
||||
next_state <= IDLE ;
|
||||
end
|
||||
|
||||
ARP_REQ :
|
||||
next_state <= ARP_SEND ;
|
||||
ARP_SEND :
|
||||
begin
|
||||
if (mac_send_end)
|
||||
next_state <= ARP_WAIT ;
|
||||
else
|
||||
next_state <= ARP_SEND ;
|
||||
end
|
||||
ARP_WAIT :
|
||||
begin
|
||||
if (arp_found)
|
||||
next_state <= WAIT ;
|
||||
else if (wait_cnt == pack_total_len)
|
||||
next_state <= ARP_REQ ;
|
||||
else
|
||||
next_state <= ARP_WAIT ;
|
||||
end
|
||||
GEN_REQ :
|
||||
begin
|
||||
if (udp_ram_data_req)
|
||||
next_state <= WRITE_RAM ;
|
||||
else
|
||||
next_state <= GEN_REQ ;
|
||||
end
|
||||
WRITE_RAM :
|
||||
begin
|
||||
`ifdef TEST_SPEED
|
||||
if (ram_cnt == udp_send_data_length - 1)
|
||||
`else
|
||||
if (write_ram_end)
|
||||
`endif
|
||||
next_state <= WAIT ;
|
||||
else
|
||||
next_state <= WRITE_RAM ;
|
||||
end
|
||||
|
||||
SEND :
|
||||
begin
|
||||
if (udp_tx_end)
|
||||
next_state <= WAIT ;
|
||||
else
|
||||
next_state <= SEND ;
|
||||
end
|
||||
|
||||
WAIT :
|
||||
begin
|
||||
`ifdef TEST_SPEED
|
||||
if (wait_cnt == 32'd90) //frame gap
|
||||
`else
|
||||
if (wait_cnt == pack_total_len)
|
||||
`endif
|
||||
next_state <= CHECK_ARP ;
|
||||
else
|
||||
next_state <= WAIT ;
|
||||
end
|
||||
CHECK_ARP :
|
||||
begin
|
||||
if (mac_not_exist)
|
||||
next_state <= ARP_REQ ;
|
||||
else if (almost_full_d1)
|
||||
next_state <= CHECK_ARP ;
|
||||
else
|
||||
next_state <= GEN_REQ ;
|
||||
end
|
||||
default :
|
||||
next_state <= IDLE ;
|
||||
endcase
|
||||
end
|
||||
|
||||
|
||||
assign write_ram_end = (write_sel)? udp_write_end : write_end ;
|
||||
assign tx_ram_wr_data = (write_sel)? udp_rec_ram_rdata : ram_wr_data ;
|
||||
assign tx_ram_wr_en = (write_sel)? udp_ram_wr_en : ram_wr_en ;
|
||||
|
||||
|
||||
always@(posedge gmii_rx_clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
begin
|
||||
gmii_rx_dv_d0 <= 1'b0 ;
|
||||
gmii_rxd_d0 <= 8'd0 ;
|
||||
end
|
||||
else
|
||||
begin
|
||||
gmii_rx_dv_d0 <= gmii_rx_dv ;
|
||||
gmii_rxd_d0 <= gmii_rxd ;
|
||||
end
|
||||
end
|
||||
|
||||
always@(posedge gmii_tx_clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
begin
|
||||
gmii_tx_en <= 1'b0 ;
|
||||
gmii_txd <= 8'd0 ;
|
||||
end
|
||||
else
|
||||
begin
|
||||
gmii_tx_en <= gmii_tx_en_tmp ;
|
||||
gmii_txd <= gmii_txd_tmp ;
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
|
||||
|
||||
mac_top mac_top0
|
||||
(
|
||||
.gmii_tx_clk (gmii_tx_clk) ,
|
||||
.gmii_rx_clk (gmii_rx_clk) ,
|
||||
.rst_n (rst_n) ,
|
||||
|
||||
.source_mac_addr (48'h00_0a_35_01_fe_c0) , //source mac address
|
||||
.TTL (8'h80),
|
||||
.source_ip_addr (32'hc0a80002),
|
||||
.destination_ip_addr (32'hc0a80003),
|
||||
.udp_send_source_port (16'h1f90),
|
||||
.udp_send_destination_port (16'h1f90),
|
||||
|
||||
.ram_wr_data (tx_ram_wr_data) ,
|
||||
.ram_wr_en (tx_ram_wr_en),
|
||||
.udp_ram_data_req (udp_ram_data_req),
|
||||
.udp_send_data_length (udp_send_data_length),
|
||||
.udp_tx_end (udp_tx_end ),
|
||||
.almost_full (almost_full ),
|
||||
|
||||
.udp_tx_req (udp_tx_req),
|
||||
.arp_request_req (arp_request_req ),
|
||||
|
||||
.mac_send_end (mac_send_end),
|
||||
.mac_data_valid (gmii_tx_en_tmp),
|
||||
.mac_tx_data (gmii_txd_tmp),
|
||||
.rx_dv (gmii_rx_dv_d0 ),
|
||||
.mac_rx_datain (gmii_rxd_d0 ),
|
||||
|
||||
.udp_rec_ram_rdata (udp_rec_ram_rdata),
|
||||
.udp_rec_ram_read_addr (udp_rec_ram_read_addr),
|
||||
.udp_rec_data_length (udp_rec_data_length ),
|
||||
|
||||
.udp_rec_data_valid (udp_rec_data_valid),
|
||||
.arp_found (arp_found ),
|
||||
.mac_not_exist (mac_not_exist )
|
||||
) ;
|
||||
|
||||
always @(*)
|
||||
begin
|
||||
udp_data[0] <={"H","E","L","L"};
|
||||
udp_data[1] <={"O"," ","A","L"};
|
||||
udp_data[2] <={"I","N","X"," "};
|
||||
udp_data[3] <={"H","E","I","J"};
|
||||
udp_data[4] <={"I","N","\r","\n"};
|
||||
|
||||
end
|
||||
|
||||
//reg almost_full_d0 ;
|
||||
//reg almost_full_d1 ;
|
||||
|
||||
always@(posedge gmii_rx_clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
begin
|
||||
almost_full_d0 <= 1'b0 ;
|
||||
almost_full_d1 <= 1'b0 ;
|
||||
end
|
||||
else
|
||||
begin
|
||||
almost_full_d0 <= almost_full ;
|
||||
almost_full_d1 <= almost_full_d0 ;
|
||||
end
|
||||
end
|
||||
|
||||
always@(posedge gmii_rx_clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
udp_send_data_length <= 16'd0 ;
|
||||
else if (write_sel)
|
||||
udp_send_data_length <= udp_rec_data_length - 8 ;
|
||||
else
|
||||
`ifdef TEST_SPEED
|
||||
udp_send_data_length <= 16'd1000 ;
|
||||
`else
|
||||
udp_send_data_length <= 4*UDP_DEPTH ;
|
||||
`endif
|
||||
end
|
||||
|
||||
|
||||
always@(posedge gmii_tx_clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
write_sel <= 1'b0 ;
|
||||
else if (state == WAIT)
|
||||
begin
|
||||
if (udp_rec_data_valid)
|
||||
write_sel <= 1'b1 ;
|
||||
else
|
||||
write_sel <= 1'b0 ;
|
||||
end
|
||||
end
|
||||
|
||||
assign udp_tx_req = (state == GEN_REQ) ;
|
||||
assign arp_request_req = (state == ARP_REQ) ;
|
||||
|
||||
always@(posedge gmii_tx_clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
wait_cnt <= 0 ;
|
||||
else if ((state==IDLE||state == WAIT || state == ARP_WAIT) && state != next_state)
|
||||
wait_cnt <= 0 ;
|
||||
else if (state==IDLE||state == WAIT || state == ARP_WAIT)
|
||||
wait_cnt <= wait_cnt + 1'b1 ;
|
||||
else
|
||||
wait_cnt <= 0 ;
|
||||
end
|
||||
|
||||
|
||||
`ifdef TEST_SPEED
|
||||
/*************************************************************/
|
||||
//Test ethernet speed
|
||||
//reg [15:0] ram_cnt ;
|
||||
always@(posedge gmii_tx_clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
ram_cnt <= 11'd0 ;
|
||||
else if (state == WRITE_RAM)
|
||||
ram_cnt <= ram_cnt + 1'b1 ;
|
||||
else
|
||||
ram_cnt <= 11'd0 ;
|
||||
end
|
||||
|
||||
always@(posedge gmii_tx_clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
ram_wr_en <= 1'b0 ;
|
||||
else if (state == WRITE_RAM)
|
||||
ram_wr_en <= 1'b1 ;
|
||||
else
|
||||
ram_wr_en <= 1'b0 ;
|
||||
end
|
||||
|
||||
|
||||
always@(posedge gmii_tx_clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
ram_wr_data <= 8'd0 ;
|
||||
else if (state == WRITE_RAM)
|
||||
ram_wr_data <= ram_cnt[7:0] ;
|
||||
else
|
||||
ram_wr_data <= 8'd0 ;
|
||||
end
|
||||
/*************************************************************/
|
||||
`else
|
||||
always@(posedge gmii_tx_clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
begin
|
||||
write_end <= 1'b0;
|
||||
ram_wr_data <= 0;
|
||||
ram_wr_en <= 0 ;
|
||||
i <= 0 ;
|
||||
j <= 0 ;
|
||||
end
|
||||
else if (state == WRITE_RAM)
|
||||
begin
|
||||
if(i == 5)
|
||||
begin
|
||||
ram_wr_en <=1'b0;
|
||||
write_end <= 1'b1;
|
||||
end
|
||||
else
|
||||
begin
|
||||
ram_wr_en <= 1'b1 ;
|
||||
write_end <= 1'b0 ;
|
||||
j <= j + 1'b1 ;
|
||||
case(j)
|
||||
2'd0 : ram_wr_data <= udp_data[i][31:24] ;
|
||||
2'd1 : ram_wr_data <= udp_data[i][23:16] ;
|
||||
2'd2 : ram_wr_data <= udp_data[i][15:8] ;
|
||||
2'd3 : ram_wr_data <= udp_data[i][7:0] ;
|
||||
default : ram_wr_data <= 8'h00 ;
|
||||
endcase
|
||||
|
||||
if (j == 3)
|
||||
begin
|
||||
j <= 0 ;
|
||||
i <= i + 1'b1;
|
||||
end
|
||||
end
|
||||
end
|
||||
else
|
||||
begin
|
||||
write_end <= 1'b0;
|
||||
ram_wr_data <= 0;
|
||||
ram_wr_en <= 0 ;
|
||||
i <= 0 ;
|
||||
j <= 0 ;
|
||||
end
|
||||
end
|
||||
`endif
|
||||
|
||||
//send udp received data to udp tx ram
|
||||
always@(posedge gmii_tx_clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
udp_rec_ram_read_addr <= 11'd0 ;
|
||||
else if (state == WRITE_RAM)
|
||||
udp_rec_ram_read_addr <= udp_rec_ram_read_addr + 1'b1 ;
|
||||
else
|
||||
udp_rec_ram_read_addr <= 11'd0 ;
|
||||
end
|
||||
|
||||
always@(posedge gmii_tx_clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
udp_ram_wr_en <= 1'b0 ;
|
||||
else if (state == WRITE_RAM && udp_rec_ram_read_addr < udp_rec_data_length - 8)
|
||||
udp_ram_wr_en <= 1'b1 ;
|
||||
else
|
||||
udp_ram_wr_en <= 1'b0 ;
|
||||
end
|
||||
|
||||
always@(posedge gmii_tx_clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
udp_write_end <= 1'b0 ;
|
||||
else if (state == WRITE_RAM && udp_rec_ram_read_addr == udp_rec_data_length - 8)
|
||||
udp_write_end <= 1'b1 ;
|
||||
else
|
||||
udp_write_end <= 1'b0 ;
|
||||
end
|
||||
|
||||
|
||||
endmodule
|
||||
|
||||
|
||||
176
rtl/ethernet-udp/src/eth/mac/mac_top.v
Normal file
176
rtl/ethernet-udp/src/eth/mac/mac_top.v
Normal file
@ -0,0 +1,176 @@
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
//Module Name : mac_top
|
||||
//Description :
|
||||
//
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
`timescale 1 ns/1 ns
|
||||
module mac_top
|
||||
(
|
||||
input gmii_tx_clk ,
|
||||
input gmii_rx_clk ,
|
||||
input rst_n ,
|
||||
|
||||
input [47:0] source_mac_addr , //source mac address
|
||||
input [7:0] TTL,
|
||||
input [31:0] source_ip_addr,
|
||||
input [31:0] destination_ip_addr,
|
||||
input [15:0] udp_send_source_port,
|
||||
input [15:0] udp_send_destination_port,
|
||||
|
||||
|
||||
input [7:0] ram_wr_data,
|
||||
input ram_wr_en,
|
||||
output udp_ram_data_req,
|
||||
input [15:0] udp_send_data_length,
|
||||
output udp_tx_end,
|
||||
output almost_full,
|
||||
|
||||
input udp_tx_req,
|
||||
input arp_request_req,
|
||||
output mac_data_valid,
|
||||
output mac_send_end,
|
||||
output [7:0] mac_tx_data,
|
||||
|
||||
input rx_dv,
|
||||
input [7:0] mac_rx_datain,
|
||||
output [7:0] udp_rec_ram_rdata ,
|
||||
input [10:0] udp_rec_ram_read_addr,
|
||||
output [15:0] udp_rec_data_length,
|
||||
output udp_rec_data_valid,
|
||||
|
||||
output arp_found,
|
||||
output mac_not_exist
|
||||
|
||||
) ;
|
||||
|
||||
|
||||
wire arp_reply_ack ;
|
||||
wire arp_reply_req ;
|
||||
wire [31:0] arp_rec_source_ip_addr ;
|
||||
wire [47:0] arp_rec_source_mac_addr ;
|
||||
wire [47:0] destination_mac_addr ;
|
||||
|
||||
wire [7:0] mac_rx_dataout ;
|
||||
wire [15:0] upper_layer_data_length ;
|
||||
wire icmp_rx_req ;
|
||||
wire icmp_rev_error ;
|
||||
wire upper_data_req ;
|
||||
wire icmp_tx_ready ;
|
||||
wire [7:0] icmp_tx_data ;
|
||||
wire icmp_tx_end ;
|
||||
wire icmp_tx_req ;
|
||||
wire icmp_tx_ack ;
|
||||
wire [15:0] icmp_send_data_length ;
|
||||
|
||||
mac_tx_top mac_tx0
|
||||
(
|
||||
.clk (gmii_tx_clk) ,
|
||||
.rst_n (rst_n) ,
|
||||
|
||||
.destination_mac_addr (destination_mac_addr) , //destination mac address
|
||||
.source_mac_addr (source_mac_addr) , //source mac address
|
||||
.TTL (TTL),
|
||||
.source_ip_addr (source_ip_addr),
|
||||
.destination_ip_addr (destination_ip_addr),
|
||||
|
||||
.udp_send_source_port (udp_send_source_port),
|
||||
.udp_send_destination_port (udp_send_destination_port),
|
||||
|
||||
.arp_reply_ack (arp_reply_ack ),
|
||||
.arp_reply_req (arp_reply_req ),
|
||||
.arp_rec_source_ip_addr (arp_rec_source_ip_addr ),
|
||||
.arp_rec_source_mac_addr (arp_rec_source_mac_addr ),
|
||||
.arp_request_req (arp_request_req ),
|
||||
|
||||
|
||||
.ram_wr_data (ram_wr_data) ,
|
||||
.ram_wr_en (ram_wr_en),
|
||||
.udp_tx_req (udp_tx_req),
|
||||
.udp_send_data_length (udp_send_data_length ),
|
||||
.udp_ram_data_req (udp_ram_data_req ),
|
||||
.udp_tx_end (udp_tx_end ),
|
||||
.almost_full (almost_full ),
|
||||
|
||||
.upper_data_req (upper_data_req ),
|
||||
.icmp_tx_ready (icmp_tx_ready ),
|
||||
.icmp_tx_data (icmp_tx_data ),
|
||||
.icmp_tx_end (icmp_tx_end ),
|
||||
.icmp_tx_req (icmp_tx_req ),
|
||||
.icmp_tx_ack (icmp_tx_ack ),
|
||||
.icmp_send_data_length (icmp_send_data_length),
|
||||
|
||||
.mac_data_valid (mac_data_valid),
|
||||
.mac_send_end (mac_send_end),
|
||||
.mac_tx_data (mac_tx_data)
|
||||
) ;
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
mac_rx_top mac_rx0
|
||||
(
|
||||
.clk (gmii_rx_clk) ,
|
||||
.rst_n (rst_n) ,
|
||||
|
||||
.rx_dv (rx_dv ),
|
||||
.mac_rx_datain (mac_rx_datain ),
|
||||
|
||||
.local_ip_addr (source_ip_addr ),
|
||||
.local_mac_addr (source_mac_addr),
|
||||
.arp_reply_ack (arp_reply_ack ),
|
||||
.arp_reply_req (arp_reply_req ),
|
||||
.arp_rec_source_ip_addr (arp_rec_source_ip_addr ),
|
||||
.arp_rec_source_mac_addr (arp_rec_source_mac_addr ),
|
||||
|
||||
.udp_rec_ram_rdata (udp_rec_ram_rdata),
|
||||
.udp_rec_ram_read_addr (udp_rec_ram_read_addr),
|
||||
.udp_rec_data_length (udp_rec_data_length ),
|
||||
.udp_rec_data_valid (udp_rec_data_valid),
|
||||
|
||||
.mac_rx_dataout (mac_rx_dataout ),
|
||||
.upper_layer_data_length (upper_layer_data_length ),
|
||||
.ip_total_data_length (icmp_send_data_length),
|
||||
.icmp_rx_req (icmp_rx_req ),
|
||||
.icmp_rev_error (icmp_rev_error ),
|
||||
|
||||
.arp_found (arp_found )
|
||||
) ;
|
||||
|
||||
|
||||
icmp_reply icmp0
|
||||
(
|
||||
.clk (gmii_rx_clk) ,
|
||||
.rst_n (rst_n) ,
|
||||
.mac_send_end (mac_send_end ),
|
||||
.icmp_rx_data (mac_rx_dataout ),
|
||||
.icmp_rx_req (icmp_rx_req ),
|
||||
.icmp_rev_error (icmp_rev_error ),
|
||||
|
||||
.upper_layer_data_length (upper_layer_data_length ),
|
||||
|
||||
.icmp_data_req (upper_data_req ),
|
||||
.icmp_tx_ready (icmp_tx_ready ),
|
||||
.icmp_tx_data (icmp_tx_data ),
|
||||
.icmp_tx_end (icmp_tx_end ),
|
||||
.ip_tx_ack (icmp_tx_ack ),
|
||||
.icmp_tx_req (icmp_tx_req )
|
||||
|
||||
|
||||
);
|
||||
|
||||
|
||||
arp_cache cache0
|
||||
(
|
||||
.clk (gmii_tx_clk),
|
||||
.rst_n (rst_n),
|
||||
.arp_found (arp_found ),
|
||||
.arp_rec_source_ip_addr (arp_rec_source_ip_addr ),
|
||||
.arp_rec_source_mac_addr (arp_rec_source_mac_addr ),
|
||||
.destination_ip_addr (destination_ip_addr),
|
||||
.destination_mac_addr (destination_mac_addr) ,
|
||||
.mac_not_exist (mac_not_exist )
|
||||
);
|
||||
endmodule
|
||||
|
||||
210
rtl/ethernet-udp/src/eth/mac/rx/arp_rx.v
Normal file
210
rtl/ethernet-udp/src/eth/mac/rx/arp_rx.v
Normal file
@ -0,0 +1,210 @@
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
//Module Name : arp_rx
|
||||
//Description : This module is used to receive ARP data and send ARP reply request
|
||||
//
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
`timescale 1 ns/1 ns
|
||||
module arp_rx
|
||||
(
|
||||
input clk,
|
||||
input rst_n,
|
||||
input crc_error,
|
||||
|
||||
input [31:0] local_ip_addr,
|
||||
input [47:0] local_mac_addr,
|
||||
input [7:0] arp_rx_data, //arp received data
|
||||
input arp_rx_req, //arp rx request from mac
|
||||
output reg arp_rx_end, //arp rx end
|
||||
|
||||
input arp_reply_ack, //arp reply ack from arp reply module
|
||||
output reg arp_reply_req, //arp reply request to arp reply module
|
||||
|
||||
output reg [31:0] arp_rec_source_ip_addr, //arp received source ip address
|
||||
output reg [47:0] arp_rec_source_mac_addr, //arp received mac address
|
||||
output reg arp_found //found destination mac address
|
||||
|
||||
) ;
|
||||
|
||||
localparam ARP_REQUEST_CODE = 16'h0001 ;
|
||||
localparam ARP_REPLY_CODE = 16'h0002 ;
|
||||
|
||||
reg [31:0] arp_rec_destination_ip_addr ;
|
||||
reg [47:0] arp_rec_destination_mac_addr ;
|
||||
reg [15:0] arp_rec_op ;
|
||||
reg [7:0] arp_rx_cnt ;
|
||||
|
||||
parameter IDLE = 4'b0001 ;
|
||||
parameter ARP_REC_DATA = 4'b0010 ;
|
||||
parameter ARP_WAIT = 4'b0100 ;
|
||||
parameter ARP_END = 4'b1000 ;
|
||||
|
||||
reg [3:0] state ;
|
||||
reg [3:0] next_state ;
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
state <= IDLE ;
|
||||
else
|
||||
state <= next_state ;
|
||||
end
|
||||
|
||||
always @(*)
|
||||
begin
|
||||
case(state)
|
||||
IDLE :
|
||||
begin
|
||||
if (arp_rx_req)
|
||||
next_state <= ARP_REC_DATA ;
|
||||
else
|
||||
next_state <= IDLE ;
|
||||
end
|
||||
ARP_REC_DATA :
|
||||
begin
|
||||
if (arp_rx_cnt == 45)
|
||||
next_state <= ARP_WAIT ;
|
||||
else
|
||||
next_state <= ARP_REC_DATA ;
|
||||
end
|
||||
ARP_WAIT :
|
||||
begin
|
||||
if (arp_rx_cnt == 99)
|
||||
next_state <= ARP_END ;
|
||||
else
|
||||
next_state <= ARP_WAIT ;
|
||||
end
|
||||
|
||||
ARP_END :
|
||||
next_state <= IDLE ;
|
||||
|
||||
default :
|
||||
next_state <= IDLE ;
|
||||
endcase
|
||||
end
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
arp_rx_end <= 1'b0 ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 44)
|
||||
arp_rx_end <= 1'b1 ;
|
||||
else
|
||||
arp_rx_end <= 1'b0 ;
|
||||
end
|
||||
|
||||
//received arp request
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
arp_reply_req <= 1'b0 ;
|
||||
else if (arp_rx_req)
|
||||
arp_reply_req <= 1'b0 ;
|
||||
else if (arp_reply_ack)
|
||||
arp_reply_req <= 1'b0 ;
|
||||
else if (state == ARP_END && crc_error == 1'b0)
|
||||
begin
|
||||
if (arp_rec_op == ARP_REQUEST_CODE && arp_rec_destination_ip_addr == local_ip_addr)
|
||||
arp_reply_req <= 1'b1 ;
|
||||
end
|
||||
end
|
||||
//received arp reply
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
arp_found <= 1'b0 ;
|
||||
else if (state == ARP_END && crc_error == 1'b0)
|
||||
begin
|
||||
if (arp_rec_op == ARP_REPLY_CODE && arp_rec_destination_ip_addr == local_ip_addr && arp_rec_destination_mac_addr == local_mac_addr)
|
||||
arp_found <= 1'b1 ;
|
||||
end
|
||||
else
|
||||
arp_found <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
arp_rx_cnt <= 8'd0 ;
|
||||
else if (state == ARP_REC_DATA || state == ARP_WAIT)
|
||||
arp_rx_cnt <= arp_rx_cnt + 1'b1 ;
|
||||
else
|
||||
arp_rx_cnt <= 8'd0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
arp_rec_op <= 16'd0 ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd6)
|
||||
arp_rec_op[15:8] <= arp_rx_data ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd7)
|
||||
arp_rec_op[7:0] <= arp_rx_data ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
arp_rec_source_mac_addr <= 48'd0 ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd8)
|
||||
arp_rec_source_mac_addr[47:40] <= arp_rx_data ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd9)
|
||||
arp_rec_source_mac_addr[39:32] <= arp_rx_data ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd10)
|
||||
arp_rec_source_mac_addr[31:24] <= arp_rx_data ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd11)
|
||||
arp_rec_source_mac_addr[23:16] <= arp_rx_data ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd12)
|
||||
arp_rec_source_mac_addr[15:8] <= arp_rx_data ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd13)
|
||||
arp_rec_source_mac_addr[7:0] <= arp_rx_data ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
arp_rec_source_ip_addr <= 32'd0 ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd14)
|
||||
arp_rec_source_ip_addr[31:24] <= arp_rx_data ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd15)
|
||||
arp_rec_source_ip_addr[23:16] <= arp_rx_data ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd16)
|
||||
arp_rec_source_ip_addr[15:8] <= arp_rx_data ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd17)
|
||||
arp_rec_source_ip_addr[7:0] <= arp_rx_data ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
arp_rec_destination_mac_addr <= 48'd0 ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd18)
|
||||
arp_rec_destination_mac_addr[47:40] <= arp_rx_data ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd19)
|
||||
arp_rec_destination_mac_addr[39:32] <= arp_rx_data ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd20)
|
||||
arp_rec_destination_mac_addr[31:24] <= arp_rx_data ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd21)
|
||||
arp_rec_destination_mac_addr[23:16] <= arp_rx_data ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd22)
|
||||
arp_rec_destination_mac_addr[15:8] <= arp_rx_data ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd23)
|
||||
arp_rec_destination_mac_addr[7:0] <= arp_rx_data ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
arp_rec_destination_ip_addr <= 32'd0 ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd24)
|
||||
arp_rec_destination_ip_addr[31:24] <= arp_rx_data ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd25)
|
||||
arp_rec_destination_ip_addr[23:16] <= arp_rx_data ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd26)
|
||||
arp_rec_destination_ip_addr[15:8] <= arp_rx_data ;
|
||||
else if (state == ARP_REC_DATA && arp_rx_cnt == 8'd27)
|
||||
arp_rec_destination_ip_addr[7:0] <= arp_rx_data ;
|
||||
end
|
||||
|
||||
|
||||
endmodule
|
||||
360
rtl/ethernet-udp/src/eth/mac/rx/ip_rx.v
Normal file
360
rtl/ethernet-udp/src/eth/mac/rx/ip_rx.v
Normal file
@ -0,0 +1,360 @@
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
//Module Name : ip_rx
|
||||
//Description : This module is used to receive IP data and verify IP header checksum
|
||||
//
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
`timescale 1 ns/1 ns
|
||||
module ip_rx
|
||||
//#
|
||||
//(
|
||||
// parameter local_mac_addr = 48'h00_0a_35_01_fe_c0,
|
||||
// parameter local_ip_addr = 32'hc0a80002
|
||||
//)
|
||||
(
|
||||
input clk,
|
||||
input rst_n,
|
||||
|
||||
input [31:0] local_ip_addr,
|
||||
input [47:0] local_mac_addr,
|
||||
|
||||
input [7:0] ip_rx_data,
|
||||
input ip_rx_req,
|
||||
input [47:0] mac_rx_destination_mac_addr,
|
||||
|
||||
output reg udp_rx_req, //udp rx request
|
||||
output reg icmp_rx_req, //icmp rx request
|
||||
output reg ip_addr_check_error, //ip address is not equal to local address
|
||||
|
||||
output reg [15:0] upper_layer_data_length, //udp or icmp data length = ip data length - ip header length
|
||||
output reg [15:0] ip_total_data_length, //send data length
|
||||
|
||||
output reg [7:0] net_protocol, //network layer protocol: 8'h11 udp 8'h01 icmp
|
||||
output reg [31:0] ip_rec_source_addr, //received source ip address
|
||||
output reg [31:0] ip_rec_destination_addr, //received destination ip address
|
||||
|
||||
output reg ip_rx_end,
|
||||
output reg ip_checksum_error
|
||||
|
||||
) ;
|
||||
|
||||
reg [15:0] ip_rx_cnt ;
|
||||
reg [15:0] ip_rec_data_length ;
|
||||
|
||||
reg [7:0] ip_rx_data_d0 ;
|
||||
reg [7:0] ip_rx_data_d1 ;
|
||||
|
||||
reg [15:0] ip_rec_checksum ;
|
||||
|
||||
reg [3:0] header_length_buf ;
|
||||
wire [5:0] header_length ;
|
||||
|
||||
parameter IDLE = 5'b00001 ;
|
||||
parameter REC_HEADER0 = 5'b00010 ;
|
||||
parameter REC_HEADER1 = 5'b00100 ;
|
||||
parameter REC_DATA = 5'b01000 ;
|
||||
parameter REC_END = 5'b10000 ;
|
||||
|
||||
reg [4:0] state ;
|
||||
reg [4:0] next_state ;
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
state <= IDLE ;
|
||||
else
|
||||
state <= next_state ;
|
||||
end
|
||||
|
||||
always @(*)
|
||||
begin
|
||||
case(state)
|
||||
IDLE : begin
|
||||
if (ip_rx_req == 1'b1)
|
||||
next_state <= REC_HEADER0 ;
|
||||
else
|
||||
next_state <= IDLE ;
|
||||
end
|
||||
REC_HEADER0 : begin
|
||||
if (ip_rx_cnt == 16'd3)
|
||||
next_state <= REC_HEADER1 ;
|
||||
else
|
||||
next_state <= REC_HEADER0 ;
|
||||
end
|
||||
REC_HEADER1 : begin
|
||||
if (ip_rx_cnt == header_length - 1)
|
||||
next_state <= REC_DATA ;
|
||||
else
|
||||
next_state <= REC_HEADER1 ;
|
||||
end
|
||||
REC_DATA : begin
|
||||
if (ip_checksum_error || ip_rx_end)
|
||||
next_state <= REC_END ;
|
||||
else if (ip_rx_cnt == 16'hffff)
|
||||
next_state <= REC_END ;
|
||||
else
|
||||
next_state <= REC_DATA ;
|
||||
end
|
||||
REC_END : next_state <= IDLE ;
|
||||
default : next_state <= IDLE ;
|
||||
endcase
|
||||
end
|
||||
|
||||
assign header_length = 4*header_length_buf ;
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ip_rx_end <= 1'b0 ;
|
||||
else if (state == REC_DATA && ip_rx_cnt == ip_total_data_length - 2)
|
||||
ip_rx_end <= 1'b1 ;
|
||||
else
|
||||
ip_rx_end <= 1'b0 ;
|
||||
end
|
||||
//mac addr and ip addr is not equal to local addr, assert error
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ip_addr_check_error <= 1'b0 ;
|
||||
else if (state == REC_DATA)
|
||||
begin
|
||||
if (mac_rx_destination_mac_addr == local_mac_addr && ip_rec_destination_addr == local_ip_addr)
|
||||
ip_addr_check_error <= 1'b0 ;
|
||||
else
|
||||
ip_addr_check_error <= 1'b1 ;
|
||||
end
|
||||
else
|
||||
ip_addr_check_error <= 1'b0 ;
|
||||
end
|
||||
//generate udp rx request signal
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
udp_rx_req <= 1'b0 ;
|
||||
else if (state == REC_HEADER1 && net_protocol == 8'h11 && ip_rx_cnt == header_length - 2)
|
||||
udp_rx_req <= 1'b1 ;
|
||||
else
|
||||
udp_rx_req <= 1'b0 ;
|
||||
end
|
||||
//generate icmp rx request signal
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
icmp_rx_req <= 1'b0 ;
|
||||
else if (state == REC_HEADER1 && net_protocol == 8'h01 && ip_rx_cnt == header_length - 2)
|
||||
icmp_rx_req <= 1'b1 ;
|
||||
else
|
||||
icmp_rx_req <= 1'b0 ;
|
||||
end
|
||||
|
||||
|
||||
//icmp or udp data length
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
begin
|
||||
upper_layer_data_length <= 16'd0 ;
|
||||
end
|
||||
else
|
||||
begin
|
||||
upper_layer_data_length <= ip_rec_data_length - header_length ;
|
||||
end
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
begin
|
||||
ip_rx_data_d0 <= 8'd0 ;
|
||||
ip_rx_data_d1 <= 8'd0 ;
|
||||
end
|
||||
else
|
||||
begin
|
||||
ip_rx_data_d0 <= ip_rx_data ;
|
||||
ip_rx_data_d1 <= ip_rx_data_d0 ;
|
||||
end
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ip_rx_cnt <= 16'd0 ;
|
||||
else if (state == REC_HEADER0 || state == REC_HEADER1 || state == REC_DATA)
|
||||
ip_rx_cnt <= ip_rx_cnt + 1'b1 ;
|
||||
else
|
||||
ip_rx_cnt <= 16'd0 ;
|
||||
end
|
||||
//total length
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ip_total_data_length <= 16'd0 ;
|
||||
else if (state == REC_HEADER1)
|
||||
begin
|
||||
if (ip_rec_data_length < 16'd46)
|
||||
ip_total_data_length <= 16'd46 ;
|
||||
else
|
||||
ip_total_data_length <= ip_rec_data_length ;
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
//ip header length
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
header_length_buf <= 4'd0 ;
|
||||
else if (state == REC_HEADER0 && ip_rx_cnt == 16'd0)
|
||||
header_length_buf <= ip_rx_data[3:0] ;
|
||||
end
|
||||
//ip data total length
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ip_rec_data_length <= 16'd0 ;
|
||||
else if (state == REC_HEADER0 && ip_rx_cnt == 16'd2)
|
||||
ip_rec_data_length[15:8] <= ip_rx_data ;
|
||||
else if (state == REC_HEADER0 && ip_rx_cnt == 16'd3)
|
||||
ip_rec_data_length[7:0] <= ip_rx_data ;
|
||||
end
|
||||
//network layer protocol
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
net_protocol <= 8'd0 ;
|
||||
else if (state == REC_HEADER1 && ip_rx_cnt == 16'd9)
|
||||
net_protocol <= ip_rx_data ;
|
||||
end
|
||||
|
||||
//ip source address
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ip_rec_source_addr <= 32'd0 ;
|
||||
else if (state == REC_HEADER1 && ip_rx_cnt == 16'd12)
|
||||
ip_rec_source_addr[31:24] <= ip_rx_data ;
|
||||
else if (state == REC_HEADER1 && ip_rx_cnt == 16'd13)
|
||||
ip_rec_source_addr[23:16] <= ip_rx_data ;
|
||||
else if (state == REC_HEADER1 && ip_rx_cnt == 16'd14)
|
||||
ip_rec_source_addr[15:8] <= ip_rx_data ;
|
||||
else if (state == REC_HEADER1 && ip_rx_cnt == 16'd15)
|
||||
ip_rec_source_addr[7:0] <= ip_rx_data ;
|
||||
end
|
||||
//ip source address
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ip_rec_destination_addr <= 32'd0 ;
|
||||
else if (state == REC_HEADER1 && ip_rx_cnt == 16'd16)
|
||||
ip_rec_destination_addr[31:24] <= ip_rx_data ;
|
||||
else if (state == REC_HEADER1 && ip_rx_cnt == 16'd17)
|
||||
ip_rec_destination_addr[23:16] <= ip_rx_data ;
|
||||
else if (state == REC_HEADER1 && ip_rx_cnt == 16'd18)
|
||||
ip_rec_destination_addr[15:8] <= ip_rx_data ;
|
||||
else if (state == REC_HEADER1 && ip_rx_cnt == 16'd19)
|
||||
ip_rec_destination_addr[7:0] <= ip_rx_data ;
|
||||
end
|
||||
|
||||
|
||||
//****************************************************************//
|
||||
//verify checksum
|
||||
//****************************************************************//
|
||||
reg [31:0] checksum_tmp ;
|
||||
reg [31:0] checksum_buf ;
|
||||
reg [31:0] check_out ;
|
||||
reg [31:0] checkout_buf ;
|
||||
wire [15:0] checksum ;
|
||||
reg [2:0] checksum_cnt ;
|
||||
|
||||
//checksum function
|
||||
function [31:0] checksum_adder
|
||||
(
|
||||
input [31:0] dataina,
|
||||
input [31:0] datainb
|
||||
);
|
||||
|
||||
begin
|
||||
checksum_adder = dataina + datainb;
|
||||
end
|
||||
endfunction
|
||||
|
||||
function [31:0] checksum_out
|
||||
(
|
||||
input [31:0] dataina
|
||||
);
|
||||
|
||||
begin
|
||||
checksum_out = dataina[15:0]+dataina[31:16];
|
||||
end
|
||||
|
||||
endfunction
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
checksum_tmp <= 32'd0;
|
||||
else if (state == REC_HEADER0 || state == REC_HEADER1)
|
||||
begin
|
||||
if (ip_rx_cnt[0] == 1'b1)
|
||||
checksum_tmp <= checksum_adder({ip_rx_data_d0, ip_rx_data},checksum_buf);
|
||||
end
|
||||
else if (state == IDLE)
|
||||
checksum_tmp <= 32'd0;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
check_out <= 32'd0;
|
||||
else if (state == REC_DATA)
|
||||
check_out <= checksum_out(checksum_tmp) ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
checksum_cnt <= 3'd0 ;
|
||||
else if (state == REC_DATA)
|
||||
begin
|
||||
if (checksum_cnt == 3'd7)
|
||||
checksum_cnt <= checksum_cnt ;
|
||||
else
|
||||
checksum_cnt <= checksum_cnt + 1'b1 ;
|
||||
end
|
||||
else
|
||||
checksum_cnt <= 3'd0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
checksum_buf <= 32'd0 ;
|
||||
else
|
||||
checksum_buf <= checksum_tmp ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
checkout_buf <= 32'd0 ;
|
||||
else
|
||||
checkout_buf <= check_out ;
|
||||
end
|
||||
|
||||
assign checksum = ~checkout_buf[15:0] ;
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ip_checksum_error <= 1'b0 ;
|
||||
else if (state == REC_DATA && checksum_cnt == 3'd2)
|
||||
begin
|
||||
if (checksum == 16'd0)
|
||||
ip_checksum_error <= 1'b0 ;
|
||||
else
|
||||
ip_checksum_error <= 1'b1 ;
|
||||
end
|
||||
else
|
||||
ip_checksum_error <= 1'b0 ;
|
||||
end
|
||||
|
||||
endmodule
|
||||
449
rtl/ethernet-udp/src/eth/mac/rx/mac_rx.v
Normal file
449
rtl/ethernet-udp/src/eth/mac/rx/mac_rx.v
Normal file
@ -0,0 +1,449 @@
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
//Module Name : mac_rx
|
||||
//Description : This module is used to receive MAC layer data and verify CRC
|
||||
//
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
`timescale 1 ns/1 ns
|
||||
module mac_rx
|
||||
(
|
||||
input clk,
|
||||
input rst_n,
|
||||
|
||||
input rx_dv,
|
||||
input [7:0] mac_rx_datain,
|
||||
|
||||
input [31:0] crc_result ,
|
||||
output reg crcen,
|
||||
output reg crcre,
|
||||
output reg [7:0] crc_din,
|
||||
|
||||
input checksum_err, //checksum error from IP layer
|
||||
|
||||
input ip_rx_end, //ip receive end
|
||||
input arp_rx_end, //arp receive end
|
||||
output reg ip_rx_req, //ip rx request
|
||||
output reg arp_rx_req, //arp rx request
|
||||
|
||||
output [7:0] mac_rx_dataout,
|
||||
output reg mac_rec_error ,
|
||||
|
||||
output reg [47:0] mac_rx_destination_mac_addr,
|
||||
output reg [47:0] mac_rx_source_mac_addr
|
||||
);
|
||||
|
||||
reg [4:0] mac_rx_cnt ;
|
||||
reg [15:0] mac_crc_cnt ;
|
||||
reg mac_sync ; //check preamble is right, then sync
|
||||
reg [63:0] preamble ;
|
||||
reg [3:0] preamble_cnt ;
|
||||
|
||||
reg [15:0] frame_type ; //type 16'h0800 IP; 16'h0806 ARP
|
||||
|
||||
|
||||
wire rx_dv_posedge ;
|
||||
reg rx_dv_d0 ;
|
||||
reg rx_dv_d1 ;
|
||||
|
||||
reg [7:0] mac_rx_data_d0 ;
|
||||
reg [7:0] mac_rx_data_d1 ;
|
||||
reg [7:0] mac_rx_data_d2 ;
|
||||
|
||||
wire mac_rx_head_end ;
|
||||
|
||||
reg [15:0] timeout ;
|
||||
|
||||
reg [31:0] crc ;
|
||||
reg [31:0] crc_check ;
|
||||
reg crc_error ;
|
||||
reg [31:0] crc_rec ;
|
||||
reg [31:0] crc_result_d0 ;
|
||||
|
||||
//MAC receive FSM
|
||||
parameter IDLE = 9'b000_000_001 ;
|
||||
parameter REC_PREAMBLE = 9'b000_000_010 ;
|
||||
parameter REC_MAC_HEAD = 9'b000_000_100 ;
|
||||
parameter REC_IDENTIFY = 9'b000_001_000 ;
|
||||
parameter REC_IP_DATA = 9'b000_010_000 ;
|
||||
parameter REC_ARP_DATA = 9'b000_100_000 ;
|
||||
parameter REC_CRC = 9'b001_000_000 ;
|
||||
parameter REC_ERROR = 9'b010_000_000 ;
|
||||
parameter REC_END = 9'b100_000_000 ;
|
||||
|
||||
reg [8:0] rec_state ;
|
||||
reg [8:0] rec_next_state ;
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
rec_state <= IDLE ;
|
||||
else
|
||||
rec_state <= rec_next_state ;
|
||||
end
|
||||
|
||||
always @(*)
|
||||
begin
|
||||
case(rec_state)
|
||||
IDLE : begin
|
||||
if (rx_dv_posedge == 1'b1)
|
||||
rec_next_state <= REC_PREAMBLE ;
|
||||
else
|
||||
rec_next_state <= IDLE ;
|
||||
end
|
||||
REC_PREAMBLE : begin
|
||||
if (mac_sync == 1'b1)
|
||||
rec_next_state <= REC_MAC_HEAD ;
|
||||
else if (timeout == 16'hffff)
|
||||
rec_next_state <= REC_ERROR ;
|
||||
else
|
||||
rec_next_state <= REC_PREAMBLE ;
|
||||
end
|
||||
|
||||
REC_MAC_HEAD : begin
|
||||
if ( mac_rx_cnt == 16'd13)
|
||||
rec_next_state <= REC_IDENTIFY ;
|
||||
else if (timeout == 16'hffff)
|
||||
rec_next_state <= REC_ERROR ;
|
||||
else
|
||||
rec_next_state <= REC_MAC_HEAD ;
|
||||
end
|
||||
REC_IDENTIFY : begin
|
||||
if (frame_type == 16'h0800)
|
||||
rec_next_state <= REC_IP_DATA ;
|
||||
else if (frame_type == 16'h0806)
|
||||
rec_next_state <= REC_ARP_DATA ;
|
||||
else if (timeout == 16'hffff)
|
||||
rec_next_state <= REC_ERROR ;
|
||||
else
|
||||
rec_next_state <= REC_IDENTIFY ;
|
||||
end
|
||||
REC_IP_DATA : begin
|
||||
if (checksum_err)
|
||||
rec_next_state <= REC_ERROR ;
|
||||
else if (ip_rx_end)
|
||||
rec_next_state <= REC_CRC ;
|
||||
else if (timeout == 16'hffff)
|
||||
rec_next_state <= REC_ERROR ;
|
||||
else
|
||||
rec_next_state <= REC_IP_DATA ;
|
||||
end
|
||||
REC_ARP_DATA : begin
|
||||
if (arp_rx_end)
|
||||
rec_next_state <= REC_CRC ;
|
||||
else if (timeout == 16'hffff)
|
||||
rec_next_state <= REC_ERROR ;
|
||||
else
|
||||
rec_next_state <= REC_ARP_DATA ;
|
||||
end
|
||||
|
||||
REC_CRC : begin
|
||||
if (crc_error)
|
||||
rec_next_state <= REC_ERROR ;
|
||||
else if (mac_rx_cnt == 7)
|
||||
rec_next_state <= REC_END ;
|
||||
else
|
||||
rec_next_state <= REC_CRC ;
|
||||
end
|
||||
REC_ERROR : rec_next_state <= IDLE ;
|
||||
REC_END : rec_next_state <= IDLE ;
|
||||
default : rec_next_state <= IDLE ;
|
||||
endcase
|
||||
end
|
||||
|
||||
|
||||
|
||||
|
||||
assign mac_rx_dataout = mac_rx_data_d2 ;
|
||||
assign rx_dv_posedge = ~rx_dv_d0 & rx_dv ;
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
begin
|
||||
crcen <= 1'b0 ;
|
||||
crcre <= 1'b1 ;
|
||||
crc_din <= 8'd0 ;
|
||||
end
|
||||
else if (rec_state == REC_MAC_HEAD || rec_state == REC_IDENTIFY || rec_state == REC_IP_DATA || rec_state == REC_ARP_DATA)
|
||||
begin
|
||||
crcen <= 1'b1 ;
|
||||
crcre <= 1'b0 ;
|
||||
crc_din <= mac_rx_data_d0 ;
|
||||
end
|
||||
else
|
||||
begin
|
||||
crcen <= 1'b0 ;
|
||||
crcre <= 1'b1 ;
|
||||
crc_din <= 8'd0 ;
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ip_rx_req <= 1'b0 ;
|
||||
else if (rec_state == REC_IDENTIFY && frame_type == 16'h0800)
|
||||
ip_rx_req <= 1'b1 ;
|
||||
else
|
||||
ip_rx_req <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
arp_rx_req <= 1'b0 ;
|
||||
else if (rec_state == REC_IDENTIFY && frame_type == 16'h0806)
|
||||
arp_rx_req <= 1'b1 ;
|
||||
else
|
||||
arp_rx_req <= 1'b0 ;
|
||||
end
|
||||
|
||||
//rx dv and rx data resigster
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
begin
|
||||
rx_dv_d0 <= 1'b0 ;
|
||||
rx_dv_d1 <= 1'b0 ;
|
||||
mac_rx_data_d0 <= 8'd0 ;
|
||||
mac_rx_data_d1 <= 8'd0 ;
|
||||
mac_rx_data_d2 <= 8'd0 ;
|
||||
end
|
||||
else
|
||||
begin
|
||||
rx_dv_d0 <= rx_dv ;
|
||||
rx_dv_d1 <= rx_dv_d0 ;
|
||||
mac_rx_data_d0 <= mac_rx_datain ;
|
||||
mac_rx_data_d1 <= mac_rx_data_d0 ;
|
||||
mac_rx_data_d2 <= mac_rx_data_d1 ;
|
||||
end
|
||||
end
|
||||
//timeout
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
timeout <= 16'd0 ;
|
||||
else if (rec_state == REC_PREAMBLE || rec_state == REC_MAC_HEAD || rec_state == REC_MAC_HEAD || rec_state == REC_IDENTIFY
|
||||
|| rec_state == REC_IP_DATA || rec_state == REC_ARP_DATA)
|
||||
timeout <= timeout + 1'b1 ;
|
||||
else
|
||||
timeout <= 16'd0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
mac_rx_cnt <= 5'd0 ;
|
||||
else if (mac_sync)
|
||||
mac_rx_cnt <= 5'd0 ;
|
||||
else if (rec_state == REC_PREAMBLE || rec_state == REC_MAC_HEAD || rec_state == REC_CRC)
|
||||
mac_rx_cnt <= mac_rx_cnt + 1'b1 ;
|
||||
else
|
||||
mac_rx_cnt <= 5'd0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
mac_crc_cnt <= 16'd0 ;
|
||||
else if (rx_dv_d1)
|
||||
mac_crc_cnt <= mac_crc_cnt + 1'b1 ;
|
||||
else
|
||||
mac_crc_cnt <= 16'd0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
mac_rec_error <= 1'b0 ;
|
||||
else if (rx_dv_posedge)
|
||||
mac_rec_error <= 1'b0 ;
|
||||
else if (rec_state == REC_ERROR)
|
||||
mac_rec_error <= 1'b1 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
crc <= 32'd0 ;
|
||||
else if (crcen)
|
||||
crc <= crc_result_d0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
crc_result_d0 <= 32'd0 ;
|
||||
else
|
||||
crc_result_d0 <= crc_result ;
|
||||
end
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
crc_check <= 32'd0 ;
|
||||
else if (rec_state == REC_CRC)
|
||||
begin
|
||||
case(mac_rx_cnt)
|
||||
5'd1 : crc_check[31:24] <= {~crc[24], ~crc[25], ~crc[26], ~crc[27], ~crc[28], ~crc[29], ~crc[30], ~crc[31]} ;
|
||||
5'd2 : crc_check[23:16] <= {~crc[16], ~crc[17], ~crc[18], ~crc[19], ~crc[20], ~crc[21], ~crc[22], ~crc[23]} ;
|
||||
5'd3 : crc_check[15:8] <= {~crc[8], ~crc[9], ~crc[10], ~crc[11], ~crc[12], ~crc[13], ~crc[14], ~crc[15]} ;
|
||||
5'd4 : crc_check[7:0] <= {~crc[0], ~crc[1], ~crc[2], ~crc[3], ~crc[4], ~crc[5], ~crc[6], ~crc[7]} ;
|
||||
default : crc_check <= crc_check ;
|
||||
endcase
|
||||
end
|
||||
else
|
||||
crc_check <= 32'd0 ;
|
||||
end
|
||||
//received crc data
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
crc_rec <= 48'd0 ;
|
||||
else if (rec_state == REC_CRC)
|
||||
begin
|
||||
case(mac_rx_cnt)
|
||||
5'd0 : crc_rec[31:24] <= mac_rx_data_d2 ;
|
||||
5'd1 : crc_rec[23:16] <= mac_rx_data_d2 ;
|
||||
5'd2 : crc_rec[15:8] <= mac_rx_data_d2 ;
|
||||
5'd3 : crc_rec[7:0] <= mac_rx_data_d2 ;
|
||||
default : crc_rec <= crc_rec ;
|
||||
endcase
|
||||
end
|
||||
else
|
||||
crc_rec <= crc_rec ;
|
||||
end
|
||||
//check crc
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
crc_error <= 1'b0 ;
|
||||
else if (rec_state == REC_CRC && mac_rx_cnt == 5)
|
||||
begin
|
||||
if (crc_check == crc_rec)
|
||||
crc_error <= 1'b0 ;
|
||||
else
|
||||
crc_error <= 1'b1 ;
|
||||
end
|
||||
else
|
||||
crc_error <= 1'b0 ;
|
||||
end
|
||||
|
||||
//mac sync signal
|
||||
always @(*)
|
||||
begin
|
||||
if (rec_state == REC_PREAMBLE)
|
||||
begin
|
||||
if (mac_rx_cnt == 7 && preamble == 64'h55_55_55_55_55_55_55_d5)
|
||||
mac_sync <= 1'b1 ;
|
||||
else
|
||||
mac_sync <= 1'b0 ;
|
||||
end
|
||||
else
|
||||
mac_sync <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
preamble_cnt <= 4'd0 ;
|
||||
else if (rx_dv)
|
||||
begin
|
||||
if (preamble_cnt < 8)
|
||||
preamble_cnt <= preamble_cnt + 1'b1 ;
|
||||
end
|
||||
else
|
||||
preamble_cnt <= 4'd0 ;
|
||||
end
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
preamble <= 64'd0 ;
|
||||
else if (rx_dv)
|
||||
begin
|
||||
if (preamble_cnt == 4'd0)
|
||||
preamble[63:56] <= mac_rx_datain ;
|
||||
if (preamble_cnt == 4'd1)
|
||||
preamble[55:48] <= mac_rx_datain ;
|
||||
if (preamble_cnt == 4'd2)
|
||||
preamble[47:40] <= mac_rx_datain ;
|
||||
if (preamble_cnt == 4'd3)
|
||||
preamble[39:32] <= mac_rx_datain ;
|
||||
if (preamble_cnt == 4'd4)
|
||||
preamble[31:24] <= mac_rx_datain ;
|
||||
if (preamble_cnt == 4'd5)
|
||||
preamble[23:16] <= mac_rx_datain ;
|
||||
if (preamble_cnt == 4'd6)
|
||||
preamble[15:8] <= mac_rx_datain ;
|
||||
if (preamble_cnt == 4'd7)
|
||||
preamble[7:0] <= mac_rx_datain ;
|
||||
end
|
||||
else
|
||||
preamble <= 64'd0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
mac_rx_destination_mac_addr <= 48'd0 ;
|
||||
else if (rec_state == REC_MAC_HEAD)
|
||||
begin
|
||||
case(mac_rx_cnt)
|
||||
5'd0 : mac_rx_destination_mac_addr[47:40] <= mac_rx_data_d0 ;
|
||||
5'd1 : mac_rx_destination_mac_addr[39:32] <= mac_rx_data_d0 ;
|
||||
5'd2 : mac_rx_destination_mac_addr[31:24] <= mac_rx_data_d0 ;
|
||||
5'd3 : mac_rx_destination_mac_addr[23:16] <= mac_rx_data_d0 ;
|
||||
5'd4 : mac_rx_destination_mac_addr[15:8] <= mac_rx_data_d0 ;
|
||||
5'd5 : mac_rx_destination_mac_addr[7:0] <= mac_rx_data_d0 ;
|
||||
default : mac_rx_destination_mac_addr <= mac_rx_destination_mac_addr ;
|
||||
endcase
|
||||
end
|
||||
else
|
||||
mac_rx_destination_mac_addr <= mac_rx_destination_mac_addr ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
mac_rx_source_mac_addr <= 48'd0 ;
|
||||
else if (rec_state == REC_MAC_HEAD)
|
||||
begin
|
||||
case(mac_rx_cnt)
|
||||
5'd6 : mac_rx_source_mac_addr[47:40] <= mac_rx_data_d0 ;
|
||||
5'd7 : mac_rx_source_mac_addr[39:32] <= mac_rx_data_d0 ;
|
||||
5'd8 : mac_rx_source_mac_addr[31:24] <= mac_rx_data_d0 ;
|
||||
5'd9 : mac_rx_source_mac_addr[23:16] <= mac_rx_data_d0 ;
|
||||
5'd10 : mac_rx_source_mac_addr[15:8] <= mac_rx_data_d0 ;
|
||||
5'd11 : mac_rx_source_mac_addr[7:0] <= mac_rx_data_d0 ;
|
||||
default : mac_rx_source_mac_addr <= mac_rx_source_mac_addr ;
|
||||
endcase
|
||||
end
|
||||
else
|
||||
mac_rx_source_mac_addr <= mac_rx_source_mac_addr ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
frame_type <= 16'd0 ;
|
||||
else if (rec_state == REC_MAC_HEAD)
|
||||
begin
|
||||
case(mac_rx_cnt)
|
||||
5'd12 : frame_type[15:8] <= mac_rx_data_d0 ;
|
||||
5'd13 : frame_type[7:0] <= mac_rx_data_d0 ;
|
||||
default : frame_type <= frame_type ;
|
||||
endcase
|
||||
end
|
||||
else
|
||||
frame_type <= frame_type ;
|
||||
end
|
||||
|
||||
|
||||
|
||||
|
||||
endmodule
|
||||
|
||||
|
||||
186
rtl/ethernet-udp/src/eth/mac/rx/mac_rx_top.v
Normal file
186
rtl/ethernet-udp/src/eth/mac/rx/mac_rx_top.v
Normal file
@ -0,0 +1,186 @@
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
//Module Name : mac_rx_top
|
||||
//Description : MAC RX Top
|
||||
//
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
`timescale 1 ns/1 ns
|
||||
module mac_rx_top
|
||||
(
|
||||
input clk,
|
||||
input rst_n,
|
||||
|
||||
input rx_dv,
|
||||
(* MARK_DEBUG="true" *)input [7:0] mac_rx_datain,
|
||||
|
||||
input [31:0] local_ip_addr,
|
||||
input [47:0] local_mac_addr,
|
||||
|
||||
input arp_reply_ack,
|
||||
output arp_reply_req,
|
||||
output [31:0] arp_rec_source_ip_addr,
|
||||
output [47:0] arp_rec_source_mac_addr,
|
||||
|
||||
|
||||
(* MARK_DEBUG="true" *)output [7:0] udp_rec_ram_rdata ,
|
||||
(* MARK_DEBUG="true" *)input [10:0] udp_rec_ram_read_addr,
|
||||
(* MARK_DEBUG="true" *)output [15:0] udp_rec_data_length,
|
||||
(* MARK_DEBUG="true" *)output udp_rec_data_valid,
|
||||
|
||||
(* MARK_DEBUG="true" *)output [7:0] mac_rx_dataout,
|
||||
(* MARK_DEBUG="true" *)output [15:0] upper_layer_data_length ,
|
||||
(* MARK_DEBUG="true" *)output [15:0] ip_total_data_length,
|
||||
output icmp_rx_req,
|
||||
output icmp_rev_error,
|
||||
|
||||
output arp_found
|
||||
) ;
|
||||
|
||||
|
||||
|
||||
wire ip_rx_req ;
|
||||
wire udp_rx_req ;
|
||||
wire ip_rx_end ;
|
||||
|
||||
wire arp_rx_req ;
|
||||
wire arp_rx_end ;
|
||||
|
||||
wire [7:0] net_protocol ;
|
||||
wire [31:0] ip_rec_destination_addr ;
|
||||
wire [31:0] ip_rec_source_ip_addr ;
|
||||
|
||||
wire ip_addr_check_error ;
|
||||
wire ip_checksum_error ;
|
||||
wire mac_rec_error ;
|
||||
|
||||
wire [47:0] mac_rx_destination_mac_addr ;
|
||||
wire [47:0] mac_rx_source_mac_addr ;
|
||||
|
||||
wire crcen ;
|
||||
wire crcre ;
|
||||
wire [7:0] crc_din ;
|
||||
wire [31:0] crc_result ;
|
||||
|
||||
|
||||
|
||||
assign icmp_rev_error = (mac_rec_error | ip_checksum_error | ip_addr_check_error) ;
|
||||
|
||||
|
||||
crc c0
|
||||
(
|
||||
.Clk (clk),
|
||||
.Reset (crcre),
|
||||
.Data_in (crc_din),
|
||||
.Enable (crcen),
|
||||
.Crc (crc_result),
|
||||
.CrcNext ()
|
||||
) ;
|
||||
|
||||
mac_rx mac0
|
||||
(
|
||||
.clk (clk) ,
|
||||
.rst_n (rst_n) ,
|
||||
|
||||
.rx_dv (rx_dv ),
|
||||
.mac_rx_datain (mac_rx_datain ),
|
||||
|
||||
.crc_result (crc_result ) ,
|
||||
.crcen (crcen ),
|
||||
.crcre (crcre ),
|
||||
.crc_din (crc_din ),
|
||||
|
||||
.checksum_err (ip_checksum_error ),
|
||||
|
||||
.ip_rx_end (ip_rx_end ),
|
||||
.arp_rx_end (arp_rx_end),
|
||||
|
||||
.ip_rx_req (ip_rx_req ),
|
||||
.arp_rx_req (arp_rx_req),
|
||||
|
||||
.mac_rx_dataout (mac_rx_dataout ),
|
||||
.mac_rec_error (mac_rec_error),
|
||||
|
||||
.mac_rx_destination_mac_addr (mac_rx_destination_mac_addr ),
|
||||
.mac_rx_source_mac_addr (mac_rx_source_mac_addr)
|
||||
);
|
||||
|
||||
|
||||
ip_rx ip0
|
||||
(
|
||||
.clk (clk),
|
||||
.rst_n (rst_n) ,
|
||||
|
||||
.local_ip_addr (local_ip_addr ),
|
||||
.local_mac_addr (local_mac_addr),
|
||||
|
||||
.ip_rx_data (mac_rx_dataout) ,
|
||||
.ip_rx_req (ip_rx_req) ,
|
||||
.ip_rx_end (ip_rx_end) ,
|
||||
.icmp_rx_req (icmp_rx_req ),
|
||||
|
||||
.ip_addr_check_error (ip_addr_check_error),
|
||||
.mac_rx_destination_mac_addr (mac_rx_destination_mac_addr),
|
||||
|
||||
.upper_layer_data_length (upper_layer_data_length ),
|
||||
.ip_total_data_length (ip_total_data_length ),
|
||||
|
||||
.net_protocol (net_protocol),
|
||||
.ip_rec_source_addr (ip_rec_source_ip_addr),
|
||||
.ip_rec_destination_addr (ip_rec_destination_addr),
|
||||
.udp_rx_req (udp_rx_req),
|
||||
.ip_checksum_error (ip_checksum_error)
|
||||
|
||||
) ;
|
||||
|
||||
|
||||
udp_rx udp0
|
||||
(
|
||||
.clk (clk) ,
|
||||
.rst_n (rst_n) ,
|
||||
|
||||
.udp_rx_data (mac_rx_dataout),
|
||||
.udp_rx_req (udp_rx_req),
|
||||
|
||||
.mac_rec_error (mac_rec_error),
|
||||
|
||||
.ip_addr_check_error (ip_addr_check_error),
|
||||
|
||||
.net_protocol (net_protocol),
|
||||
.ip_rec_source_addr (ip_rec_source_ip_addr),
|
||||
.ip_rec_destination_addr (ip_rec_destination_addr),
|
||||
.ip_checksum_error (ip_checksum_error),
|
||||
|
||||
.upper_layer_data_length (upper_layer_data_length ),
|
||||
|
||||
.udp_rec_ram_rdata (udp_rec_ram_rdata),
|
||||
.udp_rec_ram_read_addr (udp_rec_ram_read_addr),
|
||||
.udp_rec_data_length (udp_rec_data_length ),
|
||||
|
||||
.udp_rec_data_valid (udp_rec_data_valid)
|
||||
);
|
||||
|
||||
|
||||
arp_rx arp0
|
||||
(
|
||||
.clk (clk) ,
|
||||
.rst_n (rst_n),
|
||||
|
||||
.crc_error (mac_rec_error),
|
||||
|
||||
.local_ip_addr (local_ip_addr ),
|
||||
.local_mac_addr (local_mac_addr),
|
||||
|
||||
.arp_rx_data (mac_rx_dataout ),
|
||||
.arp_rx_req (arp_rx_req ),
|
||||
|
||||
.arp_reply_ack (arp_reply_ack ),
|
||||
.arp_rx_end (arp_rx_end ),
|
||||
.arp_reply_req (arp_reply_req ),
|
||||
|
||||
.arp_rec_source_ip_addr (arp_rec_source_ip_addr ),
|
||||
.arp_rec_source_mac_addr (arp_rec_source_mac_addr ),
|
||||
.arp_found (arp_found )
|
||||
|
||||
) ;
|
||||
|
||||
|
||||
endmodule
|
||||
372
rtl/ethernet-udp/src/eth/mac/rx/udp_rx.v
Normal file
372
rtl/ethernet-udp/src/eth/mac/rx/udp_rx.v
Normal file
@ -0,0 +1,372 @@
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
//Module Name : udp_rx
|
||||
//Description : This module is used to receive UDP data and verify UDP checksum
|
||||
//
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
`timescale 1 ns/1 ns
|
||||
module udp_rx
|
||||
(
|
||||
input clk,
|
||||
input rst_n,
|
||||
|
||||
input [7:0] udp_rx_data,
|
||||
input udp_rx_req,
|
||||
|
||||
input mac_rec_error,
|
||||
input [7:0] net_protocol,
|
||||
input [31:0] ip_rec_source_addr,
|
||||
input [31:0] ip_rec_destination_addr,
|
||||
input ip_checksum_error,
|
||||
input ip_addr_check_error,
|
||||
|
||||
input [15:0] upper_layer_data_length,
|
||||
output [7:0] udp_rec_ram_rdata , //udp ram read data
|
||||
input [10:0] udp_rec_ram_read_addr, //udp ram read address
|
||||
output reg [15:0] udp_rec_data_length, //udp data length
|
||||
output reg udp_rec_data_valid //udp data valid
|
||||
);
|
||||
|
||||
reg [15:0] udp_rx_cnt ;
|
||||
reg verify_end ;
|
||||
reg udp_checksum_error ;
|
||||
|
||||
(* MARK_DEBUG="true" *)reg [10:0] ram_write_addr ;
|
||||
(* MARK_DEBUG="true" *)reg ram_wr_en ;
|
||||
reg [15:0] udp_data_length ;
|
||||
reg ip_addr_check_error_d0 ;
|
||||
reg [7:0] udp_rx_data_d0 ; //udp data resigster
|
||||
|
||||
parameter IDLE = 8'b0000_0001 ;
|
||||
parameter REC_HEAD = 8'b0000_0010 ;
|
||||
parameter REC_DATA = 8'b0000_0100 ;
|
||||
parameter REC_ODD_DATA = 8'b0000_1000 ;
|
||||
parameter VERIFY_CHECKSUM = 8'b0001_0000 ;
|
||||
parameter REC_ERROR = 8'b0010_0000 ;
|
||||
parameter REC_END_WAIT = 8'b0100_0000 ;
|
||||
parameter REC_END = 8'b1000_0000 ;
|
||||
|
||||
reg [7:0] state ;
|
||||
reg [7:0] next_state ;
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
state <= IDLE ;
|
||||
else
|
||||
state <= next_state ;
|
||||
end
|
||||
|
||||
always @(*)
|
||||
begin
|
||||
case(state)
|
||||
IDLE :begin
|
||||
if (udp_rx_req == 1'b1)
|
||||
next_state <= REC_HEAD ;
|
||||
else
|
||||
next_state <= IDLE ;
|
||||
end
|
||||
REC_HEAD : begin
|
||||
if (ip_checksum_error)
|
||||
next_state <= REC_ERROR ;
|
||||
else if (udp_rx_cnt == 16'd7)
|
||||
begin
|
||||
if (udp_data_length == 16'd9)
|
||||
next_state <= REC_ODD_DATA ;
|
||||
else
|
||||
next_state <= REC_DATA ;
|
||||
end
|
||||
else if (ip_addr_check_error_d0)
|
||||
next_state <= REC_ERROR ;
|
||||
else
|
||||
next_state <= REC_HEAD ;
|
||||
end
|
||||
REC_DATA : begin
|
||||
if (ip_checksum_error)
|
||||
next_state <= REC_ERROR ;
|
||||
else if (udp_data_length[0] == 1'b1 && udp_rx_cnt == udp_data_length - 2)
|
||||
next_state <= REC_ODD_DATA ;
|
||||
else if (udp_data_length[0] == 1'b0 && udp_rx_cnt == udp_data_length - 1)
|
||||
next_state <= VERIFY_CHECKSUM ;
|
||||
else
|
||||
next_state <= REC_DATA ;
|
||||
end
|
||||
REC_ODD_DATA : begin
|
||||
if (ip_checksum_error)
|
||||
next_state <= REC_ERROR ;
|
||||
else if (udp_rx_cnt == udp_data_length - 1)
|
||||
next_state <= VERIFY_CHECKSUM ;
|
||||
else
|
||||
next_state <= REC_ODD_DATA ;
|
||||
end
|
||||
VERIFY_CHECKSUM :begin
|
||||
if (udp_checksum_error)
|
||||
next_state <= REC_ERROR ;
|
||||
else if (verify_end)
|
||||
next_state <= REC_END_WAIT ;
|
||||
else if (udp_rx_cnt == 16'hffff)
|
||||
next_state <= IDLE ;
|
||||
else
|
||||
next_state <= VERIFY_CHECKSUM ;
|
||||
end
|
||||
REC_ERROR : next_state <= IDLE ;
|
||||
REC_END_WAIT : begin
|
||||
if (udp_rx_cnt == 16'd63)
|
||||
next_state <= REC_END ;
|
||||
else
|
||||
next_state <= REC_END_WAIT ;
|
||||
end
|
||||
REC_END : next_state <= IDLE ;
|
||||
default : next_state <= IDLE ;
|
||||
endcase
|
||||
end
|
||||
|
||||
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ram_wr_en <= 1'b0 ;
|
||||
else if ((state == REC_DATA || state == REC_ODD_DATA) && udp_rx_cnt < udp_data_length)
|
||||
ram_wr_en <= 1'b1 ;
|
||||
else
|
||||
ram_wr_en <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ram_write_addr <= 11'd0 ;
|
||||
else if (state == REC_DATA || state == REC_ODD_DATA)
|
||||
ram_write_addr <= udp_rx_cnt - 8 ;
|
||||
else
|
||||
ram_write_addr <= 11'd0 ;
|
||||
end
|
||||
//ip address check
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ip_addr_check_error_d0 <= 1'b0 ;
|
||||
else
|
||||
ip_addr_check_error_d0 <= ip_addr_check_error ;
|
||||
end
|
||||
//udp data length
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
udp_data_length <= 16'd0 ;
|
||||
else if (state == IDLE)
|
||||
udp_data_length <= upper_layer_data_length ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
udp_rec_data_length <= 16'd0 ;
|
||||
else if (state == REC_END)
|
||||
udp_rec_data_length <= udp_data_length ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
udp_rx_cnt <= 16'd0 ;
|
||||
else if (state == REC_HEAD || state == REC_DATA || state == REC_END_WAIT)
|
||||
udp_rx_cnt <= udp_rx_cnt + 1'b1 ;
|
||||
else
|
||||
udp_rx_cnt <= 16'd0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
udp_rx_data_d0 <= 8'd0 ;
|
||||
else
|
||||
udp_rx_data_d0 <= udp_rx_data ;
|
||||
end
|
||||
|
||||
|
||||
udp_rx_ram_8_2048 udp_receive_ram
|
||||
(
|
||||
.clka(clk), // input wire clka
|
||||
.wea(ram_wr_en), // input wire [0 : 0] wea
|
||||
.addra(ram_write_addr), // input wire [10 : 0] addra
|
||||
.dina(udp_rx_data_d0), // input wire [7 : 0] dina
|
||||
.clkb(clk), // input wire clkb
|
||||
.addrb(udp_rec_ram_read_addr), // input wire [10 : 0] addrb
|
||||
.doutb(udp_rec_ram_rdata) // output wire [7 : 0] doutb
|
||||
);
|
||||
|
||||
//****************************************************************//
|
||||
//verify checksum
|
||||
//****************************************************************//
|
||||
reg [16:0] checksum_tmp0 ;
|
||||
reg [16:0] checksum_tmp1 ;
|
||||
reg [16:0] checksum_tmp2 ;
|
||||
reg [17:0] checksum_tmp3 ;
|
||||
reg [18:0] checksum_tmp4 ;
|
||||
reg [31:0] checksum_tmp5 ;
|
||||
reg [31:0] checksum_buf ;
|
||||
reg [31:0] check_out ;
|
||||
reg [31:0] checkout_buf ;
|
||||
wire [15:0] checksum ;
|
||||
reg [2:0] checksum_cnt ;
|
||||
|
||||
//checksum function
|
||||
function [31:0] checksum_adder
|
||||
(
|
||||
input [31:0] dataina,
|
||||
input [31:0] datainb
|
||||
);
|
||||
|
||||
begin
|
||||
checksum_adder = dataina + datainb;
|
||||
end
|
||||
endfunction
|
||||
|
||||
function [31:0] checksum_out
|
||||
(
|
||||
input [31:0] dataina
|
||||
);
|
||||
|
||||
begin
|
||||
checksum_out = dataina[15:0]+dataina[31:16];
|
||||
end
|
||||
|
||||
endfunction
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
begin
|
||||
checksum_tmp0 <= 17'd0 ;
|
||||
checksum_tmp1 <= 17'd0 ;
|
||||
checksum_tmp2 <= 17'd0 ;
|
||||
checksum_tmp3 <= 18'd0 ;
|
||||
checksum_tmp4 <= 19'd0 ;
|
||||
end
|
||||
else if (state == REC_HEAD)
|
||||
begin
|
||||
checksum_tmp0 <= checksum_adder(ip_rec_source_addr[31:16],ip_rec_source_addr[15:0]); //source ip address
|
||||
checksum_tmp1 <= checksum_adder(ip_rec_destination_addr[31:16],ip_rec_destination_addr[15:0]); //destination ip address
|
||||
checksum_tmp2 <= checksum_adder({8'd0,net_protocol},udp_data_length); //protocol type
|
||||
checksum_tmp3 <= checksum_adder(checksum_tmp0,checksum_tmp1); //protocol type
|
||||
checksum_tmp4 <= checksum_adder(checksum_tmp2,checksum_tmp3);
|
||||
end
|
||||
else if (state == IDLE)
|
||||
begin
|
||||
checksum_tmp0 <= 17'd0 ;
|
||||
checksum_tmp1 <= 17'd0 ;
|
||||
checksum_tmp2 <= 17'd0 ;
|
||||
checksum_tmp3 <= 18'd0 ;
|
||||
checksum_tmp4 <= 19'd0 ;
|
||||
end
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
checksum_tmp5 <= 32'd0;
|
||||
else if (state == REC_HEAD || state == REC_DATA)
|
||||
begin
|
||||
if (udp_rx_cnt[0] == 1'b1)
|
||||
checksum_tmp5 <= checksum_adder({udp_rx_data_d0,udp_rx_data},checksum_buf);
|
||||
end
|
||||
else if (state == REC_ODD_DATA)
|
||||
checksum_tmp5 <= checksum_adder({udp_rx_data,8'h00},checksum_tmp5); //if udp data length is odd, fill with one byte 8'h00
|
||||
else if (state == IDLE)
|
||||
checksum_tmp5 <= 32'd0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
checksum_cnt <= 3'd0 ;
|
||||
else if (state == VERIFY_CHECKSUM)
|
||||
checksum_cnt <= checksum_cnt + 1'b1 ;
|
||||
else
|
||||
checksum_cnt <= 3'd0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
check_out <= 32'd0;
|
||||
else if (state == VERIFY_CHECKSUM)
|
||||
begin
|
||||
if(checksum_cnt == 3'd0)
|
||||
check_out <= checksum_adder(checksum_tmp4, checksum_tmp5);
|
||||
else if (checksum_cnt == 3'd1)
|
||||
check_out <= checksum_out(check_out) ;
|
||||
else if (checksum_cnt == 3'd2)
|
||||
check_out <= checksum_out(check_out) ;
|
||||
end
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
checksum_buf <= 32'd0 ;
|
||||
else if (state == REC_HEAD || state == REC_DATA)
|
||||
checksum_buf <= checksum_tmp5 ;
|
||||
else
|
||||
checksum_buf <= 32'd0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
checkout_buf <= 32'd0 ;
|
||||
else if (state == VERIFY_CHECKSUM)
|
||||
checkout_buf <= check_out ;
|
||||
else
|
||||
checkout_buf <= 32'd0 ;
|
||||
end
|
||||
|
||||
assign checksum = ~checkout_buf[15:0] ;
|
||||
//**************************************************//
|
||||
//generate udp rx end
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
begin
|
||||
udp_checksum_error <= 1'b0 ;
|
||||
verify_end <= 1'b0 ;
|
||||
end
|
||||
else if (state == VERIFY_CHECKSUM && checksum_cnt == 3'd4)
|
||||
begin
|
||||
if (checksum == 16'd0)
|
||||
begin
|
||||
udp_checksum_error <= 1'b0 ;
|
||||
verify_end <= 1'b1 ;
|
||||
end
|
||||
else
|
||||
begin
|
||||
udp_checksum_error <= 1'b1 ;
|
||||
verify_end <= 1'b0 ;
|
||||
end
|
||||
end
|
||||
else
|
||||
begin
|
||||
udp_checksum_error <= 1'b0 ;
|
||||
verify_end <= 1'b0 ;
|
||||
end
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
udp_rec_data_valid <= 1'b0 ;
|
||||
else if (state == REC_END_WAIT)
|
||||
udp_rec_data_valid <= 1'b0 ;
|
||||
else if (state == REC_END)
|
||||
begin
|
||||
if (mac_rec_error)
|
||||
udp_rec_data_valid <= 1'b0 ;
|
||||
else
|
||||
udp_rec_data_valid <= 1'b1 ;
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
endmodule
|
||||
306
rtl/ethernet-udp/src/eth/mac/tx/arp_tx.v
Normal file
306
rtl/ethernet-udp/src/eth/mac/tx/arp_tx.v
Normal file
@ -0,0 +1,306 @@
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
//Module Name : arp_tx
|
||||
//Description : This module is used to send arp data when request arp or reply arp
|
||||
//
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
`timescale 1 ns/1 ns
|
||||
module arp_tx
|
||||
(
|
||||
input clk ,
|
||||
input rst_n ,
|
||||
|
||||
input [47:0] destination_mac_addr , //destination mac address
|
||||
input [47:0] source_mac_addr , //source mac address
|
||||
input [31:0] source_ip_addr , //source ip address
|
||||
input [31:0] destination_ip_addr , //destination ip address
|
||||
|
||||
input mac_data_req, //mac layer request data
|
||||
input arp_request_req, //arp request
|
||||
output reg arp_reply_ack, //arp reply ack to arp rx module
|
||||
input arp_reply_req, //arp reply request from arp rx module
|
||||
output reg arp_tx_req,
|
||||
input [31:0] arp_rec_source_ip_addr,
|
||||
input [47:0] arp_rec_source_mac_addr ,
|
||||
input mac_send_end,
|
||||
input mac_tx_ack,
|
||||
|
||||
output reg arp_tx_ready,
|
||||
output reg [7:0] arp_tx_data,
|
||||
output reg arp_tx_end
|
||||
) ;
|
||||
|
||||
localparam mac_type = 16'h0806 ;
|
||||
localparam hardware_type = 16'h0001 ;
|
||||
localparam protocol_type = 16'h0800 ;
|
||||
localparam mac_length = 8'h06 ;
|
||||
localparam ip_length = 8'h04 ;
|
||||
|
||||
localparam ARP_REQUEST_CODE = 16'h0001 ;
|
||||
localparam ARP_REPLY_CODE = 16'h0002 ;
|
||||
|
||||
|
||||
reg [15:0] op ;
|
||||
|
||||
reg [31:0] arp_destination_ip_addr ;
|
||||
reg [47:0] arp_destination_mac_addr ;
|
||||
reg [15:0] arp_send_cnt ;
|
||||
reg [15:0] timeout ;
|
||||
reg mac_send_end_d0 ;
|
||||
|
||||
parameter IDLE = 8'b00000001 ;
|
||||
parameter ARP_REQUEST_WAIT_0 = 8'b00000010 ;
|
||||
parameter ARP_REQUEST_WAIT_1 = 8'b00000100 ;
|
||||
parameter ARP_REQUEST = 8'b00001000 ;
|
||||
parameter ARP_REPLY_WAIT_0 = 8'b00010000 ;
|
||||
parameter ARP_REPLY_WAIT_1 = 8'b00100000 ;
|
||||
parameter ARP_REPLY = 8'b01000000 ;
|
||||
parameter ARP_END = 8'b10000000 ;
|
||||
|
||||
reg [7:0] state ;
|
||||
reg [7:0] next_state ;
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
state <= IDLE ;
|
||||
else
|
||||
state <= next_state ;
|
||||
end
|
||||
|
||||
always @(*)
|
||||
begin
|
||||
case(state)
|
||||
IDLE :
|
||||
begin
|
||||
if (arp_request_req)
|
||||
next_state <= ARP_REQUEST_WAIT_0 ;
|
||||
else if (arp_reply_req)
|
||||
next_state <= ARP_REPLY_WAIT_0 ;
|
||||
else
|
||||
next_state <= IDLE ;
|
||||
end
|
||||
ARP_REQUEST_WAIT_0 :
|
||||
begin
|
||||
if (mac_tx_ack)
|
||||
next_state <= ARP_REQUEST_WAIT_1 ;
|
||||
else
|
||||
next_state <= ARP_REQUEST_WAIT_0 ;
|
||||
end
|
||||
ARP_REQUEST_WAIT_1 :
|
||||
begin
|
||||
if (mac_data_req)
|
||||
next_state <= ARP_REQUEST ;
|
||||
else if (timeout == 16'hffff)
|
||||
next_state <= IDLE ;
|
||||
else
|
||||
next_state <= ARP_REQUEST_WAIT_1 ;
|
||||
end
|
||||
ARP_REQUEST :
|
||||
begin
|
||||
if (arp_tx_end)
|
||||
next_state <= ARP_END ;
|
||||
else
|
||||
next_state <= ARP_REQUEST ;
|
||||
end
|
||||
ARP_REPLY_WAIT_0 :
|
||||
begin
|
||||
if (mac_tx_ack)
|
||||
next_state <= ARP_REPLY_WAIT_1 ;
|
||||
else
|
||||
next_state <= ARP_REPLY_WAIT_0 ;
|
||||
end
|
||||
ARP_REPLY_WAIT_1 :
|
||||
begin
|
||||
if (mac_data_req)
|
||||
next_state <= ARP_REPLY ;
|
||||
else if (timeout == 16'hffff)
|
||||
next_state <= IDLE ;
|
||||
else
|
||||
next_state <= ARP_REPLY_WAIT_1 ;
|
||||
end
|
||||
ARP_REPLY :
|
||||
begin
|
||||
if (arp_tx_end)
|
||||
next_state <= ARP_END ;
|
||||
else
|
||||
next_state <= ARP_REPLY ;
|
||||
end
|
||||
ARP_END :
|
||||
begin
|
||||
if (mac_send_end_d0)
|
||||
next_state <= IDLE ;
|
||||
else
|
||||
next_state <= ARP_END ;
|
||||
end
|
||||
default :
|
||||
next_state <= IDLE ;
|
||||
endcase
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
mac_send_end_d0 <= 1'b0 ;
|
||||
else
|
||||
mac_send_end_d0 <= mac_send_end ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
arp_tx_req <= 1'b0 ;
|
||||
else if (state == ARP_REQUEST_WAIT_0 || state == ARP_REPLY_WAIT_0)
|
||||
arp_tx_req <= 1'b1 ;
|
||||
else
|
||||
arp_tx_req <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
op <= 16'd0 ;
|
||||
else if (state == ARP_REPLY)
|
||||
op <= ARP_REPLY_CODE ;
|
||||
else
|
||||
op <= ARP_REQUEST_CODE ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
arp_tx_ready <= 1'b0 ;
|
||||
else if (state == ARP_REQUEST_WAIT_1 || state == ARP_REPLY_WAIT_1)
|
||||
arp_tx_ready <= 1'b1 ;
|
||||
else
|
||||
arp_tx_ready <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
arp_tx_end <= 1'b0 ;
|
||||
else if ((state == ARP_REQUEST && arp_send_cnt == 13 + 46 ) || (state == ARP_REPLY && arp_send_cnt == 13 + 46 ))
|
||||
arp_tx_end <= 1'b1 ;
|
||||
else
|
||||
arp_tx_end <= 1'b0 ;
|
||||
end
|
||||
|
||||
|
||||
//timeout counter
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
timeout <= 16'd0 ;
|
||||
else if (state == ARP_REQUEST_WAIT_1 || state == ARP_REPLY_WAIT_1)
|
||||
timeout <= timeout + 1'b1 ;
|
||||
else
|
||||
timeout <= 16'd0 ;
|
||||
end
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
arp_destination_ip_addr <= 32'd0 ;
|
||||
else if (state == ARP_REQUEST_WAIT_1)
|
||||
arp_destination_ip_addr <= destination_ip_addr ;
|
||||
else if (state == ARP_REPLY_WAIT_1)
|
||||
arp_destination_ip_addr <= arp_rec_source_ip_addr ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
arp_destination_mac_addr <= 48'd0 ;
|
||||
else if (state == ARP_REQUEST_WAIT_1)
|
||||
arp_destination_mac_addr <= destination_mac_addr ;
|
||||
else if (state == ARP_REPLY_WAIT_1)
|
||||
arp_destination_mac_addr <= arp_rec_source_mac_addr ;
|
||||
end
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
arp_reply_ack <= 1'b0 ;
|
||||
else if (state == ARP_REPLY_WAIT_1)
|
||||
arp_reply_ack <= 1'b1 ;
|
||||
else
|
||||
arp_reply_ack <= 1'b0 ;
|
||||
end
|
||||
|
||||
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
arp_send_cnt <= 16'd0 ;
|
||||
else if (state == ARP_REQUEST || state == ARP_REPLY)
|
||||
arp_send_cnt <= arp_send_cnt + 1'b1 ;
|
||||
else
|
||||
arp_send_cnt <= 16'd0 ;
|
||||
end
|
||||
|
||||
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
arp_tx_data <= 8'd0 ;
|
||||
else if(state == ARP_REQUEST || state == ARP_REPLY)
|
||||
begin
|
||||
case(arp_send_cnt)
|
||||
16'd0 : arp_tx_data <= arp_destination_mac_addr[47:40] ;
|
||||
16'd1 : arp_tx_data <= arp_destination_mac_addr[39:32] ;
|
||||
16'd2 : arp_tx_data <= arp_destination_mac_addr[31:24] ;
|
||||
16'd3 : arp_tx_data <= arp_destination_mac_addr[23:16] ;
|
||||
16'd4 : arp_tx_data <= arp_destination_mac_addr[15:8] ;
|
||||
16'd5 : arp_tx_data <= arp_destination_mac_addr[7:0] ;
|
||||
16'd6 : arp_tx_data <= source_mac_addr[47:40] ;
|
||||
16'd7 : arp_tx_data <= source_mac_addr[39:32] ;
|
||||
16'd8 : arp_tx_data <= source_mac_addr[31:24] ;
|
||||
16'd9 : arp_tx_data <= source_mac_addr[23:16] ;
|
||||
16'd10 : arp_tx_data <= source_mac_addr[15:8] ;
|
||||
16'd11 : arp_tx_data <= source_mac_addr[7:0] ;
|
||||
16'd12 : arp_tx_data <= mac_type[15:8] ; //frame type
|
||||
16'd13 : arp_tx_data <= mac_type[7:0] ;
|
||||
16'd14 : arp_tx_data <= hardware_type[15:8] ; //hardware type
|
||||
16'd15 : arp_tx_data <= hardware_type[7:0] ;
|
||||
16'd16 : arp_tx_data <= protocol_type[15:8] ; //protocol type using IP 0800
|
||||
16'd17 : arp_tx_data <= protocol_type[7:0] ;
|
||||
16'd18 : arp_tx_data <= mac_length ; //MAC address length
|
||||
16'd19 : arp_tx_data <= ip_length ; //IP address length
|
||||
16'd20 : arp_tx_data <= op[15:8] ;
|
||||
16'd21 : arp_tx_data <= op[7:0] ;
|
||||
16'd22 : arp_tx_data <= source_mac_addr[47:40] ;
|
||||
16'd23 : arp_tx_data <= source_mac_addr[39:32] ;
|
||||
16'd24 : arp_tx_data <= source_mac_addr[31:24] ;
|
||||
16'd25 : arp_tx_data <= source_mac_addr[23:16] ;
|
||||
16'd26 : arp_tx_data <= source_mac_addr[15:8] ;
|
||||
16'd27 : arp_tx_data <= source_mac_addr[7:0] ;
|
||||
16'd28 : arp_tx_data <= source_ip_addr[31:24] ;
|
||||
16'd29 : arp_tx_data <= source_ip_addr[23:16] ;
|
||||
16'd30 : arp_tx_data <= source_ip_addr[15:8] ;
|
||||
16'd31 : arp_tx_data <= source_ip_addr[7:0] ;
|
||||
16'd32 : arp_tx_data <= arp_destination_mac_addr[47:40] ;
|
||||
16'd33 : arp_tx_data <= arp_destination_mac_addr[39:32] ;
|
||||
16'd34 : arp_tx_data <= arp_destination_mac_addr[31:24] ;
|
||||
16'd35 : arp_tx_data <= arp_destination_mac_addr[23:16] ;
|
||||
16'd36 : arp_tx_data <= arp_destination_mac_addr[15:8] ;
|
||||
16'd37 : arp_tx_data <= arp_destination_mac_addr[7:0] ;
|
||||
16'd38 : arp_tx_data <= arp_destination_ip_addr[31:24] ;
|
||||
16'd39 : arp_tx_data <= arp_destination_ip_addr[23:16] ;
|
||||
16'd40 : arp_tx_data <= arp_destination_ip_addr[15:8] ;
|
||||
16'd41 : arp_tx_data <= arp_destination_ip_addr[7:0] ;
|
||||
default : arp_tx_data <= 8'd0 ;
|
||||
endcase
|
||||
end
|
||||
else
|
||||
arp_tx_data <= 8'd0 ;
|
||||
end
|
||||
|
||||
|
||||
|
||||
endmodule
|
||||
400
rtl/ethernet-udp/src/eth/mac/tx/ip_tx.v
Normal file
400
rtl/ethernet-udp/src/eth/mac/tx/ip_tx.v
Normal file
@ -0,0 +1,400 @@
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
//Module Name : ip_tx
|
||||
//Description : This module is used to send ip layer data, generate ip header checksum,
|
||||
// receive data from udp or icmp, then send to mac layer
|
||||
//
|
||||
//
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
`timescale 1 ns/1 ns
|
||||
module ip_tx
|
||||
(
|
||||
input clk ,
|
||||
input rst_n ,
|
||||
|
||||
input [47:0] destination_mac_addr , //destination mac address
|
||||
input [47:0] source_mac_addr , //source mac address
|
||||
input [7:0] TTL,
|
||||
input [7:0] ip_send_type,
|
||||
input [31:0] source_ip_addr,
|
||||
input [31:0] destination_ip_addr,
|
||||
input [7:0] upper_layer_data, //data from udp or icmp
|
||||
output reg upper_data_req, //request data from udp or icmp
|
||||
|
||||
input mac_tx_ack,
|
||||
input mac_send_end,
|
||||
input mac_data_req,
|
||||
input upper_tx_ready,
|
||||
input ip_tx_req,
|
||||
input [15:0] ip_send_data_length ,
|
||||
|
||||
output reg ip_tx_ack,
|
||||
output ip_tx_busy,
|
||||
output reg ip_tx_ready,
|
||||
output reg [7:0] ip_tx_data,
|
||||
output reg ip_tx_end
|
||||
) ;
|
||||
|
||||
localparam mac_type = 16'h0800 ;
|
||||
localparam ip_version = 4'h4 ; //ipv4
|
||||
localparam header_len = 4'h5 ; //header length
|
||||
|
||||
reg checksum_finish ;
|
||||
reg [15:0] identify_code ;
|
||||
reg [15:0] ip_send_data_length_d0 ;
|
||||
reg [15:0] ip_send_cnt ;
|
||||
reg [15:0] timeout ;
|
||||
reg [3:0] wait_cnt ;
|
||||
reg mac_send_end_d0 ;
|
||||
|
||||
parameter IDLE = 8'b0000_0001 ;
|
||||
parameter START = 8'b0000_0010 ;
|
||||
parameter WAIT_DATA_LENGTH = 8'b0000_0100 ;
|
||||
parameter GEN_CHECKSUM = 8'b0000_1000 ;
|
||||
parameter SEND_WAIT = 8'b0001_0000 ;
|
||||
parameter WAIT_MAC = 8'b0010_0000 ;
|
||||
parameter IP_SEND = 8'b0100_0000 ;
|
||||
parameter IP_END = 8'b1000_0000 ;
|
||||
|
||||
reg [7:0] state ;
|
||||
reg [7:0] next_state ;
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
state <= IDLE ;
|
||||
else
|
||||
state <= next_state ;
|
||||
end
|
||||
|
||||
always @(*)
|
||||
begin
|
||||
case(state)
|
||||
IDLE :
|
||||
begin
|
||||
if (ip_tx_req)
|
||||
next_state <= START ;
|
||||
else
|
||||
next_state <= IDLE ;
|
||||
end
|
||||
START :
|
||||
begin
|
||||
if (mac_tx_ack)
|
||||
next_state <= WAIT_DATA_LENGTH ;
|
||||
else
|
||||
next_state <= START ;
|
||||
end
|
||||
WAIT_DATA_LENGTH :
|
||||
begin
|
||||
if (wait_cnt == 4'd7)
|
||||
next_state <= GEN_CHECKSUM ;
|
||||
else
|
||||
next_state <= WAIT_DATA_LENGTH ;
|
||||
end
|
||||
GEN_CHECKSUM :
|
||||
begin
|
||||
if (checksum_finish)
|
||||
next_state <= SEND_WAIT ;
|
||||
else
|
||||
next_state <= GEN_CHECKSUM ;
|
||||
end
|
||||
|
||||
SEND_WAIT :
|
||||
begin
|
||||
if (upper_tx_ready)
|
||||
next_state <= WAIT_MAC ;
|
||||
else if (timeout == 16'hffff)
|
||||
next_state <= IDLE ;
|
||||
else
|
||||
next_state <= SEND_WAIT ;
|
||||
end
|
||||
WAIT_MAC :
|
||||
begin
|
||||
if (mac_data_req)
|
||||
next_state <= IP_SEND ;
|
||||
else if (timeout == 16'hffff)
|
||||
next_state <= IDLE ;
|
||||
else
|
||||
next_state <= WAIT_MAC ;
|
||||
end
|
||||
IP_SEND :
|
||||
begin
|
||||
if (ip_send_cnt == 14 + ip_send_data_length_d0)
|
||||
next_state <= IP_END ;
|
||||
else
|
||||
next_state <= IP_SEND ;
|
||||
end
|
||||
IP_END :
|
||||
begin
|
||||
if (mac_send_end_d0)
|
||||
next_state <= IDLE ;
|
||||
else
|
||||
next_state <= IP_END ;
|
||||
end
|
||||
default :
|
||||
next_state <= IDLE ;
|
||||
endcase
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
mac_send_end_d0 <= 1'b0 ;
|
||||
else
|
||||
mac_send_end_d0 <= mac_send_end ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ip_tx_ack <= 1'b0 ;
|
||||
else if (state == WAIT_DATA_LENGTH)
|
||||
ip_tx_ack <= 1'b1 ;
|
||||
else
|
||||
ip_tx_ack <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ip_tx_ready <= 1'b0 ;
|
||||
else if (state == WAIT_MAC)
|
||||
ip_tx_ready <= upper_tx_ready ;
|
||||
else
|
||||
ip_tx_ready <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ip_tx_end <= 1'b0 ;
|
||||
else if ((state == IP_SEND) && (ip_send_cnt == 13 + ip_send_data_length_d0))
|
||||
ip_tx_end <= 1'b1 ;
|
||||
else
|
||||
ip_tx_end <= 1'b0 ;
|
||||
end
|
||||
|
||||
//request data from icmp or udp
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
upper_data_req <= 1'b0 ;
|
||||
else if (state == IP_SEND && ip_send_cnt == 16'd30)
|
||||
upper_data_req <= 1'b1 ;
|
||||
else
|
||||
upper_data_req <= 1'b0 ;
|
||||
end
|
||||
|
||||
//timeout counter
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
timeout <= 16'd0 ;
|
||||
else if (upper_tx_ready)
|
||||
timeout <= 16'd0 ;
|
||||
else if (state == SEND_WAIT || state == WAIT_MAC)
|
||||
timeout <= timeout + 1'b1 ;
|
||||
else
|
||||
timeout <= 16'd0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
wait_cnt <= 4'd0 ;
|
||||
else if (state == WAIT_DATA_LENGTH)
|
||||
wait_cnt <= wait_cnt + 1'b1 ;
|
||||
else
|
||||
wait_cnt <= 4'd0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
identify_code <= 16'd0 ;
|
||||
else if (ip_tx_end)
|
||||
identify_code <= identify_code + 1'b1 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ip_send_data_length_d0 <= 16'd0 ;
|
||||
else
|
||||
begin
|
||||
if (ip_send_data_length < 46)
|
||||
ip_send_data_length_d0 <= 16'd46 ;
|
||||
else
|
||||
ip_send_data_length_d0 <= ip_send_data_length ;
|
||||
end
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ip_send_cnt <= 16'd0 ;
|
||||
else if (state == GEN_CHECKSUM || state == IP_SEND)
|
||||
ip_send_cnt <= ip_send_cnt + 1'b1 ;
|
||||
else
|
||||
ip_send_cnt <= 16'd0 ;
|
||||
end
|
||||
//checksum generation
|
||||
|
||||
reg [16:0] checksum_tmp0 ;
|
||||
reg [16:0] checksum_tmp1 ;
|
||||
reg [16:0] checksum_tmp2 ;
|
||||
reg [16:0] checksum_tmp3 ;
|
||||
reg [16:0] checksum_tmp4 ;
|
||||
reg [17:0] checksum_tmp5 ;
|
||||
reg [17:0] checksum_tmp6 ;
|
||||
reg [18:0] checksum_tmp7 ;
|
||||
reg [19:0] checksum_tmp8 ;
|
||||
reg [19:0] check_out ;
|
||||
reg [19:0] checkout_buf ;
|
||||
reg [15:0] checksum ;
|
||||
|
||||
|
||||
//checksum function
|
||||
function [31:0] checksum_adder
|
||||
(
|
||||
input [31:0] dataina,
|
||||
input [31:0] datainb
|
||||
);
|
||||
|
||||
begin
|
||||
checksum_adder = dataina + datainb;
|
||||
end
|
||||
endfunction
|
||||
|
||||
function [31:0] checksum_out
|
||||
(
|
||||
input [31:0] dataina
|
||||
);
|
||||
|
||||
begin
|
||||
checksum_out = dataina[15:0]+dataina[31:16];
|
||||
end
|
||||
|
||||
endfunction
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
begin
|
||||
checksum_tmp0 <= 17'd0 ;
|
||||
checksum_tmp1 <= 17'd0 ;
|
||||
checksum_tmp2 <= 17'd0 ;
|
||||
checksum_tmp3 <= 17'd0 ;
|
||||
checksum_tmp4 <= 17'd0 ;
|
||||
checksum_tmp5 <= 18'd0 ;
|
||||
checksum_tmp6 <= 18'd0 ;
|
||||
checksum_tmp7 <= 19'd0 ;
|
||||
checksum_tmp8 <= 20'd0 ;
|
||||
check_out <= 20'd0 ;
|
||||
checkout_buf <= 20'd0 ;
|
||||
end
|
||||
else if (state == GEN_CHECKSUM)
|
||||
begin
|
||||
checksum_tmp0 <= checksum_adder(16'h4500,ip_send_data_length);
|
||||
checksum_tmp1 <= checksum_adder(identify_code, 16'h4000) ;
|
||||
checksum_tmp2 <= checksum_adder({TTL,ip_send_type}, 16'h0000) ;
|
||||
checksum_tmp3 <= checksum_adder(source_ip_addr[31:16], source_ip_addr[15:0]) ;
|
||||
checksum_tmp4 <= checksum_adder(destination_ip_addr[31:16], destination_ip_addr[15:0]) ;
|
||||
checksum_tmp5 <= checksum_adder(checksum_tmp0, checksum_tmp1) ;
|
||||
checksum_tmp6 <= checksum_adder(checksum_tmp2, checksum_tmp3) ;
|
||||
checksum_tmp7 <= checksum_adder(checksum_tmp5, checksum_tmp6) ;
|
||||
checksum_tmp8 <= checksum_adder(checksum_tmp4, checksum_tmp7) ;
|
||||
check_out <= checksum_out(checksum_tmp8) ;
|
||||
checkout_buf <= checksum_out(check_out) ;
|
||||
end
|
||||
else if (state == IDLE)
|
||||
begin
|
||||
checksum_tmp0 <= 17'd0 ;
|
||||
checksum_tmp1 <= 17'd0 ;
|
||||
checksum_tmp2 <= 17'd0 ;
|
||||
checksum_tmp3 <= 17'd0 ;
|
||||
checksum_tmp4 <= 17'd0 ;
|
||||
checksum_tmp5 <= 18'd0 ;
|
||||
checksum_tmp6 <= 18'd0 ;
|
||||
checksum_tmp7 <= 19'd0 ;
|
||||
checksum_tmp8 <= 20'd0 ;
|
||||
check_out <= 20'd0 ;
|
||||
checkout_buf <= 20'd0 ;
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
checksum <= 32'd0 ;
|
||||
else if (state == GEN_CHECKSUM)
|
||||
checksum <= ~checkout_buf[15:0] ;
|
||||
end
|
||||
//assign checksum = ~checkout_buf[15:0] ;
|
||||
//*******************************************************//
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
checksum_finish <= 1'b0 ;
|
||||
else if (state == GEN_CHECKSUM && ip_send_cnt == 16'd13)
|
||||
checksum_finish <= 1'b1 ;
|
||||
else
|
||||
checksum_finish <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ip_tx_data <= 8'h00 ;
|
||||
else if (state == IP_SEND)
|
||||
begin
|
||||
case(ip_send_cnt)
|
||||
16'd0 : ip_tx_data <= destination_mac_addr[47:40] ;
|
||||
16'd1 : ip_tx_data <= destination_mac_addr[39:32] ;
|
||||
16'd2 : ip_tx_data <= destination_mac_addr[31:24] ;
|
||||
16'd3 : ip_tx_data <= destination_mac_addr[23:16] ;
|
||||
16'd4 : ip_tx_data <= destination_mac_addr[15:8] ;
|
||||
16'd5 : ip_tx_data <= destination_mac_addr[7:0] ;
|
||||
16'd6 : ip_tx_data <= source_mac_addr[47:40] ;
|
||||
16'd7 : ip_tx_data <= source_mac_addr[39:32] ;
|
||||
16'd8 : ip_tx_data <= source_mac_addr[31:24] ;
|
||||
16'd9 : ip_tx_data <= source_mac_addr[23:16] ;
|
||||
16'd10 : ip_tx_data <= source_mac_addr[15:8] ;
|
||||
16'd11 : ip_tx_data <= source_mac_addr[7:0] ;
|
||||
16'd12 : ip_tx_data <= mac_type[15:8] ;
|
||||
16'd13 : ip_tx_data <= mac_type[7:0] ;
|
||||
16'd14 : ip_tx_data <= {ip_version, header_len} ;
|
||||
16'd15 : ip_tx_data <= 8'h00 ;
|
||||
16'd16 : ip_tx_data <= ip_send_data_length[15:8] ;
|
||||
16'd17 : ip_tx_data <= ip_send_data_length[7:0] ;
|
||||
16'd18 : ip_tx_data <= identify_code[15:8] ;
|
||||
16'd19 : ip_tx_data <= identify_code[7:0] ;
|
||||
16'd20 : ip_tx_data <= 8'h40 ;
|
||||
16'd21 : ip_tx_data <= 8'h00 ;
|
||||
16'd22 : ip_tx_data <= TTL ;
|
||||
16'd23 : ip_tx_data <= ip_send_type ;
|
||||
16'd24 : ip_tx_data <= checksum[15:8] ;
|
||||
16'd25 : ip_tx_data <= checksum[7:0] ;
|
||||
16'd26 : ip_tx_data <= source_ip_addr[31:24] ;
|
||||
16'd27 : ip_tx_data <= source_ip_addr[23:16] ;
|
||||
16'd28 : ip_tx_data <= source_ip_addr[15:8] ;
|
||||
16'd29 : ip_tx_data <= source_ip_addr[7:0] ;
|
||||
16'd30 : ip_tx_data <= destination_ip_addr[31:24] ;
|
||||
16'd31 : ip_tx_data <= destination_ip_addr[23:16] ;
|
||||
16'd32 : ip_tx_data <= destination_ip_addr[15:8] ;
|
||||
16'd33 : ip_tx_data <= destination_ip_addr[7:0] ;
|
||||
default : ip_tx_data <= upper_layer_data ;
|
||||
endcase
|
||||
end
|
||||
else
|
||||
ip_tx_data <= 8'h00 ;
|
||||
end
|
||||
|
||||
|
||||
|
||||
endmodule
|
||||
194
rtl/ethernet-udp/src/eth/mac/tx/ip_tx_mode.v
Normal file
194
rtl/ethernet-udp/src/eth/mac/tx/ip_tx_mode.v
Normal file
@ -0,0 +1,194 @@
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
//Module Name : ip_tx_mode
|
||||
//Description : This module is arbitration for ip layer signal, which from udp and icmp
|
||||
//
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
`timescale 1 ns/1 ns
|
||||
module ip_tx_mode
|
||||
(
|
||||
input clk ,
|
||||
input rst_n,
|
||||
input mac_send_end,
|
||||
|
||||
|
||||
input udp_tx_req,
|
||||
input udp_tx_ready ,
|
||||
input [7:0] udp_tx_data,
|
||||
input [15:0] udp_send_data_length,
|
||||
output reg udp_tx_ack,
|
||||
|
||||
input icmp_tx_req,
|
||||
input icmp_tx_ready,
|
||||
input [7:0] icmp_tx_data,
|
||||
input [15:0] icmp_send_data_length,
|
||||
output reg icmp_tx_ack,
|
||||
|
||||
input ip_tx_ack,
|
||||
output reg ip_tx_req,
|
||||
output reg ip_tx_ready,
|
||||
output reg [7:0] ip_tx_data,
|
||||
output reg [7:0] ip_send_type,
|
||||
output reg [15:0] ip_send_data_length
|
||||
|
||||
|
||||
);
|
||||
|
||||
localparam ip_udp_type = 8'h11 ;
|
||||
localparam ip_icmp_type = 8'h01 ;
|
||||
|
||||
reg [15:0] timeout ;
|
||||
|
||||
parameter IDLE = 5'b00001 ;
|
||||
parameter UDP_WAIT = 5'b00010 ;
|
||||
parameter UDP = 5'b00100 ;
|
||||
parameter ICMP_WAIT = 5'b01000 ;
|
||||
parameter ICMP = 5'b10000 ;
|
||||
|
||||
|
||||
reg [4:0] state ;
|
||||
reg [4:0] next_state ;
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
state <= IDLE ;
|
||||
else
|
||||
state <= next_state ;
|
||||
end
|
||||
|
||||
always @(*)
|
||||
begin
|
||||
case(state)
|
||||
IDLE :
|
||||
begin
|
||||
if (udp_tx_req)
|
||||
next_state <= UDP_WAIT ;
|
||||
else if (icmp_tx_req)
|
||||
next_state <= ICMP_WAIT ;
|
||||
else
|
||||
next_state <= IDLE ;
|
||||
end
|
||||
UDP_WAIT :
|
||||
begin
|
||||
if (ip_tx_ack)
|
||||
next_state <= UDP ;
|
||||
else
|
||||
next_state <= UDP_WAIT ;
|
||||
end
|
||||
UDP :
|
||||
begin
|
||||
if (mac_send_end)
|
||||
next_state <= IDLE ;
|
||||
else if (timeout == 16'hffff)
|
||||
next_state <= IDLE ;
|
||||
else
|
||||
next_state <= UDP ;
|
||||
end
|
||||
ICMP_WAIT :
|
||||
begin
|
||||
if (ip_tx_ack)
|
||||
next_state <= ICMP ;
|
||||
else
|
||||
next_state <= ICMP_WAIT ;
|
||||
end
|
||||
ICMP :
|
||||
begin
|
||||
if (mac_send_end)
|
||||
next_state <= IDLE ;
|
||||
else if (timeout == 16'hffff)
|
||||
next_state <= IDLE ;
|
||||
else
|
||||
next_state <= ICMP ;
|
||||
end
|
||||
default :
|
||||
next_state <= IDLE ;
|
||||
endcase
|
||||
end
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
timeout <= 16'd0 ;
|
||||
else if (state == UDP || state == ICMP)
|
||||
timeout <= timeout + 1'b1 ;
|
||||
else
|
||||
timeout <= 16'd0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ip_send_data_length <= 16'd0 ;
|
||||
else if (state == ICMP_WAIT || state == ICMP)
|
||||
ip_send_data_length <= icmp_send_data_length ;
|
||||
else
|
||||
ip_send_data_length <= udp_send_data_length + 28 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ip_tx_req <= 1'b0 ;
|
||||
else if (state == UDP_WAIT || state == ICMP_WAIT)
|
||||
ip_tx_req <= 1'b1 ;
|
||||
else
|
||||
ip_tx_req <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
udp_tx_ack <= 1'b0 ;
|
||||
else if (state == UDP)
|
||||
udp_tx_ack <= 1'b1 ;
|
||||
else
|
||||
udp_tx_ack <= 1'b0 ;
|
||||
end
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
icmp_tx_ack <= 1'b0 ;
|
||||
else if (state == ICMP)
|
||||
icmp_tx_ack <= 1'b1 ;
|
||||
else
|
||||
icmp_tx_ack <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
begin
|
||||
ip_tx_ready <= 1'b0 ;
|
||||
ip_tx_data <= 8'h00 ;
|
||||
ip_send_type <= ip_udp_type ;
|
||||
end
|
||||
else if (state == UDP)
|
||||
begin
|
||||
ip_tx_ready <= udp_tx_ready ;
|
||||
ip_tx_data <= udp_tx_data ;
|
||||
ip_send_type <= ip_udp_type ;
|
||||
|
||||
end
|
||||
else if (state == ICMP)
|
||||
begin
|
||||
ip_tx_ready <= icmp_tx_ready ;
|
||||
ip_tx_data <= icmp_tx_data ;
|
||||
ip_send_type <= ip_icmp_type ;
|
||||
|
||||
end
|
||||
else
|
||||
begin
|
||||
ip_tx_ready <= 1'b0 ;
|
||||
ip_tx_data <= 8'h00 ;
|
||||
ip_send_type <= ip_udp_type ;
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
|
||||
endmodule
|
||||
|
||||
|
||||
256
rtl/ethernet-udp/src/eth/mac/tx/mac_tx.v
Normal file
256
rtl/ethernet-udp/src/eth/mac/tx/mac_tx.v
Normal file
@ -0,0 +1,256 @@
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
//Module Name : mac_tx
|
||||
//Description : This module is MAC layer module, which receive data from ARP or IP module,
|
||||
// In this module, CRC checksum is generated
|
||||
//
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
`timescale 1 ns/1 ns
|
||||
module mac_tx
|
||||
(
|
||||
input clk,
|
||||
input rst_n,
|
||||
|
||||
input [31:0] crc_result ,
|
||||
output reg crcen,
|
||||
output reg crcre,
|
||||
output reg [7:0] crc_din,
|
||||
|
||||
input mac_tx_req,
|
||||
input [7:0] mac_frame_data, //data from ip or arp
|
||||
input mac_tx_ready, //ready from ip or arp
|
||||
input mac_tx_end, //end from ip or arp
|
||||
|
||||
output reg mac_tx_ack,
|
||||
output reg [7:0] mac_tx_data,
|
||||
output reg mac_send_end,
|
||||
output reg mac_data_valid,
|
||||
output reg mac_data_req //request data from arp or ip
|
||||
|
||||
) ;
|
||||
|
||||
|
||||
reg [3:0] mac_tx_cnt ;
|
||||
reg [31:0] crc ;
|
||||
|
||||
reg [7:0] mac_frame_data_dly ;
|
||||
reg mac_tx_end_dly ;
|
||||
reg [7:0] mac_tx_data_tmp ;
|
||||
reg mac_data_valid_tmp ;
|
||||
reg [15:0] timeout ;
|
||||
|
||||
|
||||
//MAC send FSM
|
||||
parameter SEND_IDLE = 6'b000_001 ;
|
||||
parameter SEND_START = 6'b000_010 ;
|
||||
parameter SEND_PREAMBLE = 6'b000_100 ;
|
||||
parameter SEND_DATA = 6'b001_000 ;
|
||||
parameter SEND_CRC = 6'b010_000 ;
|
||||
parameter SEND_END = 6'b100_000 ;
|
||||
|
||||
reg [5:0] send_state ;
|
||||
reg [5:0] send_next_state ;
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
send_state <= SEND_START ;
|
||||
else
|
||||
send_state <= send_next_state ;
|
||||
end
|
||||
|
||||
always @(*)
|
||||
begin
|
||||
case(send_state)
|
||||
SEND_IDLE :
|
||||
begin
|
||||
if (mac_tx_req)
|
||||
send_next_state <= SEND_START ;
|
||||
else
|
||||
send_next_state <= SEND_IDLE ;
|
||||
end
|
||||
SEND_START :
|
||||
begin
|
||||
if (mac_tx_ready)
|
||||
send_next_state <= SEND_PREAMBLE ;
|
||||
else
|
||||
send_next_state <= SEND_START ;
|
||||
end
|
||||
SEND_PREAMBLE :
|
||||
begin
|
||||
if (mac_tx_cnt == 7)
|
||||
send_next_state <= SEND_DATA ;
|
||||
else
|
||||
send_next_state <= SEND_PREAMBLE ;
|
||||
end
|
||||
SEND_DATA :
|
||||
begin
|
||||
if (mac_tx_end_dly)
|
||||
send_next_state <= SEND_CRC ;
|
||||
else if (timeout == 16'hffff)
|
||||
send_next_state <= SEND_END ;
|
||||
else
|
||||
send_next_state <= SEND_DATA ;
|
||||
end
|
||||
SEND_CRC :
|
||||
begin
|
||||
if (mac_tx_cnt == 4)
|
||||
send_next_state <= SEND_END ;
|
||||
else
|
||||
send_next_state <= SEND_CRC ;
|
||||
end
|
||||
SEND_END :
|
||||
send_next_state <= SEND_IDLE ;
|
||||
default :
|
||||
send_next_state <= SEND_IDLE ;
|
||||
endcase
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
mac_tx_ack <= 1'b0 ;
|
||||
else if (send_state == SEND_START)
|
||||
mac_tx_ack <= 1'b1 ;
|
||||
else
|
||||
mac_tx_ack <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
mac_send_end <= 1'b0 ;
|
||||
else if (send_state == SEND_END)
|
||||
mac_send_end <= 1'b1 ;
|
||||
else
|
||||
mac_send_end <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
begin
|
||||
crcre <= 1'b1 ;
|
||||
crcen <= 1'b0 ;
|
||||
crc_din <= 8'd0 ;
|
||||
end
|
||||
else if (send_state == SEND_DATA || (send_state == SEND_PREAMBLE && mac_tx_cnt == 7))
|
||||
begin
|
||||
crcre <= 1'b0 ;
|
||||
crcen <= 1'b1 ;
|
||||
crc_din <= mac_frame_data ;
|
||||
end
|
||||
else
|
||||
begin
|
||||
crcre <= 1'b1 ;
|
||||
crcen <= 1'b0 ;
|
||||
crc_din <= 8'd0 ;
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
mac_data_valid_tmp <= 1'b0 ;
|
||||
else if (send_state == SEND_PREAMBLE || send_state == SEND_DATA || (send_state == SEND_CRC && mac_tx_cnt < 4))
|
||||
mac_data_valid_tmp <= 1'b1 ;
|
||||
else
|
||||
mac_data_valid_tmp <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
mac_data_valid <= 1'b0 ;
|
||||
else
|
||||
mac_data_valid <= mac_data_valid_tmp ;
|
||||
end
|
||||
//request data from arp or ip
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
mac_data_req <= 1'b0 ;
|
||||
else if (send_state == SEND_PREAMBLE && mac_tx_cnt == 3)
|
||||
mac_data_req <= 1'b1 ;
|
||||
else
|
||||
mac_data_req <= 1'b0 ;
|
||||
end
|
||||
//timeout counter
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
timeout <= 16'd0 ;
|
||||
else if (send_state == SEND_DATA)
|
||||
timeout <= timeout + 1'b1 ;
|
||||
else
|
||||
timeout <= 16'd0 ;
|
||||
end
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
crc <= 32'hffffffff ;
|
||||
else if (crcen)
|
||||
crc <= crc_result ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
begin
|
||||
mac_frame_data_dly <= 8'd0 ;
|
||||
mac_tx_end_dly <= 1'b0 ;
|
||||
end
|
||||
else
|
||||
begin
|
||||
mac_frame_data_dly <= mac_frame_data ;
|
||||
mac_tx_end_dly <= mac_tx_end ;
|
||||
end
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
mac_tx_cnt <= 4'd0 ;
|
||||
else if (send_state == SEND_PREAMBLE || send_state == SEND_CRC)
|
||||
mac_tx_cnt <= mac_tx_cnt + 1'b1 ;
|
||||
else
|
||||
mac_tx_cnt <= 4'd0 ;
|
||||
end
|
||||
//mac send data frame
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
mac_tx_data_tmp <= 8'h00 ;
|
||||
else if (send_state == SEND_PREAMBLE)
|
||||
begin
|
||||
if (mac_tx_cnt < 7)
|
||||
mac_tx_data_tmp <= 8'h55 ;
|
||||
else
|
||||
mac_tx_data_tmp <= 8'hd5 ;
|
||||
end
|
||||
else if (send_state == SEND_DATA)
|
||||
mac_tx_data_tmp <= mac_frame_data_dly ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
mac_tx_data <= 8'h00 ;
|
||||
else if (send_state == SEND_CRC)
|
||||
begin
|
||||
case(mac_tx_cnt)
|
||||
4'd0 : mac_tx_data <= mac_tx_data_tmp ;
|
||||
4'd1 : mac_tx_data <= {~crc[24], ~crc[25], ~crc[26], ~crc[27], ~crc[28], ~crc[29], ~crc[30], ~crc[31]} ;
|
||||
4'd2 : mac_tx_data <= {~crc[16], ~crc[17], ~crc[18], ~crc[19], ~crc[20], ~crc[21], ~crc[22], ~crc[23]} ;
|
||||
4'd3 : mac_tx_data <= {~crc[8], ~crc[9], ~crc[10], ~crc[11], ~crc[12], ~crc[13], ~crc[14], ~crc[15]} ;
|
||||
4'd4 : mac_tx_data <= {~crc[0], ~crc[1], ~crc[2], ~crc[3], ~crc[4], ~crc[5], ~crc[6], ~crc[7]} ;
|
||||
default : mac_tx_data <= 8'h00 ;
|
||||
endcase
|
||||
end
|
||||
else
|
||||
mac_tx_data <= mac_tx_data_tmp ;
|
||||
end
|
||||
|
||||
endmodule
|
||||
174
rtl/ethernet-udp/src/eth/mac/tx/mac_tx_mode.v
Normal file
174
rtl/ethernet-udp/src/eth/mac/tx/mac_tx_mode.v
Normal file
@ -0,0 +1,174 @@
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
//Module Name : mac_tx_mode
|
||||
//Description : This module is arbitration for MAC layer signal, which from IP and ARP
|
||||
//
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
`timescale 1 ns/1 ns
|
||||
module mac_tx_mode
|
||||
(
|
||||
input clk ,
|
||||
input rst_n,
|
||||
input mac_send_end,
|
||||
|
||||
input arp_tx_req,
|
||||
input arp_tx_ready ,
|
||||
input [7:0] arp_tx_data,
|
||||
input arp_tx_end,
|
||||
output reg arp_tx_ack,
|
||||
|
||||
input ip_tx_req,
|
||||
input ip_tx_ready,
|
||||
input [7:0] ip_tx_data,
|
||||
input ip_tx_end,
|
||||
output reg ip_tx_ack,
|
||||
|
||||
input mac_tx_ack,
|
||||
output reg mac_tx_req,
|
||||
output reg mac_tx_ready,
|
||||
output reg [7:0] mac_tx_data,
|
||||
output reg mac_tx_end
|
||||
);
|
||||
|
||||
|
||||
|
||||
reg [15:0] timeout ;
|
||||
|
||||
parameter IDLE = 5'b00001 ;
|
||||
parameter ARP_WAIT = 5'b00010 ;
|
||||
parameter ARP = 5'b00100 ;
|
||||
parameter IP_WAIT = 5'b01000 ;
|
||||
parameter IP = 5'b10000 ;
|
||||
|
||||
|
||||
reg [4:0] state ;
|
||||
reg [4:0] next_state ;
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
state <= IDLE ;
|
||||
else
|
||||
state <= next_state ;
|
||||
end
|
||||
|
||||
always @(*)
|
||||
begin
|
||||
case(state)
|
||||
IDLE :
|
||||
begin
|
||||
if (arp_tx_req)
|
||||
next_state <= ARP_WAIT ;
|
||||
else if (ip_tx_req)
|
||||
next_state <= IP_WAIT ;
|
||||
else
|
||||
next_state <= IDLE ;
|
||||
end
|
||||
ARP_WAIT :
|
||||
begin
|
||||
if (mac_tx_ack)
|
||||
next_state <= ARP ;
|
||||
else
|
||||
next_state <= IP ;
|
||||
end
|
||||
ARP :
|
||||
begin
|
||||
if (mac_send_end)
|
||||
next_state <= IDLE ;
|
||||
else if (timeout == 16'hffff)
|
||||
next_state <= IDLE ;
|
||||
else
|
||||
next_state <= ARP ;
|
||||
end
|
||||
IP_WAIT :
|
||||
begin
|
||||
if (mac_tx_ack)
|
||||
next_state <= IP ;
|
||||
else
|
||||
next_state <= IP_WAIT ;
|
||||
end
|
||||
IP :
|
||||
begin
|
||||
if (mac_send_end)
|
||||
next_state <= IDLE ;
|
||||
else if (timeout == 16'hffff)
|
||||
next_state <= IDLE ;
|
||||
else
|
||||
next_state <= IP ;
|
||||
end
|
||||
default :
|
||||
next_state <= IDLE ;
|
||||
endcase
|
||||
end
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
timeout <= 16'd0 ;
|
||||
else if (state == ARP || state == IP)
|
||||
timeout <= timeout + 1'b1 ;
|
||||
else
|
||||
timeout <= 16'd0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
arp_tx_ack <= 1'b0 ;
|
||||
else if (state == ARP)
|
||||
arp_tx_ack <= 1'b1 ;
|
||||
else
|
||||
arp_tx_ack <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ip_tx_ack <= 1'b0 ;
|
||||
else if (state == IP)
|
||||
ip_tx_ack <= 1'b1 ;
|
||||
else
|
||||
ip_tx_ack <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
mac_tx_req <= 1'b0 ;
|
||||
else if (state == ARP_WAIT || state == IP_WAIT)
|
||||
mac_tx_req <= 1'b1 ;
|
||||
else
|
||||
mac_tx_req <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
begin
|
||||
mac_tx_ready <= 1'b0 ;
|
||||
mac_tx_data <= 8'h00 ;
|
||||
mac_tx_end <= 1'b0 ;
|
||||
end
|
||||
else if (state == ARP)
|
||||
begin
|
||||
mac_tx_ready <= arp_tx_ready ;
|
||||
mac_tx_data <= arp_tx_data ;
|
||||
mac_tx_end <= arp_tx_end ;
|
||||
end
|
||||
else if (state == IP)
|
||||
begin
|
||||
mac_tx_ready <= ip_tx_ready ;
|
||||
mac_tx_data <= ip_tx_data ;
|
||||
mac_tx_end <= ip_tx_end ;
|
||||
end
|
||||
else
|
||||
begin
|
||||
mac_tx_ready <= 1'b0 ;
|
||||
mac_tx_data <= 8'h00 ;
|
||||
mac_tx_end <= 1'b0 ;
|
||||
end
|
||||
end
|
||||
|
||||
endmodule
|
||||
|
||||
|
||||
258
rtl/ethernet-udp/src/eth/mac/tx/mac_tx_top.v
Normal file
258
rtl/ethernet-udp/src/eth/mac/tx/mac_tx_top.v
Normal file
@ -0,0 +1,258 @@
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
//Module Name : mac_tx_top
|
||||
//Description : MAC TX Top module
|
||||
//
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
`timescale 1 ns/1 ns
|
||||
module mac_tx_top
|
||||
(
|
||||
input clk ,
|
||||
input rst_n ,
|
||||
|
||||
input [47:0] destination_mac_addr , //destination mac address
|
||||
input [47:0] source_mac_addr , //source mac address
|
||||
input [7:0] TTL,
|
||||
input [31:0] source_ip_addr,
|
||||
input [31:0] destination_ip_addr,
|
||||
input [15:0] udp_send_source_port,
|
||||
input [15:0] udp_send_destination_port,
|
||||
|
||||
output arp_reply_ack,
|
||||
input arp_reply_req,
|
||||
input [31:0] arp_rec_source_ip_addr,
|
||||
input [47:0] arp_rec_source_mac_addr,
|
||||
input arp_request_req,
|
||||
|
||||
|
||||
(* MARK_DEBUG="true" *)input [7:0] ram_wr_data,
|
||||
(* MARK_DEBUG="true" *)input ram_wr_en,
|
||||
(* MARK_DEBUG="true" *)input udp_tx_req,
|
||||
(* MARK_DEBUG="true" *)output udp_ram_data_req,
|
||||
(* MARK_DEBUG="true" *)input [15:0] udp_send_data_length,
|
||||
(* MARK_DEBUG="true" *)output udp_tx_end,
|
||||
(* MARK_DEBUG="true" *)output almost_full,
|
||||
|
||||
output upper_data_req,
|
||||
input icmp_tx_ready,
|
||||
input [7:0] icmp_tx_data,
|
||||
input icmp_tx_end,
|
||||
input icmp_tx_req,
|
||||
output icmp_tx_ack,
|
||||
input [15:0] icmp_send_data_length,
|
||||
|
||||
(* MARK_DEBUG="true" *)output mac_data_valid,
|
||||
(* MARK_DEBUG="true" *)output mac_send_end,
|
||||
(* MARK_DEBUG="true" *)output [7:0] mac_tx_data
|
||||
) ;
|
||||
|
||||
|
||||
wire crcen ;
|
||||
wire crcre ;
|
||||
wire [7:0] crc_din ;
|
||||
wire [31:0] crc_result ;
|
||||
|
||||
wire mac_data_req ;
|
||||
wire [7:0] mac_frame_data ;
|
||||
wire mac_tx_ready ;
|
||||
wire mac_tx_end ;
|
||||
|
||||
wire ip_tx_ready ;
|
||||
wire [7:0] ip_tx_data ;
|
||||
wire ip_tx_end ;
|
||||
|
||||
wire arp_tx_ready ;
|
||||
wire [7:0] arp_tx_data ;
|
||||
wire arp_tx_end ;
|
||||
|
||||
|
||||
wire [15:0] ip_send_data_length ;
|
||||
|
||||
|
||||
wire [7:0] udp_tx_data ;
|
||||
wire udp_data_req ;
|
||||
wire udp_tx_ready ;
|
||||
wire udp_tx_req_tmp ;
|
||||
|
||||
wire upper_tx_ready ;
|
||||
wire [7:0] upper_layer_data ;
|
||||
|
||||
|
||||
|
||||
|
||||
wire [7:0] ip_send_type ;
|
||||
|
||||
|
||||
wire arp_tx_req ;
|
||||
wire arp_tx_ack ;
|
||||
wire ip_tx_req ;
|
||||
wire ip_tx_ack ;
|
||||
wire mac_tx_ack ;
|
||||
wire mac_tx_req ;
|
||||
wire mac_ip_tx_ack ;
|
||||
wire mac_arp_tx_ack ;
|
||||
|
||||
wire udp_tx_ack;
|
||||
mac_tx mac0
|
||||
(
|
||||
.clk (clk ),
|
||||
.rst_n (rst_n ),
|
||||
|
||||
.crc_result (crc_result ),
|
||||
.crcen (crcen ),
|
||||
.crcre (crcre ),
|
||||
.crc_din (crc_din ),
|
||||
|
||||
.mac_tx_req (mac_tx_req ),
|
||||
.mac_frame_data (mac_frame_data ),
|
||||
.mac_tx_ready (mac_tx_ready ),
|
||||
.mac_tx_end (mac_tx_end ) ,
|
||||
|
||||
.mac_tx_ack (mac_tx_ack ),
|
||||
.mac_tx_data (mac_tx_data ),
|
||||
.mac_send_end (mac_send_end ),
|
||||
.mac_data_valid (mac_data_valid ),
|
||||
.mac_data_req (mac_data_req )
|
||||
|
||||
) ;
|
||||
|
||||
mac_tx_mode mode0
|
||||
(
|
||||
.clk (clk ),
|
||||
.rst_n (rst_n ),
|
||||
.mac_send_end (mac_send_end ),
|
||||
|
||||
.arp_tx_req (arp_tx_req ),
|
||||
.arp_tx_ready (arp_tx_ready ),
|
||||
.arp_tx_data (arp_tx_data ),
|
||||
.arp_tx_end (arp_tx_end ),
|
||||
.arp_tx_ack (mac_arp_tx_ack ),
|
||||
|
||||
.ip_tx_req (ip_tx_req ),
|
||||
.ip_tx_ready (ip_tx_ready ),
|
||||
.ip_tx_data (ip_tx_data ),
|
||||
.ip_tx_end (ip_tx_end ),
|
||||
.ip_tx_ack (mac_ip_tx_ack ),
|
||||
|
||||
.mac_tx_ack (mac_tx_ack ),
|
||||
.mac_tx_req (mac_tx_req ),
|
||||
.mac_tx_ready (mac_tx_ready ),
|
||||
.mac_tx_data (mac_frame_data ),
|
||||
.mac_tx_end (mac_tx_end )
|
||||
);
|
||||
|
||||
crc c0
|
||||
(
|
||||
.Clk (clk ),
|
||||
.Reset (crcre ),
|
||||
.Data_in (crc_din ),
|
||||
.Enable (crcen ),
|
||||
.Crc (crc_result ),
|
||||
.CrcNext ( )
|
||||
) ;
|
||||
|
||||
arp_tx arp_tx0
|
||||
(
|
||||
.clk (clk ) ,
|
||||
.rst_n (rst_n ) ,
|
||||
|
||||
.destination_mac_addr (destination_mac_addr ) , //destination mac address
|
||||
.source_mac_addr (source_mac_addr ) , //source mac address
|
||||
.source_ip_addr (source_ip_addr ) , //source ip address
|
||||
.destination_ip_addr (destination_ip_addr ) , //destination ip address
|
||||
|
||||
.mac_data_req (mac_data_req ) ,
|
||||
.mac_send_end (mac_send_end ),
|
||||
|
||||
.mac_tx_ack (mac_arp_tx_ack ),
|
||||
.arp_tx_req (arp_tx_req ),
|
||||
.arp_request_req (arp_request_req ) , //arp request
|
||||
.arp_reply_ack (arp_reply_ack ),
|
||||
.arp_reply_req (arp_reply_req ),
|
||||
.arp_rec_source_ip_addr (arp_rec_source_ip_addr ),
|
||||
.arp_rec_source_mac_addr (arp_rec_source_mac_addr ),
|
||||
.arp_tx_ready (arp_tx_ready ) ,
|
||||
.arp_tx_data (arp_tx_data ) ,
|
||||
.arp_tx_end (arp_tx_end )
|
||||
) ;
|
||||
|
||||
|
||||
ip_tx ip0
|
||||
(
|
||||
.clk (clk ),
|
||||
.rst_n (rst_n ),
|
||||
.destination_mac_addr (destination_mac_addr ), //destination mac address
|
||||
.source_mac_addr (source_mac_addr ), //source mac address
|
||||
.ip_send_data_length (ip_send_data_length ),
|
||||
.TTL (TTL ),
|
||||
.ip_send_type (ip_send_type ),
|
||||
.source_ip_addr (source_ip_addr ),
|
||||
.destination_ip_addr (destination_ip_addr ),
|
||||
.upper_layer_data (upper_layer_data ),
|
||||
.upper_data_req (upper_data_req ),
|
||||
.upper_tx_ready (upper_tx_ready ),
|
||||
|
||||
.mac_data_req (mac_data_req ),
|
||||
.mac_send_end (mac_send_end ),
|
||||
.mac_tx_ack (mac_ip_tx_ack ),
|
||||
|
||||
.ip_tx_req (ip_tx_req ),
|
||||
.ip_tx_ack (ip_tx_ack ),
|
||||
.ip_tx_ready (ip_tx_ready ),
|
||||
.ip_tx_data (ip_tx_data ),
|
||||
.ip_tx_end (ip_tx_end )
|
||||
|
||||
) ;
|
||||
|
||||
ip_tx_mode ipmode
|
||||
(
|
||||
.clk (clk ),
|
||||
.rst_n (rst_n ),
|
||||
.mac_send_end (mac_send_end ),
|
||||
|
||||
.udp_tx_req (udp_tx_req_tmp ),
|
||||
.udp_tx_ack (udp_tx_ack ),
|
||||
.udp_tx_ready (udp_tx_ready ),
|
||||
.udp_tx_data (udp_tx_data ),
|
||||
.udp_send_data_length (udp_send_data_length ),
|
||||
|
||||
.icmp_tx_req (icmp_tx_req ),
|
||||
.icmp_tx_ack (icmp_tx_ack ),
|
||||
.icmp_tx_ready (icmp_tx_ready ),
|
||||
.icmp_tx_data (icmp_tx_data ),
|
||||
.icmp_send_data_length (icmp_send_data_length ),
|
||||
|
||||
.ip_tx_req (ip_tx_req ),
|
||||
.ip_tx_ack (ip_tx_ack ),
|
||||
.ip_tx_ready (upper_tx_ready ),
|
||||
.ip_tx_data (upper_layer_data ),
|
||||
.ip_send_type (ip_send_type ),
|
||||
.ip_send_data_length (ip_send_data_length )
|
||||
|
||||
|
||||
);
|
||||
|
||||
udp_tx udp0
|
||||
(
|
||||
.clk (clk ),
|
||||
.rst_n (rst_n ),
|
||||
.source_ip_addr (source_ip_addr ),
|
||||
.destination_ip_addr (destination_ip_addr ),
|
||||
.udp_send_source_port (udp_send_source_port ),
|
||||
.udp_send_destination_port (udp_send_destination_port ),
|
||||
.udp_send_data_length (udp_send_data_length ),
|
||||
.udp_ram_data_req (udp_ram_data_req ),
|
||||
.mac_send_end (mac_send_end ),
|
||||
.ip_tx_req (udp_tx_req_tmp ),
|
||||
.ip_tx_ack (udp_tx_ack ),
|
||||
.ram_wr_data (ram_wr_data ),
|
||||
.ram_wr_en (ram_wr_en ),
|
||||
.udp_tx_req (udp_tx_req ),
|
||||
.udp_data_req (upper_data_req ),
|
||||
.udp_tx_ready (udp_tx_ready ),
|
||||
.udp_tx_data (udp_tx_data ),
|
||||
.udp_tx_end (udp_tx_end ),
|
||||
.almost_full (almost_full )
|
||||
) ;
|
||||
|
||||
endmodule
|
||||
|
||||
631
rtl/ethernet-udp/src/eth/mac/tx/udp_tx.v
Normal file
631
rtl/ethernet-udp/src/eth/mac/tx/udp_tx.v
Normal file
@ -0,0 +1,631 @@
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
//Module Name : udp_tx
|
||||
//Description : This module is used to send UDP data and generate UDP checksum
|
||||
//
|
||||
//////////////////////////////////////////////////////////////////////////////////////
|
||||
`timescale 1 ns/1 ns
|
||||
module udp_tx
|
||||
(
|
||||
input clk,
|
||||
input rst_n,
|
||||
|
||||
input [31:0] source_ip_addr,
|
||||
input [31:0] destination_ip_addr,
|
||||
|
||||
input [15:0] udp_send_source_port,
|
||||
input [15:0] udp_send_destination_port,
|
||||
input [15:0] udp_send_data_length,
|
||||
|
||||
input [7:0] ram_wr_data, //write data to udp tx ram
|
||||
input ram_wr_en, //write en
|
||||
output reg udp_ram_data_req, //request data written to ram
|
||||
input mac_send_end, //mac send finished
|
||||
input udp_tx_req,
|
||||
output reg ip_tx_req, //udp reqest ip
|
||||
input ip_tx_ack, //ip ack for udp transfer
|
||||
input udp_data_req,
|
||||
output reg udp_tx_ready,
|
||||
output reg [7:0] udp_tx_data,
|
||||
output reg udp_tx_end,
|
||||
output almost_full
|
||||
|
||||
) ;
|
||||
|
||||
|
||||
reg ram_rd_en ;
|
||||
wire [3:0] usedw ;
|
||||
reg [3:0] fifo_count ;
|
||||
|
||||
reg [7:0] ram_rdata_d0 ;
|
||||
reg [7:0] ram_rdata_d1 ;
|
||||
reg [7:0] ram_wr_data_d0 ;
|
||||
reg [7:0] ram_wr_data_d1 ;
|
||||
|
||||
wire [7:0] ram_rdata ;
|
||||
reg [5:0] ram_data_length ;
|
||||
|
||||
reg [15:0] udp_send_cnt ;
|
||||
reg [15:0] udp_data_length ; //valid data length
|
||||
reg [15:0] udp_total_data_length ;//data length when transfer
|
||||
|
||||
reg [15:0] timeout ;
|
||||
|
||||
reg mac_send_end_d0 ;
|
||||
|
||||
|
||||
|
||||
parameter IDLE = 6'b000001 ;
|
||||
parameter START = 6'b000010 ;
|
||||
parameter LEN_LATCH = 6'b000100 ;
|
||||
parameter SEND_WAIT = 6'b001000 ;
|
||||
parameter UDP_SEND = 6'b010000 ;
|
||||
parameter UDP_END = 6'b100000 ;
|
||||
|
||||
|
||||
reg [5:0] state ;
|
||||
reg [5:0] next_state ;
|
||||
|
||||
|
||||
reg [16:0] checksum_tmp0 ;
|
||||
reg [16:0] checksum_tmp1 ;
|
||||
reg [16:0] checksum_tmp2 ;
|
||||
reg [16:0] checksum_tmp3 ;
|
||||
reg [16:0] checksum_tmp4 ;
|
||||
reg [17:0] checksum_tmp5 ;
|
||||
reg [17:0] checksum_tmp6 ;
|
||||
reg [18:0] checksum_tmp7 ;
|
||||
reg [19:0] checksum_tmp8 ;
|
||||
|
||||
reg [31:0] checksum_tmp9 ;
|
||||
|
||||
reg [31:0] checksum_buf ;
|
||||
reg [31:0] check_out ;
|
||||
reg [31:0] checkout_buf ;
|
||||
wire [15:0] checksum ;
|
||||
reg [15:0] checksum_cnt ;
|
||||
|
||||
reg checksum_wr ;
|
||||
reg checksum_rd ;
|
||||
reg [31:0] checksum_in ;
|
||||
reg checksum_finish ;
|
||||
reg [15:0] checksum_udp_len ;
|
||||
wire [31:0] checksum_q ;
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
state <= IDLE ;
|
||||
else
|
||||
state <= next_state ;
|
||||
end
|
||||
|
||||
always @(*)
|
||||
begin
|
||||
case(state)
|
||||
IDLE :
|
||||
begin
|
||||
if (usedw > 4'd0)
|
||||
next_state <= START ;
|
||||
else
|
||||
next_state <= IDLE ;
|
||||
end
|
||||
START :
|
||||
begin
|
||||
next_state <= LEN_LATCH ;
|
||||
end
|
||||
LEN_LATCH :
|
||||
begin
|
||||
if (ip_tx_ack)
|
||||
next_state <= SEND_WAIT ;
|
||||
else
|
||||
next_state <= LEN_LATCH ;
|
||||
end
|
||||
SEND_WAIT :
|
||||
begin
|
||||
if (udp_data_req)
|
||||
next_state <= UDP_SEND ;
|
||||
else if (timeout == 16'hffff)
|
||||
next_state <= IDLE ;
|
||||
else
|
||||
next_state <= SEND_WAIT ;
|
||||
end
|
||||
|
||||
UDP_SEND :
|
||||
begin
|
||||
if (udp_send_cnt == udp_total_data_length)
|
||||
next_state <= UDP_END ;
|
||||
else
|
||||
next_state <= UDP_SEND ;
|
||||
end
|
||||
UDP_END :
|
||||
begin
|
||||
if (mac_send_end_d0)
|
||||
next_state <= IDLE ;
|
||||
else
|
||||
next_state <= UDP_END ;
|
||||
end
|
||||
default :
|
||||
next_state <= IDLE ;
|
||||
endcase
|
||||
end
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
fifo_count <= 4'd0 ;
|
||||
else
|
||||
fifo_count <= usedw ;
|
||||
end
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
checksum_rd <= 1'b0 ;
|
||||
else if (state == IDLE && state != next_state)
|
||||
checksum_rd <= 1'b1 ;
|
||||
else
|
||||
checksum_rd <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ip_tx_req <= 1'b0 ;
|
||||
else if (state == LEN_LATCH)
|
||||
ip_tx_req <= 1'b1 ;
|
||||
else
|
||||
ip_tx_req <= 1'b0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
mac_send_end_d0 <= 1'b0 ;
|
||||
else
|
||||
mac_send_end_d0 <= mac_send_end ;
|
||||
end
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
udp_tx_ready <= 1'b0 ;
|
||||
else if (state == SEND_WAIT)
|
||||
udp_tx_ready <= 1'b1 ;
|
||||
else
|
||||
udp_tx_ready <= 1'b0 ;
|
||||
end
|
||||
|
||||
|
||||
|
||||
|
||||
//timeout counter
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
timeout <= 16'd0 ;
|
||||
else if (state == SEND_WAIT)
|
||||
timeout <= timeout + 1'b1 ;
|
||||
else
|
||||
timeout <= 16'd0 ;
|
||||
end
|
||||
|
||||
udp_tx_data_fifo tx_data_fifo
|
||||
(
|
||||
.clk (clk ), // input wire clk
|
||||
.srst (~rst_n ), // input wire srst
|
||||
.din (ram_wr_data ), // input wire [7 : 0] din
|
||||
.wr_en (ram_wr_en ), // input wire wr_en
|
||||
.rd_en (ram_rd_en ), // input wire rd_en
|
||||
.dout (ram_rdata ), // output wire [7 : 0] dout
|
||||
.full ( ), // output wire full
|
||||
.almost_full (almost_full ), // output wire almost_full
|
||||
.empty ( ), // output wire empty
|
||||
.data_count ( ) // output wire [11 : 0] data_count
|
||||
);
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
begin
|
||||
ram_wr_data_d0 <= 8'd0 ;
|
||||
ram_wr_data_d1 <= 8'd0 ;
|
||||
end
|
||||
else
|
||||
begin
|
||||
ram_wr_data_d0 <= ram_wr_data ;
|
||||
ram_wr_data_d1 <= ram_wr_data_d0 ;
|
||||
end
|
||||
end
|
||||
//ram signal
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
begin
|
||||
ram_rdata_d0 <= 8'd0 ;
|
||||
ram_rdata_d1 <= 8'd0 ;
|
||||
end
|
||||
else
|
||||
begin
|
||||
ram_rdata_d0 <= ram_rdata ;
|
||||
ram_rdata_d1 <= ram_rdata_d0 ;
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
ram_rd_en <= 1'b0 ;
|
||||
else if (state == UDP_SEND && udp_send_cnt > 4 && udp_send_cnt < udp_data_length - 3)
|
||||
ram_rd_en <= 1'b1 ;
|
||||
else
|
||||
ram_rd_en <= 1'b0 ;
|
||||
end
|
||||
|
||||
|
||||
//checksum counter
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
udp_send_cnt <= 16'd0 ;
|
||||
else if (state == UDP_SEND)
|
||||
udp_send_cnt <= udp_send_cnt + 1'b1 ;
|
||||
else
|
||||
udp_send_cnt <= 16'd0 ;
|
||||
end
|
||||
|
||||
|
||||
|
||||
reg [15:0] fifo_udp_len ;
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
fifo_udp_len <= 16'd0 ;
|
||||
else
|
||||
fifo_udp_len <= checksum_q[31:16] ;
|
||||
end
|
||||
//generate udp and ip data length
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
begin
|
||||
udp_total_data_length <= 16'd0 ;
|
||||
udp_data_length <= 16'd0 ;
|
||||
end
|
||||
else if (state == LEN_LATCH)
|
||||
begin
|
||||
udp_data_length <= fifo_udp_len ;
|
||||
if (fifo_udp_len < 26)
|
||||
udp_total_data_length <= 26 ;
|
||||
else
|
||||
udp_total_data_length <= fifo_udp_len ;
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
|
||||
//*****************************************************************************************//
|
||||
//send udp data
|
||||
//*****************************************************************************************//
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
udp_tx_data <= 8'h00 ;
|
||||
else if (state == UDP_SEND)
|
||||
begin
|
||||
case(udp_send_cnt)
|
||||
16'd0 : udp_tx_data <= udp_send_source_port[15:8] ;
|
||||
16'd1 : udp_tx_data <= udp_send_source_port[7:0] ;
|
||||
16'd2 : udp_tx_data <= udp_send_destination_port[15:8] ;
|
||||
16'd3 : udp_tx_data <= udp_send_destination_port[7:0] ;
|
||||
16'd4 : udp_tx_data <= udp_data_length[15:8] ;
|
||||
16'd5 : udp_tx_data <= udp_data_length[7:0] ;
|
||||
16'd6 : udp_tx_data <= checksum_q[15:8] ;
|
||||
16'd7 : udp_tx_data <= checksum_q[7:0] ;
|
||||
default :
|
||||
begin
|
||||
if (udp_data_length < 26)
|
||||
begin
|
||||
if (udp_send_cnt <= udp_data_length - 1)
|
||||
udp_tx_data <= ram_rdata_d0 ;
|
||||
else
|
||||
udp_tx_data <= 8'h00 ;
|
||||
end
|
||||
else
|
||||
udp_tx_data <= ram_rdata_d0 ;
|
||||
end
|
||||
endcase
|
||||
end
|
||||
else
|
||||
udp_tx_data <= 8'h00 ;
|
||||
end
|
||||
|
||||
|
||||
//*****************************************************************************************//
|
||||
//generate udp checksum
|
||||
//*****************************************************************************************//
|
||||
localparam CK_IDLE = 6'b000001 ;
|
||||
localparam HEADER_CHECKSUM = 6'b000010 ;
|
||||
localparam GEN_CHECKSUM = 6'b000100 ;
|
||||
localparam GEN_ODD_CHECKSUM = 6'b001000 ;
|
||||
localparam GEN_CHECKSUM_END = 6'b010000 ;
|
||||
localparam CHECKSUM_WAIT = 6'b100000 ;
|
||||
|
||||
reg [5:0] ck_state ;
|
||||
reg [5:0] ck_next_state ;
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
ck_state <= IDLE ;
|
||||
else
|
||||
ck_state <= ck_next_state ;
|
||||
end
|
||||
|
||||
always @(*)
|
||||
begin
|
||||
case(ck_state)
|
||||
CK_IDLE :
|
||||
begin
|
||||
if (udp_tx_req)
|
||||
ck_next_state <= HEADER_CHECKSUM ;
|
||||
else
|
||||
ck_next_state <= CK_IDLE ;
|
||||
end
|
||||
HEADER_CHECKSUM :
|
||||
begin
|
||||
if (checksum_cnt == 16'd8)
|
||||
begin
|
||||
if (checksum_udp_len == 16'd9)
|
||||
ck_next_state <= GEN_ODD_CHECKSUM ;
|
||||
else
|
||||
ck_next_state <= GEN_CHECKSUM ;
|
||||
end
|
||||
else
|
||||
ck_next_state <= HEADER_CHECKSUM ;
|
||||
end
|
||||
GEN_CHECKSUM :
|
||||
begin
|
||||
if (checksum_udp_len[0] == 1'b0 && checksum_cnt == checksum_udp_len - 9)
|
||||
ck_next_state <= GEN_CHECKSUM_END ;
|
||||
else if (checksum_udp_len[0] == 1'b1 && checksum_cnt == checksum_udp_len - 10)
|
||||
ck_next_state <= GEN_ODD_CHECKSUM ;
|
||||
else
|
||||
ck_next_state <= GEN_CHECKSUM ;
|
||||
end
|
||||
GEN_ODD_CHECKSUM:
|
||||
begin
|
||||
if (checksum_cnt == checksum_udp_len - 9)
|
||||
ck_next_state <= GEN_CHECKSUM_END ;
|
||||
else
|
||||
ck_next_state <= GEN_ODD_CHECKSUM ;
|
||||
end
|
||||
GEN_CHECKSUM_END :
|
||||
begin
|
||||
if (checksum_finish)
|
||||
ck_next_state <= CHECKSUM_WAIT ;
|
||||
else
|
||||
ck_next_state <= GEN_CHECKSUM_END ;
|
||||
end
|
||||
CHECKSUM_WAIT :
|
||||
begin
|
||||
ck_next_state <= CK_IDLE ;
|
||||
end
|
||||
default :
|
||||
ck_next_state <= CK_IDLE ;
|
||||
endcase
|
||||
end
|
||||
|
||||
|
||||
|
||||
//checksum function
|
||||
function [31:0] checksum_adder
|
||||
(
|
||||
input [31:0] dataina,
|
||||
input [31:0] datainb
|
||||
);
|
||||
|
||||
begin
|
||||
checksum_adder = dataina + datainb;
|
||||
end
|
||||
endfunction
|
||||
|
||||
function [31:0] checksum_out
|
||||
(
|
||||
input [31:0] dataina
|
||||
);
|
||||
|
||||
begin
|
||||
checksum_out = dataina[15:0]+dataina[31:16];
|
||||
end
|
||||
|
||||
endfunction
|
||||
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
begin
|
||||
checksum_tmp0 <= 17'd0 ;
|
||||
checksum_tmp1 <= 17'd0 ;
|
||||
checksum_tmp2 <= 17'd0 ;
|
||||
checksum_tmp3 <= 17'd0 ;
|
||||
checksum_tmp4 <= 17'd0 ;
|
||||
checksum_tmp5 <= 18'd0 ;
|
||||
checksum_tmp6 <= 18'd0 ;
|
||||
checksum_tmp7 <= 19'd0 ;
|
||||
checksum_tmp8 <= 20'd0 ;
|
||||
end
|
||||
else if (ck_state == HEADER_CHECKSUM)
|
||||
begin
|
||||
checksum_tmp0 <= checksum_adder(source_ip_addr[31:16],source_ip_addr[15:0]); //source ip address
|
||||
checksum_tmp1 <= checksum_adder(destination_ip_addr[31:16],destination_ip_addr[15:0]); //destination ip address
|
||||
checksum_tmp2 <= checksum_adder({8'd0,8'd17},checksum_udp_len); //protocol type
|
||||
checksum_tmp3 <= checksum_adder(udp_send_source_port,udp_send_destination_port); //udp data length
|
||||
checksum_tmp4 <= checksum_adder(checksum_udp_len, 16'd0);
|
||||
checksum_tmp5 <= checksum_adder(checksum_tmp0, checksum_tmp1);
|
||||
checksum_tmp6 <= checksum_adder(checksum_tmp2, checksum_tmp3);
|
||||
checksum_tmp7 <= checksum_adder(checksum_tmp5, checksum_tmp6);
|
||||
checksum_tmp8 <= checksum_adder(checksum_tmp4, checksum_tmp7);
|
||||
end
|
||||
else if (ck_state == CK_IDLE)
|
||||
begin
|
||||
checksum_tmp0 <= 17'd0 ;
|
||||
checksum_tmp1 <= 17'd0 ;
|
||||
checksum_tmp2 <= 17'd0 ;
|
||||
checksum_tmp3 <= 17'd0 ;
|
||||
checksum_tmp4 <= 17'd0 ;
|
||||
checksum_tmp5 <= 18'd0 ;
|
||||
checksum_tmp6 <= 18'd0 ;
|
||||
checksum_tmp7 <= 19'd0 ;
|
||||
checksum_tmp8 <= 20'd0 ;
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
checksum_tmp9 <= 32'd0 ;
|
||||
else if (ck_state == GEN_CHECKSUM)
|
||||
begin
|
||||
if(checksum_cnt[0] == 1'b1)
|
||||
checksum_tmp9 <= checksum_adder({ram_wr_data_d1,ram_wr_data_d0},checksum_buf);
|
||||
end
|
||||
else if (ck_state == GEN_ODD_CHECKSUM)
|
||||
checksum_tmp9 <= checksum_adder({ram_wr_data_d0,8'h00},checksum_tmp9); //if udp data length is odd, fill with one byte 8'h00
|
||||
else if (ck_state == CK_IDLE)
|
||||
checksum_tmp9 <= 32'd0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
checksum_buf <= 32'd0 ;
|
||||
else if (ck_state == GEN_CHECKSUM)
|
||||
checksum_buf <= checksum_tmp9 ;
|
||||
else
|
||||
checksum_buf <= 32'd0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
checksum_cnt <= 16'd0 ;
|
||||
else if ((ck_state == HEADER_CHECKSUM || ck_state == GEN_ODD_CHECKSUM || ck_state == GEN_CHECKSUM_END) && (ck_state != ck_next_state))
|
||||
checksum_cnt <= 16'd0 ;
|
||||
else if (ck_state == GEN_CHECKSUM && ck_next_state == GEN_CHECKSUM_END)
|
||||
checksum_cnt <= 16'd0 ;
|
||||
else if (ck_state == HEADER_CHECKSUM || ck_state == GEN_CHECKSUM || ck_state == GEN_ODD_CHECKSUM || ck_state == GEN_CHECKSUM_END)
|
||||
checksum_cnt <= checksum_cnt + 1'b1 ;
|
||||
else
|
||||
checksum_cnt <= 16'd0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
check_out <= 32'd0;
|
||||
else if (ck_state == GEN_CHECKSUM_END)
|
||||
begin
|
||||
if(checksum_cnt == 16'd0)
|
||||
check_out <= checksum_adder(checksum_tmp9, checksum_tmp8);
|
||||
else if (checksum_cnt == 16'd1)
|
||||
check_out <= checksum_out(check_out) ;
|
||||
else if (checksum_cnt == 16'd2)
|
||||
check_out <= checksum_out(check_out) ;
|
||||
end
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
checkout_buf <= 32'd0 ;
|
||||
else if (ck_state == GEN_CHECKSUM_END)
|
||||
checkout_buf <= ~check_out ;
|
||||
end
|
||||
|
||||
// assign checksum = ~checkout_buf[15:0] ;
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
checksum_finish <= 1'b0 ;
|
||||
else if (ck_state == GEN_CHECKSUM_END && checksum_cnt == 16'd4)
|
||||
checksum_finish <= 1'b1 ;
|
||||
else
|
||||
checksum_finish <= 1'b0 ;
|
||||
end
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if(rst_n == 1'b0)
|
||||
udp_ram_data_req <= 1'b0 ;
|
||||
else if (ck_state == HEADER_CHECKSUM && checksum_cnt == 16'd5)
|
||||
udp_ram_data_req <= 1'b1 ;
|
||||
else
|
||||
udp_ram_data_req <= 1'b0 ;
|
||||
end
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
checksum_wr <= 1'b0 ;
|
||||
else if (ck_state == CHECKSUM_WAIT)
|
||||
checksum_wr <= 1'b1 ;
|
||||
else
|
||||
checksum_wr <= 1'b0 ;
|
||||
end
|
||||
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
checksum_udp_len <= 16'd0 ;
|
||||
else if ((ck_state == CK_IDLE) && (ck_state != ck_next_state))
|
||||
checksum_udp_len <= udp_send_data_length + 8 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
checksum_in <= 32'd0 ;
|
||||
else if (ck_state == CHECKSUM_WAIT)
|
||||
checksum_in <= {checksum_udp_len, checkout_buf[15:0] } ;
|
||||
else
|
||||
checksum_in <= 32'd0 ;
|
||||
end
|
||||
|
||||
always @(posedge clk or negedge rst_n)
|
||||
begin
|
||||
if (~rst_n)
|
||||
udp_tx_end <= 1'b0 ;
|
||||
else if (ck_state == CHECKSUM_WAIT)
|
||||
udp_tx_end <= 1'b1 ;
|
||||
else
|
||||
udp_tx_end <= 1'b0 ;
|
||||
end
|
||||
|
||||
udp_checksum_fifo udp_tx_checksum
|
||||
(
|
||||
.clk (clk ), // input wire clk
|
||||
.srst (~rst_n ), // input wire srst
|
||||
.din (checksum_in), // input wire [31 : 0] din
|
||||
.wr_en (checksum_wr), // input wire wr_en
|
||||
.rd_en (checksum_rd), // input wire rd_en
|
||||
.dout (checksum_q ), // output wire [31 : 0] dout
|
||||
.full ( ), // output wire full
|
||||
.empty ( ), // output wire empty
|
||||
.data_count (usedw ) // output wire [3 : 0] data_count
|
||||
);
|
||||
|
||||
endmodule
|
||||
20
rtl/ethernet-udp/src/eth/reset.v
Normal file
20
rtl/ethernet-udp/src/eth/reset.v
Normal file
@ -0,0 +1,20 @@
|
||||
|
||||
module reset(
|
||||
input clk,
|
||||
input key1,
|
||||
output rst_n
|
||||
);
|
||||
reg[27:0] cnt = 28'd0;
|
||||
reg rst_n_reg;
|
||||
assign rst_n = rst_n_reg;
|
||||
always@(posedge clk)
|
||||
if(key1==1'b0)
|
||||
cnt <= 0;
|
||||
else
|
||||
if(cnt != 28'h3ffffff)
|
||||
cnt <= cnt + 1'd1;
|
||||
else
|
||||
cnt <= cnt;
|
||||
always@(posedge clk)
|
||||
rst_n_reg <= (cnt == 28'h3ffffff);
|
||||
endmodule
|
||||
253
rtl/ethernet-udp/src/eth/util_gmii_to_rgmii.v
Normal file
253
rtl/ethernet-udp/src/eth/util_gmii_to_rgmii.v
Normal file
@ -0,0 +1,253 @@
|
||||
module util_gmii_to_rgmii (
|
||||
reset,
|
||||
sys_clk,
|
||||
rgmii_td,
|
||||
rgmii_tx_ctl,
|
||||
rgmii_txc,
|
||||
rgmii_rd,
|
||||
rgmii_rx_ctl,
|
||||
gmii_rx_clk,
|
||||
rgmii_rxc,
|
||||
gmii_txd,
|
||||
gmii_tx_en,
|
||||
gmii_tx_er,
|
||||
gmii_tx_clk,
|
||||
gmii_crs,
|
||||
gmii_col,
|
||||
gmii_rxd,
|
||||
gmii_rx_dv,
|
||||
gmii_rx_er,
|
||||
speed_selection,
|
||||
duplex_mode,
|
||||
rgmii_rx_ctl_idelay
|
||||
);
|
||||
input rgmii_rxc;//add
|
||||
input reset;
|
||||
input sys_clk;
|
||||
output [ 3:0] rgmii_td;
|
||||
output rgmii_tx_ctl;
|
||||
output rgmii_txc;
|
||||
input [ 3:0] rgmii_rd;
|
||||
input rgmii_rx_ctl;
|
||||
output gmii_rx_clk;
|
||||
input [ 7:0] gmii_txd;
|
||||
input gmii_tx_en;
|
||||
input gmii_tx_er;
|
||||
output gmii_tx_clk;
|
||||
output gmii_crs;
|
||||
output gmii_col;
|
||||
output [ 7:0] gmii_rxd;
|
||||
output gmii_rx_dv;
|
||||
output gmii_rx_er;
|
||||
input [ 1:0] speed_selection; // 1x gigabit, 01 100Mbps, 00 10mbps
|
||||
input duplex_mode; // 1 full, 0 half
|
||||
output rgmii_rx_ctl_idelay;
|
||||
|
||||
|
||||
wire gigabit;
|
||||
wire gmii_tx_clk_s;
|
||||
wire gmii_rx_dv_s;
|
||||
|
||||
wire [ 7:0] gmii_rxd_s;
|
||||
wire rgmii_rx_ctl_delay;
|
||||
wire rgmii_rx_ctl_s;
|
||||
// registers
|
||||
reg tx_reset_d1;
|
||||
reg tx_reset_sync;
|
||||
reg rx_reset_d1;
|
||||
reg [ 7:0] gmii_txd_r;
|
||||
reg gmii_tx_en_r;
|
||||
reg gmii_tx_er_r;
|
||||
reg [ 7:0] gmii_txd_r_d1;
|
||||
reg gmii_tx_en_r_d1;
|
||||
reg gmii_tx_er_r_d1;
|
||||
|
||||
reg rgmii_tx_ctl_r;
|
||||
reg [ 3:0] gmii_txd_low;
|
||||
reg gmii_col;
|
||||
reg gmii_crs;
|
||||
|
||||
reg [ 7:0] gmii_rxd;
|
||||
reg gmii_rx_dv;
|
||||
reg gmii_rx_er;
|
||||
wire gmii_rx_clk_s;
|
||||
reg[1:0] speed_selection_d0;
|
||||
reg[1:0] speed_selection_d1;
|
||||
|
||||
wire [3:0] rgmii_rd_idelay;
|
||||
wire [4:0] cntvaluein ;
|
||||
wire [4:0] cntvalueout ;
|
||||
wire ld ;
|
||||
always @(posedge gmii_rx_clk)
|
||||
begin
|
||||
speed_selection_d0<= speed_selection;
|
||||
speed_selection_d1<= speed_selection_d0;
|
||||
end
|
||||
//assign gigabit = speed_selection [1];
|
||||
assign gigabit = 1'b1;
|
||||
assign gmii_tx_clk = gmii_tx_clk_s;
|
||||
assign gmii_tx_clk_s = gmii_rx_clk;
|
||||
// assign gmii_rx_clk =~gmii_rx_clk_s;
|
||||
// assign gmii_rx_clk=speed_selection_d0[1]?gmii_rx_clk_s:gmii_rx_clk_s;
|
||||
// BUFG bufmr_rgmii_rxc(
|
||||
// .I(rgmii_rxc),
|
||||
// .O(gmii_rx_clk)
|
||||
// );
|
||||
assign gmii_rx_clk=rgmii_rxc;
|
||||
always @(posedge gmii_rx_clk)
|
||||
begin
|
||||
gmii_rxd = gmii_rxd_s;
|
||||
gmii_rx_dv = gmii_rx_dv_s;
|
||||
gmii_rx_er = gmii_rx_dv_s ^ rgmii_rx_ctl_s;
|
||||
end
|
||||
|
||||
always @(posedge gmii_tx_clk_s) begin
|
||||
tx_reset_d1 <= reset;
|
||||
tx_reset_sync <= tx_reset_d1;
|
||||
end
|
||||
|
||||
always @(posedge gmii_tx_clk_s)
|
||||
begin
|
||||
rgmii_tx_ctl_r = gmii_tx_en_r ^ gmii_tx_er_r;
|
||||
gmii_txd_low = gigabit ? gmii_txd_r[7:4] : gmii_txd_r[3:0];
|
||||
gmii_col = duplex_mode ? 1'b0 : (gmii_tx_en_r| gmii_tx_er_r) & ( gmii_rx_dv | gmii_rx_er) ;
|
||||
gmii_crs = duplex_mode ? 1'b0 : (gmii_tx_en_r| gmii_tx_er_r| gmii_rx_dv | gmii_rx_er);
|
||||
end
|
||||
|
||||
always @(posedge gmii_tx_clk_s) begin
|
||||
if (tx_reset_sync == 1'b1) begin
|
||||
gmii_txd_r <= 8'h0;
|
||||
gmii_tx_en_r <= 1'b0;
|
||||
gmii_tx_er_r <= 1'b0;
|
||||
end
|
||||
else
|
||||
begin
|
||||
gmii_txd_r <= gmii_txd;
|
||||
gmii_tx_en_r <= gmii_tx_en;
|
||||
gmii_tx_er_r <= gmii_tx_er;
|
||||
gmii_txd_r_d1 <= gmii_txd_r;
|
||||
gmii_tx_en_r_d1 <= gmii_tx_en_r;
|
||||
gmii_tx_er_r_d1 <= gmii_tx_er_r;
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
ODDR #(
|
||||
.DDR_CLK_EDGE("SAME_EDGE")
|
||||
) rgmii_txc_out (
|
||||
.Q (rgmii_txc),
|
||||
.C (gmii_tx_clk_s),
|
||||
.CE(1),
|
||||
.D1(1),
|
||||
.D2(0),
|
||||
.R(tx_reset_sync),
|
||||
.S(0));
|
||||
|
||||
generate
|
||||
genvar i;
|
||||
for (i = 0; i < 4; i = i + 1) begin : gen_tx_data
|
||||
ODDR #(
|
||||
.DDR_CLK_EDGE("SAME_EDGE")
|
||||
) rgmii_td_out (
|
||||
.Q (rgmii_td[i]),
|
||||
.C (gmii_tx_clk_s),
|
||||
.CE(1),
|
||||
.D1(gmii_txd_r_d1[i]),
|
||||
.D2(gmii_txd_low[i]),
|
||||
.R(tx_reset_sync),
|
||||
.S(0));
|
||||
end
|
||||
endgenerate
|
||||
|
||||
ODDR #(
|
||||
.DDR_CLK_EDGE("SAME_EDGE")
|
||||
) rgmii_tx_ctl_out (
|
||||
.Q (rgmii_tx_ctl),
|
||||
.C (gmii_tx_clk_s),
|
||||
.CE(1),
|
||||
.D1(gmii_tx_en_r_d1),
|
||||
.D2(rgmii_tx_ctl_r),
|
||||
.R(tx_reset_sync),
|
||||
.S(0));
|
||||
|
||||
generate
|
||||
for (i = 0; i < 4; i = i + 1) begin
|
||||
|
||||
(* IODELAY_GROUP = "rgmii_idelay_group" *) // Specifies group name for associated IDELAYs/ODELAYs and IDELAYCTRL
|
||||
|
||||
IDELAYE2 #(
|
||||
.CINVCTRL_SEL("FALSE"), // Enable dynamic clock inversion (FALSE, TRUE)
|
||||
.DELAY_SRC("IDATAIN"), // Delay input (IDATAIN, DATAIN)
|
||||
.HIGH_PERFORMANCE_MODE("FALSE"), // Reduced jitter ("TRUE"), Reduced power ("FALSE")
|
||||
.IDELAY_TYPE("FIXED"), // FIXED, VARIABLE, VAR_LOAD, VAR_LOAD_PIPE
|
||||
.IDELAY_VALUE(16), // Input delay tap setting (0-31)
|
||||
.PIPE_SEL("FALSE"), // Select pipelined mode, FALSE, TRUE
|
||||
.REFCLK_FREQUENCY(200.0), // IDELAYCTRL clock input frequency in MHz (190.0-210.0, 290.0-310.0).
|
||||
.SIGNAL_PATTERN("DATA") // DATA, CLOCK input signal
|
||||
)
|
||||
IDELAYE2_inst (
|
||||
.CNTVALUEOUT(), // 5-bit output: Counter value output
|
||||
.DATAOUT(rgmii_rd_idelay[i]), // 1-bit output: Delayed data output
|
||||
.C(gmii_rx_clk), // 1-bit input: Clock input
|
||||
.CE(0), // 1-bit input: Active high enable increment/decrement input
|
||||
.CINVCTRL(0), // 1-bit input: Dynamic clock inversion input
|
||||
.CNTVALUEIN(0), // 5-bit input: Counter value input
|
||||
.DATAIN(0), // 1-bit input: Internal delay data input
|
||||
.IDATAIN(rgmii_rd[i]), // 1-bit input: Data input from the I/O
|
||||
.INC(0), // 1-bit input: Increment / Decrement tap delay input
|
||||
.LD(0), // 1-bit input: Load IDELAY_VALUE input
|
||||
.LDPIPEEN(0), // 1-bit input: Enable PIPELINE register to load data input
|
||||
.REGRST(0) // 1-bit input: Active-high reset tap-delay input
|
||||
);
|
||||
|
||||
IDDR #(
|
||||
.DDR_CLK_EDGE("SAME_EDGE_PIPELINED")
|
||||
) rgmii_rx_iddr (
|
||||
.Q1(gmii_rxd_s[i]),
|
||||
.Q2(gmii_rxd_s[i+4]),
|
||||
.C(gmii_rx_clk),
|
||||
.CE(1),
|
||||
.D(rgmii_rd_idelay[i]),
|
||||
.R(0),
|
||||
.S(0));
|
||||
end
|
||||
endgenerate
|
||||
|
||||
(* IODELAY_GROUP = "rgmii_idelay_group" *) // Specifies group name for associated IDELAYs/ODELAYs and IDELAYCTRL
|
||||
IDELAYE2 #(
|
||||
.CINVCTRL_SEL("FALSE"), // Enable dynamic clock inversion (FALSE, TRUE)
|
||||
.DELAY_SRC("IDATAIN"), // Delay input (IDATAIN, DATAIN)
|
||||
.HIGH_PERFORMANCE_MODE("FALSE"), // Reduced jitter ("TRUE"), Reduced power ("FALSE")
|
||||
.IDELAY_TYPE("FIXED"), // FIXED, VARIABLE, VAR_LOAD, VAR_LOAD_PIPE
|
||||
.IDELAY_VALUE(16), // Input delay tap setting (0-31)
|
||||
.PIPE_SEL("FALSE"), // Select pipelined mode, FALSE, TRUE
|
||||
.REFCLK_FREQUENCY(200.0), // IDELAYCTRL clock input frequency in MHz (190.0-210.0, 290.0-310.0).
|
||||
.SIGNAL_PATTERN("DATA") // DATA, CLOCK input signal
|
||||
)
|
||||
IDELAYE2_ctrl_inst (
|
||||
.CNTVALUEOUT(), // 5-bit output: Counter value output
|
||||
.DATAOUT(rgmii_rx_ctl_idelay), // 1-bit output: Delayed data output
|
||||
.C(gmii_rx_clk), // 1-bit input: Clock input
|
||||
.CE(0), // 1-bit input: Active high enable increment/decrement input
|
||||
.CINVCTRL(0), // 1-bit input: Dynamic clock inversion input
|
||||
.CNTVALUEIN(0), // 5-bit input: Counter value input
|
||||
.DATAIN(0), // 1-bit input: Internal delay data input
|
||||
.IDATAIN(rgmii_rx_ctl), // 1-bit input: Data input from the I/O
|
||||
.INC(0), // 1-bit input: Increment / Decrement tap delay input
|
||||
.LD(0), // 1-bit input: Load IDELAY_VALUE input
|
||||
.LDPIPEEN(0), // 1-bit input: Enable PIPELINE register to load data input
|
||||
.REGRST(0) // 1-bit input: Active-high reset tap-delay input
|
||||
);
|
||||
|
||||
IDDR #(
|
||||
.DDR_CLK_EDGE("SAME_EDGE_PIPELINED")
|
||||
) rgmii_rx_ctl_iddr (
|
||||
.Q1(gmii_rx_dv_s),
|
||||
.Q2(rgmii_rx_ctl_s),
|
||||
.C(gmii_rx_clk),
|
||||
.CE(1),
|
||||
.D(rgmii_rx_ctl_idelay),
|
||||
.R(0),
|
||||
.S(0));
|
||||
|
||||
endmodule
|
||||
461
rtl/ethernet-udp/src/ip/eth_data_fifo/eth_data_fifo.xci
Normal file
461
rtl/ethernet-udp/src/ip/eth_data_fifo/eth_data_fifo.xci
Normal file
@ -0,0 +1,461 @@
|
||||
{
|
||||
"schema": "xilinx.com:schema:json_instance:1.0",
|
||||
"ip_inst": {
|
||||
"xci_name": "eth_data_fifo",
|
||||
"component_reference": "xilinx.com:ip:fifo_generator:13.2",
|
||||
"ip_revision": "13",
|
||||
"gen_directory": "../../../../ethernet_test.gen/sources_1/ip/eth_data_fifo",
|
||||
"parameters": {
|
||||
"component_parameters": {
|
||||
"Component_Name": [ { "value": "eth_data_fifo", "resolve_type": "user", "usage": "all" } ],
|
||||
"Fifo_Implementation": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"synchronization_stages": [ { "value": "2", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"synchronization_stages_axi": [ { "value": "2", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"INTERFACE_TYPE": [ { "value": "Native", "resolve_type": "user", "usage": "all" } ],
|
||||
"Performance_Options": [ { "value": "Standard_FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"asymmetric_port_width": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Data_Width": [ { "value": "8", "value_src": "user", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Input_Depth": [ { "value": "4096", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Output_Data_Width": [ { "value": "8", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Output_Depth": [ { "value": "4096", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Use_Embedded_Registers": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Reset_Pin": [ { "value": "true", "value_src": "user", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Enable_Reset_Synchronization": [ { "value": "true", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Reset_Type": [ { "value": "Asynchronous_Reset", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Full_Flags_Reset_Value": [ { "value": "1", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Use_Dout_Reset": [ { "value": "true", "value_src": "user", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Dout_Reset_Value": [ { "value": "0", "resolve_type": "user", "usage": "all" } ],
|
||||
"dynamic_power_saving": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Almost_Full_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Almost_Empty_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Valid_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Valid_Sense": [ { "value": "Active_High", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Underflow_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Underflow_Sense": [ { "value": "Active_High", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Write_Acknowledge_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Write_Acknowledge_Sense": [ { "value": "Active_High", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Overflow_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Overflow_Sense": [ { "value": "Active_High", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"ecc_pipeline_reg": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Use_Extra_Logic": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Data_Count": [ { "value": "true", "value_src": "user", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Data_Count_Width": [ { "value": "12", "value_src": "user", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Write_Data_Count": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Write_Data_Count_Width": [ { "value": "12", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Read_Data_Count": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Read_Data_Count_Width": [ { "value": "12", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Disable_Timing_Violations": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Read_Clock_Frequency": [ { "value": "1", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Write_Clock_Frequency": [ { "value": "1", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value": [ { "value": "4094", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Negate_Value": [ { "value": "4093", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value": [ { "value": "2", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Negate_Value": [ { "value": "3", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"PROTOCOL": [ { "value": "AXI4", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Clock_Type_AXI": [ { "value": "Common_Clock", "resolve_type": "user", "usage": "all" } ],
|
||||
"HAS_ACLKEN": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Clock_Enable_Type": [ { "value": "Slave_Interface_Clock_Enable", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"READ_WRITE_MODE": [ { "value": "READ_WRITE", "resolve_type": "user", "usage": "all" } ],
|
||||
"ID_WIDTH": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"ADDRESS_WIDTH": [ { "value": "32", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"DATA_WIDTH": [ { "value": "64", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"AWUSER_Width": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"WUSER_Width": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"BUSER_Width": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"ARUSER_Width": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"RUSER_Width": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"TDATA_NUM_BYTES": [ { "value": "1", "resolve_type": "user", "usage": "all" } ],
|
||||
"TID_WIDTH": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"TDEST_WIDTH": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"TUSER_WIDTH": [ { "value": "4", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Enable_TREADY": [ { "value": "true", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Enable_TLAST": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"HAS_TSTRB": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"TSTRB_WIDTH": [ { "value": "1", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"HAS_TKEEP": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"TKEEP_WIDTH": [ { "value": "1", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"wach_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_wach": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_wach": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_wach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_wach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_wach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_wach": [ { "value": "16", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_wach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_wach": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_wach": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_wach": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_wach": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"wdch_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_wdch": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_wdch": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_wdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_wdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_wdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_wdch": [ { "value": "1024", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_wdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_wdch": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_wdch": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_wdch": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_wdch": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"wrch_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_wrch": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_wrch": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_wrch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_wrch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_wrch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_wrch": [ { "value": "16", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_wrch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_wrch": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_wrch": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_wrch": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_wrch": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"rach_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_rach": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_rach": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_rach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_rach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_rach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_rach": [ { "value": "16", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_rach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_rach": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_rach": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_rach": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_rach": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"rdch_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_rdch": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_rdch": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_rdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_rdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_rdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_rdch": [ { "value": "1024", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_rdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_rdch": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_rdch": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_rdch": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_rdch": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"axis_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_axis": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_axis": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_axis": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_axis": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_axis": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_axis": [ { "value": "1024", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_axis": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_axis": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_axis": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_axis": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_axis": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Register_Slice_Mode_wach": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_Slice_Mode_wdch": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_Slice_Mode_wrch": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_Slice_Mode_rach": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_Slice_Mode_rdch": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_Slice_Mode_axis": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Underflow_Flag_AXI": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Underflow_Sense_AXI": [ { "value": "Active_High", "resolve_type": "user", "usage": "all" } ],
|
||||
"Overflow_Flag_AXI": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Overflow_Sense_AXI": [ { "value": "Active_High", "resolve_type": "user", "usage": "all" } ],
|
||||
"Disable_Timing_Violations_AXI": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Add_NGC_Constraint_AXI": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Enable_Common_Underflow": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Enable_Common_Overflow": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"enable_read_pointer_increment_by2": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Use_Embedded_Registers_axis": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"enable_low_latency": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"use_dout_register": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Master_interface_Clock_enable_memory_mapped": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Slave_interface_Clock_enable_memory_mapped": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Output_Register_Type": [ { "value": "Embedded_Reg", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_Safety_Circuit": [ { "value": "false", "value_src": "user", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Enable_ECC_Type": [ { "value": "Hard_ECC", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"C_SELECT_XPM": [ { "value": "0", "resolve_type": "user", "format": "long", "usage": "all" } ]
|
||||
},
|
||||
"model_parameters": {
|
||||
"C_COMMON_CLOCK": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_SELECT_XPM": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_COUNT_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DATA_COUNT_WIDTH": [ { "value": "12", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DEFAULT_VALUE": [ { "value": "BlankString", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_DIN_WIDTH": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DOUT_RST_VAL": [ { "value": "0", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_DOUT_WIDTH": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ENABLE_RLOCS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_FAMILY": [ { "value": "artix7", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_FULL_FLAGS_RST_VAL": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_ALMOST_EMPTY": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_ALMOST_FULL": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_BACKUP": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNT": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_INT_CLK": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_MEMINIT_FILE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_OVERFLOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_RD_DATA_COUNT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_RD_RST": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_RST": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_SRST": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_UNDERFLOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_VALID": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_WR_ACK": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_WR_DATA_COUNT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_WR_RST": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_INIT_WR_PNTR_VAL": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_MEMORY_TYPE": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_MIF_FILE_NAME": [ { "value": "BlankString", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_OPTIMIZATION_MODE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_OVERFLOW_LOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PRELOAD_LATENCY": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PRELOAD_REGS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE": [ { "value": "4kx9", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL": [ { "value": "2", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_NEGATE_VAL": [ { "value": "3", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL": [ { "value": "4094", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_NEGATE_VAL": [ { "value": "4093", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RD_DATA_COUNT_WIDTH": [ { "value": "12", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RD_DEPTH": [ { "value": "4096", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RD_FREQ": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RD_PNTR_WIDTH": [ { "value": "12", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_UNDERFLOW_LOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_DOUT_RST": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_EMBEDDED_REG": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_PIPELINE_REG": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_POWER_SAVING_MODE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_FIFO16_FLAGS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_FWFT_DATA_COUNT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_VALID_LOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_ACK_LOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DATA_COUNT_WIDTH": [ { "value": "12", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH": [ { "value": "4096", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_FREQ": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH": [ { "value": "12", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_RESPONSE_LATENCY": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_MSGON_VAL": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ENABLE_RST_SYNC": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_EN_SAFETY_CKT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_SYNCHRONIZER_STAGE": [ { "value": "2", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_INTERFACE_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_TYPE": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_WR_CHANNEL": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_RD_CHANNEL": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_SLAVE_CE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_MASTER_CE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ADD_NGC_CONSTRAINT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_COMMON_OVERFLOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_COMMON_UNDERFLOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_DEFAULT_SETTINGS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_ID_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_ADDR_WIDTH": [ { "value": "32", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_DATA_WIDTH": [ { "value": "64", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_LEN_WIDTH": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_LOCK_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_ID": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_AWUSER": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_WUSER": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_BUSER": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_ARUSER": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_RUSER": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_ARUSER_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_AWUSER_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_WUSER_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_BUSER_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_RUSER_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TDATA": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TID": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TDEST": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TUSER": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TREADY": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TLAST": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TSTRB": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TKEEP": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TDATA_WIDTH": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TID_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TDEST_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TUSER_WIDTH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TSTRB_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TKEEP_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WACH_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WDCH_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WRCH_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RACH_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RDCH_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_WACH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_WDCH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_WRCH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_RACH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_RDCH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_AXIS": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_WACH": [ { "value": "512x36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_WDCH": [ { "value": "1kx36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_WRCH": [ { "value": "512x36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_RACH": [ { "value": "512x36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_RDCH": [ { "value": "1kx36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_AXIS": [ { "value": "1kx18", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_USE_ECC_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_WACH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_WDCH": [ { "value": "64", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_WRCH": [ { "value": "2", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_RACH": [ { "value": "32", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_RDCH": [ { "value": "64", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_AXIS": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_WACH": [ { "value": "16", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_WDCH": [ { "value": "1024", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_WRCH": [ { "value": "16", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_RACH": [ { "value": "16", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_RDCH": [ { "value": "1024", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_AXIS": [ { "value": "1024", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_WACH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_WDCH": [ { "value": "10", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_WRCH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_RACH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_RDCH": [ { "value": "10", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_AXIS": [ { "value": "10", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_WACH": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_WDCH": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_WRCH": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_RACH": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_RDCH": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_AXIS": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_WACH": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_WDCH": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_WRCH": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_RACH": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_RDCH": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_AXIS": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ]
|
||||
},
|
||||
"project_parameters": {
|
||||
"ARCHITECTURE": [ { "value": "artix7" } ],
|
||||
"BASE_BOARD_PART": [ { "value": "" } ],
|
||||
"BOARD_CONNECTIONS": [ { "value": "" } ],
|
||||
"DEVICE": [ { "value": "xc7a35t" } ],
|
||||
"PACKAGE": [ { "value": "fgg484" } ],
|
||||
"PREFHDL": [ { "value": "VERILOG" } ],
|
||||
"SILICON_REVISION": [ { "value": "" } ],
|
||||
"SIMULATOR_LANGUAGE": [ { "value": "MIXED" } ],
|
||||
"SPEEDGRADE": [ { "value": "-1" } ],
|
||||
"STATIC_POWER": [ { "value": "" } ],
|
||||
"TEMPERATURE_GRADE": [ { "value": "" } ]
|
||||
},
|
||||
"runtime_parameters": {
|
||||
"IPCONTEXT": [ { "value": "IP_Flow" } ],
|
||||
"IPREVISION": [ { "value": "13" } ],
|
||||
"MANAGED": [ { "value": "TRUE" } ],
|
||||
"OUTPUTDIR": [ { "value": "../../../../ethernet_test.gen/sources_1/ip/eth_data_fifo" } ],
|
||||
"SELECTEDSIMMODEL": [ { "value": "" } ],
|
||||
"SHAREDDIR": [ { "value": "." } ],
|
||||
"SWVERSION": [ { "value": "2025.1" } ],
|
||||
"SYNTHESISFLOW": [ { "value": "OUT_OF_CONTEXT" } ]
|
||||
}
|
||||
},
|
||||
"boundary": {
|
||||
"ports": {
|
||||
"clk": [ { "direction": "in", "driver_value": "0" } ],
|
||||
"rst": [ { "direction": "in", "driver_value": "0" } ],
|
||||
"din": [ { "direction": "in", "size_left": "7", "size_right": "0", "driver_value": "0" } ],
|
||||
"wr_en": [ { "direction": "in", "driver_value": "0" } ],
|
||||
"rd_en": [ { "direction": "in", "driver_value": "0" } ],
|
||||
"dout": [ { "direction": "out", "size_left": "7", "size_right": "0", "driver_value": "0" } ],
|
||||
"full": [ { "direction": "out", "driver_value": "0x0" } ],
|
||||
"empty": [ { "direction": "out", "driver_value": "0x1" } ],
|
||||
"data_count": [ { "direction": "out", "size_left": "11", "size_right": "0", "driver_value": "0" } ]
|
||||
},
|
||||
"interfaces": {
|
||||
"core_clk": {
|
||||
"vlnv": "xilinx.com:signal:clock:1.0",
|
||||
"abstraction_type": "xilinx.com:signal:clock_rtl:1.0",
|
||||
"mode": "slave",
|
||||
"parameters": {
|
||||
"FREQ_HZ": [ { "value": "100000000", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"FREQ_TOLERANCE_HZ": [ { "value": "0", "resolve_type": "generated", "format": "long", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"PHASE": [ { "value": "0.0", "resolve_type": "generated", "format": "float", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"CLK_DOMAIN": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"ASSOCIATED_BUSIF": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"ASSOCIATED_PORT": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"ASSOCIATED_RESET": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"INSERT_VIP": [ { "value": "0", "resolve_type": "user", "format": "long", "usage": "simulation.rtl", "is_ips_inferred": true, "is_static_object": false } ]
|
||||
},
|
||||
"port_maps": {
|
||||
"CLK": [ { "physical_name": "clk" } ]
|
||||
}
|
||||
},
|
||||
"FIFO_WRITE": {
|
||||
"vlnv": "xilinx.com:interface:fifo_write:1.0",
|
||||
"abstraction_type": "xilinx.com:interface:fifo_write_rtl:1.0",
|
||||
"mode": "slave",
|
||||
"port_maps": {
|
||||
"FULL": [ { "physical_name": "full" } ],
|
||||
"WR_DATA": [ { "physical_name": "din" } ],
|
||||
"WR_EN": [ { "physical_name": "wr_en" } ]
|
||||
}
|
||||
},
|
||||
"FIFO_READ": {
|
||||
"vlnv": "xilinx.com:interface:fifo_read:1.0",
|
||||
"abstraction_type": "xilinx.com:interface:fifo_read_rtl:1.0",
|
||||
"mode": "slave",
|
||||
"port_maps": {
|
||||
"EMPTY": [ { "physical_name": "empty" } ],
|
||||
"RD_DATA": [ { "physical_name": "dout" } ],
|
||||
"RD_EN": [ { "physical_name": "rd_en" } ]
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
277
rtl/ethernet-udp/src/ip/icmp_rx_ram_8_256/icmp_rx_ram_8_256.xci
Normal file
277
rtl/ethernet-udp/src/ip/icmp_rx_ram_8_256/icmp_rx_ram_8_256.xci
Normal file
@ -0,0 +1,277 @@
|
||||
{
|
||||
"schema": "xilinx.com:schema:json_instance:1.0",
|
||||
"ip_inst": {
|
||||
"xci_name": "icmp_rx_ram_8_256",
|
||||
"component_reference": "xilinx.com:ip:blk_mem_gen:8.4",
|
||||
"ip_revision": "11",
|
||||
"gen_directory": "../../../../ethernet_test.gen/sources_1/ip/icmp_rx_ram_8_256",
|
||||
"parameters": {
|
||||
"component_parameters": {
|
||||
"Component_Name": [ { "value": "icmp_rx_ram_8_256", "resolve_type": "user", "usage": "all" } ],
|
||||
"Interface_Type": [ { "value": "Native", "resolve_type": "user", "usage": "all" } ],
|
||||
"AXI_Type": [ { "value": "AXI4_Full", "resolve_type": "user", "usage": "all" } ],
|
||||
"AXI_Slave_Type": [ { "value": "Memory_Slave", "resolve_type": "user", "usage": "all" } ],
|
||||
"Use_AXI_ID": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"AXI_ID_Width": [ { "value": "4", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Memory_Type": [ { "value": "Simple_Dual_Port_RAM", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"PRIM_type_to_Implement": [ { "value": "BRAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_32bit_Address": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"ecctype": [ { "value": "No_ECC", "resolve_type": "user", "usage": "all" } ],
|
||||
"ECC": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"softecc": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"EN_SLEEP_PIN": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"EN_DEEPSLEEP_PIN": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"EN_SHUTDOWN_PIN": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"EN_ECC_PIPE": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"RD_ADDR_CHNG_A": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"RD_ADDR_CHNG_B": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Use_Error_Injection_Pins": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Error_Injection_Type": [ { "value": "Single_Bit_Error_Injection", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Use_Byte_Write_Enable": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Byte_Size": [ { "value": "9", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Algorithm": [ { "value": "Minimum_Area", "resolve_type": "user", "usage": "all" } ],
|
||||
"Primitive": [ { "value": "8kx2", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Assume_Synchronous_Clk": [ { "value": "true", "value_src": "user", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Write_Width_A": [ { "value": "8", "value_src": "user", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Write_Depth_A": [ { "value": "256", "value_src": "user", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Read_Width_A": [ { "value": "8", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Operating_Mode_A": [ { "value": "NO_CHANGE", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_A": [ { "value": "Always_Enabled", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Write_Width_B": [ { "value": "8", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Read_Width_B": [ { "value": "8", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Operating_Mode_B": [ { "value": "READ_FIRST", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_B": [ { "value": "Always_Enabled", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_PortA_Output_of_Memory_Primitives": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Register_PortA_Output_of_Memory_Core": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Use_REGCEA_Pin": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Register_PortB_Output_of_Memory_Primitives": [ { "value": "false", "value_src": "user", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Register_PortB_Output_of_Memory_Core": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Use_REGCEB_Pin": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"register_porta_input_of_softecc": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"register_portb_output_of_softecc": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Pipeline_Stages": [ { "value": "0", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Load_Init_File": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Coe_File": [ { "value": "no_coe_file_loaded", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Fill_Remaining_Memory_Locations": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Remaining_Memory_Locations": [ { "value": "0", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Use_RSTA_Pin": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Reset_Memory_Latch_A": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Reset_Priority_A": [ { "value": "CE", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Output_Reset_Value_A": [ { "value": "0", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Use_RSTB_Pin": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Reset_Memory_Latch_B": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Reset_Priority_B": [ { "value": "CE", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Output_Reset_Value_B": [ { "value": "0", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Reset_Type": [ { "value": "SYNC", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Additional_Inputs_for_Power_Estimation": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Port_A_Clock": [ { "value": "100", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Port_A_Write_Rate": [ { "value": "50", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Port_B_Clock": [ { "value": "100", "value_src": "user", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Port_B_Write_Rate": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Port_A_Enable_Rate": [ { "value": "100", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Port_B_Enable_Rate": [ { "value": "100", "value_src": "user", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Collision_Warnings": [ { "value": "ALL", "resolve_type": "user", "usage": "all" } ],
|
||||
"Disable_Collision_Warnings": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Disable_Out_of_Range_Warnings": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"use_bram_block": [ { "value": "Stand_Alone", "resolve_type": "user", "usage": "all" } ],
|
||||
"MEM_FILE": [ { "value": "no_mem_loaded", "resolve_type": "user", "usage": "all" } ],
|
||||
"CTRL_ECC_ALGO": [ { "value": "NONE", "resolve_type": "user", "usage": "all" } ],
|
||||
"EN_SAFETY_CKT": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"READ_LATENCY_A": [ { "value": "1", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"READ_LATENCY_B": [ { "value": "1", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ]
|
||||
},
|
||||
"model_parameters": {
|
||||
"C_FAMILY": [ { "value": "artix7", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_XDEVICEFAMILY": [ { "value": "artix7", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_ELABORATION_DIR": [ { "value": "./", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_INTERFACE_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_TYPE": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_SLAVE_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_BRAM_BLOCK": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ENABLE_32BIT_ADDRESS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_CTRL_ECC_ALGO": [ { "value": "NONE", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_HAS_AXI_ID": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_ID_WIDTH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_MEM_TYPE": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_BYTE_SIZE": [ { "value": "9", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ALGORITHM": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PRIM_TYPE": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_LOAD_INIT_FILE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_INIT_FILE_NAME": [ { "value": "no_coe_file_loaded", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_INIT_FILE": [ { "value": "icmp_rx_ram_8_256.mem", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_USE_DEFAULT_DATA": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DEFAULT_DATA": [ { "value": "0", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_HAS_RSTA": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RST_PRIORITY_A": [ { "value": "CE", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_RSTRAM_A": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_INITA_VAL": [ { "value": "0", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_HAS_ENA": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_REGCEA": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_BYTE_WEA": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WEA_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WRITE_MODE_A": [ { "value": "NO_CHANGE", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_WRITE_WIDTH_A": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_READ_WIDTH_A": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WRITE_DEPTH_A": [ { "value": "256", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_READ_DEPTH_A": [ { "value": "256", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ADDRA_WIDTH": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_RSTB": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RST_PRIORITY_B": [ { "value": "CE", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_RSTRAM_B": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_INITB_VAL": [ { "value": "0", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_HAS_ENB": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_REGCEB": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_BYTE_WEB": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WEB_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WRITE_MODE_B": [ { "value": "READ_FIRST", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_WRITE_WIDTH_B": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_READ_WIDTH_B": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WRITE_DEPTH_B": [ { "value": "256", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_READ_DEPTH_B": [ { "value": "256", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ADDRB_WIDTH": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_MEM_OUTPUT_REGS_A": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_MEM_OUTPUT_REGS_B": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_MUX_OUTPUT_REGS_A": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_MUX_OUTPUT_REGS_B": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_MUX_PIPELINE_STAGES": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_SOFTECC_INPUT_REGS_A": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_SOFTECC_OUTPUT_REGS_B": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_SOFTECC": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_EN_ECC_PIPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_READ_LATENCY_A": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_READ_LATENCY_B": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_INJECTERR": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_SIM_COLLISION_CHECK": [ { "value": "ALL", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_COMMON_CLK": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DISABLE_WARN_BHV_COLL": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_EN_SLEEP_PIN": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_URAM": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_EN_RDADDRA_CHG": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_EN_RDADDRB_CHG": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_EN_DEEPSLEEP_PIN": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_EN_SHUTDOWN_PIN": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_EN_SAFETY_CKT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DISABLE_WARN_BHV_RANGE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_COUNT_36K_BRAM": [ { "value": "0", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_COUNT_18K_BRAM": [ { "value": "1", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_EST_POWER_SUMMARY": [ { "value": "Estimated Power for IP : 2.68455 mW", "resolve_type": "generated", "usage": "all" } ]
|
||||
},
|
||||
"project_parameters": {
|
||||
"ARCHITECTURE": [ { "value": "artix7" } ],
|
||||
"BASE_BOARD_PART": [ { "value": "" } ],
|
||||
"BOARD_CONNECTIONS": [ { "value": "" } ],
|
||||
"DEVICE": [ { "value": "xc7a35t" } ],
|
||||
"PACKAGE": [ { "value": "fgg484" } ],
|
||||
"PREFHDL": [ { "value": "VERILOG" } ],
|
||||
"SILICON_REVISION": [ { "value": "" } ],
|
||||
"SIMULATOR_LANGUAGE": [ { "value": "MIXED" } ],
|
||||
"SPEEDGRADE": [ { "value": "-1" } ],
|
||||
"STATIC_POWER": [ { "value": "" } ],
|
||||
"TEMPERATURE_GRADE": [ { "value": "" } ]
|
||||
},
|
||||
"runtime_parameters": {
|
||||
"IPCONTEXT": [ { "value": "IP_Flow" } ],
|
||||
"IPREVISION": [ { "value": "11" } ],
|
||||
"MANAGED": [ { "value": "TRUE" } ],
|
||||
"OUTPUTDIR": [ { "value": "../../../../ethernet_test.gen/sources_1/ip/icmp_rx_ram_8_256" } ],
|
||||
"SELECTEDSIMMODEL": [ { "value": "" } ],
|
||||
"SHAREDDIR": [ { "value": "." } ],
|
||||
"SWVERSION": [ { "value": "2025.1" } ],
|
||||
"SYNTHESISFLOW": [ { "value": "OUT_OF_CONTEXT" } ]
|
||||
}
|
||||
},
|
||||
"boundary": {
|
||||
"ports": {
|
||||
"clka": [ { "direction": "in", "driver_value": "0" } ],
|
||||
"wea": [ { "direction": "in", "size_left": "0", "size_right": "0", "driver_value": "0" } ],
|
||||
"addra": [ { "direction": "in", "size_left": "7", "size_right": "0", "driver_value": "0" } ],
|
||||
"dina": [ { "direction": "in", "size_left": "7", "size_right": "0", "driver_value": "0" } ],
|
||||
"clkb": [ { "direction": "in", "driver_value": "0" } ],
|
||||
"addrb": [ { "direction": "in", "size_left": "7", "size_right": "0", "driver_value": "0" } ],
|
||||
"doutb": [ { "direction": "out", "size_left": "7", "size_right": "0" } ]
|
||||
},
|
||||
"interfaces": {
|
||||
"CLK.ACLK": {
|
||||
"vlnv": "xilinx.com:signal:clock:1.0",
|
||||
"abstraction_type": "xilinx.com:signal:clock_rtl:1.0",
|
||||
"mode": "slave",
|
||||
"parameters": {
|
||||
"ASSOCIATED_BUSIF": [ { "value": "AXI_SLAVE_S_AXI:AXILite_SLAVE_S_AXI", "value_src": "constant", "usage": "all" } ],
|
||||
"ASSOCIATED_RESET": [ { "value": "s_aresetn", "value_src": "constant", "usage": "all" } ],
|
||||
"FREQ_HZ": [ { "value": "100000000", "resolve_type": "generated", "format": "long", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"FREQ_TOLERANCE_HZ": [ { "value": "0", "resolve_type": "generated", "format": "long", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"PHASE": [ { "value": "0.0", "resolve_type": "generated", "format": "float", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"CLK_DOMAIN": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"ASSOCIATED_PORT": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"INSERT_VIP": [ { "value": "0", "resolve_type": "user", "format": "long", "usage": "simulation.rtl", "is_ips_inferred": true, "is_static_object": false } ]
|
||||
}
|
||||
},
|
||||
"RST.ARESETN": {
|
||||
"vlnv": "xilinx.com:signal:reset:1.0",
|
||||
"abstraction_type": "xilinx.com:signal:reset_rtl:1.0",
|
||||
"mode": "slave",
|
||||
"parameters": {
|
||||
"POLARITY": [ { "value": "ACTIVE_LOW", "value_src": "constant", "usage": "all" } ],
|
||||
"INSERT_VIP": [ { "value": "0", "resolve_type": "user", "format": "long", "usage": "simulation.rtl", "is_ips_inferred": true, "is_static_object": false } ]
|
||||
}
|
||||
},
|
||||
"BRAM_PORTA": {
|
||||
"vlnv": "xilinx.com:interface:bram:1.0",
|
||||
"abstraction_type": "xilinx.com:interface:bram_rtl:1.0",
|
||||
"mode": "slave",
|
||||
"parameters": {
|
||||
"MEM_ADDRESS_MODE": [ { "value": "BYTE_ADDRESS", "resolve_type": "user", "usage": "all" } ],
|
||||
"MEM_SIZE": [ { "value": "8192", "resolve_type": "generated", "format": "long", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"MEM_WIDTH": [ { "value": "32", "resolve_type": "generated", "format": "long", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"MEM_ECC": [ { "value": "NONE", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"MASTER_TYPE": [ { "value": "OTHER", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"READ_WRITE_MODE": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"READ_LATENCY": [ { "value": "1", "resolve_type": "generated", "format": "long", "is_ips_inferred": true, "is_static_object": false } ]
|
||||
},
|
||||
"port_maps": {
|
||||
"ADDR": [ { "physical_name": "addra" } ],
|
||||
"CLK": [ { "physical_name": "clka" } ],
|
||||
"DIN": [ { "physical_name": "dina" } ],
|
||||
"WE": [ { "physical_name": "wea" } ]
|
||||
}
|
||||
},
|
||||
"BRAM_PORTB": {
|
||||
"vlnv": "xilinx.com:interface:bram:1.0",
|
||||
"abstraction_type": "xilinx.com:interface:bram_rtl:1.0",
|
||||
"mode": "slave",
|
||||
"parameters": {
|
||||
"MEM_ADDRESS_MODE": [ { "value": "BYTE_ADDRESS", "resolve_type": "user", "usage": "all" } ],
|
||||
"MEM_SIZE": [ { "value": "8192", "resolve_type": "generated", "format": "long", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"MEM_WIDTH": [ { "value": "32", "resolve_type": "generated", "format": "long", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"MEM_ECC": [ { "value": "NONE", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"MASTER_TYPE": [ { "value": "OTHER", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"READ_WRITE_MODE": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"READ_LATENCY": [ { "value": "1", "resolve_type": "generated", "format": "long", "is_ips_inferred": true, "is_static_object": false } ]
|
||||
},
|
||||
"port_maps": {
|
||||
"ADDR": [ { "physical_name": "addrb" } ],
|
||||
"CLK": [ { "physical_name": "clkb" } ],
|
||||
"DOUT": [ { "physical_name": "doutb" } ]
|
||||
}
|
||||
}
|
||||
},
|
||||
"memory_maps": {
|
||||
"S_1": {
|
||||
"address_blocks": {
|
||||
"Mem0": {
|
||||
"base_address": "0",
|
||||
"range": "4096",
|
||||
"usage": "memory",
|
||||
"access": "read-write",
|
||||
"parameters": {
|
||||
"OFFSET_BASE_PARAM": [ { "value": "C_BASEADDR" } ],
|
||||
"OFFSET_HIGH_PARAM": [ { "value": "C_HIGHADDR" } ]
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
461
rtl/ethernet-udp/src/ip/len_fifo/len_fifo.xci
Normal file
461
rtl/ethernet-udp/src/ip/len_fifo/len_fifo.xci
Normal file
@ -0,0 +1,461 @@
|
||||
{
|
||||
"schema": "xilinx.com:schema:json_instance:1.0",
|
||||
"ip_inst": {
|
||||
"xci_name": "len_fifo",
|
||||
"component_reference": "xilinx.com:ip:fifo_generator:13.2",
|
||||
"ip_revision": "13",
|
||||
"gen_directory": "../../../../ethernet_test.gen/sources_1/ip/len_fifo",
|
||||
"parameters": {
|
||||
"component_parameters": {
|
||||
"Component_Name": [ { "value": "len_fifo", "resolve_type": "user", "usage": "all" } ],
|
||||
"Fifo_Implementation": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"synchronization_stages": [ { "value": "2", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"synchronization_stages_axi": [ { "value": "2", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"INTERFACE_TYPE": [ { "value": "Native", "resolve_type": "user", "usage": "all" } ],
|
||||
"Performance_Options": [ { "value": "Standard_FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"asymmetric_port_width": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Data_Width": [ { "value": "16", "value_src": "user", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Input_Depth": [ { "value": "32", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Output_Data_Width": [ { "value": "16", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Output_Depth": [ { "value": "32", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Use_Embedded_Registers": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Reset_Pin": [ { "value": "true", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Enable_Reset_Synchronization": [ { "value": "true", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Reset_Type": [ { "value": "Asynchronous_Reset", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Full_Flags_Reset_Value": [ { "value": "1", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Use_Dout_Reset": [ { "value": "true", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Dout_Reset_Value": [ { "value": "0", "resolve_type": "user", "usage": "all" } ],
|
||||
"dynamic_power_saving": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Almost_Full_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Almost_Empty_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Valid_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Valid_Sense": [ { "value": "Active_High", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Underflow_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Underflow_Sense": [ { "value": "Active_High", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Write_Acknowledge_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Write_Acknowledge_Sense": [ { "value": "Active_High", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Overflow_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Overflow_Sense": [ { "value": "Active_High", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"ecc_pipeline_reg": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Use_Extra_Logic": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Data_Count": [ { "value": "true", "value_src": "user", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Data_Count_Width": [ { "value": "5", "value_src": "user", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Write_Data_Count": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Write_Data_Count_Width": [ { "value": "5", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Read_Data_Count": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Read_Data_Count_Width": [ { "value": "5", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Disable_Timing_Violations": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Read_Clock_Frequency": [ { "value": "1", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Write_Clock_Frequency": [ { "value": "1", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value": [ { "value": "30", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Negate_Value": [ { "value": "29", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value": [ { "value": "2", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Negate_Value": [ { "value": "3", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"PROTOCOL": [ { "value": "AXI4", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Clock_Type_AXI": [ { "value": "Common_Clock", "resolve_type": "user", "usage": "all" } ],
|
||||
"HAS_ACLKEN": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Clock_Enable_Type": [ { "value": "Slave_Interface_Clock_Enable", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"READ_WRITE_MODE": [ { "value": "READ_WRITE", "resolve_type": "user", "usage": "all" } ],
|
||||
"ID_WIDTH": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"ADDRESS_WIDTH": [ { "value": "32", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"DATA_WIDTH": [ { "value": "64", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"AWUSER_Width": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"WUSER_Width": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"BUSER_Width": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"ARUSER_Width": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"RUSER_Width": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"TDATA_NUM_BYTES": [ { "value": "1", "resolve_type": "user", "usage": "all" } ],
|
||||
"TID_WIDTH": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"TDEST_WIDTH": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"TUSER_WIDTH": [ { "value": "4", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Enable_TREADY": [ { "value": "true", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Enable_TLAST": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"HAS_TSTRB": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"TSTRB_WIDTH": [ { "value": "1", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"HAS_TKEEP": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"TKEEP_WIDTH": [ { "value": "1", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"wach_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_wach": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_wach": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_wach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_wach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_wach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_wach": [ { "value": "16", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_wach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_wach": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_wach": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_wach": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_wach": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"wdch_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_wdch": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_wdch": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_wdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_wdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_wdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_wdch": [ { "value": "1024", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_wdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_wdch": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_wdch": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_wdch": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_wdch": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"wrch_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_wrch": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_wrch": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_wrch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_wrch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_wrch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_wrch": [ { "value": "16", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_wrch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_wrch": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_wrch": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_wrch": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_wrch": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"rach_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_rach": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_rach": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_rach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_rach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_rach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_rach": [ { "value": "16", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_rach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_rach": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_rach": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_rach": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_rach": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"rdch_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_rdch": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_rdch": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_rdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_rdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_rdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_rdch": [ { "value": "1024", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_rdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_rdch": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_rdch": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_rdch": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_rdch": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"axis_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_axis": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_axis": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_axis": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_axis": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_axis": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_axis": [ { "value": "1024", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_axis": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_axis": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_axis": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_axis": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_axis": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Register_Slice_Mode_wach": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_Slice_Mode_wdch": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_Slice_Mode_wrch": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_Slice_Mode_rach": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_Slice_Mode_rdch": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_Slice_Mode_axis": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Underflow_Flag_AXI": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Underflow_Sense_AXI": [ { "value": "Active_High", "resolve_type": "user", "usage": "all" } ],
|
||||
"Overflow_Flag_AXI": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Overflow_Sense_AXI": [ { "value": "Active_High", "resolve_type": "user", "usage": "all" } ],
|
||||
"Disable_Timing_Violations_AXI": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Add_NGC_Constraint_AXI": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Enable_Common_Underflow": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Enable_Common_Overflow": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"enable_read_pointer_increment_by2": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Use_Embedded_Registers_axis": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"enable_low_latency": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"use_dout_register": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Master_interface_Clock_enable_memory_mapped": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Slave_interface_Clock_enable_memory_mapped": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Output_Register_Type": [ { "value": "Embedded_Reg", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_Safety_Circuit": [ { "value": "false", "value_src": "user", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Enable_ECC_Type": [ { "value": "Hard_ECC", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"C_SELECT_XPM": [ { "value": "0", "resolve_type": "user", "format": "long", "usage": "all" } ]
|
||||
},
|
||||
"model_parameters": {
|
||||
"C_COMMON_CLOCK": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_SELECT_XPM": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_COUNT_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DATA_COUNT_WIDTH": [ { "value": "5", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DEFAULT_VALUE": [ { "value": "BlankString", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_DIN_WIDTH": [ { "value": "16", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DOUT_RST_VAL": [ { "value": "0", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_DOUT_WIDTH": [ { "value": "16", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ENABLE_RLOCS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_FAMILY": [ { "value": "artix7", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_FULL_FLAGS_RST_VAL": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_ALMOST_EMPTY": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_ALMOST_FULL": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_BACKUP": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNT": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_INT_CLK": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_MEMINIT_FILE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_OVERFLOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_RD_DATA_COUNT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_RD_RST": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_RST": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_SRST": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_UNDERFLOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_VALID": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_WR_ACK": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_WR_DATA_COUNT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_WR_RST": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_INIT_WR_PNTR_VAL": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_MEMORY_TYPE": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_MIF_FILE_NAME": [ { "value": "BlankString", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_OPTIMIZATION_MODE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_OVERFLOW_LOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PRELOAD_LATENCY": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PRELOAD_REGS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE": [ { "value": "512x36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL": [ { "value": "2", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_NEGATE_VAL": [ { "value": "3", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL": [ { "value": "30", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_NEGATE_VAL": [ { "value": "29", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RD_DATA_COUNT_WIDTH": [ { "value": "5", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RD_DEPTH": [ { "value": "32", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RD_FREQ": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RD_PNTR_WIDTH": [ { "value": "5", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_UNDERFLOW_LOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_DOUT_RST": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_EMBEDDED_REG": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_PIPELINE_REG": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_POWER_SAVING_MODE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_FIFO16_FLAGS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_FWFT_DATA_COUNT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_VALID_LOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_ACK_LOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DATA_COUNT_WIDTH": [ { "value": "5", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH": [ { "value": "32", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_FREQ": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH": [ { "value": "5", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_RESPONSE_LATENCY": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_MSGON_VAL": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ENABLE_RST_SYNC": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_EN_SAFETY_CKT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_SYNCHRONIZER_STAGE": [ { "value": "2", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_INTERFACE_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_TYPE": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_WR_CHANNEL": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_RD_CHANNEL": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_SLAVE_CE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_MASTER_CE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ADD_NGC_CONSTRAINT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_COMMON_OVERFLOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_COMMON_UNDERFLOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_DEFAULT_SETTINGS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_ID_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_ADDR_WIDTH": [ { "value": "32", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_DATA_WIDTH": [ { "value": "64", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_LEN_WIDTH": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_LOCK_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_ID": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_AWUSER": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_WUSER": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_BUSER": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_ARUSER": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_RUSER": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_ARUSER_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_AWUSER_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_WUSER_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_BUSER_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_RUSER_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TDATA": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TID": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TDEST": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TUSER": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TREADY": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TLAST": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TSTRB": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TKEEP": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TDATA_WIDTH": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TID_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TDEST_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TUSER_WIDTH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TSTRB_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TKEEP_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WACH_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WDCH_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WRCH_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RACH_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RDCH_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_WACH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_WDCH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_WRCH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_RACH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_RDCH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_AXIS": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_WACH": [ { "value": "512x36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_WDCH": [ { "value": "1kx36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_WRCH": [ { "value": "512x36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_RACH": [ { "value": "512x36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_RDCH": [ { "value": "1kx36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_AXIS": [ { "value": "1kx18", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_USE_ECC_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_WACH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_WDCH": [ { "value": "64", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_WRCH": [ { "value": "2", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_RACH": [ { "value": "32", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_RDCH": [ { "value": "64", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_AXIS": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_WACH": [ { "value": "16", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_WDCH": [ { "value": "1024", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_WRCH": [ { "value": "16", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_RACH": [ { "value": "16", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_RDCH": [ { "value": "1024", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_AXIS": [ { "value": "1024", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_WACH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_WDCH": [ { "value": "10", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_WRCH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_RACH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_RDCH": [ { "value": "10", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_AXIS": [ { "value": "10", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_WACH": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_WDCH": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_WRCH": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_RACH": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_RDCH": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_AXIS": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_WACH": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_WDCH": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_WRCH": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_RACH": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_RDCH": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_AXIS": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ]
|
||||
},
|
||||
"project_parameters": {
|
||||
"ARCHITECTURE": [ { "value": "artix7" } ],
|
||||
"BASE_BOARD_PART": [ { "value": "" } ],
|
||||
"BOARD_CONNECTIONS": [ { "value": "" } ],
|
||||
"DEVICE": [ { "value": "xc7a35t" } ],
|
||||
"PACKAGE": [ { "value": "fgg484" } ],
|
||||
"PREFHDL": [ { "value": "VERILOG" } ],
|
||||
"SILICON_REVISION": [ { "value": "" } ],
|
||||
"SIMULATOR_LANGUAGE": [ { "value": "MIXED" } ],
|
||||
"SPEEDGRADE": [ { "value": "-1" } ],
|
||||
"STATIC_POWER": [ { "value": "" } ],
|
||||
"TEMPERATURE_GRADE": [ { "value": "" } ]
|
||||
},
|
||||
"runtime_parameters": {
|
||||
"IPCONTEXT": [ { "value": "IP_Flow" } ],
|
||||
"IPREVISION": [ { "value": "13" } ],
|
||||
"MANAGED": [ { "value": "TRUE" } ],
|
||||
"OUTPUTDIR": [ { "value": "../../../../ethernet_test.gen/sources_1/ip/len_fifo" } ],
|
||||
"SELECTEDSIMMODEL": [ { "value": "" } ],
|
||||
"SHAREDDIR": [ { "value": "." } ],
|
||||
"SWVERSION": [ { "value": "2025.1" } ],
|
||||
"SYNTHESISFLOW": [ { "value": "OUT_OF_CONTEXT" } ]
|
||||
}
|
||||
},
|
||||
"boundary": {
|
||||
"ports": {
|
||||
"clk": [ { "direction": "in", "driver_value": "0" } ],
|
||||
"rst": [ { "direction": "in", "driver_value": "0" } ],
|
||||
"din": [ { "direction": "in", "size_left": "15", "size_right": "0", "driver_value": "0" } ],
|
||||
"wr_en": [ { "direction": "in", "driver_value": "0" } ],
|
||||
"rd_en": [ { "direction": "in", "driver_value": "0" } ],
|
||||
"dout": [ { "direction": "out", "size_left": "15", "size_right": "0", "driver_value": "0" } ],
|
||||
"full": [ { "direction": "out", "driver_value": "0x0" } ],
|
||||
"empty": [ { "direction": "out", "driver_value": "0x1" } ],
|
||||
"data_count": [ { "direction": "out", "size_left": "4", "size_right": "0", "driver_value": "0" } ]
|
||||
},
|
||||
"interfaces": {
|
||||
"core_clk": {
|
||||
"vlnv": "xilinx.com:signal:clock:1.0",
|
||||
"abstraction_type": "xilinx.com:signal:clock_rtl:1.0",
|
||||
"mode": "slave",
|
||||
"parameters": {
|
||||
"FREQ_HZ": [ { "value": "100000000", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"FREQ_TOLERANCE_HZ": [ { "value": "0", "resolve_type": "generated", "format": "long", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"PHASE": [ { "value": "0.0", "resolve_type": "generated", "format": "float", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"CLK_DOMAIN": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"ASSOCIATED_BUSIF": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"ASSOCIATED_PORT": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"ASSOCIATED_RESET": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"INSERT_VIP": [ { "value": "0", "resolve_type": "user", "format": "long", "usage": "simulation.rtl", "is_ips_inferred": true, "is_static_object": false } ]
|
||||
},
|
||||
"port_maps": {
|
||||
"CLK": [ { "physical_name": "clk" } ]
|
||||
}
|
||||
},
|
||||
"FIFO_WRITE": {
|
||||
"vlnv": "xilinx.com:interface:fifo_write:1.0",
|
||||
"abstraction_type": "xilinx.com:interface:fifo_write_rtl:1.0",
|
||||
"mode": "slave",
|
||||
"port_maps": {
|
||||
"FULL": [ { "physical_name": "full" } ],
|
||||
"WR_DATA": [ { "physical_name": "din" } ],
|
||||
"WR_EN": [ { "physical_name": "wr_en" } ]
|
||||
}
|
||||
},
|
||||
"FIFO_READ": {
|
||||
"vlnv": "xilinx.com:interface:fifo_read:1.0",
|
||||
"abstraction_type": "xilinx.com:interface:fifo_read_rtl:1.0",
|
||||
"mode": "slave",
|
||||
"port_maps": {
|
||||
"EMPTY": [ { "physical_name": "empty" } ],
|
||||
"RD_DATA": [ { "physical_name": "dout" } ],
|
||||
"RD_EN": [ { "physical_name": "rd_en" } ]
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
461
rtl/ethernet-udp/src/ip/udp_checksum_fifo/udp_checksum_fifo.xci
Normal file
461
rtl/ethernet-udp/src/ip/udp_checksum_fifo/udp_checksum_fifo.xci
Normal file
@ -0,0 +1,461 @@
|
||||
{
|
||||
"schema": "xilinx.com:schema:json_instance:1.0",
|
||||
"ip_inst": {
|
||||
"xci_name": "udp_checksum_fifo",
|
||||
"component_reference": "xilinx.com:ip:fifo_generator:13.2",
|
||||
"ip_revision": "13",
|
||||
"gen_directory": "../../../../ethernet_test.gen/sources_1/ip/udp_checksum_fifo",
|
||||
"parameters": {
|
||||
"component_parameters": {
|
||||
"Component_Name": [ { "value": "udp_checksum_fifo", "resolve_type": "user", "usage": "all" } ],
|
||||
"Fifo_Implementation": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"synchronization_stages": [ { "value": "2", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"synchronization_stages_axi": [ { "value": "2", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"INTERFACE_TYPE": [ { "value": "Native", "resolve_type": "user", "usage": "all" } ],
|
||||
"Performance_Options": [ { "value": "Standard_FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"asymmetric_port_width": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Data_Width": [ { "value": "32", "value_src": "user", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Input_Depth": [ { "value": "16", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Output_Data_Width": [ { "value": "32", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Output_Depth": [ { "value": "16", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Use_Embedded_Registers": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Reset_Pin": [ { "value": "true", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Enable_Reset_Synchronization": [ { "value": "true", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Reset_Type": [ { "value": "Synchronous_Reset", "resolve_type": "user", "usage": "all" } ],
|
||||
"Full_Flags_Reset_Value": [ { "value": "0", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Use_Dout_Reset": [ { "value": "true", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Dout_Reset_Value": [ { "value": "0", "resolve_type": "user", "usage": "all" } ],
|
||||
"dynamic_power_saving": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Almost_Full_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Almost_Empty_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Valid_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Valid_Sense": [ { "value": "Active_High", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Underflow_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Underflow_Sense": [ { "value": "Active_High", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Write_Acknowledge_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Write_Acknowledge_Sense": [ { "value": "Active_High", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Overflow_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Overflow_Sense": [ { "value": "Active_High", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"ecc_pipeline_reg": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Use_Extra_Logic": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Data_Count": [ { "value": "true", "value_src": "user", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Data_Count_Width": [ { "value": "4", "value_src": "user", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Write_Data_Count": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Write_Data_Count_Width": [ { "value": "4", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Read_Data_Count": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Read_Data_Count_Width": [ { "value": "4", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Disable_Timing_Violations": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Read_Clock_Frequency": [ { "value": "1", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Write_Clock_Frequency": [ { "value": "1", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value": [ { "value": "14", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Negate_Value": [ { "value": "13", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value": [ { "value": "2", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Negate_Value": [ { "value": "3", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"PROTOCOL": [ { "value": "AXI4", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Clock_Type_AXI": [ { "value": "Common_Clock", "resolve_type": "user", "usage": "all" } ],
|
||||
"HAS_ACLKEN": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Clock_Enable_Type": [ { "value": "Slave_Interface_Clock_Enable", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"READ_WRITE_MODE": [ { "value": "READ_WRITE", "resolve_type": "user", "usage": "all" } ],
|
||||
"ID_WIDTH": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"ADDRESS_WIDTH": [ { "value": "32", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"DATA_WIDTH": [ { "value": "64", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"AWUSER_Width": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"WUSER_Width": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"BUSER_Width": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"ARUSER_Width": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"RUSER_Width": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"TDATA_NUM_BYTES": [ { "value": "1", "resolve_type": "user", "usage": "all" } ],
|
||||
"TID_WIDTH": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"TDEST_WIDTH": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"TUSER_WIDTH": [ { "value": "4", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Enable_TREADY": [ { "value": "true", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Enable_TLAST": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"HAS_TSTRB": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"TSTRB_WIDTH": [ { "value": "1", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"HAS_TKEEP": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"TKEEP_WIDTH": [ { "value": "1", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"wach_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_wach": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_wach": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_wach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_wach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_wach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_wach": [ { "value": "16", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_wach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_wach": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_wach": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_wach": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_wach": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"wdch_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_wdch": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_wdch": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_wdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_wdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_wdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_wdch": [ { "value": "1024", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_wdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_wdch": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_wdch": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_wdch": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_wdch": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"wrch_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_wrch": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_wrch": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_wrch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_wrch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_wrch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_wrch": [ { "value": "16", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_wrch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_wrch": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_wrch": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_wrch": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_wrch": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"rach_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_rach": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_rach": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_rach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_rach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_rach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_rach": [ { "value": "16", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_rach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_rach": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_rach": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_rach": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_rach": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"rdch_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_rdch": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_rdch": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_rdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_rdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_rdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_rdch": [ { "value": "1024", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_rdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_rdch": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_rdch": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_rdch": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_rdch": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"axis_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_axis": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_axis": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_axis": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_axis": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_axis": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_axis": [ { "value": "1024", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_axis": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_axis": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_axis": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_axis": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_axis": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Register_Slice_Mode_wach": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_Slice_Mode_wdch": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_Slice_Mode_wrch": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_Slice_Mode_rach": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_Slice_Mode_rdch": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_Slice_Mode_axis": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Underflow_Flag_AXI": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Underflow_Sense_AXI": [ { "value": "Active_High", "resolve_type": "user", "usage": "all" } ],
|
||||
"Overflow_Flag_AXI": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Overflow_Sense_AXI": [ { "value": "Active_High", "resolve_type": "user", "usage": "all" } ],
|
||||
"Disable_Timing_Violations_AXI": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Add_NGC_Constraint_AXI": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Enable_Common_Underflow": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Enable_Common_Overflow": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"enable_read_pointer_increment_by2": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Use_Embedded_Registers_axis": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"enable_low_latency": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"use_dout_register": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Master_interface_Clock_enable_memory_mapped": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Slave_interface_Clock_enable_memory_mapped": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Output_Register_Type": [ { "value": "Embedded_Reg", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_Safety_Circuit": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_Type": [ { "value": "Hard_ECC", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"C_SELECT_XPM": [ { "value": "0", "resolve_type": "user", "format": "long", "usage": "all" } ]
|
||||
},
|
||||
"model_parameters": {
|
||||
"C_COMMON_CLOCK": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_SELECT_XPM": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_COUNT_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DATA_COUNT_WIDTH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DEFAULT_VALUE": [ { "value": "BlankString", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_DIN_WIDTH": [ { "value": "32", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DOUT_RST_VAL": [ { "value": "0", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_DOUT_WIDTH": [ { "value": "32", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ENABLE_RLOCS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_FAMILY": [ { "value": "artix7", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_FULL_FLAGS_RST_VAL": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_ALMOST_EMPTY": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_ALMOST_FULL": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_BACKUP": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNT": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_INT_CLK": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_MEMINIT_FILE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_OVERFLOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_RD_DATA_COUNT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_RD_RST": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_RST": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_SRST": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_UNDERFLOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_VALID": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_WR_ACK": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_WR_DATA_COUNT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_WR_RST": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_INIT_WR_PNTR_VAL": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_MEMORY_TYPE": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_MIF_FILE_NAME": [ { "value": "BlankString", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_OPTIMIZATION_MODE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_OVERFLOW_LOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PRELOAD_LATENCY": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PRELOAD_REGS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE": [ { "value": "512x36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL": [ { "value": "2", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_NEGATE_VAL": [ { "value": "3", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL": [ { "value": "14", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_NEGATE_VAL": [ { "value": "13", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RD_DATA_COUNT_WIDTH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RD_DEPTH": [ { "value": "16", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RD_FREQ": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RD_PNTR_WIDTH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_UNDERFLOW_LOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_DOUT_RST": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_EMBEDDED_REG": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_PIPELINE_REG": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_POWER_SAVING_MODE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_FIFO16_FLAGS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_FWFT_DATA_COUNT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_VALID_LOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_ACK_LOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DATA_COUNT_WIDTH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH": [ { "value": "16", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_FREQ": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_RESPONSE_LATENCY": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_MSGON_VAL": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ENABLE_RST_SYNC": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_EN_SAFETY_CKT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_SYNCHRONIZER_STAGE": [ { "value": "2", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_INTERFACE_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_TYPE": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_WR_CHANNEL": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_RD_CHANNEL": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_SLAVE_CE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_MASTER_CE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ADD_NGC_CONSTRAINT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_COMMON_OVERFLOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_COMMON_UNDERFLOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_DEFAULT_SETTINGS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_ID_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_ADDR_WIDTH": [ { "value": "32", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_DATA_WIDTH": [ { "value": "64", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_LEN_WIDTH": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_LOCK_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_ID": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_AWUSER": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_WUSER": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_BUSER": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_ARUSER": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_RUSER": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_ARUSER_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_AWUSER_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_WUSER_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_BUSER_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_RUSER_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TDATA": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TID": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TDEST": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TUSER": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TREADY": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TLAST": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TSTRB": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TKEEP": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TDATA_WIDTH": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TID_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TDEST_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TUSER_WIDTH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TSTRB_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TKEEP_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WACH_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WDCH_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WRCH_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RACH_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RDCH_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_WACH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_WDCH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_WRCH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_RACH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_RDCH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_AXIS": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_WACH": [ { "value": "512x36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_WDCH": [ { "value": "1kx36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_WRCH": [ { "value": "512x36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_RACH": [ { "value": "512x36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_RDCH": [ { "value": "1kx36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_AXIS": [ { "value": "1kx18", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_USE_ECC_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_WACH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_WDCH": [ { "value": "64", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_WRCH": [ { "value": "2", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_RACH": [ { "value": "32", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_RDCH": [ { "value": "64", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_AXIS": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_WACH": [ { "value": "16", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_WDCH": [ { "value": "1024", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_WRCH": [ { "value": "16", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_RACH": [ { "value": "16", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_RDCH": [ { "value": "1024", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_AXIS": [ { "value": "1024", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_WACH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_WDCH": [ { "value": "10", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_WRCH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_RACH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_RDCH": [ { "value": "10", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_AXIS": [ { "value": "10", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_WACH": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_WDCH": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_WRCH": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_RACH": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_RDCH": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_AXIS": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_WACH": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_WDCH": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_WRCH": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_RACH": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_RDCH": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_AXIS": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ]
|
||||
},
|
||||
"project_parameters": {
|
||||
"ARCHITECTURE": [ { "value": "artix7" } ],
|
||||
"BASE_BOARD_PART": [ { "value": "" } ],
|
||||
"BOARD_CONNECTIONS": [ { "value": "" } ],
|
||||
"DEVICE": [ { "value": "xc7a35t" } ],
|
||||
"PACKAGE": [ { "value": "fgg484" } ],
|
||||
"PREFHDL": [ { "value": "VERILOG" } ],
|
||||
"SILICON_REVISION": [ { "value": "" } ],
|
||||
"SIMULATOR_LANGUAGE": [ { "value": "MIXED" } ],
|
||||
"SPEEDGRADE": [ { "value": "-1" } ],
|
||||
"STATIC_POWER": [ { "value": "" } ],
|
||||
"TEMPERATURE_GRADE": [ { "value": "" } ]
|
||||
},
|
||||
"runtime_parameters": {
|
||||
"IPCONTEXT": [ { "value": "IP_Flow" } ],
|
||||
"IPREVISION": [ { "value": "13" } ],
|
||||
"MANAGED": [ { "value": "TRUE" } ],
|
||||
"OUTPUTDIR": [ { "value": "../../../../ethernet_test.gen/sources_1/ip/udp_checksum_fifo" } ],
|
||||
"SELECTEDSIMMODEL": [ { "value": "" } ],
|
||||
"SHAREDDIR": [ { "value": "." } ],
|
||||
"SWVERSION": [ { "value": "2025.1" } ],
|
||||
"SYNTHESISFLOW": [ { "value": "OUT_OF_CONTEXT" } ]
|
||||
}
|
||||
},
|
||||
"boundary": {
|
||||
"ports": {
|
||||
"clk": [ { "direction": "in", "driver_value": "0" } ],
|
||||
"srst": [ { "direction": "in", "driver_value": "0" } ],
|
||||
"din": [ { "direction": "in", "size_left": "31", "size_right": "0", "driver_value": "0" } ],
|
||||
"wr_en": [ { "direction": "in", "driver_value": "0" } ],
|
||||
"rd_en": [ { "direction": "in", "driver_value": "0" } ],
|
||||
"dout": [ { "direction": "out", "size_left": "31", "size_right": "0", "driver_value": "0" } ],
|
||||
"full": [ { "direction": "out", "driver_value": "0x0" } ],
|
||||
"empty": [ { "direction": "out", "driver_value": "0x1" } ],
|
||||
"data_count": [ { "direction": "out", "size_left": "3", "size_right": "0", "driver_value": "0" } ]
|
||||
},
|
||||
"interfaces": {
|
||||
"core_clk": {
|
||||
"vlnv": "xilinx.com:signal:clock:1.0",
|
||||
"abstraction_type": "xilinx.com:signal:clock_rtl:1.0",
|
||||
"mode": "slave",
|
||||
"parameters": {
|
||||
"FREQ_HZ": [ { "value": "100000000", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"FREQ_TOLERANCE_HZ": [ { "value": "0", "resolve_type": "generated", "format": "long", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"PHASE": [ { "value": "0.0", "resolve_type": "generated", "format": "float", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"CLK_DOMAIN": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"ASSOCIATED_BUSIF": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"ASSOCIATED_PORT": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"ASSOCIATED_RESET": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"INSERT_VIP": [ { "value": "0", "resolve_type": "user", "format": "long", "usage": "simulation.rtl", "is_ips_inferred": true, "is_static_object": false } ]
|
||||
},
|
||||
"port_maps": {
|
||||
"CLK": [ { "physical_name": "clk" } ]
|
||||
}
|
||||
},
|
||||
"FIFO_WRITE": {
|
||||
"vlnv": "xilinx.com:interface:fifo_write:1.0",
|
||||
"abstraction_type": "xilinx.com:interface:fifo_write_rtl:1.0",
|
||||
"mode": "slave",
|
||||
"port_maps": {
|
||||
"FULL": [ { "physical_name": "full" } ],
|
||||
"WR_DATA": [ { "physical_name": "din" } ],
|
||||
"WR_EN": [ { "physical_name": "wr_en" } ]
|
||||
}
|
||||
},
|
||||
"FIFO_READ": {
|
||||
"vlnv": "xilinx.com:interface:fifo_read:1.0",
|
||||
"abstraction_type": "xilinx.com:interface:fifo_read_rtl:1.0",
|
||||
"mode": "slave",
|
||||
"port_maps": {
|
||||
"EMPTY": [ { "physical_name": "empty" } ],
|
||||
"RD_DATA": [ { "physical_name": "dout" } ],
|
||||
"RD_EN": [ { "physical_name": "rd_en" } ]
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
277
rtl/ethernet-udp/src/ip/udp_rx_ram_8_2048/udp_rx_ram_8_2048.xci
Normal file
277
rtl/ethernet-udp/src/ip/udp_rx_ram_8_2048/udp_rx_ram_8_2048.xci
Normal file
@ -0,0 +1,277 @@
|
||||
{
|
||||
"schema": "xilinx.com:schema:json_instance:1.0",
|
||||
"ip_inst": {
|
||||
"xci_name": "udp_rx_ram_8_2048",
|
||||
"component_reference": "xilinx.com:ip:blk_mem_gen:8.4",
|
||||
"ip_revision": "11",
|
||||
"gen_directory": "../../../../ethernet_test.gen/sources_1/ip/udp_rx_ram_8_2048",
|
||||
"parameters": {
|
||||
"component_parameters": {
|
||||
"Component_Name": [ { "value": "udp_rx_ram_8_2048", "resolve_type": "user", "usage": "all" } ],
|
||||
"Interface_Type": [ { "value": "Native", "resolve_type": "user", "usage": "all" } ],
|
||||
"AXI_Type": [ { "value": "AXI4_Full", "resolve_type": "user", "usage": "all" } ],
|
||||
"AXI_Slave_Type": [ { "value": "Memory_Slave", "resolve_type": "user", "usage": "all" } ],
|
||||
"Use_AXI_ID": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"AXI_ID_Width": [ { "value": "4", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Memory_Type": [ { "value": "Simple_Dual_Port_RAM", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"PRIM_type_to_Implement": [ { "value": "BRAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_32bit_Address": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"ecctype": [ { "value": "No_ECC", "resolve_type": "user", "usage": "all" } ],
|
||||
"ECC": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"softecc": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"EN_SLEEP_PIN": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"EN_DEEPSLEEP_PIN": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"EN_SHUTDOWN_PIN": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"EN_ECC_PIPE": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"RD_ADDR_CHNG_A": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"RD_ADDR_CHNG_B": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Use_Error_Injection_Pins": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Error_Injection_Type": [ { "value": "Single_Bit_Error_Injection", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Use_Byte_Write_Enable": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Byte_Size": [ { "value": "9", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Algorithm": [ { "value": "Minimum_Area", "resolve_type": "user", "usage": "all" } ],
|
||||
"Primitive": [ { "value": "8kx2", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Assume_Synchronous_Clk": [ { "value": "true", "value_src": "user", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Write_Width_A": [ { "value": "8", "value_src": "user", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Write_Depth_A": [ { "value": "2048", "value_src": "user", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Read_Width_A": [ { "value": "8", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Operating_Mode_A": [ { "value": "NO_CHANGE", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_A": [ { "value": "Always_Enabled", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Write_Width_B": [ { "value": "8", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Read_Width_B": [ { "value": "8", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Operating_Mode_B": [ { "value": "READ_FIRST", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_B": [ { "value": "Always_Enabled", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_PortA_Output_of_Memory_Primitives": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Register_PortA_Output_of_Memory_Core": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Use_REGCEA_Pin": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Register_PortB_Output_of_Memory_Primitives": [ { "value": "false", "value_src": "user", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Register_PortB_Output_of_Memory_Core": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Use_REGCEB_Pin": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"register_porta_input_of_softecc": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"register_portb_output_of_softecc": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Pipeline_Stages": [ { "value": "0", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Load_Init_File": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Coe_File": [ { "value": "no_coe_file_loaded", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Fill_Remaining_Memory_Locations": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Remaining_Memory_Locations": [ { "value": "0", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Use_RSTA_Pin": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Reset_Memory_Latch_A": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Reset_Priority_A": [ { "value": "CE", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Output_Reset_Value_A": [ { "value": "0", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Use_RSTB_Pin": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Reset_Memory_Latch_B": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Reset_Priority_B": [ { "value": "CE", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Output_Reset_Value_B": [ { "value": "0", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Reset_Type": [ { "value": "SYNC", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Additional_Inputs_for_Power_Estimation": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Port_A_Clock": [ { "value": "100", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Port_A_Write_Rate": [ { "value": "50", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Port_B_Clock": [ { "value": "100", "value_src": "user", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Port_B_Write_Rate": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Port_A_Enable_Rate": [ { "value": "100", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Port_B_Enable_Rate": [ { "value": "100", "value_src": "user", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Collision_Warnings": [ { "value": "ALL", "resolve_type": "user", "usage": "all" } ],
|
||||
"Disable_Collision_Warnings": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Disable_Out_of_Range_Warnings": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"use_bram_block": [ { "value": "Stand_Alone", "resolve_type": "user", "usage": "all" } ],
|
||||
"MEM_FILE": [ { "value": "no_mem_loaded", "resolve_type": "user", "usage": "all" } ],
|
||||
"CTRL_ECC_ALGO": [ { "value": "NONE", "resolve_type": "user", "usage": "all" } ],
|
||||
"EN_SAFETY_CKT": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"READ_LATENCY_A": [ { "value": "1", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"READ_LATENCY_B": [ { "value": "1", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ]
|
||||
},
|
||||
"model_parameters": {
|
||||
"C_FAMILY": [ { "value": "artix7", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_XDEVICEFAMILY": [ { "value": "artix7", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_ELABORATION_DIR": [ { "value": "./", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_INTERFACE_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_TYPE": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_SLAVE_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_BRAM_BLOCK": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ENABLE_32BIT_ADDRESS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_CTRL_ECC_ALGO": [ { "value": "NONE", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_HAS_AXI_ID": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_ID_WIDTH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_MEM_TYPE": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_BYTE_SIZE": [ { "value": "9", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ALGORITHM": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PRIM_TYPE": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_LOAD_INIT_FILE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_INIT_FILE_NAME": [ { "value": "no_coe_file_loaded", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_INIT_FILE": [ { "value": "udp_rx_ram_8_2048.mem", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_USE_DEFAULT_DATA": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DEFAULT_DATA": [ { "value": "0", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_HAS_RSTA": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RST_PRIORITY_A": [ { "value": "CE", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_RSTRAM_A": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_INITA_VAL": [ { "value": "0", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_HAS_ENA": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_REGCEA": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_BYTE_WEA": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WEA_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WRITE_MODE_A": [ { "value": "NO_CHANGE", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_WRITE_WIDTH_A": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_READ_WIDTH_A": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WRITE_DEPTH_A": [ { "value": "2048", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_READ_DEPTH_A": [ { "value": "2048", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ADDRA_WIDTH": [ { "value": "11", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_RSTB": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RST_PRIORITY_B": [ { "value": "CE", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_RSTRAM_B": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_INITB_VAL": [ { "value": "0", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_HAS_ENB": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_REGCEB": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_BYTE_WEB": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WEB_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WRITE_MODE_B": [ { "value": "READ_FIRST", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_WRITE_WIDTH_B": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_READ_WIDTH_B": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WRITE_DEPTH_B": [ { "value": "2048", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_READ_DEPTH_B": [ { "value": "2048", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ADDRB_WIDTH": [ { "value": "11", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_MEM_OUTPUT_REGS_A": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_MEM_OUTPUT_REGS_B": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_MUX_OUTPUT_REGS_A": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_MUX_OUTPUT_REGS_B": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_MUX_PIPELINE_STAGES": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_SOFTECC_INPUT_REGS_A": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_SOFTECC_OUTPUT_REGS_B": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_SOFTECC": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_EN_ECC_PIPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_READ_LATENCY_A": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_READ_LATENCY_B": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_INJECTERR": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_SIM_COLLISION_CHECK": [ { "value": "ALL", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_COMMON_CLK": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DISABLE_WARN_BHV_COLL": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_EN_SLEEP_PIN": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_URAM": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_EN_RDADDRA_CHG": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_EN_RDADDRB_CHG": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_EN_DEEPSLEEP_PIN": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_EN_SHUTDOWN_PIN": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_EN_SAFETY_CKT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DISABLE_WARN_BHV_RANGE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_COUNT_36K_BRAM": [ { "value": "0", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_COUNT_18K_BRAM": [ { "value": "1", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_EST_POWER_SUMMARY": [ { "value": "Estimated Power for IP : 2.4787 mW", "resolve_type": "generated", "usage": "all" } ]
|
||||
},
|
||||
"project_parameters": {
|
||||
"ARCHITECTURE": [ { "value": "artix7" } ],
|
||||
"BASE_BOARD_PART": [ { "value": "" } ],
|
||||
"BOARD_CONNECTIONS": [ { "value": "" } ],
|
||||
"DEVICE": [ { "value": "xc7a35t" } ],
|
||||
"PACKAGE": [ { "value": "fgg484" } ],
|
||||
"PREFHDL": [ { "value": "VERILOG" } ],
|
||||
"SILICON_REVISION": [ { "value": "" } ],
|
||||
"SIMULATOR_LANGUAGE": [ { "value": "MIXED" } ],
|
||||
"SPEEDGRADE": [ { "value": "-1" } ],
|
||||
"STATIC_POWER": [ { "value": "" } ],
|
||||
"TEMPERATURE_GRADE": [ { "value": "" } ]
|
||||
},
|
||||
"runtime_parameters": {
|
||||
"IPCONTEXT": [ { "value": "IP_Flow" } ],
|
||||
"IPREVISION": [ { "value": "11" } ],
|
||||
"MANAGED": [ { "value": "TRUE" } ],
|
||||
"OUTPUTDIR": [ { "value": "../../../../ethernet_test.gen/sources_1/ip/udp_rx_ram_8_2048" } ],
|
||||
"SELECTEDSIMMODEL": [ { "value": "" } ],
|
||||
"SHAREDDIR": [ { "value": "." } ],
|
||||
"SWVERSION": [ { "value": "2025.1" } ],
|
||||
"SYNTHESISFLOW": [ { "value": "OUT_OF_CONTEXT" } ]
|
||||
}
|
||||
},
|
||||
"boundary": {
|
||||
"ports": {
|
||||
"clka": [ { "direction": "in", "driver_value": "0" } ],
|
||||
"wea": [ { "direction": "in", "size_left": "0", "size_right": "0", "driver_value": "0" } ],
|
||||
"addra": [ { "direction": "in", "size_left": "10", "size_right": "0", "driver_value": "0" } ],
|
||||
"dina": [ { "direction": "in", "size_left": "7", "size_right": "0", "driver_value": "0" } ],
|
||||
"clkb": [ { "direction": "in", "driver_value": "0" } ],
|
||||
"addrb": [ { "direction": "in", "size_left": "10", "size_right": "0", "driver_value": "0" } ],
|
||||
"doutb": [ { "direction": "out", "size_left": "7", "size_right": "0" } ]
|
||||
},
|
||||
"interfaces": {
|
||||
"CLK.ACLK": {
|
||||
"vlnv": "xilinx.com:signal:clock:1.0",
|
||||
"abstraction_type": "xilinx.com:signal:clock_rtl:1.0",
|
||||
"mode": "slave",
|
||||
"parameters": {
|
||||
"ASSOCIATED_BUSIF": [ { "value": "AXI_SLAVE_S_AXI:AXILite_SLAVE_S_AXI", "value_src": "constant", "usage": "all" } ],
|
||||
"ASSOCIATED_RESET": [ { "value": "s_aresetn", "value_src": "constant", "usage": "all" } ],
|
||||
"FREQ_HZ": [ { "value": "100000000", "resolve_type": "generated", "format": "long", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"FREQ_TOLERANCE_HZ": [ { "value": "0", "resolve_type": "generated", "format": "long", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"PHASE": [ { "value": "0.0", "resolve_type": "generated", "format": "float", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"CLK_DOMAIN": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"ASSOCIATED_PORT": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"INSERT_VIP": [ { "value": "0", "resolve_type": "user", "format": "long", "usage": "simulation.rtl", "is_ips_inferred": true, "is_static_object": false } ]
|
||||
}
|
||||
},
|
||||
"RST.ARESETN": {
|
||||
"vlnv": "xilinx.com:signal:reset:1.0",
|
||||
"abstraction_type": "xilinx.com:signal:reset_rtl:1.0",
|
||||
"mode": "slave",
|
||||
"parameters": {
|
||||
"POLARITY": [ { "value": "ACTIVE_LOW", "value_src": "constant", "usage": "all" } ],
|
||||
"INSERT_VIP": [ { "value": "0", "resolve_type": "user", "format": "long", "usage": "simulation.rtl", "is_ips_inferred": true, "is_static_object": false } ]
|
||||
}
|
||||
},
|
||||
"BRAM_PORTA": {
|
||||
"vlnv": "xilinx.com:interface:bram:1.0",
|
||||
"abstraction_type": "xilinx.com:interface:bram_rtl:1.0",
|
||||
"mode": "slave",
|
||||
"parameters": {
|
||||
"MEM_ADDRESS_MODE": [ { "value": "BYTE_ADDRESS", "resolve_type": "user", "usage": "all" } ],
|
||||
"MEM_SIZE": [ { "value": "8192", "resolve_type": "generated", "format": "long", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"MEM_WIDTH": [ { "value": "32", "resolve_type": "generated", "format": "long", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"MEM_ECC": [ { "value": "NONE", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"MASTER_TYPE": [ { "value": "OTHER", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"READ_WRITE_MODE": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"READ_LATENCY": [ { "value": "1", "resolve_type": "generated", "format": "long", "is_ips_inferred": true, "is_static_object": false } ]
|
||||
},
|
||||
"port_maps": {
|
||||
"ADDR": [ { "physical_name": "addra" } ],
|
||||
"CLK": [ { "physical_name": "clka" } ],
|
||||
"DIN": [ { "physical_name": "dina" } ],
|
||||
"WE": [ { "physical_name": "wea" } ]
|
||||
}
|
||||
},
|
||||
"BRAM_PORTB": {
|
||||
"vlnv": "xilinx.com:interface:bram:1.0",
|
||||
"abstraction_type": "xilinx.com:interface:bram_rtl:1.0",
|
||||
"mode": "slave",
|
||||
"parameters": {
|
||||
"MEM_ADDRESS_MODE": [ { "value": "BYTE_ADDRESS", "resolve_type": "user", "usage": "all" } ],
|
||||
"MEM_SIZE": [ { "value": "8192", "resolve_type": "generated", "format": "long", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"MEM_WIDTH": [ { "value": "32", "resolve_type": "generated", "format": "long", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"MEM_ECC": [ { "value": "NONE", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"MASTER_TYPE": [ { "value": "OTHER", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"READ_WRITE_MODE": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"READ_LATENCY": [ { "value": "1", "resolve_type": "generated", "format": "long", "is_ips_inferred": true, "is_static_object": false } ]
|
||||
},
|
||||
"port_maps": {
|
||||
"ADDR": [ { "physical_name": "addrb" } ],
|
||||
"CLK": [ { "physical_name": "clkb" } ],
|
||||
"DOUT": [ { "physical_name": "doutb" } ]
|
||||
}
|
||||
}
|
||||
},
|
||||
"memory_maps": {
|
||||
"S_1": {
|
||||
"address_blocks": {
|
||||
"Mem0": {
|
||||
"base_address": "0",
|
||||
"range": "4096",
|
||||
"usage": "memory",
|
||||
"access": "read-write",
|
||||
"parameters": {
|
||||
"OFFSET_BASE_PARAM": [ { "value": "C_BASEADDR" } ],
|
||||
"OFFSET_HIGH_PARAM": [ { "value": "C_HIGHADDR" } ]
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
463
rtl/ethernet-udp/src/ip/udp_tx_data_fifo/udp_tx_data_fifo.xci
Normal file
463
rtl/ethernet-udp/src/ip/udp_tx_data_fifo/udp_tx_data_fifo.xci
Normal file
@ -0,0 +1,463 @@
|
||||
{
|
||||
"schema": "xilinx.com:schema:json_instance:1.0",
|
||||
"ip_inst": {
|
||||
"xci_name": "udp_tx_data_fifo",
|
||||
"component_reference": "xilinx.com:ip:fifo_generator:13.2",
|
||||
"ip_revision": "13",
|
||||
"gen_directory": "../../../../ethernet_test.gen/sources_1/ip/udp_tx_data_fifo",
|
||||
"parameters": {
|
||||
"component_parameters": {
|
||||
"Component_Name": [ { "value": "udp_tx_data_fifo", "resolve_type": "user", "usage": "all" } ],
|
||||
"Fifo_Implementation": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"synchronization_stages": [ { "value": "2", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"synchronization_stages_axi": [ { "value": "2", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"INTERFACE_TYPE": [ { "value": "Native", "resolve_type": "user", "usage": "all" } ],
|
||||
"Performance_Options": [ { "value": "Standard_FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"asymmetric_port_width": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Data_Width": [ { "value": "8", "value_src": "user", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Input_Depth": [ { "value": "4096", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Output_Data_Width": [ { "value": "8", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Output_Depth": [ { "value": "4096", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Use_Embedded_Registers": [ { "value": "false", "value_src": "user", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Reset_Pin": [ { "value": "true", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Enable_Reset_Synchronization": [ { "value": "true", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Reset_Type": [ { "value": "Synchronous_Reset", "resolve_type": "user", "usage": "all" } ],
|
||||
"Full_Flags_Reset_Value": [ { "value": "0", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Use_Dout_Reset": [ { "value": "true", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Dout_Reset_Value": [ { "value": "0", "resolve_type": "user", "usage": "all" } ],
|
||||
"dynamic_power_saving": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Almost_Full_Flag": [ { "value": "true", "value_src": "user", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Almost_Empty_Flag": [ { "value": "false", "value_src": "user", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Valid_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Valid_Sense": [ { "value": "Active_High", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Underflow_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Underflow_Sense": [ { "value": "Active_High", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Write_Acknowledge_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Write_Acknowledge_Sense": [ { "value": "Active_High", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Overflow_Flag": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Overflow_Sense": [ { "value": "Active_High", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"ecc_pipeline_reg": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Use_Extra_Logic": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Data_Count": [ { "value": "true", "value_src": "user", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Data_Count_Width": [ { "value": "12", "value_src": "user", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"Write_Data_Count": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Write_Data_Count_Width": [ { "value": "12", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Read_Data_Count": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Read_Data_Count_Width": [ { "value": "12", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Disable_Timing_Violations": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Read_Clock_Frequency": [ { "value": "1", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Write_Clock_Frequency": [ { "value": "1", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type": [ { "value": "No_Programmable_Full_Threshold", "value_src": "user", "resolve_type": "user", "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value": [ { "value": "4094", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Negate_Value": [ { "value": "4093", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value": [ { "value": "2", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Negate_Value": [ { "value": "3", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"PROTOCOL": [ { "value": "AXI4", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Clock_Type_AXI": [ { "value": "Common_Clock", "resolve_type": "user", "usage": "all" } ],
|
||||
"HAS_ACLKEN": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Clock_Enable_Type": [ { "value": "Slave_Interface_Clock_Enable", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"READ_WRITE_MODE": [ { "value": "READ_WRITE", "resolve_type": "user", "usage": "all" } ],
|
||||
"ID_WIDTH": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"ADDRESS_WIDTH": [ { "value": "32", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"DATA_WIDTH": [ { "value": "64", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"AWUSER_Width": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"WUSER_Width": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"BUSER_Width": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"ARUSER_Width": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"RUSER_Width": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"TDATA_NUM_BYTES": [ { "value": "1", "resolve_type": "user", "usage": "all" } ],
|
||||
"TID_WIDTH": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"TDEST_WIDTH": [ { "value": "0", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"TUSER_WIDTH": [ { "value": "4", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Enable_TREADY": [ { "value": "true", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Enable_TLAST": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"HAS_TSTRB": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"TSTRB_WIDTH": [ { "value": "1", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"HAS_TKEEP": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"TKEEP_WIDTH": [ { "value": "1", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"wach_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_wach": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_wach": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_wach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_wach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_wach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_wach": [ { "value": "16", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_wach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_wach": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_wach": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_wach": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_wach": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"wdch_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_wdch": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_wdch": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_wdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_wdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_wdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_wdch": [ { "value": "1024", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_wdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_wdch": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_wdch": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_wdch": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_wdch": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"wrch_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_wrch": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_wrch": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_wrch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_wrch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_wrch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_wrch": [ { "value": "16", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_wrch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_wrch": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_wrch": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_wrch": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_wrch": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"rach_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_rach": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_rach": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_rach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_rach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_rach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_rach": [ { "value": "16", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_rach": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_rach": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_rach": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_rach": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_rach": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"rdch_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_rdch": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_rdch": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_rdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_rdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_rdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_rdch": [ { "value": "1024", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_rdch": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_rdch": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_rdch": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_rdch": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_rdch": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"axis_type": [ { "value": "FIFO", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Implementation_axis": [ { "value": "Common_Clock_Block_RAM", "resolve_type": "user", "usage": "all" } ],
|
||||
"FIFO_Application_Type_axis": [ { "value": "Data_FIFO", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_axis": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Sbit_Error_axis": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Inject_Dbit_Error_axis": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Input_Depth_axis": [ { "value": "1024", "resolve_type": "user", "usage": "all" } ],
|
||||
"Enable_Data_Counts_axis": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Full_Type_axis": [ { "value": "No_Programmable_Full_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Full_Threshold_Assert_Value_axis": [ { "value": "1023", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Programmable_Empty_Type_axis": [ { "value": "No_Programmable_Empty_Threshold", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Empty_Threshold_Assert_Value_axis": [ { "value": "1022", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ],
|
||||
"Register_Slice_Mode_wach": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_Slice_Mode_wdch": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_Slice_Mode_wrch": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_Slice_Mode_rach": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_Slice_Mode_rdch": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Register_Slice_Mode_axis": [ { "value": "Fully_Registered", "resolve_type": "user", "usage": "all" } ],
|
||||
"Underflow_Flag_AXI": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Underflow_Sense_AXI": [ { "value": "Active_High", "resolve_type": "user", "usage": "all" } ],
|
||||
"Overflow_Flag_AXI": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Overflow_Sense_AXI": [ { "value": "Active_High", "resolve_type": "user", "usage": "all" } ],
|
||||
"Disable_Timing_Violations_AXI": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Add_NGC_Constraint_AXI": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Enable_Common_Underflow": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Enable_Common_Overflow": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"enable_read_pointer_increment_by2": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],
|
||||
"Use_Embedded_Registers_axis": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"enable_low_latency": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"use_dout_register": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Master_interface_Clock_enable_memory_mapped": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Slave_interface_Clock_enable_memory_mapped": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Output_Register_Type": [ { "value": "Embedded_Reg", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"Enable_Safety_Circuit": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],
|
||||
"Enable_ECC_Type": [ { "value": "Hard_ECC", "resolve_type": "user", "enabled": false, "usage": "all" } ],
|
||||
"C_SELECT_XPM": [ { "value": "0", "resolve_type": "user", "format": "long", "usage": "all" } ]
|
||||
},
|
||||
"model_parameters": {
|
||||
"C_COMMON_CLOCK": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_SELECT_XPM": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_COUNT_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DATA_COUNT_WIDTH": [ { "value": "12", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DEFAULT_VALUE": [ { "value": "BlankString", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_DIN_WIDTH": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DOUT_RST_VAL": [ { "value": "0", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_DOUT_WIDTH": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ENABLE_RLOCS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_FAMILY": [ { "value": "artix7", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_FULL_FLAGS_RST_VAL": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_ALMOST_EMPTY": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_ALMOST_FULL": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_BACKUP": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNT": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_INT_CLK": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_MEMINIT_FILE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_OVERFLOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_RD_DATA_COUNT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_RD_RST": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_RST": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_SRST": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_UNDERFLOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_VALID": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_WR_ACK": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_WR_DATA_COUNT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_WR_RST": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_INIT_WR_PNTR_VAL": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_MEMORY_TYPE": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_MIF_FILE_NAME": [ { "value": "BlankString", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_OPTIMIZATION_MODE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_OVERFLOW_LOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PRELOAD_LATENCY": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PRELOAD_REGS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE": [ { "value": "4kx9", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL": [ { "value": "2", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_NEGATE_VAL": [ { "value": "3", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL": [ { "value": "4094", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_NEGATE_VAL": [ { "value": "4093", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RD_DATA_COUNT_WIDTH": [ { "value": "12", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RD_DEPTH": [ { "value": "4096", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RD_FREQ": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RD_PNTR_WIDTH": [ { "value": "12", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_UNDERFLOW_LOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_DOUT_RST": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_EMBEDDED_REG": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_PIPELINE_REG": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_POWER_SAVING_MODE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_FIFO16_FLAGS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_FWFT_DATA_COUNT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_VALID_LOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_ACK_LOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DATA_COUNT_WIDTH": [ { "value": "12", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH": [ { "value": "4096", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_FREQ": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH": [ { "value": "12", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_RESPONSE_LATENCY": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_MSGON_VAL": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ENABLE_RST_SYNC": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_EN_SAFETY_CKT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_SYNCHRONIZER_STAGE": [ { "value": "2", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_INTERFACE_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_TYPE": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_WR_CHANNEL": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_RD_CHANNEL": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_SLAVE_CE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_MASTER_CE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ADD_NGC_CONSTRAINT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_COMMON_OVERFLOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_COMMON_UNDERFLOW": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_DEFAULT_SETTINGS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_ID_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_ADDR_WIDTH": [ { "value": "32", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_DATA_WIDTH": [ { "value": "64", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_LEN_WIDTH": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_LOCK_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_ID": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_AWUSER": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_WUSER": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_BUSER": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_ARUSER": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXI_RUSER": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_ARUSER_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_AWUSER_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_WUSER_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_BUSER_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXI_RUSER_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TDATA": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TID": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TDEST": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TUSER": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TREADY": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TLAST": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TSTRB": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_AXIS_TKEEP": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TDATA_WIDTH": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TID_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TDEST_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TUSER_WIDTH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TSTRB_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TKEEP_WIDTH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WACH_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WDCH_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WRCH_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RACH_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_RDCH_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_AXIS_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_WACH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_WDCH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_WRCH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_RACH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_RDCH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_IMPLEMENTATION_TYPE_AXIS": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_APPLICATION_TYPE_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_WACH": [ { "value": "512x36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_WDCH": [ { "value": "1kx36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_WRCH": [ { "value": "512x36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_RACH": [ { "value": "512x36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_RDCH": [ { "value": "1kx36", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_PRIM_FIFO_TYPE_AXIS": [ { "value": "1kx18", "resolve_type": "generated", "usage": "all" } ],
|
||||
"C_USE_ECC_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_USE_ECC_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_ERROR_INJECTION_TYPE_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_WACH": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_WDCH": [ { "value": "64", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_WRCH": [ { "value": "2", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_RACH": [ { "value": "32", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_RDCH": [ { "value": "64", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_DIN_WIDTH_AXIS": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_WACH": [ { "value": "16", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_WDCH": [ { "value": "1024", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_WRCH": [ { "value": "16", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_RACH": [ { "value": "16", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_RDCH": [ { "value": "1024", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_DEPTH_AXIS": [ { "value": "1024", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_WACH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_WDCH": [ { "value": "10", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_WRCH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_RACH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_RDCH": [ { "value": "10", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_WR_PNTR_WIDTH_AXIS": [ { "value": "10", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_DATA_COUNTS_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_HAS_PROG_FLAGS_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_TYPE_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_WACH": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_WDCH": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_WRCH": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_RACH": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_RDCH": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_FULL_THRESH_ASSERT_VAL_AXIS": [ { "value": "1023", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_TYPE_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_WACH": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_WDCH": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_WRCH": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_RACH": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_RDCH": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_PROG_EMPTY_THRESH_ASSERT_VAL_AXIS": [ { "value": "1022", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_WACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_WDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_WRCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_RACH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_RDCH": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],
|
||||
"C_REG_SLICE_MODE_AXIS": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ]
|
||||
},
|
||||
"project_parameters": {
|
||||
"ARCHITECTURE": [ { "value": "artix7" } ],
|
||||
"BASE_BOARD_PART": [ { "value": "" } ],
|
||||
"BOARD_CONNECTIONS": [ { "value": "" } ],
|
||||
"DEVICE": [ { "value": "xc7a35t" } ],
|
||||
"PACKAGE": [ { "value": "fgg484" } ],
|
||||
"PREFHDL": [ { "value": "VERILOG" } ],
|
||||
"SILICON_REVISION": [ { "value": "" } ],
|
||||
"SIMULATOR_LANGUAGE": [ { "value": "MIXED" } ],
|
||||
"SPEEDGRADE": [ { "value": "-1" } ],
|
||||
"STATIC_POWER": [ { "value": "" } ],
|
||||
"TEMPERATURE_GRADE": [ { "value": "" } ]
|
||||
},
|
||||
"runtime_parameters": {
|
||||
"IPCONTEXT": [ { "value": "IP_Flow" } ],
|
||||
"IPREVISION": [ { "value": "13" } ],
|
||||
"MANAGED": [ { "value": "TRUE" } ],
|
||||
"OUTPUTDIR": [ { "value": "../../../../ethernet_test.gen/sources_1/ip/udp_tx_data_fifo" } ],
|
||||
"SELECTEDSIMMODEL": [ { "value": "" } ],
|
||||
"SHAREDDIR": [ { "value": "." } ],
|
||||
"SWVERSION": [ { "value": "2025.1" } ],
|
||||
"SYNTHESISFLOW": [ { "value": "OUT_OF_CONTEXT" } ]
|
||||
}
|
||||
},
|
||||
"boundary": {
|
||||
"ports": {
|
||||
"clk": [ { "direction": "in", "driver_value": "0" } ],
|
||||
"srst": [ { "direction": "in", "driver_value": "0" } ],
|
||||
"din": [ { "direction": "in", "size_left": "7", "size_right": "0", "driver_value": "0" } ],
|
||||
"wr_en": [ { "direction": "in", "driver_value": "0" } ],
|
||||
"rd_en": [ { "direction": "in", "driver_value": "0" } ],
|
||||
"dout": [ { "direction": "out", "size_left": "7", "size_right": "0", "driver_value": "0" } ],
|
||||
"full": [ { "direction": "out", "driver_value": "0x0" } ],
|
||||
"almost_full": [ { "direction": "out", "driver_value": "0x0" } ],
|
||||
"empty": [ { "direction": "out", "driver_value": "0x1" } ],
|
||||
"data_count": [ { "direction": "out", "size_left": "11", "size_right": "0", "driver_value": "0" } ]
|
||||
},
|
||||
"interfaces": {
|
||||
"core_clk": {
|
||||
"vlnv": "xilinx.com:signal:clock:1.0",
|
||||
"abstraction_type": "xilinx.com:signal:clock_rtl:1.0",
|
||||
"mode": "slave",
|
||||
"parameters": {
|
||||
"FREQ_HZ": [ { "value": "100000000", "resolve_type": "user", "format": "long", "usage": "all" } ],
|
||||
"FREQ_TOLERANCE_HZ": [ { "value": "0", "resolve_type": "generated", "format": "long", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"PHASE": [ { "value": "0.0", "resolve_type": "generated", "format": "float", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"CLK_DOMAIN": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"ASSOCIATED_BUSIF": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"ASSOCIATED_PORT": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"ASSOCIATED_RESET": [ { "value": "", "resolve_type": "generated", "is_ips_inferred": true, "is_static_object": false } ],
|
||||
"INSERT_VIP": [ { "value": "0", "resolve_type": "user", "format": "long", "usage": "simulation.rtl", "is_ips_inferred": true, "is_static_object": false } ]
|
||||
},
|
||||
"port_maps": {
|
||||
"CLK": [ { "physical_name": "clk" } ]
|
||||
}
|
||||
},
|
||||
"FIFO_WRITE": {
|
||||
"vlnv": "xilinx.com:interface:fifo_write:1.0",
|
||||
"abstraction_type": "xilinx.com:interface:fifo_write_rtl:1.0",
|
||||
"mode": "slave",
|
||||
"port_maps": {
|
||||
"ALMOST_FULL": [ { "physical_name": "almost_full" } ],
|
||||
"FULL": [ { "physical_name": "full" } ],
|
||||
"WR_DATA": [ { "physical_name": "din" } ],
|
||||
"WR_EN": [ { "physical_name": "wr_en" } ]
|
||||
}
|
||||
},
|
||||
"FIFO_READ": {
|
||||
"vlnv": "xilinx.com:interface:fifo_read:1.0",
|
||||
"abstraction_type": "xilinx.com:interface:fifo_read_rtl:1.0",
|
||||
"mode": "slave",
|
||||
"port_maps": {
|
||||
"EMPTY": [ { "physical_name": "empty" } ],
|
||||
"RD_DATA": [ { "physical_name": "dout" } ],
|
||||
"RD_EN": [ { "physical_name": "rd_en" } ]
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
47
rtl/ethernet-udp/tests/eth_axis/Makefile
Normal file
47
rtl/ethernet-udp/tests/eth_axis/Makefile
Normal file
@ -0,0 +1,47 @@
|
||||
# SPDX-License-Identifier: MIT
|
||||
#
|
||||
# Copyright (c) 2025 FPGA Ninja, LLC
|
||||
#
|
||||
# Authors:
|
||||
# - Alex Forencich
|
||||
#
|
||||
|
||||
# FPGA settings
|
||||
FPGA_PART = xc7a35tfgg484-1
|
||||
FPGA_TOP = ethernet_test_minimal
|
||||
FPGA_ARCH = artix7
|
||||
|
||||
RTL_DIR = ../../src
|
||||
|
||||
# Files for synthesis
|
||||
SYN_FILES = ethernet_test_minimal.v
|
||||
|
||||
include ../../../../scripts/vivado.mk
|
||||
|
||||
SYN_FILES += $(sort $(shell find ../../src -type f \( -name '*.v' -o -name '*.sv' \)))
|
||||
|
||||
XCI_FILES = $(sort $(shell find ../../src -type f -name '*.xci'))
|
||||
|
||||
program: $(PROJECT).bit
|
||||
echo "open_hw_manager" > program.tcl
|
||||
echo "connect_hw_server" >> program.tcl
|
||||
echo "open_hw_target" >> program.tcl
|
||||
echo "current_hw_device [lindex [get_hw_devices] 0]" >> program.tcl
|
||||
echo "refresh_hw_device -update_hw_probes false [current_hw_device]" >> program.tcl
|
||||
echo "set_property PROGRAM.FILE {$(PROJECT).bit} [current_hw_device]" >> program.tcl
|
||||
echo "program_hw_devices [current_hw_device]" >> program.tcl
|
||||
echo "exit" >> program.tcl
|
||||
vivado -nojournal -nolog -mode batch -source program.tcl
|
||||
|
||||
$(PROJECT).mcs $(PROJECT).prm: $(PROJECT).bit
|
||||
echo "write_cfgmem -force -format mcs -size 16 -interface SPIx4 -loadbit {up 0x0000000 $*.bit} -checksum -file $*.mcs" > generate_mcs.tcl
|
||||
echo "exit" >> generate_mcs.tcl
|
||||
vivado -nojournal -nolog -mode batch -source generate_mcs.tcl
|
||||
mkdir -p rev
|
||||
COUNT=100; \
|
||||
while [ -e rev/$*_rev$$COUNT.bit ]; \
|
||||
do COUNT=$$((COUNT+1)); done; \
|
||||
COUNT=$$((COUNT-1)); \
|
||||
for x in .mcs .prm; \
|
||||
do cp $*$$x rev/$*_rev$$COUNT$$x; \
|
||||
echo "Output: rev/$*_rev$$COUNT$$x"; done;
|
||||
352
rtl/ethernet-udp/tests/eth_axis/ethernet_test_minimal.xdc
Normal file
352
rtl/ethernet-udp/tests/eth_axis/ethernet_test_minimal.xdc
Normal file
@ -0,0 +1,352 @@
|
||||
# constrains for minimal ethernet stack
|
||||
|
||||
create_clock -period 5.000 [get_ports sys_clk_p]
|
||||
set_property IOSTANDARD DIFF_SSTL15 [get_ports sys_clk_p]
|
||||
set_property IOSTANDARD DIFF_SSTL15 [get_ports sys_clk_n]
|
||||
set_property PACKAGE_PIN R4 [get_ports sys_clk_p]
|
||||
set_property PACKAGE_PIN T4 [get_ports sys_clk_n]
|
||||
|
||||
set_property PACKAGE_PIN F15 [get_ports rst_n]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports rst_n]
|
||||
|
||||
set_property PACKAGE_PIN L13 [get_ports {led[0]}]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports {led[0]}]
|
||||
set_property PACKAGE_PIN M13 [get_ports {led[1]}]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports {led[1]}]
|
||||
set_property PACKAGE_PIN K14 [get_ports {led[2]}]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports {led[2]}]
|
||||
set_property PACKAGE_PIN K13 [get_ports {led[3]}]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports {led[3]}]
|
||||
#########################ethernet######################
|
||||
create_clock -period 8.000 [get_ports rgmii_rxc]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports {rgmii_rxd[*]}]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports {rgmii_txd[*]}]
|
||||
set_property SLEW FAST [get_ports {rgmii_txd[*]}]
|
||||
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports e_mdc]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports e_mdio]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports e_reset]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports rgmii_rxc]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports rgmii_rxctl]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports rgmii_txc]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports rgmii_txctl]
|
||||
set_property SLEW FAST [get_ports rgmii_txc]
|
||||
set_property SLEW FAST [get_ports rgmii_txctl]
|
||||
|
||||
set_property PACKAGE_PIN P17 [get_ports {rgmii_rxd[3]}]
|
||||
set_property PACKAGE_PIN U17 [get_ports {rgmii_rxd[2]}]
|
||||
set_property PACKAGE_PIN U18 [get_ports {rgmii_rxd[1]}]
|
||||
set_property PACKAGE_PIN P19 [get_ports {rgmii_rxd[0]}]
|
||||
set_property PACKAGE_PIN R16 [get_ports {rgmii_txd[3]}]
|
||||
set_property PACKAGE_PIN R17 [get_ports {rgmii_txd[2]}]
|
||||
set_property PACKAGE_PIN P16 [get_ports {rgmii_txd[1]}]
|
||||
set_property PACKAGE_PIN N14 [get_ports {rgmii_txd[0]}]
|
||||
set_property PACKAGE_PIN N13 [get_ports e_mdc]
|
||||
set_property PACKAGE_PIN P14 [get_ports e_mdio]
|
||||
set_property PACKAGE_PIN R14 [get_ports e_reset]
|
||||
set_property PACKAGE_PIN V18 [get_ports rgmii_rxc]
|
||||
set_property PACKAGE_PIN R19 [get_ports rgmii_rxctl]
|
||||
set_property PACKAGE_PIN P15 [get_ports rgmii_txc]
|
||||
set_property PACKAGE_PIN N17 [get_ports rgmii_txctl]
|
||||
|
||||
|
||||
connect_debug_port u_ila_0/probe0 [get_nets [list {mac_test0/mac_top0/mac_rx0/upper_layer_data_length[0]} {mac_test0/mac_top0/mac_rx0/upper_layer_data_length[1]} {mac_test0/mac_top0/mac_rx0/upper_layer_data_length[2]} {mac_test0/mac_top0/mac_rx0/upper_layer_data_length[3]} {mac_test0/mac_top0/mac_rx0/upper_layer_data_length[4]} {mac_test0/mac_top0/mac_rx0/upper_layer_data_length[5]} {mac_test0/mac_top0/mac_rx0/upper_layer_data_length[6]} {mac_test0/mac_top0/mac_rx0/upper_layer_data_length[7]} {mac_test0/mac_top0/mac_rx0/upper_layer_data_length[8]} {mac_test0/mac_top0/mac_rx0/upper_layer_data_length[9]} {mac_test0/mac_top0/mac_rx0/upper_layer_data_length[10]} {mac_test0/mac_top0/mac_rx0/upper_layer_data_length[11]} {mac_test0/mac_top0/mac_rx0/upper_layer_data_length[12]} {mac_test0/mac_top0/mac_rx0/upper_layer_data_length[13]} {mac_test0/mac_top0/mac_rx0/upper_layer_data_length[14]} {mac_test0/mac_top0/mac_rx0/upper_layer_data_length[15]}]]
|
||||
connect_debug_port u_ila_0/probe1 [get_nets [list {mac_test0/mac_top0/mac_rx0/udp_rec_ram_read_addr[0]} {mac_test0/mac_top0/mac_rx0/udp_rec_ram_read_addr[1]} {mac_test0/mac_top0/mac_rx0/udp_rec_ram_read_addr[2]} {mac_test0/mac_top0/mac_rx0/udp_rec_ram_read_addr[3]} {mac_test0/mac_top0/mac_rx0/udp_rec_ram_read_addr[4]} {mac_test0/mac_top0/mac_rx0/udp_rec_ram_read_addr[5]} {mac_test0/mac_top0/mac_rx0/udp_rec_ram_read_addr[6]} {mac_test0/mac_top0/mac_rx0/udp_rec_ram_read_addr[7]} {mac_test0/mac_top0/mac_rx0/udp_rec_ram_read_addr[8]} {mac_test0/mac_top0/mac_rx0/udp_rec_ram_read_addr[9]} {mac_test0/mac_top0/mac_rx0/udp_rec_ram_read_addr[10]}]]
|
||||
connect_debug_port u_ila_0/probe2 [get_nets [list {mac_test0/mac_top0/mac_rx0/udp_rec_ram_rdata[0]} {mac_test0/mac_top0/mac_rx0/udp_rec_ram_rdata[1]} {mac_test0/mac_top0/mac_rx0/udp_rec_ram_rdata[2]} {mac_test0/mac_top0/mac_rx0/udp_rec_ram_rdata[3]} {mac_test0/mac_top0/mac_rx0/udp_rec_ram_rdata[4]} {mac_test0/mac_top0/mac_rx0/udp_rec_ram_rdata[5]} {mac_test0/mac_top0/mac_rx0/udp_rec_ram_rdata[6]} {mac_test0/mac_top0/mac_rx0/udp_rec_ram_rdata[7]}]]
|
||||
connect_debug_port u_ila_0/probe3 [get_nets [list {mac_test0/mac_top0/mac_rx0/udp_rec_data_length[0]} {mac_test0/mac_top0/mac_rx0/udp_rec_data_length[1]} {mac_test0/mac_top0/mac_rx0/udp_rec_data_length[2]} {mac_test0/mac_top0/mac_rx0/udp_rec_data_length[3]} {mac_test0/mac_top0/mac_rx0/udp_rec_data_length[4]} {mac_test0/mac_top0/mac_rx0/udp_rec_data_length[5]} {mac_test0/mac_top0/mac_rx0/udp_rec_data_length[6]} {mac_test0/mac_top0/mac_rx0/udp_rec_data_length[7]} {mac_test0/mac_top0/mac_rx0/udp_rec_data_length[8]} {mac_test0/mac_top0/mac_rx0/udp_rec_data_length[9]} {mac_test0/mac_top0/mac_rx0/udp_rec_data_length[10]} {mac_test0/mac_top0/mac_rx0/udp_rec_data_length[11]} {mac_test0/mac_top0/mac_rx0/udp_rec_data_length[12]} {mac_test0/mac_top0/mac_rx0/udp_rec_data_length[13]} {mac_test0/mac_top0/mac_rx0/udp_rec_data_length[14]} {mac_test0/mac_top0/mac_rx0/udp_rec_data_length[15]}]]
|
||||
connect_debug_port u_ila_0/probe4 [get_nets [list {mac_test0/mac_top0/mac_rx0/mac_rx_dataout[0]} {mac_test0/mac_top0/mac_rx0/mac_rx_dataout[1]} {mac_test0/mac_top0/mac_rx0/mac_rx_dataout[2]} {mac_test0/mac_top0/mac_rx0/mac_rx_dataout[3]} {mac_test0/mac_top0/mac_rx0/mac_rx_dataout[4]} {mac_test0/mac_top0/mac_rx0/mac_rx_dataout[5]} {mac_test0/mac_top0/mac_rx0/mac_rx_dataout[6]} {mac_test0/mac_top0/mac_rx0/mac_rx_dataout[7]}]]
|
||||
connect_debug_port u_ila_0/probe5 [get_nets [list {mac_test0/mac_top0/mac_rx0/ip_total_data_length[0]} {mac_test0/mac_top0/mac_rx0/ip_total_data_length[1]} {mac_test0/mac_top0/mac_rx0/ip_total_data_length[2]} {mac_test0/mac_top0/mac_rx0/ip_total_data_length[3]} {mac_test0/mac_top0/mac_rx0/ip_total_data_length[4]} {mac_test0/mac_top0/mac_rx0/ip_total_data_length[5]} {mac_test0/mac_top0/mac_rx0/ip_total_data_length[6]} {mac_test0/mac_top0/mac_rx0/ip_total_data_length[7]} {mac_test0/mac_top0/mac_rx0/ip_total_data_length[8]} {mac_test0/mac_top0/mac_rx0/ip_total_data_length[9]} {mac_test0/mac_top0/mac_rx0/ip_total_data_length[10]} {mac_test0/mac_top0/mac_rx0/ip_total_data_length[11]} {mac_test0/mac_top0/mac_rx0/ip_total_data_length[12]} {mac_test0/mac_top0/mac_rx0/ip_total_data_length[13]} {mac_test0/mac_top0/mac_rx0/ip_total_data_length[14]} {mac_test0/mac_top0/mac_rx0/ip_total_data_length[15]}]]
|
||||
connect_debug_port u_ila_0/probe6 [get_nets [list {mac_test0/mac_top0/mac_rx0/mac_rx_datain[0]} {mac_test0/mac_top0/mac_rx0/mac_rx_datain[1]} {mac_test0/mac_top0/mac_rx0/mac_rx_datain[2]} {mac_test0/mac_top0/mac_rx0/mac_rx_datain[3]} {mac_test0/mac_top0/mac_rx0/mac_rx_datain[4]} {mac_test0/mac_top0/mac_rx0/mac_rx_datain[5]} {mac_test0/mac_top0/mac_rx0/mac_rx_datain[6]} {mac_test0/mac_top0/mac_rx0/mac_rx_datain[7]}]]
|
||||
connect_debug_port u_ila_0/probe7 [get_nets [list {mac_test0/mac_top0/mac_tx0/udp_send_data_length[0]} {mac_test0/mac_top0/mac_tx0/udp_send_data_length[1]} {mac_test0/mac_top0/mac_tx0/udp_send_data_length[2]} {mac_test0/mac_top0/mac_tx0/udp_send_data_length[3]} {mac_test0/mac_top0/mac_tx0/udp_send_data_length[4]} {mac_test0/mac_top0/mac_tx0/udp_send_data_length[5]} {mac_test0/mac_top0/mac_tx0/udp_send_data_length[6]} {mac_test0/mac_top0/mac_tx0/udp_send_data_length[7]} {mac_test0/mac_top0/mac_tx0/udp_send_data_length[8]} {mac_test0/mac_top0/mac_tx0/udp_send_data_length[9]} {mac_test0/mac_top0/mac_tx0/udp_send_data_length[10]} {mac_test0/mac_top0/mac_tx0/udp_send_data_length[11]} {mac_test0/mac_top0/mac_tx0/udp_send_data_length[12]} {mac_test0/mac_top0/mac_tx0/udp_send_data_length[13]} {mac_test0/mac_top0/mac_tx0/udp_send_data_length[14]} {mac_test0/mac_top0/mac_tx0/udp_send_data_length[15]}]]
|
||||
connect_debug_port u_ila_0/probe8 [get_nets [list {mac_test0/mac_top0/mac_tx0/ram_wr_data[0]} {mac_test0/mac_top0/mac_tx0/ram_wr_data[1]} {mac_test0/mac_top0/mac_tx0/ram_wr_data[2]} {mac_test0/mac_top0/mac_tx0/ram_wr_data[3]} {mac_test0/mac_top0/mac_tx0/ram_wr_data[4]} {mac_test0/mac_top0/mac_tx0/ram_wr_data[5]} {mac_test0/mac_top0/mac_tx0/ram_wr_data[6]} {mac_test0/mac_top0/mac_tx0/ram_wr_data[7]}]]
|
||||
connect_debug_port u_ila_0/probe9 [get_nets [list {mac_test0/mac_top0/mac_tx0/mac_tx_data[0]} {mac_test0/mac_top0/mac_tx0/mac_tx_data[1]} {mac_test0/mac_top0/mac_tx0/mac_tx_data[2]} {mac_test0/mac_top0/mac_tx0/mac_tx_data[3]} {mac_test0/mac_top0/mac_tx0/mac_tx_data[4]} {mac_test0/mac_top0/mac_tx0/mac_tx_data[5]} {mac_test0/mac_top0/mac_tx0/mac_tx_data[6]} {mac_test0/mac_top0/mac_tx0/mac_tx_data[7]}]]
|
||||
connect_debug_port u_ila_0/probe10 [get_nets [list {mac_test0/mac_top0/mac_rx0/udp0/ram_write_addr[0]} {mac_test0/mac_top0/mac_rx0/udp0/ram_write_addr[1]} {mac_test0/mac_top0/mac_rx0/udp0/ram_write_addr[2]} {mac_test0/mac_top0/mac_rx0/udp0/ram_write_addr[3]} {mac_test0/mac_top0/mac_rx0/udp0/ram_write_addr[4]} {mac_test0/mac_top0/mac_rx0/udp0/ram_write_addr[5]} {mac_test0/mac_top0/mac_rx0/udp0/ram_write_addr[6]} {mac_test0/mac_top0/mac_rx0/udp0/ram_write_addr[7]} {mac_test0/mac_top0/mac_rx0/udp0/ram_write_addr[8]} {mac_test0/mac_top0/mac_rx0/udp0/ram_write_addr[9]} {mac_test0/mac_top0/mac_rx0/udp0/ram_write_addr[10]}]]
|
||||
connect_debug_port u_ila_0/probe19 [get_nets [list mac_test0/mac_top0/mac_tx0/almost_full]]
|
||||
connect_debug_port u_ila_0/probe27 [get_nets [list mac_test0/mac_top0/mac_tx0/mac_data_valid]]
|
||||
connect_debug_port u_ila_0/probe28 [get_nets [list mac_test0/mac_top0/mac_tx0/mac_send_end]]
|
||||
connect_debug_port u_ila_0/probe29 [get_nets [list mac_test0/mac_top0/mac_tx0/ram_wr_en]]
|
||||
connect_debug_port u_ila_0/probe30 [get_nets [list mac_test0/mac_top0/mac_rx0/udp0/ram_wr_en]]
|
||||
connect_debug_port u_ila_0/probe33 [get_nets [list mac_test0/mac_top0/mac_tx0/udp_ram_data_req]]
|
||||
connect_debug_port u_ila_0/probe34 [get_nets [list mac_test0/mac_top0/mac_rx0/udp_rec_data_valid]]
|
||||
connect_debug_port u_ila_0/probe35 [get_nets [list mac_test0/mac_top0/mac_tx0/udp_tx_end]]
|
||||
connect_debug_port u_ila_0/probe36 [get_nets [list mac_test0/mac_top0/mac_tx0/udp_tx_req]]
|
||||
|
||||
connect_debug_port u_ila_0/probe9 [get_nets [list {m_axis_rx_tdata_OBUF[0]} {m_axis_rx_tdata_OBUF[1]} {m_axis_rx_tdata_OBUF[2]} {m_axis_rx_tdata_OBUF[3]} {m_axis_rx_tdata_OBUF[4]} {m_axis_rx_tdata_OBUF[5]} {m_axis_rx_tdata_OBUF[6]} {m_axis_rx_tdata_OBUF[7]}]]
|
||||
connect_debug_port u_ila_0/probe26 [get_nets [list m_axis_rx_tlast_OBUF]]
|
||||
connect_debug_port u_ila_0/probe27 [get_nets [list m_axis_rx_tvalid_OBUF]]
|
||||
|
||||
|
||||
create_debug_core u_ila_0 ila
|
||||
set_property ALL_PROBE_SAME_MU true [get_debug_cores u_ila_0]
|
||||
set_property ALL_PROBE_SAME_MU_CNT 1 [get_debug_cores u_ila_0]
|
||||
set_property C_ADV_TRIGGER false [get_debug_cores u_ila_0]
|
||||
set_property C_DATA_DEPTH 1024 [get_debug_cores u_ila_0]
|
||||
set_property C_EN_STRG_QUAL false [get_debug_cores u_ila_0]
|
||||
set_property C_INPUT_PIPE_STAGES 0 [get_debug_cores u_ila_0]
|
||||
set_property C_TRIGIN_EN false [get_debug_cores u_ila_0]
|
||||
set_property C_TRIGOUT_EN false [get_debug_cores u_ila_0]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/clk]
|
||||
connect_debug_port u_ila_0/clk [get_nets [list rgmii_rxc_IBUF_BUFG]]
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe0]
|
||||
set_property port_width 8 [get_debug_ports u_ila_0/probe0]
|
||||
connect_debug_port u_ila_0/probe0 [get_nets [list {arbi_inst/gmii_txd[0]} {arbi_inst/gmii_txd[1]} {arbi_inst/gmii_txd[2]} {arbi_inst/gmii_txd[3]} {arbi_inst/gmii_txd[4]} {arbi_inst/gmii_txd[5]} {arbi_inst/gmii_txd[6]} {arbi_inst/gmii_txd[7]}]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe1]
|
||||
set_property port_width 8 [get_debug_ports u_ila_0/probe1]
|
||||
connect_debug_port u_ila_0/probe1 [get_nets [list {arbi_inst/gmii_rxd[0]} {arbi_inst/gmii_rxd[1]} {arbi_inst/gmii_rxd[2]} {arbi_inst/gmii_rxd[3]} {arbi_inst/gmii_rxd[4]} {arbi_inst/gmii_rxd[5]} {arbi_inst/gmii_rxd[6]} {arbi_inst/gmii_rxd[7]}]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe2]
|
||||
set_property port_width 8 [get_debug_ports u_ila_0/probe2]
|
||||
connect_debug_port u_ila_0/probe2 [get_nets [list {arbi_inst/e_txd[0]} {arbi_inst/e_txd[1]} {arbi_inst/e_txd[2]} {arbi_inst/e_txd[3]} {arbi_inst/e_txd[4]} {arbi_inst/e_txd[5]} {arbi_inst/e_txd[6]} {arbi_inst/e_txd[7]}]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe3]
|
||||
set_property port_width 8 [get_debug_ports u_ila_0/probe3]
|
||||
connect_debug_port u_ila_0/probe3 [get_nets [list {arbi_inst/e_rxd[0]} {arbi_inst/e_rxd[1]} {arbi_inst/e_rxd[2]} {arbi_inst/e_rxd[3]} {arbi_inst/e_rxd[4]} {arbi_inst/e_rxd[5]} {arbi_inst/e_rxd[6]} {arbi_inst/e_rxd[7]}]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe4]
|
||||
set_property port_width 8 [get_debug_ports u_ila_0/probe4]
|
||||
connect_debug_port u_ila_0/probe4 [get_nets [list {arbi_inst/tx_buffer_inst/tx_wdata[0]} {arbi_inst/tx_buffer_inst/tx_wdata[1]} {arbi_inst/tx_buffer_inst/tx_wdata[2]} {arbi_inst/tx_buffer_inst/tx_wdata[3]} {arbi_inst/tx_buffer_inst/tx_wdata[4]} {arbi_inst/tx_buffer_inst/tx_wdata[5]} {arbi_inst/tx_buffer_inst/tx_wdata[6]} {arbi_inst/tx_buffer_inst/tx_wdata[7]}]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe5]
|
||||
set_property port_width 8 [get_debug_ports u_ila_0/probe5]
|
||||
connect_debug_port u_ila_0/probe5 [get_nets [list {arbi_inst/tx_buffer_inst/tx_rdata[0]} {arbi_inst/tx_buffer_inst/tx_rdata[1]} {arbi_inst/tx_buffer_inst/tx_rdata[2]} {arbi_inst/tx_buffer_inst/tx_rdata[3]} {arbi_inst/tx_buffer_inst/tx_rdata[4]} {arbi_inst/tx_buffer_inst/tx_rdata[5]} {arbi_inst/tx_buffer_inst/tx_rdata[6]} {arbi_inst/tx_buffer_inst/tx_rdata[7]}]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe6]
|
||||
set_property port_width 16 [get_debug_ports u_ila_0/probe6]
|
||||
connect_debug_port u_ila_0/probe6 [get_nets [list {arbi_inst/tx_buffer_inst/tx_data_cnt[0]} {arbi_inst/tx_buffer_inst/tx_data_cnt[1]} {arbi_inst/tx_buffer_inst/tx_data_cnt[2]} {arbi_inst/tx_buffer_inst/tx_data_cnt[3]} {arbi_inst/tx_buffer_inst/tx_data_cnt[4]} {arbi_inst/tx_buffer_inst/tx_data_cnt[5]} {arbi_inst/tx_buffer_inst/tx_data_cnt[6]} {arbi_inst/tx_buffer_inst/tx_data_cnt[7]} {arbi_inst/tx_buffer_inst/tx_data_cnt[8]} {arbi_inst/tx_buffer_inst/tx_data_cnt[9]} {arbi_inst/tx_buffer_inst/tx_data_cnt[10]} {arbi_inst/tx_buffer_inst/tx_data_cnt[11]} {arbi_inst/tx_buffer_inst/tx_data_cnt[12]} {arbi_inst/tx_buffer_inst/tx_data_cnt[13]} {arbi_inst/tx_buffer_inst/tx_data_cnt[14]} {arbi_inst/tx_buffer_inst/tx_data_cnt[15]}]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe7]
|
||||
set_property port_width 8 [get_debug_ports u_ila_0/probe7]
|
||||
connect_debug_port u_ila_0/probe7 [get_nets [list {arbi_inst/rx_buffer_inst/e10_100_rxd[0]} {arbi_inst/rx_buffer_inst/e10_100_rxd[1]} {arbi_inst/rx_buffer_inst/e10_100_rxd[2]} {arbi_inst/rx_buffer_inst/e10_100_rxd[3]} {arbi_inst/rx_buffer_inst/e10_100_rxd[4]} {arbi_inst/rx_buffer_inst/e10_100_rxd[5]} {arbi_inst/rx_buffer_inst/e10_100_rxd[6]} {arbi_inst/rx_buffer_inst/e10_100_rxd[7]}]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe8]
|
||||
set_property port_width 2 [get_debug_ports u_ila_0/probe8]
|
||||
connect_debug_port u_ila_0/probe8 [get_nets [list {axis_mac_inst/rx_state[0]} {axis_mac_inst/rx_state[1]}]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe9]
|
||||
set_property port_width 16 [get_debug_ports u_ila_0/probe9]
|
||||
connect_debug_port u_ila_0/probe9 [get_nets [list {axis_mac_inst/rx_payload_len[0]} {axis_mac_inst/rx_payload_len[1]} {axis_mac_inst/rx_payload_len[2]} {axis_mac_inst/rx_payload_len[3]} {axis_mac_inst/rx_payload_len[4]} {axis_mac_inst/rx_payload_len[5]} {axis_mac_inst/rx_payload_len[6]} {axis_mac_inst/rx_payload_len[7]} {axis_mac_inst/rx_payload_len[8]} {axis_mac_inst/rx_payload_len[9]} {axis_mac_inst/rx_payload_len[10]} {axis_mac_inst/rx_payload_len[11]} {axis_mac_inst/rx_payload_len[12]} {axis_mac_inst/rx_payload_len[13]} {axis_mac_inst/rx_payload_len[14]} {axis_mac_inst/rx_payload_len[15]}]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe10]
|
||||
set_property port_width 16 [get_debug_ports u_ila_0/probe10]
|
||||
connect_debug_port u_ila_0/probe10 [get_nets [list {axis_mac_inst/rx_index[0]} {axis_mac_inst/rx_index[1]} {axis_mac_inst/rx_index[2]} {axis_mac_inst/rx_index[3]} {axis_mac_inst/rx_index[4]} {axis_mac_inst/rx_index[5]} {axis_mac_inst/rx_index[6]} {axis_mac_inst/rx_index[7]} {axis_mac_inst/rx_index[8]} {axis_mac_inst/rx_index[9]} {axis_mac_inst/rx_index[10]} {axis_mac_inst/rx_index[11]} {axis_mac_inst/rx_index[12]} {axis_mac_inst/rx_index[13]} {axis_mac_inst/rx_index[14]} {axis_mac_inst/rx_index[15]}]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe11]
|
||||
set_property port_width 8 [get_debug_ports u_ila_0/probe11]
|
||||
connect_debug_port u_ila_0/probe11 [get_nets [list {axis_mac_inst/m_axis_rx_tdata[0]} {axis_mac_inst/m_axis_rx_tdata[1]} {axis_mac_inst/m_axis_rx_tdata[2]} {axis_mac_inst/m_axis_rx_tdata[3]} {axis_mac_inst/m_axis_rx_tdata[4]} {axis_mac_inst/m_axis_rx_tdata[5]} {axis_mac_inst/m_axis_rx_tdata[6]} {axis_mac_inst/m_axis_rx_tdata[7]}]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe12]
|
||||
set_property port_width 8 [get_debug_ports u_ila_0/probe12]
|
||||
connect_debug_port u_ila_0/probe12 [get_nets [list {axis_mac_inst/mac_top0/mac_tx0/mac_tx_data[0]} {axis_mac_inst/mac_top0/mac_tx0/mac_tx_data[1]} {axis_mac_inst/mac_top0/mac_tx0/mac_tx_data[2]} {axis_mac_inst/mac_top0/mac_tx0/mac_tx_data[3]} {axis_mac_inst/mac_top0/mac_tx0/mac_tx_data[4]} {axis_mac_inst/mac_top0/mac_tx0/mac_tx_data[5]} {axis_mac_inst/mac_top0/mac_tx0/mac_tx_data[6]} {axis_mac_inst/mac_top0/mac_tx0/mac_tx_data[7]}]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe13]
|
||||
set_property port_width 16 [get_debug_ports u_ila_0/probe13]
|
||||
connect_debug_port u_ila_0/probe13 [get_nets [list {axis_mac_inst/mac_top0/mac_rx0/upper_layer_data_length[0]} {axis_mac_inst/mac_top0/mac_rx0/upper_layer_data_length[1]} {axis_mac_inst/mac_top0/mac_rx0/upper_layer_data_length[2]} {axis_mac_inst/mac_top0/mac_rx0/upper_layer_data_length[3]} {axis_mac_inst/mac_top0/mac_rx0/upper_layer_data_length[4]} {axis_mac_inst/mac_top0/mac_rx0/upper_layer_data_length[5]} {axis_mac_inst/mac_top0/mac_rx0/upper_layer_data_length[6]} {axis_mac_inst/mac_top0/mac_rx0/upper_layer_data_length[7]} {axis_mac_inst/mac_top0/mac_rx0/upper_layer_data_length[8]} {axis_mac_inst/mac_top0/mac_rx0/upper_layer_data_length[9]} {axis_mac_inst/mac_top0/mac_rx0/upper_layer_data_length[10]} {axis_mac_inst/mac_top0/mac_rx0/upper_layer_data_length[11]} {axis_mac_inst/mac_top0/mac_rx0/upper_layer_data_length[12]} {axis_mac_inst/mac_top0/mac_rx0/upper_layer_data_length[13]} {axis_mac_inst/mac_top0/mac_rx0/upper_layer_data_length[14]} {axis_mac_inst/mac_top0/mac_rx0/upper_layer_data_length[15]}]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe14]
|
||||
set_property port_width 11 [get_debug_ports u_ila_0/probe14]
|
||||
connect_debug_port u_ila_0/probe14 [get_nets [list {axis_mac_inst/mac_top0/mac_rx0/udp_rec_ram_read_addr[0]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_ram_read_addr[1]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_ram_read_addr[2]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_ram_read_addr[3]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_ram_read_addr[4]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_ram_read_addr[5]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_ram_read_addr[6]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_ram_read_addr[7]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_ram_read_addr[8]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_ram_read_addr[9]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_ram_read_addr[10]}]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe15]
|
||||
set_property port_width 8 [get_debug_ports u_ila_0/probe15]
|
||||
connect_debug_port u_ila_0/probe15 [get_nets [list {axis_mac_inst/mac_top0/mac_rx0/udp_rec_ram_rdata[0]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_ram_rdata[1]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_ram_rdata[2]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_ram_rdata[3]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_ram_rdata[4]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_ram_rdata[5]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_ram_rdata[6]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_ram_rdata[7]}]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe16]
|
||||
set_property port_width 16 [get_debug_ports u_ila_0/probe16]
|
||||
connect_debug_port u_ila_0/probe16 [get_nets [list {axis_mac_inst/mac_top0/mac_rx0/udp_rec_data_length[0]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_data_length[1]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_data_length[2]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_data_length[3]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_data_length[4]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_data_length[5]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_data_length[6]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_data_length[7]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_data_length[8]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_data_length[9]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_data_length[10]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_data_length[11]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_data_length[12]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_data_length[13]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_data_length[14]} {axis_mac_inst/mac_top0/mac_rx0/udp_rec_data_length[15]}]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe17]
|
||||
set_property port_width 8 [get_debug_ports u_ila_0/probe17]
|
||||
connect_debug_port u_ila_0/probe17 [get_nets [list {axis_mac_inst/mac_top0/mac_rx0/mac_rx_dataout[0]} {axis_mac_inst/mac_top0/mac_rx0/mac_rx_dataout[1]} {axis_mac_inst/mac_top0/mac_rx0/mac_rx_dataout[2]} {axis_mac_inst/mac_top0/mac_rx0/mac_rx_dataout[3]} {axis_mac_inst/mac_top0/mac_rx0/mac_rx_dataout[4]} {axis_mac_inst/mac_top0/mac_rx0/mac_rx_dataout[5]} {axis_mac_inst/mac_top0/mac_rx0/mac_rx_dataout[6]} {axis_mac_inst/mac_top0/mac_rx0/mac_rx_dataout[7]}]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe18]
|
||||
set_property port_width 16 [get_debug_ports u_ila_0/probe18]
|
||||
connect_debug_port u_ila_0/probe18 [get_nets [list {axis_mac_inst/mac_top0/mac_rx0/ip_total_data_length[0]} {axis_mac_inst/mac_top0/mac_rx0/ip_total_data_length[1]} {axis_mac_inst/mac_top0/mac_rx0/ip_total_data_length[2]} {axis_mac_inst/mac_top0/mac_rx0/ip_total_data_length[3]} {axis_mac_inst/mac_top0/mac_rx0/ip_total_data_length[4]} {axis_mac_inst/mac_top0/mac_rx0/ip_total_data_length[5]} {axis_mac_inst/mac_top0/mac_rx0/ip_total_data_length[6]} {axis_mac_inst/mac_top0/mac_rx0/ip_total_data_length[7]} {axis_mac_inst/mac_top0/mac_rx0/ip_total_data_length[8]} {axis_mac_inst/mac_top0/mac_rx0/ip_total_data_length[9]} {axis_mac_inst/mac_top0/mac_rx0/ip_total_data_length[10]} {axis_mac_inst/mac_top0/mac_rx0/ip_total_data_length[11]} {axis_mac_inst/mac_top0/mac_rx0/ip_total_data_length[12]} {axis_mac_inst/mac_top0/mac_rx0/ip_total_data_length[13]} {axis_mac_inst/mac_top0/mac_rx0/ip_total_data_length[14]} {axis_mac_inst/mac_top0/mac_rx0/ip_total_data_length[15]}]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe19]
|
||||
set_property port_width 8 [get_debug_ports u_ila_0/probe19]
|
||||
connect_debug_port u_ila_0/probe19 [get_nets [list {axis_mac_inst/mac_top0/mac_rx0/mac_rx_datain[0]} {axis_mac_inst/mac_top0/mac_rx0/mac_rx_datain[1]} {axis_mac_inst/mac_top0/mac_rx0/mac_rx_datain[2]} {axis_mac_inst/mac_top0/mac_rx0/mac_rx_datain[3]} {axis_mac_inst/mac_top0/mac_rx0/mac_rx_datain[4]} {axis_mac_inst/mac_top0/mac_rx0/mac_rx_datain[5]} {axis_mac_inst/mac_top0/mac_rx0/mac_rx_datain[6]} {axis_mac_inst/mac_top0/mac_rx0/mac_rx_datain[7]}]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe20]
|
||||
set_property port_width 11 [get_debug_ports u_ila_0/probe20]
|
||||
connect_debug_port u_ila_0/probe20 [get_nets [list {axis_mac_inst/mac_top0/mac_rx0/udp0/ram_write_addr[0]} {axis_mac_inst/mac_top0/mac_rx0/udp0/ram_write_addr[1]} {axis_mac_inst/mac_top0/mac_rx0/udp0/ram_write_addr[2]} {axis_mac_inst/mac_top0/mac_rx0/udp0/ram_write_addr[3]} {axis_mac_inst/mac_top0/mac_rx0/udp0/ram_write_addr[4]} {axis_mac_inst/mac_top0/mac_rx0/udp0/ram_write_addr[5]} {axis_mac_inst/mac_top0/mac_rx0/udp0/ram_write_addr[6]} {axis_mac_inst/mac_top0/mac_rx0/udp0/ram_write_addr[7]} {axis_mac_inst/mac_top0/mac_rx0/udp0/ram_write_addr[8]} {axis_mac_inst/mac_top0/mac_rx0/udp0/ram_write_addr[9]} {axis_mac_inst/mac_top0/mac_rx0/udp0/ram_write_addr[10]}]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe21]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe21]
|
||||
connect_debug_port u_ila_0/probe21 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/almost_full]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe22]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe22]
|
||||
connect_debug_port u_ila_0/probe22 [get_nets [list arbi_inst/rx_buffer_inst/e10_100_rx_dv]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe23]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe23]
|
||||
connect_debug_port u_ila_0/probe23 [get_nets [list arbi_inst/e_rx_dv]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe24]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe24]
|
||||
connect_debug_port u_ila_0/probe24 [get_nets [list arbi_inst/e_tx_en]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe25]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe25]
|
||||
connect_debug_port u_ila_0/probe25 [get_nets [list arbi_inst/gmii_rx_dv]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe26]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe26]
|
||||
connect_debug_port u_ila_0/probe26 [get_nets [list arbi_inst/rx_buffer_inst/gmii_rx_dv_d0]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe27]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe27]
|
||||
connect_debug_port u_ila_0/probe27 [get_nets [list arbi_inst/rx_buffer_inst/gmii_rx_dv_d1]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe28]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe28]
|
||||
connect_debug_port u_ila_0/probe28 [get_nets [list arbi_inst/gmii_tx_en]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe29]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe29]
|
||||
connect_debug_port u_ila_0/probe29 [get_nets [list axis_mac_inst/m_axis_rx_tlast]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe30]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe30]
|
||||
connect_debug_port u_ila_0/probe30 [get_nets [list axis_mac_inst/m_axis_rx_tvalid]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe31]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe31]
|
||||
connect_debug_port u_ila_0/probe31 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/mac_data_valid]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe32]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe32]
|
||||
connect_debug_port u_ila_0/probe32 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/mac_send_end]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe33]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe33]
|
||||
connect_debug_port u_ila_0/probe33 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_0]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe34]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe34]
|
||||
connect_debug_port u_ila_0/probe34 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_1]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe35]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe35]
|
||||
connect_debug_port u_ila_0/probe35 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_2]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe36]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe36]
|
||||
connect_debug_port u_ila_0/probe36 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_3]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe37]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe37]
|
||||
connect_debug_port u_ila_0/probe37 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_4]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe38]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe38]
|
||||
connect_debug_port u_ila_0/probe38 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_5]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe39]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe39]
|
||||
connect_debug_port u_ila_0/probe39 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_6]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe40]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe40]
|
||||
connect_debug_port u_ila_0/probe40 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_7]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe41]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe41]
|
||||
connect_debug_port u_ila_0/probe41 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_8]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe42]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe42]
|
||||
connect_debug_port u_ila_0/probe42 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_9]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe43]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe43]
|
||||
connect_debug_port u_ila_0/probe43 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_10]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe44]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe44]
|
||||
connect_debug_port u_ila_0/probe44 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_11]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe45]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe45]
|
||||
connect_debug_port u_ila_0/probe45 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_12]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe46]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe46]
|
||||
connect_debug_port u_ila_0/probe46 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_13]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe47]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe47]
|
||||
connect_debug_port u_ila_0/probe47 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_14]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe48]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe48]
|
||||
connect_debug_port u_ila_0/probe48 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_15]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe49]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe49]
|
||||
connect_debug_port u_ila_0/probe49 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_16]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe50]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe50]
|
||||
connect_debug_port u_ila_0/probe50 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_17]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe51]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe51]
|
||||
connect_debug_port u_ila_0/probe51 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_18]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe52]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe52]
|
||||
connect_debug_port u_ila_0/probe52 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_19]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe53]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe53]
|
||||
connect_debug_port u_ila_0/probe53 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_20]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe54]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe54]
|
||||
connect_debug_port u_ila_0/probe54 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_21]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe55]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe55]
|
||||
connect_debug_port u_ila_0/probe55 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_22]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe56]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe56]
|
||||
connect_debug_port u_ila_0/probe56 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_23]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe57]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe57]
|
||||
connect_debug_port u_ila_0/probe57 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_24]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe58]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe58]
|
||||
connect_debug_port u_ila_0/probe58 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/n_0_25]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe59]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe59]
|
||||
connect_debug_port u_ila_0/probe59 [get_nets [list axis_mac_inst/mac_top0/mac_rx0/udp0/ram_wr_en]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe60]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe60]
|
||||
connect_debug_port u_ila_0/probe60 [get_nets [list arbi_inst/tx_buffer_inst/tx_rden]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe61]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe61]
|
||||
connect_debug_port u_ila_0/probe61 [get_nets [list arbi_inst/tx_buffer_inst/tx_wren]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe62]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe62]
|
||||
connect_debug_port u_ila_0/probe62 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/udp_ram_data_req]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe63]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe63]
|
||||
connect_debug_port u_ila_0/probe63 [get_nets [list axis_mac_inst/mac_top0/mac_rx0/udp_rec_data_valid]]
|
||||
create_debug_port u_ila_0 probe
|
||||
set_property PROBE_TYPE DATA_AND_TRIGGER [get_debug_ports u_ila_0/probe64]
|
||||
set_property port_width 1 [get_debug_ports u_ila_0/probe64]
|
||||
connect_debug_port u_ila_0/probe64 [get_nets [list axis_mac_inst/mac_top0/mac_tx0/udp_tx_end]]
|
||||
set_property C_CLK_INPUT_FREQ_HZ 300000000 [get_debug_cores dbg_hub]
|
||||
set_property C_ENABLE_CLK_DIVIDER false [get_debug_cores dbg_hub]
|
||||
set_property C_USER_SCAN_CHAIN 1 [get_debug_cores dbg_hub]
|
||||
connect_debug_port dbg_hub/clk [get_nets rgmii_rxc_IBUF_BUFG]
|
||||
47
rtl/ethernet-udp/tests/eth_minimal/Makefile
Normal file
47
rtl/ethernet-udp/tests/eth_minimal/Makefile
Normal file
@ -0,0 +1,47 @@
|
||||
# SPDX-License-Identifier: MIT
|
||||
#
|
||||
# Copyright (c) 2025 FPGA Ninja, LLC
|
||||
#
|
||||
# Authors:
|
||||
# - Alex Forencich
|
||||
#
|
||||
|
||||
# FPGA settings
|
||||
FPGA_PART = xc7a35tfgg484-1
|
||||
FPGA_TOP = ethernet_test_minimal
|
||||
FPGA_ARCH = artix7
|
||||
|
||||
RTL_DIR = ../../src
|
||||
|
||||
# Files for synthesis
|
||||
SYN_FILES = ethernet_test_minimal.v
|
||||
|
||||
include ../../../../scripts/vivado.mk
|
||||
|
||||
SYN_FILES += $(sort $(shell find ../../src -type f \( -name '*.v' -o -name '*.sv' \)))
|
||||
|
||||
XCI_FILES = $(sort $(shell find ../../src -type f -name '*.xci'))
|
||||
|
||||
program: $(PROJECT).bit
|
||||
echo "open_hw_manager" > program.tcl
|
||||
echo "connect_hw_server" >> program.tcl
|
||||
echo "open_hw_target" >> program.tcl
|
||||
echo "current_hw_device [lindex [get_hw_devices] 0]" >> program.tcl
|
||||
echo "refresh_hw_device -update_hw_probes false [current_hw_device]" >> program.tcl
|
||||
echo "set_property PROGRAM.FILE {$(PROJECT).bit} [current_hw_device]" >> program.tcl
|
||||
echo "program_hw_devices [current_hw_device]" >> program.tcl
|
||||
echo "exit" >> program.tcl
|
||||
vivado -nojournal -nolog -mode batch -source program.tcl
|
||||
|
||||
$(PROJECT).mcs $(PROJECT).prm: $(PROJECT).bit
|
||||
echo "write_cfgmem -force -format mcs -size 16 -interface SPIx4 -loadbit {up 0x0000000 $*.bit} -checksum -file $*.mcs" > generate_mcs.tcl
|
||||
echo "exit" >> generate_mcs.tcl
|
||||
vivado -nojournal -nolog -mode batch -source generate_mcs.tcl
|
||||
mkdir -p rev
|
||||
COUNT=100; \
|
||||
while [ -e rev/$*_rev$$COUNT.bit ]; \
|
||||
do COUNT=$$((COUNT+1)); done; \
|
||||
COUNT=$$((COUNT-1)); \
|
||||
for x in .mcs .prm; \
|
||||
do cp $*$$x rev/$*_rev$$COUNT$$x; \
|
||||
echo "Output: rev/$*_rev$$COUNT$$x"; done;
|
||||
162
rtl/ethernet-udp/tests/eth_minimal/ethernet_test_minimal.v
Normal file
162
rtl/ethernet-udp/tests/eth_minimal/ethernet_test_minimal.v
Normal file
@ -0,0 +1,162 @@
|
||||
//////////////////////////////////////////////////////////////////////////////////
|
||||
// //
|
||||
// //
|
||||
// Author: lhj //
|
||||
// //
|
||||
// ALINX(shanghai) Technology Co.,Ltd //
|
||||
// heijin //
|
||||
// WEB: http://www.alinx.com/ //
|
||||
// BBS: http://www.heijin.org/ //
|
||||
// //
|
||||
//////////////////////////////////////////////////////////////////////////////////
|
||||
// //
|
||||
// Copyright (c) 2017,ALINX(shanghai) Technology Co.,Ltd //
|
||||
// All rights reserved //
|
||||
// //
|
||||
// This source file may be used and distributed without restriction provided //
|
||||
// that this copyright statement is not removed from the file and that any //
|
||||
// derivative work contains the original copyright notice and the associated //
|
||||
// disclaimer. //
|
||||
// //
|
||||
//////////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
//================================================================================
|
||||
// Revision History:
|
||||
// Date By Revision Change Description
|
||||
//--------------------------------------------------------------------------------
|
||||
// 2019/08/19
|
||||
//*******************************************************************************/
|
||||
module ethernet_test_minimal
|
||||
(
|
||||
input sys_clk_p, //system clock positive
|
||||
input sys_clk_n, //system clock negative
|
||||
input rst_n, //reset ,low active
|
||||
output [3:0] led, //display network rate status
|
||||
output e_reset, //phy reset
|
||||
output e_mdc, //phy emdio clock
|
||||
inout e_mdio, //phy emdio data
|
||||
output[3:0] rgmii_txd, //phy data send
|
||||
output rgmii_txctl, //phy data send control
|
||||
output rgmii_txc, //Clock for sending data
|
||||
input[3:0] rgmii_rxd, //recieve data
|
||||
input rgmii_rxctl, //Control signal for receiving data
|
||||
input rgmii_rxc //Clock for recieving data
|
||||
);
|
||||
wire [ 7:0] gmii_txd; //gmii data
|
||||
wire gmii_tx_en; //gmii send enable
|
||||
wire gmii_tx_er;
|
||||
wire gmii_tx_clk; //gmii send clock
|
||||
wire gmii_crs;
|
||||
wire gmii_col;
|
||||
wire [ 7:0] gmii_rxd; //gmii recieving data
|
||||
wire gmii_rx_dv; //gmii recieving data valid
|
||||
wire gmii_rx_er;
|
||||
wire gmii_rx_clk; //gmii recieve clock
|
||||
wire [ 1:0] speed_selection; // 1x gigabit, 01 100Mbps, 00 10mbps
|
||||
wire duplex_mode; // 1 full, 0 half
|
||||
wire rgmii_rxcpll;
|
||||
|
||||
wire [31:0] pack_total_len ; //package length
|
||||
|
||||
wire [1:0] speed ; //net speed select
|
||||
wire link ; //link status
|
||||
wire e_rx_dv ;
|
||||
wire [7:0] e_rxd ;
|
||||
wire e_tx_en ;
|
||||
wire [7:0] e_txd ;
|
||||
wire e_rst_n ;
|
||||
wire sys_clk ;
|
||||
|
||||
|
||||
assign duplex_mode = 1'b1;
|
||||
|
||||
|
||||
/*************************************************************************
|
||||
generate single end clock
|
||||
**************************************************************************/
|
||||
IBUFDS sys_clk_ibufgds
|
||||
(
|
||||
.O (sys_clk ),
|
||||
.I (sys_clk_p ),
|
||||
.IB (sys_clk_n )
|
||||
);
|
||||
|
||||
(* IODELAY_GROUP = "rgmii_idelay_group" *) // Specifies group name for associated IDELAYs/ODELAYs and IDELAYCTRL
|
||||
|
||||
IDELAYCTRL IDELAYCTRL_inst (
|
||||
.RDY(), // 1-bit output: Ready output
|
||||
.REFCLK(sys_clk), // 1-bit input: Reference clock input
|
||||
.RST(1'b0) // 1-bit input: Active high reset input
|
||||
);
|
||||
/*************************************************************************
|
||||
GMII and RGMII data conversion
|
||||
****************************************************************************/
|
||||
util_gmii_to_rgmii util_gmii_to_rgmii_m0
|
||||
(
|
||||
.reset (1'b0 ),
|
||||
.rgmii_td (rgmii_txd ),
|
||||
.rgmii_tx_ctl (rgmii_txctl ),
|
||||
.rgmii_txc (rgmii_txc ),
|
||||
.rgmii_rd (rgmii_rxd ),
|
||||
.rgmii_rx_ctl (rgmii_rxctl ),
|
||||
.gmii_rx_clk (gmii_rx_clk ),
|
||||
.gmii_txd (e_txd ),
|
||||
.gmii_tx_en (e_tx_en ),
|
||||
.gmii_tx_er (1'b0 ),
|
||||
.gmii_tx_clk (gmii_tx_clk ),
|
||||
.gmii_crs (gmii_crs ),
|
||||
.gmii_col (gmii_col ),
|
||||
.gmii_rxd (gmii_rxd ),
|
||||
.rgmii_rxc (rgmii_rxc ),//add
|
||||
.gmii_rx_dv (gmii_rx_dv ),
|
||||
.gmii_rx_er (gmii_rx_er ),
|
||||
.speed_selection (2'b10 ),
|
||||
.duplex_mode (duplex_mode )
|
||||
);
|
||||
/*************************************************************************
|
||||
Different conversion of GMII data according to different network speeds
|
||||
****************************************************************************/
|
||||
|
||||
gmii_arbi arbi_inst
|
||||
(
|
||||
.clk (gmii_tx_clk ),
|
||||
.rst_n (rst_n ),
|
||||
.speed (2'b10 ),
|
||||
.link (1'b1 ),
|
||||
.pack_total_len (pack_total_len ),
|
||||
.e_rst_n (e_rst_n ),
|
||||
.gmii_rx_dv (gmii_rx_dv ),
|
||||
.gmii_rxd (gmii_rxd ),
|
||||
.gmii_tx_en (gmii_tx_en ),
|
||||
.gmii_txd (gmii_txd ),
|
||||
.e_rx_dv (e_rx_dv ),
|
||||
.e_rxd (e_rxd ),
|
||||
.e_tx_en (e_tx_en ),
|
||||
.e_txd (e_txd )
|
||||
);
|
||||
|
||||
|
||||
/*************************************************************************
|
||||
Mac layer protocol test
|
||||
****************************************************************************/
|
||||
mac_test mac_test0
|
||||
(
|
||||
.gmii_tx_clk (gmii_tx_clk ),
|
||||
.gmii_rx_clk (gmii_rx_clk ) ,
|
||||
.rst_n (e_rst_n ),
|
||||
.pack_total_len (pack_total_len ),
|
||||
.gmii_rx_dv (e_rx_dv ),
|
||||
.gmii_rxd (e_rxd ),
|
||||
.gmii_tx_en (gmii_tx_en ),
|
||||
.gmii_txd (gmii_txd )
|
||||
);
|
||||
/*************************************************************************
|
||||
Generate PHY reset signal
|
||||
****************************************************************************/
|
||||
reset reset_m0
|
||||
(
|
||||
.clk (sys_clk ),
|
||||
.key1 (rst_n ),
|
||||
.rst_n (e_reset )
|
||||
);
|
||||
endmodule
|
||||
51
rtl/ethernet-udp/tests/eth_minimal/ethernet_test_minimal.xdc
Normal file
51
rtl/ethernet-udp/tests/eth_minimal/ethernet_test_minimal.xdc
Normal file
@ -0,0 +1,51 @@
|
||||
# constrains for minimal ethernet stack
|
||||
|
||||
create_clock -period 5.000 [get_ports sys_clk_p]
|
||||
set_property IOSTANDARD DIFF_SSTL15 [get_ports sys_clk_p]
|
||||
set_property IOSTANDARD DIFF_SSTL15 [get_ports sys_clk_n]
|
||||
set_property PACKAGE_PIN R4 [get_ports sys_clk_p]
|
||||
set_property PACKAGE_PIN T4 [get_ports sys_clk_n]
|
||||
|
||||
set_property PACKAGE_PIN F15 [get_ports rst_n]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports rst_n]
|
||||
|
||||
set_property PACKAGE_PIN L13 [get_ports {led[0]}]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports {led[0]}]
|
||||
set_property PACKAGE_PIN M13 [get_ports {led[1]}]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports {led[1]}]
|
||||
set_property PACKAGE_PIN K14 [get_ports {led[2]}]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports {led[2]}]
|
||||
set_property PACKAGE_PIN K13 [get_ports {led[3]}]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports {led[3]}]
|
||||
#########################ethernet######################
|
||||
create_clock -period 8.000 [get_ports rgmii_rxc]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports {rgmii_rxd[*]}]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports {rgmii_txd[*]}]
|
||||
set_property SLEW FAST [get_ports {rgmii_txd[*]}]
|
||||
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports e_mdc]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports e_mdio]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports e_reset]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports rgmii_rxc]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports rgmii_rxctl]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports rgmii_txc]
|
||||
set_property IOSTANDARD LVCMOS33 [get_ports rgmii_txctl]
|
||||
set_property SLEW FAST [get_ports rgmii_txc]
|
||||
set_property SLEW FAST [get_ports rgmii_txctl]
|
||||
|
||||
set_property PACKAGE_PIN P17 [get_ports {rgmii_rxd[3]}]
|
||||
set_property PACKAGE_PIN U17 [get_ports {rgmii_rxd[2]}]
|
||||
set_property PACKAGE_PIN U18 [get_ports {rgmii_rxd[1]}]
|
||||
set_property PACKAGE_PIN P19 [get_ports {rgmii_rxd[0]}]
|
||||
set_property PACKAGE_PIN R16 [get_ports {rgmii_txd[3]}]
|
||||
set_property PACKAGE_PIN R17 [get_ports {rgmii_txd[2]}]
|
||||
set_property PACKAGE_PIN P16 [get_ports {rgmii_txd[1]}]
|
||||
set_property PACKAGE_PIN N14 [get_ports {rgmii_txd[0]}]
|
||||
set_property PACKAGE_PIN N13 [get_ports e_mdc]
|
||||
set_property PACKAGE_PIN P14 [get_ports e_mdio]
|
||||
set_property PACKAGE_PIN R14 [get_ports e_reset]
|
||||
set_property PACKAGE_PIN V18 [get_ports rgmii_rxc]
|
||||
set_property PACKAGE_PIN R19 [get_ports rgmii_rxctl]
|
||||
set_property PACKAGE_PIN P15 [get_ports rgmii_txc]
|
||||
set_property PACKAGE_PIN N17 [get_ports rgmii_txctl]
|
||||
|
||||
249
rtl/ethernet-udp/tests/test_axis_mac_rx.sv
Normal file
249
rtl/ethernet-udp/tests/test_axis_mac_rx.sv
Normal file
@ -0,0 +1,249 @@
|
||||
`timescale 1ns / 1ps
|
||||
|
||||
module tb_mac_test;
|
||||
|
||||
reg rst_n = 1'b0;
|
||||
reg gmii_rx_clk = 1'b0;
|
||||
reg gmii_tx_clk = 1'b0;
|
||||
reg gmii_rx_dv = 1'b0;
|
||||
reg [7:0] gmii_rxd = 8'h00;
|
||||
|
||||
wire gmii_tx_en;
|
||||
wire [7:0] gmii_txd;
|
||||
|
||||
wire [7:0] m_axis_rx_tdata;
|
||||
wire m_axis_rx_tvalid;
|
||||
reg m_axis_rx_tready = 1'b0;
|
||||
wire m_axis_rx_tlast;
|
||||
|
||||
int cnt = 0;
|
||||
|
||||
|
||||
// ============================================================
|
||||
// DUT
|
||||
// ============================================================
|
||||
axis_mac dut (
|
||||
.rst_n(rst_n),
|
||||
.gmii_tx_clk(gmii_tx_clk),
|
||||
.gmii_rx_clk(gmii_rx_clk),
|
||||
.gmii_rx_dv(gmii_rx_dv),
|
||||
.gmii_rxd(gmii_rxd),
|
||||
.gmii_tx_en(gmii_tx_en),
|
||||
.gmii_txd(gmii_txd),
|
||||
.m_axis_rx_tdata(m_axis_rx_tdata),
|
||||
.m_axis_rx_tvalid(m_axis_rx_tvalid),
|
||||
.m_axis_rx_tready(m_axis_rx_tready),
|
||||
.m_axis_rx_tlast(m_axis_rx_tlast)
|
||||
);
|
||||
|
||||
// ============================================================
|
||||
// Clocks
|
||||
// ============================================================
|
||||
always #4 gmii_rx_clk = ~gmii_rx_clk;
|
||||
always #4 gmii_tx_clk = ~gmii_tx_clk;
|
||||
|
||||
// ============================================================
|
||||
// Helpers
|
||||
// ============================================================
|
||||
task automatic gmii_idle;
|
||||
input integer cycles;
|
||||
integer i;
|
||||
begin
|
||||
gmii_rx_dv <= 1'b0;
|
||||
gmii_rxd <= 8'h00;
|
||||
for (i = 0; i < cycles; i = i + 1) begin
|
||||
@(posedge gmii_rx_clk);
|
||||
end
|
||||
end
|
||||
endtask
|
||||
|
||||
task automatic send_gmii_byte;
|
||||
input [7:0] b;
|
||||
begin
|
||||
@(posedge gmii_rx_clk);
|
||||
gmii_rx_dv <= 1'b1;
|
||||
gmii_rxd <= b;
|
||||
end
|
||||
endtask
|
||||
|
||||
task automatic end_gmii_frame;
|
||||
begin
|
||||
@(posedge gmii_rx_clk);
|
||||
gmii_rx_dv <= 1'b0;
|
||||
gmii_rxd <= 8'h00;
|
||||
end
|
||||
endtask
|
||||
|
||||
task automatic send_gmii_frame;
|
||||
input integer frame_len;
|
||||
input [8*2048-1:0] frame_data_flat;
|
||||
integer i;
|
||||
reg [7:0] current_byte;
|
||||
begin
|
||||
gmii_idle(12);
|
||||
|
||||
for (i = 0; i < frame_len; i = i + 1) begin
|
||||
current_byte = frame_data_flat[i*8 +: 8];
|
||||
send_gmii_byte(current_byte);
|
||||
end
|
||||
|
||||
end_gmii_frame();
|
||||
|
||||
// inter-frame gap
|
||||
gmii_idle(12);
|
||||
end
|
||||
endtask
|
||||
|
||||
reg [7:0] frame_mem [0:2047];
|
||||
|
||||
task automatic send_gmii_frame_mem;
|
||||
input integer frame_len;
|
||||
integer i;
|
||||
begin
|
||||
gmii_idle(12);
|
||||
|
||||
for (i = 0; i < frame_len; i = i + 1) begin
|
||||
send_gmii_byte(frame_mem[i]);
|
||||
end
|
||||
|
||||
end_gmii_frame();
|
||||
gmii_idle(12);
|
||||
end
|
||||
endtask
|
||||
|
||||
// ============================================================
|
||||
// Monitor AXIS RX
|
||||
// ============================================================
|
||||
always @(posedge gmii_rx_clk) begin
|
||||
if (m_axis_rx_tvalid && m_axis_rx_tready) begin
|
||||
$write("%02x ", m_axis_rx_tdata);
|
||||
if (m_axis_rx_tlast)
|
||||
$write("<TLAST>");
|
||||
end
|
||||
cnt = cnt + 1;
|
||||
if (cnt % 8 < 6) begin
|
||||
m_axis_rx_tready = 1'b1;
|
||||
end else m_axis_rx_tready = 1'b0;
|
||||
end
|
||||
|
||||
// ============================================================
|
||||
// Test sequence
|
||||
// ============================================================
|
||||
integer i;
|
||||
|
||||
initial begin
|
||||
// init
|
||||
gmii_rx_dv = 1'b0;
|
||||
gmii_rxd = 8'h00;
|
||||
rst_n = 1'b0;
|
||||
|
||||
gmii_idle(200);
|
||||
rst_n = 1'b1;
|
||||
gmii_idle(200);
|
||||
|
||||
|
||||
frame_mem[0] = 8'h55;
|
||||
frame_mem[1] = 8'h55;
|
||||
frame_mem[2] = 8'h55;
|
||||
frame_mem[3] = 8'h55;
|
||||
frame_mem[4] = 8'h55;
|
||||
frame_mem[5] = 8'h55;
|
||||
frame_mem[6] = 8'h55;
|
||||
frame_mem[7] = 8'hd5;
|
||||
|
||||
frame_mem[8] = 8'h00;
|
||||
frame_mem[9] = 8'h0a;
|
||||
frame_mem[10] = 8'h35;
|
||||
frame_mem[11] = 8'h01;
|
||||
frame_mem[12] = 8'hfe;
|
||||
frame_mem[13] = 8'hc0;
|
||||
|
||||
frame_mem[14] = 8'h30;
|
||||
frame_mem[15] = 8'h56;
|
||||
frame_mem[16] = 8'h0f;
|
||||
frame_mem[17] = 8'ha0;
|
||||
frame_mem[18] = 8'h12;
|
||||
frame_mem[19] = 8'hec;
|
||||
|
||||
frame_mem[20] = 8'h08;
|
||||
frame_mem[21] = 8'h00;
|
||||
|
||||
frame_mem[22] = 8'h45;
|
||||
frame_mem[23] = 8'h00;
|
||||
frame_mem[24] = 8'h00;
|
||||
frame_mem[25] = 8'h23;
|
||||
frame_mem[26] = 8'h65;
|
||||
frame_mem[27] = 8'hfa;
|
||||
frame_mem[28] = 8'h40;
|
||||
frame_mem[29] = 8'h00;
|
||||
frame_mem[30] = 8'h40;
|
||||
frame_mem[31] = 8'h11;
|
||||
frame_mem[32] = 8'h53;
|
||||
frame_mem[33] = 8'h7a;
|
||||
|
||||
frame_mem[34] = 8'hc0;
|
||||
frame_mem[35] = 8'ha8;
|
||||
frame_mem[36] = 8'h00;
|
||||
frame_mem[37] = 8'h03;
|
||||
|
||||
frame_mem[38] = 8'hc0;
|
||||
frame_mem[39] = 8'ha8;
|
||||
frame_mem[40] = 8'h00;
|
||||
frame_mem[41] = 8'h02;
|
||||
|
||||
frame_mem[42] = 8'hc0;
|
||||
frame_mem[43] = 8'h31;
|
||||
frame_mem[44] = 8'h1f;
|
||||
frame_mem[45] = 8'h90;
|
||||
|
||||
frame_mem[46] = 8'h00;
|
||||
frame_mem[47] = 8'h0f;
|
||||
frame_mem[48] = 8'he4;
|
||||
frame_mem[49] = 8'h7f;
|
||||
|
||||
frame_mem[50] = 8'h6e;
|
||||
frame_mem[51] = 8'h65;
|
||||
frame_mem[52] = 8'h77;
|
||||
frame_mem[53] = 8'h5f;
|
||||
frame_mem[54] = 8'h6d;
|
||||
frame_mem[55] = 8'h73;
|
||||
frame_mem[56] = 8'h67;
|
||||
|
||||
// FCS
|
||||
frame_mem[57] = 8'h00;
|
||||
frame_mem[58] = 8'h00;
|
||||
frame_mem[59] = 8'h00;
|
||||
frame_mem[60] = 8'h00;
|
||||
|
||||
frame_mem[61] = 8'h00;
|
||||
frame_mem[62] = 8'h00;
|
||||
frame_mem[63] = 8'h00;
|
||||
frame_mem[64] = 8'h00;
|
||||
|
||||
frame_mem[65] = 8'h00;
|
||||
frame_mem[66] = 8'h00;
|
||||
frame_mem[67] = 8'h00;
|
||||
|
||||
frame_mem[68] = 8'h8c;
|
||||
frame_mem[69] = 8'ha2;
|
||||
frame_mem[70] = 8'h2e;
|
||||
frame_mem[71] = 8'h26;
|
||||
frame_mem[72] = 8'hdd;
|
||||
send_gmii_frame_mem(73);
|
||||
|
||||
gmii_idle(200);
|
||||
send_gmii_frame_mem(57);
|
||||
gmii_idle(20);
|
||||
send_gmii_frame_mem(57);
|
||||
gmii_idle(200);
|
||||
send_gmii_frame_mem(66);
|
||||
gmii_idle(200);
|
||||
send_gmii_frame_mem(66);
|
||||
send_gmii_frame_mem(66);
|
||||
gmii_idle(200);
|
||||
|
||||
$display("\nSimulation done");
|
||||
$finish;
|
||||
end
|
||||
|
||||
endmodule
|
||||
@ -1,99 +0,0 @@
|
||||
`timescale 1ns / 1ps
|
||||
|
||||
|
||||
module generator
|
||||
#(
|
||||
parameter DATA_WIDTH = 14
|
||||
)
|
||||
(
|
||||
input clk_in,
|
||||
input rst,
|
||||
input start,
|
||||
input [31:0] pulse_width,
|
||||
input [31:0] pulse_period,
|
||||
input [DATA_WIDTH-1:0] pulse_height,
|
||||
input [15:0] pulse_num,
|
||||
|
||||
output pulse,
|
||||
output[DATA_WIDTH-1:0] pulse_height_out
|
||||
|
||||
);
|
||||
|
||||
logic [DATA_WIDTH-1:0] pulse_height_reg, pulse_height_out_reg;
|
||||
logic pulse_reg;
|
||||
|
||||
logic [31:0] pulse_width_reg, pulse_period_reg;
|
||||
logic [15:0] pulse_num_reg;
|
||||
|
||||
logic enable;
|
||||
logic [15:0] cnt_pulse_num;
|
||||
logic [31:0] cnt_period;
|
||||
|
||||
logic start_d;
|
||||
|
||||
always @(posedge clk_in) begin
|
||||
start_d <= start;
|
||||
end
|
||||
|
||||
wire start_pulse = start & ~start_d;
|
||||
|
||||
|
||||
always @(posedge clk_in) begin
|
||||
if (rst) begin
|
||||
pulse_reg <= '0;
|
||||
pulse_height_reg <= 0;
|
||||
pulse_height_out_reg <= '0;
|
||||
|
||||
pulse_width_reg <= '0;
|
||||
pulse_period_reg <= '0;
|
||||
pulse_num_reg <= '0;
|
||||
enable <= 0;
|
||||
cnt_pulse_num <= '0;
|
||||
cnt_period <= '0;
|
||||
end else begin
|
||||
if (start) begin
|
||||
enable <= 1'b1;
|
||||
// pulse_width_reg <= pulse_width;
|
||||
// pulse_period_reg <= pulse_period;
|
||||
// pulse_num_reg <= pulse_num;
|
||||
// pulse_height_reg <= pulse_height;
|
||||
|
||||
cnt_pulse_num <= '0;
|
||||
cnt_period <= '0;
|
||||
end
|
||||
if (enable) begin
|
||||
pulse_reg <= 1;
|
||||
|
||||
pulse_width_reg <= pulse_width;
|
||||
pulse_period_reg <= pulse_period;
|
||||
pulse_num_reg <= pulse_num;
|
||||
pulse_height_reg <= pulse_height;
|
||||
|
||||
if (pulse_reg) begin
|
||||
|
||||
if (cnt_period < pulse_width_reg) begin
|
||||
pulse_height_out_reg <= pulse_height_reg;
|
||||
end else begin
|
||||
pulse_height_out_reg <= '0;
|
||||
end
|
||||
if (cnt_period == pulse_period_reg - 1) begin
|
||||
cnt_period <= 0;
|
||||
if (cnt_pulse_num == pulse_num_reg - 1) begin
|
||||
enable <= 0;
|
||||
pulse_reg <= 0;
|
||||
end else begin
|
||||
cnt_pulse_num <= cnt_pulse_num + 1;
|
||||
end
|
||||
end else begin
|
||||
cnt_period <= cnt_period + 1;
|
||||
end
|
||||
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
assign pulse_height_out = pulse_height_out_reg;
|
||||
assign pulse = pulse_reg;
|
||||
|
||||
endmodule
|
||||
|
||||
@ -1,105 +0,0 @@
|
||||
`timescale 1ns / 1ps
|
||||
|
||||
module generator_tb;
|
||||
|
||||
parameter DATA_WIDTH = 14;
|
||||
parameter CLK_PERIOD = 16;
|
||||
|
||||
logic clk;
|
||||
logic rst;
|
||||
logic start;
|
||||
|
||||
logic [31:0] pulse_width;
|
||||
logic [31:0] pulse_period;
|
||||
logic [DATA_WIDTH-1:0] pulse_height;
|
||||
logic [15:0] pulse_num;
|
||||
|
||||
logic pulse;
|
||||
logic [DATA_WIDTH-1:0] pulse_height_out;
|
||||
|
||||
// DUT
|
||||
generator #(
|
||||
.DATA_WIDTH(DATA_WIDTH)
|
||||
) dut (
|
||||
.clk_in(clk),
|
||||
.rst(rst),
|
||||
.start(start),
|
||||
.pulse_width(pulse_width),
|
||||
.pulse_period(pulse_period),
|
||||
.pulse_height(pulse_height),
|
||||
.pulse_num(pulse_num),
|
||||
.pulse(pulse),
|
||||
.pulse_height_out(pulse_height_out)
|
||||
);
|
||||
|
||||
// Clock
|
||||
initial begin
|
||||
clk = 0;
|
||||
forever #(CLK_PERIOD/2) clk = ~clk;
|
||||
end
|
||||
|
||||
initial begin
|
||||
$display("\n=== GENERATOR TEST ===\n");
|
||||
|
||||
rst = 1;
|
||||
start = 0;
|
||||
|
||||
pulse_width = 0;
|
||||
pulse_period = 0;
|
||||
pulse_height = 0;
|
||||
pulse_num = 0;
|
||||
|
||||
repeat(5) @(posedge clk);
|
||||
rst = 0;
|
||||
|
||||
// --- Test 1 ---
|
||||
// 3 clk 1, 5 clk 0, 4 pulses
|
||||
repeat(2) @(posedge clk);
|
||||
pulse_width = 3;
|
||||
pulse_period = 8;
|
||||
pulse_num = 4;
|
||||
pulse_height = 14'h3FF;
|
||||
start = 1;
|
||||
|
||||
repeat(1) @(posedge clk);
|
||||
start = 0;
|
||||
|
||||
repeat(50) @(posedge clk);
|
||||
|
||||
// --- Test 2 ---
|
||||
$display("\n--- SECOND RUN ---\n");
|
||||
|
||||
@(posedge clk);
|
||||
pulse_width = 2;
|
||||
pulse_period = 5;
|
||||
pulse_num = 3;
|
||||
pulse_height = 14'h155;
|
||||
start = 1;
|
||||
|
||||
@(posedge clk);
|
||||
start = 0;
|
||||
|
||||
repeat(40) @(posedge clk);
|
||||
|
||||
pulse_width = 3;
|
||||
pulse_period = 8;
|
||||
pulse_num = 4;
|
||||
pulse_height = 14'h3FF;
|
||||
start = 1;
|
||||
|
||||
repeat(1) @(posedge clk);
|
||||
start = 0;
|
||||
|
||||
repeat(50) @(posedge clk);
|
||||
|
||||
$display("\n=== TEST FINISHED ===");
|
||||
$finish;
|
||||
end
|
||||
|
||||
// Display
|
||||
always @(posedge clk) begin
|
||||
$display("t=%0t | pulse=%0b | height=%h",
|
||||
$time, pulse, pulse_height_out);
|
||||
end
|
||||
|
||||
endmodule
|
||||
0
rtl/generator/tests/generator_tests.sv
Normal file
0
rtl/generator/tests/generator_tests.sv
Normal file
151
scripts/vivado.mk
Normal file
151
scripts/vivado.mk
Normal file
@ -0,0 +1,151 @@
|
||||
# SPDX-License-Identifier: MIT
|
||||
###################################################################
|
||||
#
|
||||
# Xilinx Vivado FPGA Makefile
|
||||
#
|
||||
# Copyright (c) 2016-2025 Alex Forencich
|
||||
#
|
||||
###################################################################
|
||||
#
|
||||
# Parameters:
|
||||
# FPGA_TOP - Top module name
|
||||
# FPGA_FAMILY - FPGA family (e.g. VirtexUltrascale)
|
||||
# FPGA_DEVICE - FPGA device (e.g. xcvu095-ffva2104-2-e)
|
||||
# SYN_FILES - list of source files
|
||||
# INC_FILES - list of include files
|
||||
# XDC_FILES - list of timing constraint files
|
||||
# XCI_FILES - list of IP XCI files
|
||||
# IP_TCL_FILES - list of IP TCL files (sourced during project creation)
|
||||
# CONFIG_TCL_FILES - list of config TCL files (sourced before each build)
|
||||
#
|
||||
# Note: both SYN_FILES and INC_FILES support file list files. File list
|
||||
# files are files with a .f extension that contain a list of additional
|
||||
# files to include, one path relative to the .f file location per line.
|
||||
# The .f files are processed recursively, and then the complete file list
|
||||
# is de-duplicated, with later files in the list taking precedence.
|
||||
#
|
||||
# Example:
|
||||
#
|
||||
# FPGA_TOP = fpga
|
||||
# FPGA_FAMILY = VirtexUltrascale
|
||||
# FPGA_DEVICE = xcvu095-ffva2104-2-e
|
||||
# SYN_FILES = rtl/fpga.v
|
||||
# XDC_FILES = fpga.xdc
|
||||
# XCI_FILES = ip/pcspma.xci
|
||||
# include ../common/vivado.mk
|
||||
#
|
||||
###################################################################
|
||||
|
||||
# phony targets
|
||||
.PHONY: fpga vivado tmpclean clean distclean
|
||||
|
||||
# prevent make from deleting intermediate files and reports
|
||||
.PRECIOUS: %.xpr %.bit %.bin %.ltx %.xsa %.mcs %.prm
|
||||
.SECONDARY:
|
||||
|
||||
|
||||
FPGA_TOP ?= $(FPGA_TOP)
|
||||
PROJECT ?= $(FPGA_TOP)
|
||||
XDC_FILES ?= $(PROJECT).xdc
|
||||
|
||||
# handle file list files
|
||||
process_f_file = $(call process_f_files,$(addprefix $(dir $1),$(shell cat $1)))
|
||||
process_f_files = $(foreach f,$1,$(if $(filter %.f,$f),$(call process_f_file,$f),$f))
|
||||
uniq_base = $(if $1,$(call uniq_base,$(foreach f,$1,$(if $(filter-out $(notdir $(lastword $1)),$(notdir $f)),$f,))) $(lastword $1))
|
||||
SYN_FILES := $(call uniq_base,$(call process_f_files,$(SYN_FILES)))
|
||||
INC_FILES := $(call uniq_base,$(call process_f_files,$(INC_FILES)))
|
||||
|
||||
###################################################################
|
||||
# Main Targets
|
||||
#
|
||||
# all: build everything (fpga)
|
||||
# fpga: build FPGA config
|
||||
# vivado: open project in Vivado
|
||||
# tmpclean: remove intermediate files
|
||||
# clean: remove output files and project files
|
||||
# distclean: remove archived output files
|
||||
###################################################################
|
||||
|
||||
all: fpga
|
||||
|
||||
fpga: $(PROJECT).bit
|
||||
|
||||
vivado: $(PROJECT).xpr
|
||||
vivado $(PROJECT).xpr
|
||||
|
||||
tmpclean::
|
||||
-rm -rf *.log *.jou *.cache *.gen *.hbs *.hw *.ip_user_files *.runs *.xpr *.html *.xml *.sim *.srcs *.str .Xil defines.v
|
||||
-rm -rf create_project.tcl update_config.tcl run_synth.tcl run_impl.tcl generate_bit.tcl
|
||||
|
||||
clean:: tmpclean
|
||||
-rm -rf *.bit *.bin *.ltx *.xsa program.tcl generate_mcs.tcl *.mcs *.prm flash.tcl
|
||||
-rm -rf *_utilization.rpt *_utilization_hierarchical.rpt
|
||||
|
||||
distclean:: clean
|
||||
-rm -rf rev
|
||||
|
||||
###################################################################
|
||||
# Target implementations
|
||||
###################################################################
|
||||
|
||||
# Vivado project file
|
||||
|
||||
# create fresh project if Makefile or IP files have changed
|
||||
create_project.tcl: Makefile $(XCI_FILES) $(IP_TCL_FILES)
|
||||
rm -rf defines.v
|
||||
touch defines.v
|
||||
for x in $(DEFS); do echo '`define' $$x >> defines.v; done
|
||||
echo "create_project -force -part $(FPGA_PART) $(PROJECT)" > $@
|
||||
echo "add_files -fileset sources_1 defines.v $(SYN_FILES)" >> $@
|
||||
echo "set_property top $(FPGA_TOP) [current_fileset]" >> $@
|
||||
echo "add_files -fileset constrs_1 $(XDC_FILES)" >> $@
|
||||
for x in $(XCI_FILES); do echo "import_ip $$x" >> $@; done
|
||||
for x in $(IP_TCL_FILES); do echo "source $$x" >> $@; done
|
||||
for x in $(CONFIG_TCL_FILES); do echo "source $$x" >> $@; done
|
||||
|
||||
# source config TCL scripts if any source file has changed
|
||||
update_config.tcl: $(CONFIG_TCL_FILES) $(SYN_FILES) $(INC_FILES) $(XDC_FILES)
|
||||
echo "open_project -quiet $(PROJECT).xpr" > $@
|
||||
for x in $(CONFIG_TCL_FILES); do echo "source $$x" >> $@; done
|
||||
|
||||
$(PROJECT).xpr: create_project.tcl update_config.tcl
|
||||
vivado -nojournal -nolog -mode batch $(foreach x,$?,-source $x)
|
||||
|
||||
# synthesis run
|
||||
$(PROJECT).runs/synth_1/$(PROJECT).dcp: create_project.tcl update_config.tcl $(SYN_FILES) $(INC_FILES) $(XDC_FILES) | $(PROJECT).xpr
|
||||
echo "open_project $(PROJECT).xpr" > run_synth.tcl
|
||||
echo "reset_run synth_1" >> run_synth.tcl
|
||||
echo "launch_runs -jobs 4 synth_1" >> run_synth.tcl
|
||||
echo "wait_on_run synth_1" >> run_synth.tcl
|
||||
vivado -nojournal -nolog -mode batch -source run_synth.tcl
|
||||
|
||||
# implementation run
|
||||
$(PROJECT).runs/impl_1/$(PROJECT)_routed.dcp: $(PROJECT).runs/synth_1/$(PROJECT).dcp
|
||||
echo "open_project $(PROJECT).xpr" > run_impl.tcl
|
||||
echo "reset_run impl_1" >> run_impl.tcl
|
||||
echo "launch_runs -jobs 4 impl_1" >> run_impl.tcl
|
||||
echo "wait_on_run impl_1" >> run_impl.tcl
|
||||
echo "open_run impl_1" >> run_impl.tcl
|
||||
echo "report_utilization -file $(PROJECT)_utilization.rpt" >> run_impl.tcl
|
||||
echo "report_utilization -hierarchical -file $(PROJECT)_utilization_hierarchical.rpt" >> run_impl.tcl
|
||||
vivado -nojournal -nolog -mode batch -source run_impl.tcl
|
||||
|
||||
# output files (including potentially bit, bin, ltx, and xsa)
|
||||
$(PROJECT).bit $(PROJECT).bin $(PROJECT).ltx $(PROJECT).xsa: $(PROJECT).runs/impl_1/$(PROJECT)_routed.dcp
|
||||
echo "open_project $(PROJECT).xpr" > generate_bit.tcl
|
||||
echo "open_run impl_1" >> generate_bit.tcl
|
||||
echo "write_bitstream -force -bin_file $(PROJECT).runs/impl_1/$(PROJECT).bit" >> generate_bit.tcl
|
||||
echo "write_debug_probes -force $(PROJECT).runs/impl_1/$(PROJECT).ltx" >> generate_bit.tcl
|
||||
echo "write_hw_platform -fixed -force -include_bit $(PROJECT).xsa" >> generate_bit.tcl
|
||||
vivado -nojournal -nolog -mode batch -source generate_bit.tcl
|
||||
ln -f -s $(PROJECT).runs/impl_1/$(PROJECT).bit .
|
||||
ln -f -s $(PROJECT).runs/impl_1/$(PROJECT).bin .
|
||||
if [ -e $(PROJECT).runs/impl_1/$(PROJECT).ltx ]; then ln -f -s $(PROJECT).runs/impl_1/$(PROJECT).ltx .; fi
|
||||
mkdir -p rev
|
||||
COUNT=100; \
|
||||
while [ -e rev/$(PROJECT)_rev$$COUNT.bit ]; \
|
||||
do COUNT=$$((COUNT+1)); done; \
|
||||
cp -pv $(PROJECT).runs/impl_1/$(PROJECT).bit rev/$(PROJECT)_rev$$COUNT.bit; \
|
||||
cp -pv $(PROJECT).runs/impl_1/$(PROJECT).bin rev/$(PROJECT)_rev$$COUNT.bin; \
|
||||
if [ -e $(PROJECT).runs/impl_1/$(PROJECT).ltx ]; then cp -pv $(PROJECT).runs/impl_1/$(PROJECT).ltx rev/$(PROJECT)_rev$$COUNT.ltx; fi; \
|
||||
if [ -e $(PROJECT).xsa ]; then cp -pv $(PROJECT).xsa rev/$(PROJECT)_rev$$COUNT.xsa; fi
|
||||
Reference in New Issue
Block a user