亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? tb_ethernet_with_cop.v

?? FPGA數(shù)字電子系統(tǒng)設(shè)計(jì)與開(kāi)發(fā)實(shí)例導(dǎo)航光盤內(nèi)附源碼
?? V
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):

//



`include "tb_eth_defines.v"
`include "eth_defines.v"
`include "timescale.v"

module tb_ethernet_with_cop();


parameter Tp = 1;


reg           wb_clk_o;
reg           wb_rst_o;

reg           mtx_clk;
reg           mrx_clk;

wire   [3:0]  MTxD;
wire          MTxEn;
wire          MTxErr;

reg    [3:0]  MRxD;     // This goes to PHY
reg           MRxDV;    // This goes to PHY
reg           MRxErr;   // This goes to PHY
reg           MColl;    // This goes to PHY
reg           MCrs;     // This goes to PHY

wire          Mdi_I;
wire          Mdo_O;
wire          Mdo_OE;
wire          Mdc_O;

integer tx_log;
integer rx_log;

reg StartTB;

`ifdef ETH_XILINX_RAMB4
  reg gsr;
`endif


integer packet_ready_cnt, send_packet_cnt;


// Ethernet Slave Interface signals
wire [31:0] eth_sl_wb_adr_i, eth_sl_wb_dat_o, eth_sl_wb_dat_i;
wire  [3:0] eth_sl_wb_sel_i;
wire        eth_sl_wb_we_i, eth_sl_wb_cyc_i, eth_sl_wb_stb_i, eth_sl_wb_ack_o, eth_sl_wb_err_o;

// Memory Slave Interface signals
wire [31:0] mem_sl_wb_adr_i, mem_sl_wb_dat_o, mem_sl_wb_dat_i;
wire  [3:0] mem_sl_wb_sel_i;
wire        mem_sl_wb_we_i, mem_sl_wb_cyc_i, mem_sl_wb_stb_i, mem_sl_wb_ack_o, mem_sl_wb_err_o;

// Ethernet Master Interface signals
wire [31:0] eth_ma_wb_adr_o, eth_ma_wb_dat_i, eth_ma_wb_dat_o;
wire  [3:0] eth_ma_wb_sel_o;
wire        eth_ma_wb_we_o, eth_ma_wb_cyc_o, eth_ma_wb_stb_o, eth_ma_wb_ack_i, eth_ma_wb_err_i;

`ifdef ETH_WISHBONE_B3
wire  [2:0] eth_ma_wb_cti_o;
wire  [1:0] eth_ma_wb_bte_o;
`endif


// Host Master Interface signals
wire [31:0] host_ma_wb_adr_o, host_ma_wb_dat_i, host_ma_wb_dat_o;
wire  [3:0] host_ma_wb_sel_o;
wire        host_ma_wb_we_o, host_ma_wb_cyc_o, host_ma_wb_stb_o, host_ma_wb_ack_i, host_ma_wb_err_i;



eth_cop i_eth_cop
(
  // WISHBONE common
  .wb_clk_i(wb_clk_o), .wb_rst_i(wb_rst_o), 

  // WISHBONE MASTER 1  Ethernet Master Interface is connected here
  .m1_wb_adr_i(eth_ma_wb_adr_o),  .m1_wb_sel_i(eth_ma_wb_sel_o),  .m1_wb_we_i (eth_ma_wb_we_o), 
  .m1_wb_dat_o(eth_ma_wb_dat_i),  .m1_wb_dat_i(eth_ma_wb_dat_o),  .m1_wb_cyc_i(eth_ma_wb_cyc_o), 
  .m1_wb_stb_i(eth_ma_wb_stb_o),  .m1_wb_ack_o(eth_ma_wb_ack_i),  .m1_wb_err_o(eth_ma_wb_err_i), 

  // WISHBONE MASTER 2  Host Interface is connected here
  .m2_wb_adr_i(host_ma_wb_adr_o), .m2_wb_sel_i(host_ma_wb_sel_o), .m2_wb_we_i (host_ma_wb_we_o), 
  .m2_wb_dat_o(host_ma_wb_dat_i), .m2_wb_dat_i(host_ma_wb_dat_o), .m2_wb_cyc_i(host_ma_wb_cyc_o), 
  .m2_wb_stb_i(host_ma_wb_stb_o), .m2_wb_ack_o(host_ma_wb_ack_i), .m2_wb_err_o(host_ma_wb_err_i), 

  // WISHBONE slave 1   Ethernet Slave Interface is connected here
 	.s1_wb_adr_o(eth_sl_wb_adr_i),  .s1_wb_sel_o(eth_sl_wb_sel_i),  .s1_wb_we_o (eth_sl_wb_we_i), 
 	.s1_wb_cyc_o(eth_sl_wb_cyc_i),  .s1_wb_stb_o(eth_sl_wb_stb_i),  .s1_wb_ack_i(eth_sl_wb_ack_o), 
 	.s1_wb_err_i(eth_sl_wb_err_o),  .s1_wb_dat_i(eth_sl_wb_dat_o),  .s1_wb_dat_o(eth_sl_wb_dat_i), 

  // WISHBONE slave 2   Memory Interface is connected here
 	.s2_wb_adr_o(mem_sl_wb_adr_i),  .s2_wb_sel_o(mem_sl_wb_sel_i),  .s2_wb_we_o (mem_sl_wb_we_i), 
 	.s2_wb_cyc_o(mem_sl_wb_cyc_i),  .s2_wb_stb_o(mem_sl_wb_stb_i),  .s2_wb_ack_i(mem_sl_wb_ack_o), 
 	.s2_wb_err_i(mem_sl_wb_err_o),  .s2_wb_dat_i(mem_sl_wb_dat_o),  .s2_wb_dat_o(mem_sl_wb_dat_i)
);




// Connecting Ethernet top module
eth_top ethtop
(
  // WISHBONE common
  .wb_clk_i(wb_clk_o),              .wb_rst_i(wb_rst_o), 

  // WISHBONE slave
 	.wb_adr_i(eth_sl_wb_adr_i[11:2]), .wb_sel_i(eth_sl_wb_sel_i),   .wb_we_i(eth_sl_wb_we_i), 
 	.wb_cyc_i(eth_sl_wb_cyc_i),       .wb_stb_i(eth_sl_wb_stb_i),   .wb_ack_o(eth_sl_wb_ack_o), 
 	.wb_err_o(eth_sl_wb_err_o),       .wb_dat_i(eth_sl_wb_dat_i),   .wb_dat_o(eth_sl_wb_dat_o), 
 	
  // WISHBONE master
  .m_wb_adr_o(eth_ma_wb_adr_o),     .m_wb_sel_o(eth_ma_wb_sel_o), .m_wb_we_o(eth_ma_wb_we_o), 
  .m_wb_dat_i(eth_ma_wb_dat_i),     .m_wb_dat_o(eth_ma_wb_dat_o), .m_wb_cyc_o(eth_ma_wb_cyc_o), 
  .m_wb_stb_o(eth_ma_wb_stb_o),     .m_wb_ack_i(eth_ma_wb_ack_i), .m_wb_err_i(eth_ma_wb_err_i), 

`ifdef ETH_WISHBONE_B3
  .m_wb_cti_o(eth_ma_wb_cti_o),     .m_wb_bte_o(eth_ma_wb_bte_o), 
`endif

  //TX
  .mtx_clk_pad_i(mtx_clk), .mtxd_pad_o(MTxD), .mtxen_pad_o(MTxEn), .mtxerr_pad_o(MTxErr),

  //RX
  .mrx_clk_pad_i(mrx_clk), .mrxd_pad_i(MRxD), .mrxdv_pad_i(MRxDV), .mrxerr_pad_i(MRxErr), 
  .mcoll_pad_i(MColl),    .mcrs_pad_i(MCrs), 
  
  // MIIM
  .mdc_pad_o(Mdc_O), .md_pad_i(Mdi_I), .md_pad_o(Mdo_O), .md_padoe_o(Mdo_OE),
  
  .int_o()

  // Bist
`ifdef ETH_BIST
  ,
  .scanb_rst      (1'b0),
  .scanb_clk      (1'b0),
  .scanb_si       (1'b0),
  .scanb_so       (),
  .scanb_en       (1'b0)
`endif
  
);



// Connecting Memory Interface Module
eth_memory i_eth_memory
(
  // WISHBONE common
 	.wb_clk_i(wb_clk_o),         .wb_rst_i(wb_rst_o), 

  // WISHBONE slave:   Memory Interface is connected here
 	.wb_adr_i(mem_sl_wb_adr_i),  .wb_sel_i(mem_sl_wb_sel_i),  .wb_we_i (mem_sl_wb_we_i), 
 	.wb_cyc_i(mem_sl_wb_cyc_i),  .wb_stb_i(mem_sl_wb_stb_i),  .wb_ack_o(mem_sl_wb_ack_o), 
 	.wb_err_o(mem_sl_wb_err_o),  .wb_dat_o(mem_sl_wb_dat_o),  .wb_dat_i(mem_sl_wb_dat_i)
);


// Connecting Host Interface
eth_host eth_host
(
  // WISHBONE common
  .wb_clk_i(wb_clk_o),         .wb_rst_i(wb_rst_o), 

  // WISHBONE master
  .wb_adr_o(host_ma_wb_adr_o), .wb_sel_o(host_ma_wb_sel_o), .wb_we_o (host_ma_wb_we_o), 
  .wb_dat_i(host_ma_wb_dat_i), .wb_dat_o(host_ma_wb_dat_o), .wb_cyc_o(host_ma_wb_cyc_o), 
  .wb_stb_o(host_ma_wb_stb_o), .wb_ack_i(host_ma_wb_ack_i), .wb_err_i(host_ma_wb_err_i)
);





// Reset pulse
initial
begin
  MCrs=0;                                     // This should come from PHY
  MColl=0;                                    // This should come from PHY
  MRxD=0;                                     // This should come from PHY
  MRxDV=0;                                    // This should come from PHY
  MRxErr=0;                                   // This should come from PHY
  packet_ready_cnt = 0;
  send_packet_cnt = 0;
  tx_log = $fopen("ethernet_tx.log");
  rx_log = $fopen("ethernet_rx.log");
  wb_rst_o =  1'b1;
`ifdef ETH_XILINX_RAMB4
  gsr           =  1'b0;
  #100 gsr      =  1'b1;
  #100 gsr      =  1'b0;
`endif
  #100 wb_rst_o =  1'b0;
  #100 StartTB  =  1'b1;
end

`ifdef ETH_XILINX_RAMB4
  assign glbl.GSR = gsr;
`endif



// Generating wb_clk_o clock
initial
begin
  wb_clk_o=0;
//  forever #20 wb_clk_o = ~wb_clk_o;  // 2*20 ns -> 25 MHz    
  forever #12.5 wb_clk_o = ~wb_clk_o;  // 2*12.5 ns -> 40 MHz    
end

// Generating mtx_clk clock
initial
begin
  mtx_clk=0;
  #3 forever #20 mtx_clk = ~mtx_clk;   // 2*20 ns -> 25 MHz
end

// Generating mrx_clk clock
initial
begin
  mrx_clk=0;
  #16 forever #20 mrx_clk = ~mrx_clk;   // 2*20 ns -> 25 MHz
end

reg [31:0] tmp;
initial
begin
  wait(StartTB);  // Start of testbench
  

  eth_host.wb_write(`ETH_MODER, 4'hf, 32'h0); // Reset OFF
  eth_host.wb_read(`ETH_MODER, 4'hf, tmp);
  eth_host.wb_write(`ETH_MAC_ADDR1, 4'hf, 32'h0002); // Set ETH_MAC_ADDR1 register
  eth_host.wb_write(`ETH_MAC_ADDR0, 4'hf, 32'h03040506); // Set ETH_MAC_ADDR0 register

  initialize_txbd(3);
  initialize_rxbd(4);

//  eth_host.wb_write(`ETH_MODER, 4'hf, `ETH_MODER_RXEN  | `ETH_MODER_TXEN | `ETH_MODER_PRO | 
//                                      `ETH_MODER_CRCEN | `ETH_MODER_PAD); // Set MODER register
//  eth_host.wb_write(`ETH_MODER, 4'hf, `ETH_MODER_RXEN  | `ETH_MODER_TXEN | 
//                                      `ETH_MODER_CRCEN | `ETH_MODER_PAD); // Set MODER register
//  eth_host.wb_write(`ETH_MODER, 4'hf, `ETH_MODER_RXEN  | `ETH_MODER_TXEN | `ETH_MODER_BRO | 
//                                      `ETH_MODER_CRCEN | `ETH_MODER_PAD); // Set MODER register
//  eth_host.wb_write(`ETH_MODER, 4'hf, `ETH_MODER_RXEN  | `ETH_MODER_TXEN | `ETH_MODER_PRO | 
//                                      `ETH_MODER_CRCEN | `ETH_MODER_PAD | `ETH_MODER_LOOPBCK); // Set MODER register
  eth_host.wb_write(`ETH_MODER, 4'hf, `ETH_MODER_RXEN  | `ETH_MODER_TXEN | `ETH_MODER_PRO | 
                                      `ETH_MODER_CRCEN | `ETH_MODER_PAD | `ETH_MODER_LOOPBCK | 
                                      `ETH_MODER_FULLD); // Set MODER register
  eth_host.wb_read(`ETH_MODER, 4'hf, tmp);

  set_packet(16'h364, 8'h1);
  set_packet(16'h234, 8'h11);
  send_packet;
  repeat (1000) @(posedge mrx_clk);   // Waiting for TxEthMac to finish transmit

//  repeat (10000) @(posedge wb_clk_o);   // Waiting for TxEthMac to finish transmit
  set_packet(16'h534, 8'h21);
//  set_packet(16'h34, 8'h31);

/*
  eth_host.wb_write(`ETH_CTRLMODER, 4'hf, 32'h4);   // Enable Tx Flow control
  eth_host.wb_write(`ETH_CTRLMODER, 4'hf, 32'h5);   // Enable Tx Flow control
  eth_host.wb_write(`ETH_TX_CTRL, 4'hf, 32'h10013); // Send Control frame with PAUSE_TV=0x0013
*/

  send_packet;
  repeat (1000) @(posedge mrx_clk);   // Waiting for TxEthMac to finish transmit
  send_packet;
  repeat (1000) @(posedge mrx_clk);   // Waiting for TxEthMac to finish transmit

/*
  send_packet;
*/

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩成人在线一区| 成人一级视频在线观看| 这里只有精品视频在线观看| 视频一区在线视频| 日韩一区二区在线看| 精品一区免费av| 五月婷婷综合网| 在线成人av影院| 麻豆专区一区二区三区四区五区| 精品国产欧美一区二区| 福利视频网站一区二区三区| 亚洲视频你懂的| 欧美日本一区二区三区| 麻豆精品视频在线观看免费 | 欧美激情一区二区| 91小视频在线免费看| 午夜精品福利在线| 欧美精品色一区二区三区| 欧美日韩成人激情| 成人欧美一区二区三区| 99精品视频在线观看免费| 久久99九九99精品| 日韩不卡在线观看日韩不卡视频| 亚洲天堂免费在线观看视频| 国产无一区二区| 精品欧美乱码久久久久久| 欧美久久久久中文字幕| 欧美性一二三区| 在线观看亚洲专区| 在线亚洲欧美专区二区| 99久久免费视频.com| 国产福利精品一区| 国产精品一区二区果冻传媒| 国产一区不卡在线| 国产精品资源在线看| 国内精品视频一区二区三区八戒| 乱一区二区av| 黄色精品一二区| 激情深爱一区二区| 欧美色中文字幕| 91精品福利在线| 色屁屁一区二区| 91国产精品成人| 欧美日韩专区在线| 欧美精品在线观看播放| 7777精品伊人久久久大香线蕉最新版 | 一区二区三区四区不卡视频| 亚洲人午夜精品天堂一二香蕉| 中文字幕在线观看不卡视频| 国产精品美女久久久久aⅴ国产馆| 国产精品视频看| 亚洲老司机在线| 亚洲一区二区免费视频| 图片区小说区区亚洲影院| 首页亚洲欧美制服丝腿| 琪琪一区二区三区| 久久国产精品72免费观看| 韩日欧美一区二区三区| 成人综合在线网站| 色94色欧美sute亚洲线路二| 欧美日韩一级大片网址| 精品国产一区久久| 亚洲国产精品99久久久久久久久 | 亚洲成av人影院| 日日骚欧美日韩| 国产一区二区在线电影| gogogo免费视频观看亚洲一| 在线影视一区二区三区| 日韩一级视频免费观看在线| 精品国内二区三区| 中文字幕一区二区三区在线播放| 国产激情精品久久久第一区二区| 成人午夜免费av| 欧美性受极品xxxx喷水| 日韩亚洲欧美中文三级| 中文字幕第一区二区| 亚洲在线视频网站| 精品一二三四区| 色婷婷精品大视频在线蜜桃视频| 3751色影院一区二区三区| 久久九九久精品国产免费直播| 亚洲人成在线观看一区二区| 奇米一区二区三区av| 成人动漫中文字幕| 制服视频三区第一页精品| 国产网站一区二区| 水野朝阳av一区二区三区| 高清在线观看日韩| 91麻豆精品国产无毒不卡在线观看| 久久久精品人体av艺术| 亚洲18色成人| youjizz久久| 精品国产网站在线观看| 亚洲一区二区三区美女| 国产91在线看| 欧美一区二区在线观看| 综合久久久久久| 久久精品国产一区二区| 日本久久电影网| 中文字幕乱码亚洲精品一区| 麻豆一区二区三| 欧美日韩中字一区| 自拍偷拍亚洲激情| 国产精品一区二区久久精品爱涩| 欧美久久高跟鞋激| 亚洲日本在线视频观看| 国产高清不卡一区| 精品奇米国产一区二区三区| 五月婷婷久久综合| 欧洲一区二区三区在线| 中文字幕av在线一区二区三区| 久久精品国产第一区二区三区| 欧美日韩一区二区三区在线| 中文字幕一区在线观看视频| 国产精品白丝av| 精品国产一区二区三区久久久蜜月 | 高清不卡一区二区| 精品国产1区二区| 蜜臀av一区二区在线免费观看 | 国产成人在线看| 日韩欧美的一区二区| 午夜精品成人在线| 欧美专区亚洲专区| 亚洲精品中文在线影院| av不卡一区二区三区| 国产精品卡一卡二| 成人免费不卡视频| 中文字幕高清一区| 成人免费毛片高清视频| 国产亚洲一区二区三区| 国产剧情一区在线| 久久精品人人做人人爽人人| 紧缚奴在线一区二区三区| 日韩亚洲欧美成人一区| 麻豆精品国产传媒mv男同 | 中文字幕一区二区三区蜜月| 成人在线一区二区三区| 国产精品美女一区二区三区 | 亚洲综合免费观看高清完整版 | 欧美色男人天堂| 亚洲国产精品麻豆| 欧美伦理电影网| 日韩av中文在线观看| 91精品国产综合久久久久久漫画| 三级影片在线观看欧美日韩一区二区 | 久久综合久久久久88| 国产乱对白刺激视频不卡| 国产亚洲短视频| 成人h精品动漫一区二区三区| 国产精品日韩精品欧美在线| 97久久精品人人爽人人爽蜜臀| 亚洲三级理论片| 欧美日韩在线三级| 麻豆国产精品官网| 国产日韩v精品一区二区| av电影天堂一区二区在线| 亚洲欧美日韩系列| 欧美日韩高清影院| 久久99精品久久久| 亚洲国产精品ⅴa在线观看| 色一区在线观看| 午夜精品久久一牛影视| 精品免费日韩av| 不卡av在线免费观看| 午夜a成v人精品| 久久这里只有精品视频网| 91在线免费视频观看| 午夜免费久久看| 精品91自产拍在线观看一区| 不卡电影一区二区三区| 婷婷综合久久一区二区三区| 精品成人一区二区三区| 91在线免费视频观看| 日本午夜精品一区二区三区电影| 久久综合资源网| 色妹子一区二区| 精品在线一区二区三区| 亚洲欧美国产高清| 日韩欧美国产午夜精品| 波多野结衣中文一区| 视频精品一区二区| 国产精品麻豆欧美日韩ww| 7777精品伊人久久久大香线蕉| 国产精品一区二区91| 亚洲在线一区二区三区| 国产午夜久久久久| 欧美日韩高清在线播放| aaa亚洲精品一二三区| 麻豆一区二区99久久久久| 亚洲欧美成aⅴ人在线观看| 精品国产自在久精品国产| 欧美中文字幕亚洲一区二区va在线| 久久97超碰色| 五月婷婷久久综合| 亚洲视频你懂的| 国产亚洲人成网站| 日韩欧美一区二区不卡| 欧美在线你懂的| www.亚洲色图.com| 国产一区二区按摩在线观看|