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

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

?? eth_rxethmac.v

?? FPGA數字電子系統設計與開發實例導航光盤內附源碼
?? V
字號:

//
//
//

`include "timescale.v"


module eth_rxethmac (MRxClk, MRxDV, MRxD, Reset, Transmitting, MaxFL, r_IFG, HugEn, DlyCrcEn, 
                     RxData, RxValid, RxStartFrm, RxEndFrm, ByteCnt, ByteCntEq0, ByteCntGreat2, 
                     ByteCntMaxFrame, CrcError, StateIdle, StatePreamble, StateSFD, StateData,
                     MAC, r_Pro, r_Bro,r_HASH0, r_HASH1, RxAbort, AddressMiss, PassAll, ControlFrmAddressOK
                    );

parameter Tp = 1;



input         MRxClk;
input         MRxDV;
input   [3:0] MRxD;
input         Transmitting;
input         HugEn;
input         DlyCrcEn;
input  [15:0] MaxFL;
input         r_IFG;
input         Reset;
input  [47:0] MAC;     //  Station Address  
input         r_Bro;   //  broadcast disable
input         r_Pro;   //  promiscuous enable 
input [31:0]  r_HASH0; //  lower 4 bytes Hash Table
input [31:0]  r_HASH1; //  upper 4 bytes Hash Table
input         PassAll;
input         ControlFrmAddressOK;

output  [7:0] RxData;
output        RxValid;
output        RxStartFrm;
output        RxEndFrm;
output [15:0] ByteCnt;
output        ByteCntEq0;
output        ByteCntGreat2;
output        ByteCntMaxFrame;
output        CrcError;
output        StateIdle;
output        StatePreamble;
output        StateSFD;
output  [1:0] StateData;
output        RxAbort;
output        AddressMiss;

reg     [7:0] RxData;
reg           RxValid;
reg           RxStartFrm;
reg           RxEndFrm;
reg           Broadcast;
reg           Multicast;
reg     [8:0] CrcHash;
reg           CrcHashGood;
reg           DelayData;
reg     [3:0] LatchedNibble;
reg     [7:0] LatchedByte;
reg     [7:0] RxData_d;
reg           RxValid_d;
reg           RxStartFrm_d;
reg           RxEndFrm_d;

wire          MRxDEqD;
wire          MRxDEq5;
wire          StateDrop;
wire          ByteCntEq1;
wire          ByteCntEq2;
wire          ByteCntEq3;
wire          ByteCntEq4;
wire          ByteCntEq5;
wire          ByteCntEq6;
wire          ByteCntEq7;
wire          ByteCntSmall7;
wire   [31:0] Crc;
wire          Enable_Crc;
wire          Initialize_Crc;
wire    [3:0] Data_Crc;
wire          GenerateRxValid;
wire          GenerateRxStartFrm;
wire          GenerateRxEndFrm;
wire          DribbleRxEndFrm;
wire    [3:0] DlyCrcCnt;


assign MRxDEqD = MRxD == 4'hd;
assign MRxDEq5 = MRxD == 4'h5;


// Rx State Machine module
eth_rxstatem rxstatem1 (.MRxClk(MRxClk), .Reset(Reset), .MRxDV(MRxDV), .ByteCntEq0(ByteCntEq0), 
                        .ByteCntGreat2(ByteCntGreat2), .Transmitting(Transmitting), .MRxDEq5(MRxDEq5), 
                        .MRxDEqD(MRxDEqD), .IFGCounterEq24(IFGCounterEq24), .ByteCntMaxFrame(ByteCntMaxFrame), 
                        .StateData(StateData), .StateIdle(StateIdle), .StatePreamble(StatePreamble), 
                        .StateSFD(StateSFD), .StateDrop(StateDrop)
                       );


// Rx Counters module
eth_rxcounters rxcounters1 (.MRxClk(MRxClk), .Reset(Reset), .MRxDV(MRxDV), .StateIdle(StateIdle), 
                            .StateSFD(StateSFD), .StateData(StateData), .StateDrop(StateDrop), 
                            .StatePreamble(StatePreamble), .MRxDEqD(MRxDEqD), .DlyCrcEn(DlyCrcEn), 
                            .DlyCrcCnt(DlyCrcCnt), .Transmitting(Transmitting), .MaxFL(MaxFL), .r_IFG(r_IFG), 
                            .HugEn(HugEn), .IFGCounterEq24(IFGCounterEq24), .ByteCntEq0(ByteCntEq0), 
                            .ByteCntEq1(ByteCntEq1), .ByteCntEq2(ByteCntEq2), .ByteCntEq3(ByteCntEq3), 
                            .ByteCntEq4(ByteCntEq4), .ByteCntEq5(ByteCntEq5), .ByteCntEq6(ByteCntEq6), 
                            .ByteCntEq7(ByteCntEq7), .ByteCntGreat2(ByteCntGreat2), 
                            .ByteCntSmall7(ByteCntSmall7), .ByteCntMaxFrame(ByteCntMaxFrame), 
                            .ByteCnt(ByteCnt)
                           );

// Rx Address Check

eth_rxaddrcheck rxaddrcheck1
              (.MRxClk(MRxClk),         .Reset( Reset),             .RxData(RxData), 
               .Broadcast (Broadcast),  .r_Bro (r_Bro),             .r_Pro(r_Pro),
               .ByteCntEq6(ByteCntEq6), .ByteCntEq7(ByteCntEq7),    .ByteCntEq2(ByteCntEq2), 
               .ByteCntEq3(ByteCntEq3), .ByteCntEq4(ByteCntEq4),    .ByteCntEq5(ByteCntEq5), 
               .HASH0(r_HASH0),         .HASH1(r_HASH1),           
               .CrcHash(CrcHash[5:0]),  .CrcHashGood(CrcHashGood),  .StateData(StateData),
               .Multicast(Multicast),   .MAC(MAC),                  .RxAbort(RxAbort),
               .RxEndFrm(RxEndFrm),     .AddressMiss(AddressMiss),  .PassAll(PassAll),
               .ControlFrmAddressOK(ControlFrmAddressOK)
              );


assign Enable_Crc = MRxDV & (|StateData & ~ByteCntMaxFrame);
assign Initialize_Crc = StateSFD | DlyCrcEn & (|DlyCrcCnt[3:0]) & DlyCrcCnt[3:0] < 4'h9;

assign Data_Crc[0] = MRxD[3];
assign Data_Crc[1] = MRxD[2];
assign Data_Crc[2] = MRxD[1];
assign Data_Crc[3] = MRxD[0];


// Connecting module Crc
eth_crc crcrx (.Clk(MRxClk), .Reset(Reset), .Data(Data_Crc), .Enable(Enable_Crc), .Initialize(Initialize_Crc), 
               .Crc(Crc), .CrcError(CrcError)
              );



// Latching CRC for use in the hash table

always @ (posedge MRxClk)
begin
  CrcHashGood <= #Tp StateData[0] & ByteCntEq6;
end

always @ (posedge MRxClk)
begin
  if(Reset | StateIdle)
    CrcHash[8:0] <= #Tp 9'h0;
  else
  if(StateData[0] & ByteCntEq6)
    CrcHash[8:0] <= #Tp Crc[31:23];
end


// Output byte stream
always @ (posedge MRxClk or posedge Reset)
begin
  if(Reset)
    begin
      RxData_d[7:0]      <= #Tp 8'h0;
      DelayData          <= #Tp 1'b0;
      LatchedNibble[3:0] <= #Tp 4'h0;
      LatchedByte[7:0]   <= #Tp 8'h0;
      RxData[7:0]        <= #Tp 8'h0;
    end
  else
    begin
      LatchedNibble[3:0] <= #Tp MRxD[3:0];                        // Latched nibble
      LatchedByte[7:0]   <= #Tp {MRxD[3:0], LatchedNibble[3:0]};  // Latched byte
      DelayData          <= #Tp StateData[0];

      if(GenerateRxValid)
        RxData_d[7:0] <= #Tp LatchedByte[7:0] & {8{|StateData}};  // Data goes through only in data state 
      else
      if(~DelayData)
        RxData_d[7:0] <= #Tp 8'h0;                                // Delaying data to be valid for two cycles. Zero when not active.

      RxData[7:0] <= #Tp RxData_d[7:0];                           // Output data byte
    end
end

    

always @ (posedge MRxClk or posedge Reset)
begin
  if(Reset)
    Broadcast <= #Tp 1'b0;
  else
    begin      
      if(StateData[0] & ~(&LatchedByte[7:0]) & ByteCntSmall7)
        Broadcast <= #Tp 1'b0;
      else
      if(StateData[0] & (&LatchedByte[7:0]) & ByteCntEq1)
        Broadcast <= #Tp 1'b1;
      else
      if(RxAbort | RxEndFrm)
        Broadcast <= #Tp 1'b0;
    end
end


always @ (posedge MRxClk or posedge Reset)
begin
  if(Reset)
    Multicast <= #Tp 1'b0;
  else
    begin      
      if(Reset)
        Multicast <= #Tp 1'b0;
      else
      if(StateData[0] & ByteCntEq1 & LatchedByte == 8'h01)
        Multicast <= #Tp 1'b1;
    else if(RxAbort | RxEndFrm)
      Multicast <= #Tp 1'b0;
    end
end


assign GenerateRxValid = StateData[0] & (~ByteCntEq0 | DlyCrcCnt >= 4'h3);

always @ (posedge MRxClk or posedge Reset)
begin
  if(Reset)
    begin
      RxValid_d <= #Tp 1'b0;
      RxValid   <= #Tp 1'b0;
    end
  else
    begin
      RxValid_d <= #Tp GenerateRxValid;
      RxValid   <= #Tp RxValid_d;
    end
end


assign GenerateRxStartFrm = StateData[0] & (ByteCntEq1 & ~DlyCrcEn | DlyCrcCnt == 4'h3 & DlyCrcEn);

always @ (posedge MRxClk or posedge Reset)
begin
  if(Reset)
    begin
      RxStartFrm_d <= #Tp 1'b0;
      RxStartFrm   <= #Tp 1'b0;
    end
  else
    begin
      RxStartFrm_d <= #Tp GenerateRxStartFrm;
      RxStartFrm   <= #Tp RxStartFrm_d;
    end
end


assign GenerateRxEndFrm = StateData[0] & (~MRxDV & ByteCntGreat2 | ByteCntMaxFrame);
assign DribbleRxEndFrm  = StateData[1] &  ~MRxDV & ByteCntGreat2;


always @ (posedge MRxClk or posedge Reset)
begin
  if(Reset)
    begin
      RxEndFrm_d <= #Tp 1'b0;
      RxEndFrm   <= #Tp 1'b0;
    end
  else
    begin
      RxEndFrm_d <= #Tp GenerateRxEndFrm;
      RxEndFrm   <= #Tp RxEndFrm_d | DribbleRxEndFrm;
    end
end


endmodule

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲另类中文字| 免费人成精品欧美精品| 日韩vs国产vs欧美| 成人午夜大片免费观看| 欧美一卡2卡3卡4卡| 亚洲激情图片一区| 国产91精品免费| 欧美一卡2卡3卡4卡| 亚洲www啪成人一区二区麻豆| 成人黄色777网| 国产日韩欧美在线一区| 麻豆精品国产91久久久久久| 欧美剧情电影在线观看完整版免费励志电影 | 99久久99精品久久久久久| 日韩午夜电影在线观看| 午夜精品福利视频网站| 一本久久a久久免费精品不卡| 国产精品视频你懂的| 国产精品主播直播| 亚洲精品一区二区三区影院| 午夜欧美大尺度福利影院在线看 | 亚洲欧美激情视频在线观看一区二区三区| 国内精品写真在线观看| 精品三级在线观看| 蜜臀精品久久久久久蜜臀 | 久久综合狠狠综合久久综合88 | 91久久一区二区| 最新国产成人在线观看| 成人伦理片在线| 中文字幕一区二区三区在线不卡 | 处破女av一区二区| 国产亲近乱来精品视频| 大尺度一区二区| 国产精品国产三级国产普通话99| 粉嫩aⅴ一区二区三区四区 | 欧美日韩欧美一区二区| 午夜精品一区二区三区免费视频 | 久久狠狠亚洲综合| 久久只精品国产| 国产成人av电影在线| 国产精品动漫网站| 在线观看一区不卡| 日韩在线观看一区二区| 日韩精品一区二区三区蜜臀| 狠狠色狠狠色综合| 中文字幕精品一区| 91精品1区2区| 日本不卡一二三区黄网| 久久综合久久综合亚洲| av不卡一区二区三区| 亚洲成人手机在线| 精品国产精品网麻豆系列| 成年人国产精品| 亚洲不卡一区二区三区| 久久美女艺术照精彩视频福利播放| 国产成人免费高清| 亚洲国产精品久久久久秋霞影院| 日韩一区二区免费高清| 成人午夜看片网址| 亚洲国产美国国产综合一区二区| 日韩欧美一区二区三区在线| 丁香婷婷综合五月| 日日夜夜一区二区| 亚洲国产精品激情在线观看| 欧美午夜在线观看| 国产a级毛片一区| 亚洲成a人片在线观看中文| 久久久亚洲精华液精华液精华液| 91毛片在线观看| 精品中文av资源站在线观看| 国产精品福利一区二区三区| 91精品国产综合久久久久久久久久 | 国产精品一级在线| 亚洲午夜久久久久久久久电影院 | 高清beeg欧美| 日日噜噜夜夜狠狠视频欧美人 | 91亚洲精品一区二区乱码| 免费欧美日韩国产三级电影| 亚洲人午夜精品天堂一二香蕉| 91精品国产色综合久久不卡电影| 不卡一二三区首页| 精品一区二区免费视频| 午夜亚洲国产au精品一区二区| 2021国产精品久久精品| 欧美精品九九99久久| 91污片在线观看| 国内精品国产三级国产a久久| 亚洲中国最大av网站| 国产精品久久久久久久浪潮网站 | 亚洲图片欧美一区| 国产精品狼人久久影院观看方式| 日韩一区二区视频在线观看| 在线免费观看视频一区| 成人黄色av网站在线| 国产老女人精品毛片久久| 日av在线不卡| 日韩av一区二区三区| 亚洲超碰精品一区二区| 一区二区三区.www| 亚洲同性gay激情无套| 欧美国产一区在线| 国产日韩精品一区二区三区在线| 精品国产乱码久久久久久图片 | 99国产欧美久久久精品| 国产不卡视频一区| 国产一区二区伦理| 国产一区视频在线看| 国产原创一区二区| 国产中文字幕精品| 国产一区二区三区四区五区美女 | 美女网站在线免费欧美精品| 亚洲电影欧美电影有声小说| 亚洲国产精品人人做人人爽| 亚洲精选视频免费看| 一区二区三区精品在线| 亚洲一区二三区| 亚洲福利电影网| 青娱乐精品视频| 美国一区二区三区在线播放| 久久精品72免费观看| 国产精品正在播放| www.久久久久久久久| 一本大道久久a久久精二百| 色综合咪咪久久| 欧美喷潮久久久xxxxx| 欧美成人一区二区三区 | 日韩一区二区三区视频在线观看| 欧美电影免费提供在线观看| 久久只精品国产| 日韩一区欧美小说| 天堂久久久久va久久久久| 久久国产人妖系列| 成人动漫精品一区二区| 欧美性受极品xxxx喷水| 日韩女优av电影| 久久精品夜色噜噜亚洲a∨| 综合久久一区二区三区| 日日夜夜一区二区| 国产成人综合在线观看| 色老汉一区二区三区| 欧美一区二区性放荡片| 亚洲国产精品av| 亚洲电影激情视频网站| 国产电影一区二区三区| 欧美探花视频资源| 欧美成人欧美edvon| 亚洲男同性恋视频| 久久爱www久久做| 91色乱码一区二区三区| 日韩免费高清av| 亚洲老妇xxxxxx| 国内偷窥港台综合视频在线播放| 色婷婷亚洲综合| 久久久一区二区三区捆绑**| 亚洲综合清纯丝袜自拍| 国产乱码精品1区2区3区| 欧美午夜精品免费| 久久精品视频在线免费观看| 亚洲国产精品久久艾草纯爱| 成人自拍视频在线观看| 欧美一区二区三区视频在线观看| 中文字幕av不卡| 国产在线精品一区二区不卡了| 色婷婷一区二区| 国产婷婷色一区二区三区| 热久久免费视频| 欧美色视频一区| 亚洲欧美日韩在线播放| 国产伦理精品不卡| 555www色欧美视频| 亚洲人成网站影音先锋播放| 国产麻豆精品久久一二三| 91精品国产全国免费观看| 亚洲综合色婷婷| 色综合天天狠狠| 自拍偷拍亚洲欧美日韩| 国产精品456| 精品国产免费一区二区三区四区| 亚洲无人区一区| 日本道色综合久久| 成人免费一区二区三区视频 | 日韩欧美卡一卡二| 亚洲国产精品人人做人人爽| 99久久精品国产精品久久| 国产欧美日本一区视频| 国产精品99久| 国产欧美日韩在线| 国产一区在线观看麻豆| 久久综合狠狠综合久久综合88| 久久电影国产免费久久电影| 日韩欧美久久久| 激情丁香综合五月| 久久综合999| 国产成人精品免费一区二区| 26uuu国产一区二区三区| 久久99国内精品| 日本一区二区三区四区在线视频 | 国产一区二区精品在线观看| 精品国产麻豆免费人成网站| 精品一区二区国语对白|