root / simple_gemac / simple_gemac_wrapper_tb.v @ c811e886
History | View | Annotate | Download (4.96 KB)
| 1 |
|
|---|---|
| 2 |
|
| 3 |
module simple_gemac_wrapper_tb; |
| 4 |
`include "eth_tasks_f36.v" |
| 5 |
|
| 6 |
reg reset = 1; |
| 7 |
initial #1000 reset = 0; |
| 8 |
wire wb_rst = reset; |
| 9 |
|
| 10 |
reg eth_clk = 0; |
| 11 |
always #50 eth_clk = ~eth_clk; |
| 12 |
|
| 13 |
reg wb_clk = 0; |
| 14 |
always #173 wb_clk = ~wb_clk; |
| 15 |
|
| 16 |
reg sys_clk = 0; |
| 17 |
always #77 sys_clk = ~ sys_clk; |
| 18 |
|
| 19 |
wire GMII_RX_DV, GMII_RX_ER, GMII_TX_EN, GMII_TX_ER, GMII_GTX_CLK; |
| 20 |
wire [7:0] GMII_RXD, GMII_TXD; |
| 21 |
|
| 22 |
wire rx_valid, rx_error, rx_ack; |
| 23 |
wire tx_ack, tx_valid, tx_error; |
| 24 |
|
| 25 |
wire [7:0] rx_data, tx_data; |
| 26 |
|
| 27 |
reg [15:0] pause_time; |
| 28 |
reg pause_req = 0; |
| 29 |
|
| 30 |
wire GMII_RX_CLK = GMII_GTX_CLK; |
| 31 |
|
| 32 |
reg [7:0] FORCE_DAT_ERR = 0; |
| 33 |
reg FORCE_ERR = 0; |
| 34 |
|
| 35 |
// Loopback |
| 36 |
assign GMII_RX_DV = GMII_TX_EN; |
| 37 |
assign GMII_RX_ER = GMII_TX_ER | FORCE_ERR; |
| 38 |
assign GMII_RXD = GMII_TXD ^ FORCE_DAT_ERR; |
| 39 |
|
| 40 |
|
| 41 |
wire [31:0] wb_dat_o; |
| 42 |
reg [31:0] wb_dat_i; |
| 43 |
reg [7:0] wb_adr; |
| 44 |
reg wb_stb=0, wb_cyc=0, wb_we=0; |
| 45 |
wire wb_ack; |
| 46 |
|
| 47 |
reg [35:0] tx_f36_data=0; |
| 48 |
reg tx_f36_src_rdy=0; |
| 49 |
wire tx_f36_dst_rdy; |
| 50 |
|
| 51 |
simple_gemac_wrapper simple_gemac_wrapper |
| 52 |
(.clk125(eth_clk), .reset(reset), |
| 53 |
.GMII_GTX_CLK(GMII_GTX_CLK), .GMII_TX_EN(GMII_TX_EN), |
| 54 |
.GMII_TX_ER(GMII_TX_ER), .GMII_TXD(GMII_TXD), |
| 55 |
.GMII_RX_CLK(GMII_RX_CLK), .GMII_RX_DV(GMII_RX_DV), |
| 56 |
.GMII_RX_ER(GMII_RX_ER), .GMII_RXD(GMII_RXD), |
| 57 |
.pause_req(pause_req), .pause_time(pause_time), |
| 58 |
|
| 59 |
.sys_clk(sys_clk), .rx_f36_data(), .rx_f36_src_rdy(), .rx_f36_dst_rdy(), |
| 60 |
.tx_f36_data(tx_f36_data), .tx_f36_src_rdy(tx_f36_src_rdy), .tx_f36_dst_rdy(tx_f36_dst_rdy), |
| 61 |
|
| 62 |
.wb_clk(wb_clk), .wb_rst(wb_rst), .wb_stb(wb_stb), .wb_cyc(wb_cyc), .wb_ack(wb_ack), .wb_we(wb_we), |
| 63 |
.wb_adr(), .wb_dat_i(wb_dat_i), .wb_dat_o(wb_dat_o), |
| 64 |
|
| 65 |
.mdio(), .mdc(), |
| 66 |
.debug() ); |
| 67 |
|
| 68 |
initial $dumpfile("simple_gemac_wrapper_tb.vcd");
|
| 69 |
initial $dumpvars(0,simple_gemac_wrapper_tb); |
| 70 |
|
| 71 |
integer i; |
| 72 |
reg [7:0] pkt_rom[0:65535]; |
| 73 |
reg [1023:0] ROMFile; |
| 74 |
|
| 75 |
initial |
| 76 |
for (i=0;i<65536;i=i+1) |
| 77 |
pkt_rom[i] <= 8'h0; |
| 78 |
|
| 79 |
initial |
| 80 |
begin |
| 81 |
@(negedge reset); |
| 82 |
repeat (10) |
| 83 |
@(posedge wb_clk); |
| 84 |
WishboneWR(0,6'b111001); |
| 85 |
WishboneWR(4,16'hF1F2); |
| 86 |
WishboneWR(8,32'hF3F4_F5F6); |
| 87 |
WishboneWR(12,16'h0000); |
| 88 |
WishboneWR(16,32'h0000_0000); |
| 89 |
|
| 90 |
@(posedge eth_clk); |
| 91 |
SendFlowCtrl(16'h0007); // Send flow control |
| 92 |
@(posedge eth_clk); |
| 93 |
#30000; |
| 94 |
@(posedge eth_clk); |
| 95 |
SendFlowCtrl(16'h0009); // Increase flow control before it expires |
| 96 |
#10000; |
| 97 |
@(posedge eth_clk); |
| 98 |
SendFlowCtrl(16'h0000); // Cancel flow control before it expires |
| 99 |
@(posedge eth_clk); |
| 100 |
|
| 101 |
repeat (1000) |
| 102 |
@(posedge sys_clk); |
| 103 |
SendPacket_to_fifo36(32'hAABBCCDD,10); // This packet gets dropped by the filters |
| 104 |
repeat (1000) |
| 105 |
@(posedge sys_clk); |
| 106 |
|
| 107 |
SendPacket_to_fifo36(32'hAABBCCDD,100); // This packet gets dropped by the filters |
| 108 |
repeat (10) |
| 109 |
@(posedge sys_clk); |
| 110 |
/* |
| 111 |
SendPacketFromFile_f36(60,0,0); // The rest are valid packets |
| 112 |
repeat (10) |
| 113 |
@(posedge clk); |
| 114 |
|
| 115 |
SendPacketFromFile_f36(61,0,0); |
| 116 |
repeat (10) |
| 117 |
@(posedge clk); |
| 118 |
SendPacketFromFile_f36(62,0,0); |
| 119 |
repeat (10) |
| 120 |
@(posedge clk); |
| 121 |
SendPacketFromFile_f36(63,0,0); |
| 122 |
repeat (1) |
| 123 |
@(posedge clk); |
| 124 |
SendPacketFromFile_f36(64,0,0); |
| 125 |
repeat (10) |
| 126 |
@(posedge clk); |
| 127 |
SendPacketFromFile_f36(59,0,0); |
| 128 |
repeat (1) |
| 129 |
@(posedge clk); |
| 130 |
SendPacketFromFile_f36(58,0,0); |
| 131 |
repeat (1) |
| 132 |
@(posedge clk); |
| 133 |
SendPacketFromFile_f36(100,0,0); |
| 134 |
repeat (1) |
| 135 |
@(posedge clk); |
| 136 |
SendPacketFromFile_f36(200,150,30); // waiting 14 empties the fifo, 15 underruns |
| 137 |
repeat (1) |
| 138 |
@(posedge clk); |
| 139 |
SendPacketFromFile_f36(100,0,30); |
| 140 |
*/ |
| 141 |
#100000 $finish; |
| 142 |
end |
| 143 |
|
| 144 |
// Force a CRC error |
| 145 |
initial |
| 146 |
begin |
| 147 |
#90000; |
| 148 |
@(posedge eth_clk); |
| 149 |
FORCE_DAT_ERR <= 8'h10; |
| 150 |
@(posedge eth_clk); |
| 151 |
FORCE_DAT_ERR <= 8'h00; |
| 152 |
end |
| 153 |
|
| 154 |
// Force an RX_ER error (i.e. link loss) |
| 155 |
initial |
| 156 |
begin |
| 157 |
#116000; |
| 158 |
@(posedge eth_clk); |
| 159 |
FORCE_ERR <= 1; |
| 160 |
@(posedge eth_clk); |
| 161 |
FORCE_ERR <= 0; |
| 162 |
end |
| 163 |
/* |
| 164 |
// Cause receive fifo to fill, causing an RX overrun |
| 165 |
initial |
| 166 |
begin |
| 167 |
#126000; |
| 168 |
@(posedge clk); |
| 169 |
rx_ll_dst_rdy2 <= 0; |
| 170 |
repeat (30) // Repeat of 14 fills the shortfifo, but works. 15 overflows |
| 171 |
@(posedge clk); |
| 172 |
rx_ll_dst_rdy2 <= 1; |
| 173 |
end |
| 174 |
*/ |
| 175 |
// Tests: Send and recv flow control, send and receive good packets, RX CRC err, RX_ER, RX overrun, TX underrun |
| 176 |
// Still need to test: CRC errors on Pause Frames, MDIO, wishbone |
| 177 |
|
| 178 |
task WishboneWR; |
| 179 |
input [7:0] adr; |
| 180 |
input [31:0] value; |
| 181 |
begin |
| 182 |
wb_adr <= adr; |
| 183 |
wb_dat_i <= value; |
| 184 |
wb_stb <= 1; |
| 185 |
wb_cyc <= 1; |
| 186 |
wb_we <= 1; |
| 187 |
while (~wb_ack) |
| 188 |
@(posedge wb_clk); |
| 189 |
@(posedge wb_clk); |
| 190 |
wb_stb <= 0; |
| 191 |
wb_cyc <= 0; |
| 192 |
wb_we <= 0; |
| 193 |
end |
| 194 |
endtask // WishboneWR |
| 195 |
/* |
| 196 |
always @(posedge clk) |
| 197 |
if(rx_ll_src_rdy2 & rx_ll_dst_rdy2) |
| 198 |
begin |
| 199 |
if(rx_ll_sof2 & ~rx_ll_eof2) |
| 200 |
$display("RX-PKT-START %d",$time);
|
| 201 |
$display("RX-PKT SOF %d EOF %d ERR%d DAT %x",rx_ll_sof2,rx_ll_eof2,rx_ll_error2,rx_ll_data2);
|
| 202 |
if(rx_ll_eof2 & ~rx_ll_sof2) |
| 203 |
$display("RX-PKT-END %d",$time);
|
| 204 |
end |
| 205 |
*/ |
| 206 |
endmodule // simple_gemac_wrapper_tb |