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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? rxreceiveengine.v

?? 基于802.3以太網(wǎng)的mac源碼
?? V
字號:
//////////////////////////////////////////////////////////////////////////                                                              //////// MODULE NAME: receive engine                                  ////////                                                              //////// DESCRIPTION: Receive Engine Top Level for the 10 Gigabit     ////////     Ethernet MAC.                                            ////////                                                              //////// This file is part of the 10 Gigabit Ethernet IP core project ////////  http://www.opencores.org/projects/ethmac10g/                ////////                                                              //////// AUTHOR(S):                                                   //////// Zheng Cao                                                    ////////                                                              //////////////////////////////////////////////////////////////////////////////                                                              //////// Copyright (c) 2005 AUTHORS.  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. ////////                                                              //////// This source file is free software; you can redistribute it   //////// and/or modify it under the terms of the GNU Lesser General   //////// Public License as published by the Free Software Foundation; //////// either version 2.1 of the License, or (at your option) any   //////// later version.                                               ////////                                                              //////// This source is distributed in the hope that it will be       //////// useful, but WITHOUT ANY WARRANTY; without even the implied   //////// warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR      //////// PURPOSE.  See the GNU Lesser General Public License for more //////// details.                                                     ////////                                                              //////// You should have received a copy of the GNU Lesser General    //////// Public License along with this source; if not, download it   //////// from http://www.opencores.org/lgpl.shtml                     ////////                                                              ////////////////////////////////////////////////////////////////////////////// CVS REVISION HISTORY://// $Log: not supported by cvs2svn $// Revision 1.6  2006/06/16 06:39:59  fisher5090// no message//// Revision 1.5  2006/06/16 06:36:28  Zheng Cao// no message//// Revision 1.4  2006/06/12 10:02:19  Zheng Cao// change rxd_in, rxc_in and rxclk_in signals'name to xgmii_rxd, xgmii_rxc and xgmii_rxclk//// Revision 1.3  2006/06/11 12:15:11  Zheng Cao// no message//// Revision 1.1  2005/12/25 16:43:10  Zheng Cao// No flow control included// ////////////////////////////////////////////////////////////////////////`include "timescale.v"`include "xgiga_define.v"module rxReceiveEngine(xgmii_rxclk, rxclk_2x, reset_in, xgmii_rxd, xgmii_rxc, rxStatRegPlus,                       cfgRxRegData_in, rx_data, rx_data_valid, rx_good_frame, rxclk_out,                       rx_bad_frame, rxCfgofRS, rxTxLinkFault);//, fcTxPauseData, fcTxPauseValid);    input xgmii_rxclk; //Input clock of receive engine    input rxclk_2x;    input reset_in; //Globle reset of receive engine    input [31:0] xgmii_rxd; //XGMII RXD    input [3:0] xgmii_rxc;  //XGMII RXC    output [17:0] rxStatRegPlus; //Signals for statistics	    input [64:0] cfgRxRegData_in; //Signals for configuration    output [63:0] rx_data; //Received data sent to upper layer    output [7:0] rx_data_valid; //Receive data valid indicator    output rx_good_frame; //Indicate that a good frame has been received    output rx_bad_frame; //Indicate that a bad frame has been received    output[2:0] rxCfgofRS; //    output [1:0] rxTxLinkFault;    output rxclk_out;//  output [31:0] fcTxPauseData;//  output fcTxPauseValid;    parameter TP =1;    wire rxclk;    wire rxclk_180;    wire locked;    wire reset_dcm;    wire reset;    reg [47:0]MAC_Addr;	//MAC Address used in receiving control frame.    reg      vlan_enable; //VLAN Enable    reg      recv_enable; //Receiver Enable    reg      inband_fcs;	//In-band FCS Enable, when this bit is '1', the MAC will pass FCS up to client    reg      jumbo_enable;//Jumbo Frame Enable    reg      recv_rst;		//Receiver reset    wire start_da, start_lt;    wire tagged_frame;    wire pause_frame;    wire [47:0] da_addr;//  wire [15:0] lt_data;    wire [`COUNTER_WIDTH-1:0] frame_cnt;    wire [2:0]  terminator_location;    wire get_sfd,get_error_code,get_terminator, get_terminator_d1;    wire receiving;    wire receiving_d1,receiving_d2;     wire length_error;    wire large_error;    wire small_error;    wire padded_frame;    wire length_65_127;    wire length_128_255;    wire length_256_511;    wire length_512_1023;    wire length_1024_max;    wire jumbo_frame;    wire local_invalid;    wire broad_valid;    wire multi_valid;    wire good_frame_get, bad_frame_get;    wire wait_crc_check;    wire crc_check_valid;    wire crc_check_invalid;    wire check_reset;    wire [1:0]link_fault;    //////////////////////////////////////////    // Input Registers    //////////////////////////////////////////     wire [63:0] rxd64;    wire [63:0] CRC_DATA;    wire [7:0] rxc8;    assign rxTxLinkFault = link_fault;    // assign fcTxPauseValid = pause_frame;      //////////////////////////////////////////    // Read Receiver Configuration Word    //////////////////////////////////////////     reg[52:0] cfgRxRegData;    always@(posedge rxclk or posedge reset)begin          if(reset)             cfgRxRegData <=#TP 0;          else            cfgRxRegData<=#TP cfgRxRegData_in;    end     always@(posedge rxclk or posedge reset)begin          if(reset) begin            MAC_Addr <= 0;            vlan_enable <= 0;            recv_enable <= 0;            inband_fcs  <= 0;            jumbo_enable <= 0;            recv_rst <= 0;          end          else begin            MAC_Addr <= cfgRxRegData[47:0];            vlan_enable <= cfgRxRegData[48];            recv_enable <= cfgRxRegData[49];            inband_fcs  <= cfgRxRegData[50];            jumbo_enable <= cfgRxRegData[51];            recv_rst <= cfgRxRegData[52];          end    end     //////////////////////////////////////////////////    // Used to count number of received frames(G&B)    //////////////////////////////////////////////////    reg[7:0] cnt;    reg cnt_en;    always@(posedge rxclk or posedge reset) begin         if (reset)            cnt_en <=0;         else if(get_sfd)			            cnt_en <=1;         else if(rx_bad_frame|rx_good_frame)           cnt_en <=0;         else           cnt_en <=cnt_en;    end    always@(posedge rxclk or posedge reset) begin          if (reset)             cnt <=0;          else if(cnt_en)             cnt<=cnt + 1;          else              cnt <=0;    end       /////////////////////////////////////////   // Reset signals   /////////////////////////////////////////   assign  reset_dcm = reset_in | recv_rst;   assign  reset = ~locked;     /////////////////////////////////////////   // Write Configuration Words	of RS    /////////////////////////////////////////   assign rxCfgofRS[0] = ~link_fault[0] & link_fault[1]; //get local fault   assign rxCfgofRS[1] = link_fault[0] & link_fault[1];  //get remote fault   assign rxCfgofRS[2] = locked;  //Receive DCM locked      ////////////////////////////////////////   // Signals for Pause Operation   ////////////////////////////////////////   assign fcTxPauseValid = pause_frame;// assign fcTxPauseData = {16{1'b0},rxd64[15:0]};   ////////////////////////////////////////   // Receive Clock Generator   ////////////////////////////////////////    assign rxclk_out = rxclk;   rxClkgen rxclk_gen(.rxclk_in(xgmii_rxclk),                .reset(reset_dcm),                .rxclk(rxclk),    // system clock                .rxclk_180(rxclk_180), //reversed clock                .locked(locked)                 );    //////////////////////////////////////   // Rx Engine DataPath   //////////////////////////////////////   rxDataPath datapath_main(.rxclk(rxclk), .reset(reset), .rxd64(rxd64), .rxc8(rxc8), .inband_fcs(inband_fcs), .receiving(receiving),                             .start_da(start_da), .start_lt(start_lt), .wait_crc_check(wait_crc_check), .get_sfd(get_sfd),                              .get_terminator(get_terminator), .get_error_code(get_error_code), .tagged_frame(tagged_frame), .pause_frame(pause_frame),                    .da_addr(da_addr), .terminator_location(terminator_location), .CRC_DATA(CRC_DATA), .rx_data_valid(rx_data_valid),                     .rx_data(rx_data), .get_terminator_d1(get_terminator_d1),.bad_frame_get(bad_frame_get),.good_frame_get(good_frame_get),                    .check_reset(check_reset),.rx_good_frame(rx_good_frame),.rx_bad_frame(rx_bad_frame));//,.fcTxPauseData(fcTxPauseData));    //////////////////////////////////////   // Destination Address Checker   //////////////////////////////////////   rxDAchecker  dachecker(.rxclk(rxclk), .reset(reset), .local_invalid(local_invalid), .broad_valid(broad_valid), .multi_valid(multi_valid), .MAC_Addr(MAC_Addr),                          .da_addr(da_addr));   /////////////////////////////////////   // Length/Type field checker   /////////////////////////////////////   rxLenTypChecker lenchecker(.rxclk(rxclk), .reset(reset), .get_terminator(get_terminator), .terminator_location(terminator_location),                      .jumbo_enable(jumbo_enable), .tagged_frame(tagged_frame), .frame_cnt(frame_cnt), .vlan_enable(vlan_enable),                     .length_error(length_error), .large_error(large_error),.small_error(small_error), .padded_frame(padded_frame),                     .length_65_127(length_65_127), .length_128_255(length_128_255), .length_256_511(length_256_511), .length_512_1023(length_512_1023),                           .length_1024_max(length_1024_max), .jumbo_frame(jumbo_frame) );    /////////////////////////////////////   // Counters used in Receive Engine   /////////////////////////////////////    rxNumCounter counters(.rxclk(rxclk), .reset(reset), .receiving(receiving), .frame_cnt(frame_cnt));    /////////////////////////////////////   // State Machine in Receive Process   /////////////////////////////////////    rxStateMachine statemachine(.rxclk(rxclk), .reset(reset), .recv_enable(recv_enable), .get_sfd(get_sfd), .local_invalid(local_invalid),                                 .length_error(length_error), .crc_check_valid(crc_check_valid), .crc_check_invalid(crc_check_invalid),                                .start_da(start_da), .start_lt(start_lt), .receiving(receiving),.good_frame_get(good_frame_get),                               .bad_frame_get(bad_frame_get), .get_error_code(get_error_code), .wait_crc_check(wait_crc_check), .get_terminator(get_terminator),                               .receiving_d1(receiving_d1),.check_reset(check_reset));   /////////////////////////////////////   // CRC Check module   /////////////////////////////////////   rxCRC crcmodule(.rxclk(rxclk), .reset(reset), .CRC_DATA(CRC_DATA), .get_terminator(get_terminator), .terminator_location(terminator_location),                   .crc_check_invalid(crc_check_invalid), .crc_check_valid(crc_check_valid),.receiving(receiving),.receiving_d1(receiving_d1),                   .get_terminator_d1(get_terminator_d1), .wait_crc_check(wait_crc_check),.get_error_code(get_error_code));   /////////////////////////////////////   // RS Layer   /////////////////////////////////////    rxRSLayer rx_rs(.rxclk(rxclk), .rxclk_180(rxclk_180), .rxclk_2x(rxclk_2x), .reset(reset), .link_fault(link_fault), .rxd64(rxd64), .rxc8(rxc8), .rxd_in(xgmii_rxd), .rxc_in(xgmii_rxc));       /////////////////////////////////////   // Statistic module   /////////////////////////////////////   rxStatModule rx_stat(.rxclk(rxclk),.reset(reset),.good_frame_get(good_frame_get), .large_error(large_error),.small_error(small_error), .crc_check_invalid(crc_check_invalid),                 .receiving(receiving), .padded_frame(padded_frame), .pause_frame(pause_frame), .broad_valid(broad_valid), .multi_valid(multi_valid),                 .length_65_127(length_65_127), .length_128_255(length_128_255), .length_256_511(length_256_511), .length_512_1023(length_512_1023),                  .length_1024_max(length_1024_max), .jumbo_frame(jumbo_frame),.get_error_code(get_error_code), .rxStatRegPlus(rxStatRegPlus));				   endmodule

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人国产精品免费观看视频| 日韩精品国产精品| 成人蜜臀av电影| 国产精品国产精品国产专区不蜜 | 亚洲精品国产高清久久伦理二区| 成人一二三区视频| 日韩一区日韩二区| 精品视频一区二区三区免费| 视频在线在亚洲| 精品国产乱码久久| 不卡视频一二三四| 亚洲愉拍自拍另类高清精品| 91麻豆精品国产91久久久久久 | 亚洲精品一区二区三区香蕉| 国产91高潮流白浆在线麻豆| 亚洲色图视频网| 欧美浪妇xxxx高跟鞋交| 成人av资源在线观看| 亚洲乱码国产乱码精品精98午夜 | 国产精品久久毛片a| 欧美性大战xxxxx久久久| 另类小说图片综合网| 国产精品欧美一级免费| 欧美色精品在线视频| 国产综合色精品一区二区三区| 亚洲欧美在线另类| 日韩欧美一区二区视频| 岛国一区二区在线观看| 丝袜亚洲另类欧美| xvideos.蜜桃一区二区| 色婷婷精品久久二区二区蜜臀av| 日韩中文字幕区一区有砖一区| 欧美激情一区在线观看| 91精品在线免费观看| 北岛玲一区二区三区四区| 午夜视频在线观看一区二区| 国产欧美综合在线| 日韩一区二区三区视频在线观看| 成人免费看黄yyy456| 美女一区二区在线观看| 亚洲另类春色校园小说| www激情久久| 欧美日韩精品三区| 91性感美女视频| 国内精品久久久久影院色| 亚洲精品国产一区二区精华液| 精品国产人成亚洲区| 欧美色图激情小说| 国产乱国产乱300精品| 天涯成人国产亚洲精品一区av| 中文字幕一区二区视频| 久久久国产一区二区三区四区小说 | 日韩欧美国产wwwww| 国产成人免费视频一区| 美国毛片一区二区三区| 午夜精彩视频在线观看不卡| 亚洲手机成人高清视频| 久久久久久久久蜜桃| 精品久久久久久久人人人人传媒 | 懂色av一区二区在线播放| 毛片av一区二区| 日韩国产欧美三级| 一区二区三区资源| 亚洲黄一区二区三区| 1024亚洲合集| 亚洲欧美色一区| 自拍偷在线精品自拍偷无码专区| 国产欧美日韩亚州综合| 久久综合999| 日韩精品专区在线| 欧美成人三级在线| 日韩免费观看2025年上映的电影| 日韩一区二区三免费高清| 91超碰这里只有精品国产| 欧美人xxxx| 8x8x8国产精品| 欧美成人综合网站| 久久亚洲欧美国产精品乐播 | 国产精品视频观看| 久久精品视频免费观看| 国产无人区一区二区三区| 国产午夜精品一区二区| 国产精品国模大尺度视频| 亚洲天堂网中文字| 亚洲一区二区三区在线| 日韩制服丝袜先锋影音| 麻豆精品在线播放| 国产麻豆午夜三级精品| 成人免费视频视频在线观看免费| 99re这里都是精品| 欧美影院精品一区| 日韩亚洲国产中文字幕欧美| 26uuu国产电影一区二区| 国产精品乱人伦中文| 亚洲免费成人av| 日韩影院在线观看| 国产在线乱码一区二区三区| 成人av网站在线观看| 欧洲激情一区二区| 日韩视频免费观看高清完整版在线观看| 日韩视频在线观看一区二区| 精品国产亚洲一区二区三区在线观看| 久久久精品欧美丰满| 亚洲精品久久7777| 久草中文综合在线| 99久久99久久免费精品蜜臀| 欧美日韩久久久| 久久中文字幕电影| 伊人夜夜躁av伊人久久| 日韩在线播放一区二区| 成人午夜免费av| 欧美久久免费观看| 中文字幕久久午夜不卡| 亚洲国产精品久久艾草纯爱 | 国产.欧美.日韩| 欧洲生活片亚洲生活在线观看| 欧美一区欧美二区| 成人免费小视频| 久久国产夜色精品鲁鲁99| 色综合久久久久综合体| 日韩免费福利电影在线观看| 中文字幕中文字幕一区二区| 青青国产91久久久久久| 99精品在线免费| 精品国产91乱码一区二区三区| 亚洲欧洲在线观看av| 久久精品免费观看| 欧美在线视频你懂得| 亚洲综合成人在线视频| 国产在线国偷精品免费看| 欧美影院一区二区| 中文字幕不卡三区| 免费人成精品欧美精品| 在线免费不卡视频| 久久精品一区二区三区av| 视频一区二区三区在线| 色综合久久精品| 国产无人区一区二区三区| 免费日本视频一区| 欧美三级电影在线看| 国产精品传媒入口麻豆| 国产在线精品一区二区不卡了| 欧美精选在线播放| 亚洲综合久久久久| 91丝袜高跟美女视频| 久久久久国色av免费看影院| 久久精品噜噜噜成人88aⅴ| 欧美日韩一区不卡| 一区二区激情视频| 成人禁用看黄a在线| 久久久久久久久久电影| 久久国产尿小便嘘嘘| 日韩欧美一级在线播放| 午夜久久久久久电影| 日本道色综合久久| 亚洲免费三区一区二区| 99国产精品一区| 国产精品区一区二区三区| 国产老肥熟一区二区三区| 精品国产百合女同互慰| 蜜桃精品视频在线观看| 日韩精品一区二区三区在线播放 | 久久精品72免费观看| 日韩视频一区二区三区在线播放| 午夜欧美大尺度福利影院在线看| 色偷偷88欧美精品久久久| 亚洲同性同志一二三专区| a在线播放不卡| 一区二区在线观看av| 日本韩国欧美国产| 午夜欧美电影在线观看| 欧美一级一级性生活免费录像| 免费在线观看一区| 精品久久久久久最新网址| 国产一区二区导航在线播放| 国产欧美久久久精品影院| 成人禁用看黄a在线| 一区二区三区四区在线免费观看| 在线观看视频一区二区欧美日韩 | 日本sm残虐另类| 欧美精品一区二区蜜臀亚洲| 国产精品白丝av| 国产精品美女久久久久久久久久久| 99久久精品情趣| 亚洲高清免费观看 | 国产精品一区二区久激情瑜伽| 国产亚洲欧美日韩俺去了| 成人sese在线| 亚洲美女精品一区| 7777精品伊人久久久大香线蕉最新版| 久久99精品国产91久久来源 | 一区二区在线看| 欧美精品国产精品| 久久99精品久久久| 亚洲视频在线观看三级| 7777精品伊人久久久大香线蕉超级流畅 | 粉嫩久久99精品久久久久久夜| 亚洲欧洲无码一区二区三区| 欧美色国产精品| 国产xxx精品视频大全|