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

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

?? eth_receivecontrol.v

?? 以太網控制器MAC的verilog代碼
?? V
字號:
//////////////////////////////////////////////////////////////////////////                                                              ////////  eth_receivecontrol.v                                        ////////                                                              ////////  This file is part of the Ethernet IP core project           ////////  http://www.opencores.org/projects/ethmac/                   ////////                                                              ////////  Author(s):                                                  ////////      - Igor Mohor (igorM@opencores.org)                      ////////                                                              ////////  All additional information is avaliable in the Readme.txt   ////////  file.                                                       ////////                                                              //////////////////////////////////////////////////////////////////////////////                                                              //////// Copyright (C) 2001 Authors                                   ////////                                                              //////// 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: eth_receivecontrol.v,v $// Revision 1.5  2003/01/22 13:49:26  tadejm// When control packets were received, they were ignored in some cases.//// Revision 1.4  2002/11/22 01:57:06  mohor// Rx Flow control fixed. CF flag added to the RX buffer descriptor. RxAbort// synchronized.//// Revision 1.3  2002/01/23 10:28:16  mohor// Link in the header changed.//// Revision 1.2  2001/10/19 08:43:51  mohor// eth_timescale.v changed to timescale.v This is done because of the// simulation of the few cores in a one joined project.//// Revision 1.1  2001/08/06 14:44:29  mohor// A define FPGA added to select between Artisan RAM (for ASIC) and Block Ram (For Virtex).// Include files fixed to contain no path.// File names and module names changed ta have a eth_ prologue in the name.// File eth_timescale.v is used to define timescale// All pin names on the top module are changed to contain _I, _O or _OE at the end.// Bidirectional signal MDIO is changed to three signals (Mdc_O, Mdi_I, Mdo_O// and Mdo_OE. The bidirectional signal must be created on the top level. This// is done due to the ASIC tools.//// Revision 1.1  2001/07/30 21:23:42  mohor// Directory structure changed. Files checked and joind together.//// Revision 1.1  2001/07/03 12:51:54  mohor// Initial release of the MAC Control module.//////////`include "timescale.v"module eth_receivecontrol (MTxClk, MRxClk, TxReset, RxReset, RxData, RxValid, RxStartFrm,                            RxEndFrm, RxFlow, ReceiveEnd, MAC, DlyCrcEn, TxDoneIn,                            TxAbortIn, TxStartFrmOut, ReceivedLengthOK, ReceivedPacketGood,                            TxUsedDataOutDetected, Pause, ReceivedPauseFrm, AddressOK,                            RxStatusWriteLatched_sync2, r_PassAll, SetPauseTimer                          );parameter Tp = 1;input       MTxClk;input       MRxClk;input       TxReset; input       RxReset; input [7:0] RxData;input       RxValid;input       RxStartFrm;input       RxEndFrm;input       RxFlow;input       ReceiveEnd;input [47:0]MAC;input       DlyCrcEn;input       TxDoneIn;input       TxAbortIn;input       TxStartFrmOut;input       ReceivedLengthOK;input       ReceivedPacketGood;input       TxUsedDataOutDetected;input       RxStatusWriteLatched_sync2;input       r_PassAll;output      Pause;output      ReceivedPauseFrm;output      AddressOK;output      SetPauseTimer;reg         Pause;reg         AddressOK;                // Multicast or unicast address detectedreg         TypeLengthOK;             // Type/Length field contains 0x8808reg         DetectionWindow;          // Detection of the PAUSE frame is possible within this windowreg         OpCodeOK;                 // PAUSE opcode detected (0x0001)reg  [2:0]  DlyCrcCnt;reg  [4:0]  ByteCnt;reg [15:0]  AssembledTimerValue;reg [15:0]  LatchedTimerValue;reg         ReceivedPauseFrm;reg         ReceivedPauseFrmWAddr;reg         PauseTimerEq0_sync1;reg         PauseTimerEq0_sync2;reg [15:0]  PauseTimer;reg         Divider2;reg  [5:0]  SlotTimer;wire [47:0] ReservedMulticast;        // 0x0180C2000001wire [15:0] TypeLength;               // 0x8808wire        ResetByteCnt;             // wire        IncrementByteCnt;         // wire        ByteCntEq0;               // ByteCnt = 0wire        ByteCntEq1;               // ByteCnt = 1wire        ByteCntEq2;               // ByteCnt = 2wire        ByteCntEq3;               // ByteCnt = 3wire        ByteCntEq4;               // ByteCnt = 4wire        ByteCntEq5;               // ByteCnt = 5wire        ByteCntEq12;              // ByteCnt = 12wire        ByteCntEq13;              // ByteCnt = 13wire        ByteCntEq14;              // ByteCnt = 14wire        ByteCntEq15;              // ByteCnt = 15wire        ByteCntEq16;              // ByteCnt = 16wire        ByteCntEq17;              // ByteCnt = 17wire        ByteCntEq18;              // ByteCnt = 18wire        DecrementPauseTimer;      // wire        PauseTimerEq0;            // wire        ResetSlotTimer;           // wire        IncrementSlotTimer;       // wire        SlotFinished;             // // Reserved multicast address and Type/Length for PAUSE controlassign ReservedMulticast = 48'h0180C2000001;assign TypeLength = 16'h8808;// Address Detection (Multicast or unicast)always @ (posedge MRxClk or posedge RxReset)begin  if(RxReset)    AddressOK <= #Tp 1'b0;  else  if(DetectionWindow & ByteCntEq0)    AddressOK <= #Tp  RxData[7:0] == ReservedMulticast[47:40] | RxData[7:0] == MAC[47:40];  else  if(DetectionWindow & ByteCntEq1)    AddressOK <= #Tp (RxData[7:0] == ReservedMulticast[39:32] | RxData[7:0] == MAC[39:32]) & AddressOK;  else  if(DetectionWindow & ByteCntEq2)    AddressOK <= #Tp (RxData[7:0] == ReservedMulticast[31:24] | RxData[7:0] == MAC[31:24]) & AddressOK;  else  if(DetectionWindow & ByteCntEq3)    AddressOK <= #Tp (RxData[7:0] == ReservedMulticast[23:16] | RxData[7:0] == MAC[23:16]) & AddressOK;  else  if(DetectionWindow & ByteCntEq4)    AddressOK <= #Tp (RxData[7:0] == ReservedMulticast[15:8]  | RxData[7:0] == MAC[15:8])  & AddressOK;  else  if(DetectionWindow & ByteCntEq5)    AddressOK <= #Tp (RxData[7:0] == ReservedMulticast[7:0]   | RxData[7:0] == MAC[7:0])   & AddressOK;  else  if(ReceiveEnd)    AddressOK <= #Tp 1'b0;end// TypeLengthOK (Type/Length Control frame detected)always @ (posedge MRxClk or posedge RxReset )begin  if(RxReset)    TypeLengthOK <= #Tp 1'b0;  else  if(DetectionWindow & ByteCntEq12)    TypeLengthOK <= #Tp ByteCntEq12 & (RxData[7:0] == TypeLength[15:8]);  else  if(DetectionWindow & ByteCntEq13)    TypeLengthOK <= #Tp ByteCntEq13 & (RxData[7:0] == TypeLength[7:0]) & TypeLengthOK;  else  if(ReceiveEnd)    TypeLengthOK <= #Tp 1'b0;end// Latch Control Frame Opcodealways @ (posedge MRxClk or posedge RxReset )begin  if(RxReset)    OpCodeOK <= #Tp 1'b0;  else  if(ByteCntEq16)    OpCodeOK <= #Tp 1'b0;  else    begin      if(DetectionWindow & ByteCntEq14)        OpCodeOK <= #Tp ByteCntEq14 & RxData[7:0] == 8'h00;          if(DetectionWindow & ByteCntEq15)        OpCodeOK <= #Tp ByteCntEq15 & RxData[7:0] == 8'h01 & OpCodeOK;    endend// ReceivedPauseFrmWAddr (+Address Check)always @ (posedge MRxClk or posedge RxReset )begin  if(RxReset)    ReceivedPauseFrmWAddr <= #Tp 1'b0;  else  if(ReceiveEnd)    ReceivedPauseFrmWAddr <= #Tp 1'b0;  else  if(ByteCntEq16 & TypeLengthOK & OpCodeOK & AddressOK)    ReceivedPauseFrmWAddr <= #Tp 1'b1;        end// Assembling 16-bit timer value from two 8-bit dataalways @ (posedge MRxClk or posedge RxReset )begin  if(RxReset)    AssembledTimerValue[15:0] <= #Tp 16'h0;  else  if(RxStartFrm)    AssembledTimerValue[15:0] <= #Tp 16'h0;  else    begin      if(DetectionWindow & ByteCntEq16)        AssembledTimerValue[15:8] <= #Tp RxData[7:0];      if(DetectionWindow & ByteCntEq17)        AssembledTimerValue[7:0] <= #Tp RxData[7:0];    endend// Detection window (while PAUSE detection is possible)always @ (posedge MRxClk or posedge RxReset )begin  if(RxReset)    DetectionWindow <= #Tp 1'b1;  else  if(ByteCntEq18)    DetectionWindow <= #Tp 1'b0;  else  if(ReceiveEnd)    DetectionWindow <= #Tp 1'b1;end// Latching Timer Valuealways @ (posedge MRxClk or posedge RxReset )begin  if(RxReset)    LatchedTimerValue[15:0] <= #Tp 16'h0;  else  if(DetectionWindow &  ReceivedPauseFrmWAddr &  ByteCntEq18)    LatchedTimerValue[15:0] <= #Tp AssembledTimerValue[15:0];  else  if(ReceiveEnd)    LatchedTimerValue[15:0] <= #Tp 16'h0;end// Delayed CEC counteralways @ (posedge MRxClk or posedge RxReset)begin  if(RxReset)    DlyCrcCnt <= #Tp 3'h0;  else  if(RxValid & RxEndFrm)    DlyCrcCnt <= #Tp 3'h0;  else  if(RxValid & ~RxEndFrm & ~DlyCrcCnt[2])    DlyCrcCnt <= #Tp DlyCrcCnt + 1'b1;end             assign ResetByteCnt = RxEndFrm;assign IncrementByteCnt = RxValid & DetectionWindow & ~ByteCntEq18 & (~DlyCrcEn | DlyCrcEn & DlyCrcCnt[2]);// Byte counteralways @ (posedge MRxClk or posedge RxReset)begin  if(RxReset)    ByteCnt[4:0] <= #Tp 5'h0;  else  if(ResetByteCnt)    ByteCnt[4:0] <= #Tp 5'h0;  else  if(IncrementByteCnt)    ByteCnt[4:0] <= #Tp ByteCnt[4:0] + 1'b1;endassign ByteCntEq0 = RxValid & ByteCnt[4:0] == 5'h0;assign ByteCntEq1 = RxValid & ByteCnt[4:0] == 5'h1;assign ByteCntEq2 = RxValid & ByteCnt[4:0] == 5'h2;assign ByteCntEq3 = RxValid & ByteCnt[4:0] == 5'h3;assign ByteCntEq4 = RxValid & ByteCnt[4:0] == 5'h4;assign ByteCntEq5 = RxValid & ByteCnt[4:0] == 5'h5;assign ByteCntEq12 = RxValid & ByteCnt[4:0] == 5'h0C;assign ByteCntEq13 = RxValid & ByteCnt[4:0] == 5'h0D;assign ByteCntEq14 = RxValid & ByteCnt[4:0] == 5'h0E;assign ByteCntEq15 = RxValid & ByteCnt[4:0] == 5'h0F;assign ByteCntEq16 = RxValid & ByteCnt[4:0] == 5'h10;assign ByteCntEq17 = RxValid & ByteCnt[4:0] == 5'h11;assign ByteCntEq18 = RxValid & ByteCnt[4:0] == 5'h12 & DetectionWindow;assign SetPauseTimer = ReceiveEnd & ReceivedPauseFrmWAddr & ReceivedPacketGood & ReceivedLengthOK & RxFlow;assign DecrementPauseTimer = SlotFinished & |PauseTimer;// PauseTimer[15:0]always @ (posedge MRxClk or posedge RxReset)begin  if(RxReset)    PauseTimer[15:0] <= #Tp 16'h0;  else  if(SetPauseTimer)    PauseTimer[15:0] <= #Tp LatchedTimerValue[15:0];  else  if(DecrementPauseTimer)    PauseTimer[15:0] <= #Tp PauseTimer[15:0] - 1'b1;endassign PauseTimerEq0 = ~(|PauseTimer[15:0]);// Synchronization of the pause timeralways @ (posedge MTxClk or posedge TxReset)begin  if(TxReset)    begin      PauseTimerEq0_sync1 <= #Tp 1'b1;      PauseTimerEq0_sync2 <= #Tp 1'b1;    end  else    begin      PauseTimerEq0_sync1 <= #Tp PauseTimerEq0;      PauseTimerEq0_sync2 <= #Tp PauseTimerEq0_sync1;    endend// Pause signal generationalways @ (posedge MTxClk or posedge TxReset)begin  if(TxReset)    Pause <= #Tp 1'b0;  else  if((TxDoneIn | TxAbortIn | ~TxUsedDataOutDetected) & ~TxStartFrmOut)    Pause <= #Tp RxFlow & ~PauseTimerEq0_sync2;end// Divider2 is used for incrementing the Slot timer every other clockalways @ (posedge MRxClk or posedge RxReset)begin  if(RxReset)    Divider2 <= #Tp 1'b0;  else  if(|PauseTimer[15:0] & RxFlow)    Divider2 <= #Tp ~Divider2;  else    Divider2 <= #Tp 1'b0;endassign ResetSlotTimer = RxReset;assign IncrementSlotTimer =  Pause & RxFlow & Divider2;// SlotTimeralways @ (posedge MRxClk or posedge RxReset)begin  if(RxReset)    SlotTimer[5:0] <= #Tp 6'h0;  else  if(ResetSlotTimer)    SlotTimer[5:0] <= #Tp 6'h0;  else  if(IncrementSlotTimer)    SlotTimer[5:0] <= #Tp SlotTimer[5:0] + 1'b1;endassign SlotFinished = &SlotTimer[5:0] & IncrementSlotTimer;  // Slot is 512 bits (64 bytes)// Pause Frame receivedalways @ (posedge MRxClk or posedge RxReset)begin  if(RxReset)    ReceivedPauseFrm <=#Tp 1'b0;  else  if(RxStatusWriteLatched_sync2 & r_PassAll | ReceivedPauseFrm & (~r_PassAll))    ReceivedPauseFrm <=#Tp 1'b0;  else  if(ByteCntEq16 & TypeLengthOK & OpCodeOK)    ReceivedPauseFrm <=#Tp 1'b1;        endendmodule

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩精品一区二区在线观看| 3d动漫精品啪啪| 亚洲电影在线播放| 亚洲国产成人在线| 91麻豆精品国产自产在线观看一区 | 国产精品理论片在线观看| 欧美在线999| 高潮精品一区videoshd| 日韩精品一二三四| 亚洲精品成人悠悠色影视| 久久综合狠狠综合久久综合88| 在线精品国精品国产尤物884a| 国产九色精品成人porny| 亚洲不卡一区二区三区| 欧美日韩日日夜夜| 不卡的av在线播放| 日韩福利视频导航| 亚洲精品乱码久久久久久黑人| 日韩三级免费观看| 欧美视频中文字幕| 欧美性猛交一区二区三区精品 | 久久网站最新地址| 日韩精品国产欧美| 亚洲精品国产高清久久伦理二区| 国产午夜精品一区二区三区四区| 欧美一区二区三区免费观看视频 | 无码av免费一区二区三区试看| 国产精品美女久久久久久久久久久| 精品国产伦理网| 日韩欧美中文一区| 欧美蜜桃一区二区三区| 欧美午夜片在线看| 在线看不卡av| 在线观看视频一区二区欧美日韩| 不卡视频免费播放| 国产麻豆视频精品| 中文字幕乱码亚洲精品一区 | 一区二区三区四区五区视频在线观看| 国产肉丝袜一区二区| 精品久久久三级丝袜| 欧美成人综合网站| 欧美精品一区男女天堂| 精品久久久久久久久久久久久久久久久| 7777精品伊人久久久大香线蕉完整版| 欧美丝袜丝nylons| 91精品在线麻豆| 91精品免费在线| 日韩午夜av电影| 日韩三级av在线播放| 欧美成人精品3d动漫h| 精品国产人成亚洲区| 久久网这里都是精品| 中文字幕av一区二区三区| 中文字幕中文乱码欧美一区二区| 国产精品嫩草99a| 亚洲日本欧美天堂| 亚洲一区二区三区四区在线观看 | 欧美v国产在线一区二区三区| 欧美一级xxx| 久久久久国色av免费看影院| 国产欧美一区二区在线| 麻豆传媒一区二区三区| 日韩欧美色电影| 欧美色图片你懂的| 色系网站成人免费| 欧美色视频在线| 在线亚洲欧美专区二区| 成人aa视频在线观看| 国产经典欧美精品| 久久99精品久久久| 亚洲国产综合色| 18欧美乱大交hd1984| 中国av一区二区三区| 久久这里只有精品首页| 精品国产免费久久| 久久久噜噜噜久久中文字幕色伊伊| 欧美成人三级电影在线| 久久精品一区蜜桃臀影院| 一区二区三区波多野结衣在线观看| 亚洲色图制服丝袜| 午夜久久久久久| 蜜桃精品在线观看| 成人免费观看av| 国产xxx精品视频大全| 成人激情免费网站| 欧美三级韩国三级日本一级| 国产亚洲欧美激情| 欧美国产国产综合| 日本女优在线视频一区二区| 亚洲人精品一区| 亚洲综合丁香婷婷六月香| 欧美一级片在线看| 精品国产一区二区亚洲人成毛片| 日韩美女在线视频| 亚洲视频免费观看| 91麻豆精品91久久久久久清纯 | 免费一区二区视频| 日产国产欧美视频一区精品| 国产精品一区二区三区网站| 91黄视频在线| 久久精品一区二区三区四区| 亚洲国产精品久久久男人的天堂 | 久久国产精品第一页| 国产mv日韩mv欧美| 日韩视频一区二区三区在线播放 | 色综合激情五月| 欧美成人免费网站| 午夜电影网亚洲视频| 99天天综合性| 久久精品亚洲麻豆av一区二区| 亚洲图片欧美色图| 一道本成人在线| 国产三级三级三级精品8ⅰ区| 亚洲成av人片一区二区三区| av高清久久久| 国产网站一区二区三区| 韩国精品主播一区二区在线观看| 欧美优质美女网站| 亚洲激情图片一区| 91香蕉国产在线观看软件| 国产嫩草影院久久久久| 激情欧美一区二区| 日韩欧美一区二区在线视频| 亚洲一区二区三区视频在线播放| 日韩欧美视频在线| 免费在线成人网| 欧美一级二级三级蜜桃| 琪琪一区二区三区| 91精品国产入口在线| 五月婷婷另类国产| 欧美日韩国产123区| 午夜久久久影院| 欧美三级视频在线观看 | 国产在线不卡一卡二卡三卡四卡| 在线成人av网站| 亚洲mv大片欧洲mv大片精品| 欧美视频中文一区二区三区在线观看| 亚洲激情在线激情| 91官网在线观看| 亚洲成人综合在线| 欧美精品久久久久久久久老牛影院 | 欧美三级视频在线观看| 亚洲大尺度视频在线观看| 欧美人妇做爰xxxⅹ性高电影 | 日本强好片久久久久久aaa| 欧美一区二区视频网站| 日本午夜精品视频在线观看| 91麻豆精品国产91久久久资源速度 | 成人激情文学综合网| 一区二区三区在线免费观看 | 亚洲电影一级黄| 久久青草欧美一区二区三区| 久久影院午夜片一区| 国产精品视频九色porn| youjizz久久| 亚洲精品免费在线播放| 在线欧美小视频| 美腿丝袜一区二区三区| 久久久国产精华| 波多野结衣中文字幕一区二区三区| 综合色天天鬼久久鬼色| 在线视频国内自拍亚洲视频| 日韩在线一二三区| 久久影院视频免费| 成人av网站在线| 亚洲一区二区欧美日韩| 欧美一区二区播放| 成人a级免费电影| 一区二区高清视频在线观看| 69堂精品视频| 成人美女视频在线观看18| 亚洲最新视频在线观看| 日韩一二三四区| av资源站一区| 亚洲成人av电影| 国产亚洲人成网站| 91网上在线视频| 久久99九九99精品| 亚洲精品乱码久久久久| 精品日韩在线观看| 色噜噜狠狠成人中文综合 | 午夜国产精品一区| 欧美激情在线免费观看| 欧美一区二区三区视频在线观看 | 884aa四虎影成人精品一区| 国产传媒日韩欧美成人| 亚洲国产一区视频| 国产日韩av一区| 欧美一区二区免费| 91啪九色porn原创视频在线观看| 精品一区二区三区在线播放| 亚洲精品一二三四区| 久久综合九色综合97婷婷| 欧美日韩亚洲另类| av午夜精品一区二区三区| 精品一区二区三区免费毛片爱| 亚洲摸摸操操av| 国产日产欧美一区| 自拍偷拍欧美激情| 色综合激情久久|