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

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

?? eth_miim.v

?? FPGA數(shù)字電子系統(tǒng)設(shè)計與開發(fā)實例導(dǎo)航光盤內(nèi)附源碼
?? V
字號:


`include "timescale.v"


module eth_miim
(
  Clk,
  Reset,
  Divider,
  NoPre,
  CtrlData,
  Rgad,
  Fiad,
  WCtrlData,
  RStat,
  ScanStat,
  Mdi,
  Mdo,
  MdoEn,
  Mdc,
  Busy,
  Prsd,
  LinkFail,
  Nvalid,
  WCtrlDataStart,
  RStatStart,
  UpdateMIIRX_DATAReg
);



input         Clk;                // Host Clock
input         Reset;              // General Reset
input   [7:0] Divider;            // Divider for the host clock
input  [15:0] CtrlData;           // Control Data (to be written to the PHY reg.)
input   [4:0] Rgad;               // Register Address (within the PHY)
input   [4:0] Fiad;               // PHY Address
input         NoPre;              // No Preamble (no 32-bit preamble)
input         WCtrlData;          // Write Control Data operation
input         RStat;              // Read Status operation
input         ScanStat;           // Scan Status operation
input         Mdi;                // MII Management Data In

output        Mdc;                // MII Management Data Clock
output        Mdo;                // MII Management Data Output
output        MdoEn;              // MII Management Data Output Enable
output        Busy;               // Busy Signal
output        LinkFail;           // Link Integrity Signal
output        Nvalid;             // Invalid Status (qualifier for the valid scan result)

output [15:0] Prsd;               // Read Status Data (data read from the PHY)

output        WCtrlDataStart;     // This signals resets the WCTRLDATA bit in the MIIM Command register
output        RStatStart;         // This signal resets the RSTAT BIT in the MIIM Command register
output        UpdateMIIRX_DATAReg;// Updates MII RX_DATA register with read data

parameter Tp = 1;


reg           Nvalid;
reg           EndBusy_d;          // Pre-end Busy signal
reg           EndBusy;            // End Busy signal (stops the operation in progress)

reg           WCtrlData_q1;       // Write Control Data operation delayed 1 Clk cycle
reg           WCtrlData_q2;       // Write Control Data operation delayed 2 Clk cycles
reg           WCtrlData_q3;       // Write Control Data operation delayed 3 Clk cycles
reg           WCtrlDataStart;     // Start Write Control Data Command (positive edge detected)
reg           WCtrlDataStart_q;
reg           WCtrlDataStart_q1;  // Start Write Control Data Command delayed 1 Mdc cycle
reg           WCtrlDataStart_q2;  // Start Write Control Data Command delayed 2 Mdc cycles

reg           RStat_q1;           // Read Status operation delayed 1 Clk cycle
reg           RStat_q2;           // Read Status operation delayed 2 Clk cycles
reg           RStat_q3;           // Read Status operation delayed 3 Clk cycles
reg           RStatStart;         // Start Read Status Command (positive edge detected)
reg           RStatStart_q1;      // Start Read Status Command delayed 1 Mdc cycle
reg           RStatStart_q2;      // Start Read Status Command delayed 2 Mdc cycles

reg           ScanStat_q1;        // Scan Status operation delayed 1 cycle
reg           ScanStat_q2;        // Scan Status operation delayed 2 cycles
reg           SyncStatMdcEn;      // Scan Status operation delayed at least cycles and synchronized to MdcEn

wire          WriteDataOp;        // Write Data Operation (positive edge detected)
wire          ReadStatusOp;       // Read Status Operation (positive edge detected)
wire          ScanStatusOp;       // Scan Status Operation (positive edge detected)
wire          StartOp;            // Start Operation (start of any of the preceding operations)
wire          EndOp;              // End of Operation

reg           InProgress;         // Operation in progress
reg           InProgress_q1;      // Operation in progress delayed 1 Mdc cycle
reg           InProgress_q2;      // Operation in progress delayed 2 Mdc cycles
reg           InProgress_q3;      // Operation in progress delayed 3 Mdc cycles

reg           WriteOp;            // Write Operation Latch (When asserted, write operation is in progress)
reg     [6:0] BitCounter;         // Bit Counter


wire          MdcFrame;           // Frame window for limiting the Mdc
wire    [3:0] ByteSelect;         // Byte Select defines which byte (preamble, data, operation, etc.) is loaded and shifted through the shift register.
wire          MdcEn;              // MII Management Data Clock Enable signal is asserted for one Clk period before Mdc rises.
wire          ShiftedBit;         // This bit is output of the shift register and is connected to the Mdo signal


wire          LatchByte1_d2;
wire          LatchByte0_d2;
reg           LatchByte1_d;
reg           LatchByte0_d;
reg     [1:0] LatchByte;          // Latch Byte selects which part of Read Status Data is updated from the shift register

reg           UpdateMIIRX_DATAReg;// Updates MII RX_DATA register with read data





// Generation of the EndBusy signal. It is used for ending the MII Management operation.
always @ (posedge Clk or posedge Reset)
begin
  if(Reset)
    begin
      EndBusy_d <= #Tp 1'b0;
      EndBusy <= #Tp 1'b0;
    end
  else
    begin
      EndBusy_d <= #Tp ~InProgress_q2 & InProgress_q3;
      EndBusy   <= #Tp EndBusy_d;
    end
end


// Update MII RX_DATA register
always @ (posedge Clk or posedge Reset)
begin
  if(Reset)
    UpdateMIIRX_DATAReg <= #Tp 0;
  else
  if(EndBusy & ~WCtrlDataStart_q)
    UpdateMIIRX_DATAReg <= #Tp 1;
  else
    UpdateMIIRX_DATAReg <= #Tp 0;    
end



// Generation of the delayed signals used for positive edge triggering.
always @ (posedge Clk or posedge Reset)
begin
  if(Reset)
    begin
      WCtrlData_q1 <= #Tp 1'b0;
      WCtrlData_q2 <= #Tp 1'b0;
      WCtrlData_q3 <= #Tp 1'b0;
      
      RStat_q1 <= #Tp 1'b0;
      RStat_q2 <= #Tp 1'b0;
      RStat_q3 <= #Tp 1'b0;

      ScanStat_q1  <= #Tp 1'b0;
      ScanStat_q2  <= #Tp 1'b0;
      SyncStatMdcEn <= #Tp 1'b0;
    end
  else
    begin
      WCtrlData_q1 <= #Tp WCtrlData;
      WCtrlData_q2 <= #Tp WCtrlData_q1;
      WCtrlData_q3 <= #Tp WCtrlData_q2;

      RStat_q1 <= #Tp RStat;
      RStat_q2 <= #Tp RStat_q1;
      RStat_q3 <= #Tp RStat_q2;

      ScanStat_q1  <= #Tp ScanStat;
      ScanStat_q2  <= #Tp ScanStat_q1;
      if(MdcEn)
        SyncStatMdcEn  <= #Tp ScanStat_q2;
    end
end


// Generation of the Start Commands (Write Control Data or Read Status)
always @ (posedge Clk or posedge Reset)
begin
  if(Reset)
    begin
      WCtrlDataStart <= #Tp 1'b0;
      WCtrlDataStart_q <= #Tp 1'b0;
      RStatStart <= #Tp 1'b0;
    end
  else
    begin
      if(EndBusy)
        begin
          WCtrlDataStart <= #Tp 1'b0;
          RStatStart <= #Tp 1'b0;
        end
      else
        begin
          if(WCtrlData_q2 & ~WCtrlData_q3)
            WCtrlDataStart <= #Tp 1'b1;
          if(RStat_q2 & ~RStat_q3)
            RStatStart <= #Tp 1'b1;
          WCtrlDataStart_q <= #Tp WCtrlDataStart;
        end
    end
end 


// Generation of the Nvalid signal (indicates when the status is invalid)
always @ (posedge Clk or posedge Reset)
begin
  if(Reset)
    Nvalid <= #Tp 1'b0;
  else
    begin
      if(~InProgress_q2 & InProgress_q3)
        begin
          Nvalid <= #Tp 1'b0;
        end
      else
        begin
          if(ScanStat_q2  & ~SyncStatMdcEn)
            Nvalid <= #Tp 1'b1;
        end
    end
end 

// Signals used for the generation of the Operation signals (positive edge)
always @ (posedge Clk or posedge Reset)
begin
  if(Reset)
    begin
      WCtrlDataStart_q1 <= #Tp 1'b0;
      WCtrlDataStart_q2 <= #Tp 1'b0;

      RStatStart_q1 <= #Tp 1'b0;
      RStatStart_q2 <= #Tp 1'b0;

      InProgress_q1 <= #Tp 1'b0;
      InProgress_q2 <= #Tp 1'b0;
      InProgress_q3 <= #Tp 1'b0;

  	  LatchByte0_d <= #Tp 1'b0;
  	  LatchByte1_d <= #Tp 1'b0;

  	  LatchByte <= #Tp 2'b00;
    end
  else
    begin
      if(MdcEn)
        begin
          WCtrlDataStart_q1 <= #Tp WCtrlDataStart;
          WCtrlDataStart_q2 <= #Tp WCtrlDataStart_q1;

          RStatStart_q1 <= #Tp RStatStart;
          RStatStart_q2 <= #Tp RStatStart_q1;

          LatchByte[0] <= #Tp LatchByte0_d;
          LatchByte[1] <= #Tp LatchByte1_d;

          LatchByte0_d <= #Tp LatchByte0_d2;
          LatchByte1_d <= #Tp LatchByte1_d2;

          InProgress_q1 <= #Tp InProgress;
          InProgress_q2 <= #Tp InProgress_q1;
          InProgress_q3 <= #Tp InProgress_q2;
        end
    end
end 


// Generation of the Operation signals
assign WriteDataOp  = WCtrlDataStart_q1 & ~WCtrlDataStart_q2;    
assign ReadStatusOp = RStatStart_q1     & ~RStatStart_q2;
assign ScanStatusOp = SyncStatMdcEn     & ~InProgress & ~InProgress_q1 & ~InProgress_q2;
assign StartOp      = WriteDataOp | ReadStatusOp | ScanStatusOp;

// Busy
assign Busy = WCtrlDataStart | RStatStart | SyncStatMdcEn | EndBusy | InProgress | InProgress_q3 | Nvalid;


// Generation of the InProgress signal (indicates when an operation is in progress)
// Generation of the WriteOp signal (indicates when a write is in progress)
always @ (posedge Clk or posedge Reset)
begin
  if(Reset)
    begin
      InProgress <= #Tp 1'b0;
      WriteOp <= #Tp 1'b0;
    end
  else
    begin
      if(MdcEn)
        begin
          if(StartOp)
            begin
              if(~InProgress)
                WriteOp <= #Tp WriteDataOp;
              InProgress <= #Tp 1'b1;
            end
          else
            begin
              if(EndOp)
                begin
                  InProgress <= #Tp 1'b0;
                  WriteOp <= #Tp 1'b0;
                end
            end
        end
    end
end



// Bit Counter counts from 0 to 63 (from 32 to 63 when NoPre is asserted)
always @ (posedge Clk or posedge Reset)
begin
  if(Reset)
    BitCounter[6:0] <= #Tp 7'h0;
  else
    begin
      if(MdcEn)
        begin
          if(InProgress)
            begin
              if(NoPre & ( BitCounter == 7'h0 ))
                BitCounter[6:0] <= #Tp 7'h21;
              else
                BitCounter[6:0] <= #Tp BitCounter[6:0] + 1'b1;
            end
          else
            BitCounter[6:0] <= #Tp 7'h0;
        end
    end
end


// Operation ends when the Bit Counter reaches 63
assign EndOp = BitCounter==63;

assign ByteSelect[0] = InProgress & ((NoPre & (BitCounter == 7'h0)) | (~NoPre & (BitCounter == 7'h20)));
assign ByteSelect[1] = InProgress & (BitCounter == 7'h28);
assign ByteSelect[2] = InProgress & WriteOp & (BitCounter == 7'h30);
assign ByteSelect[3] = InProgress & WriteOp & (BitCounter == 7'h38);


// Latch Byte selects which part of Read Status Data is updated from the shift register
assign LatchByte1_d2 = InProgress & ~WriteOp & BitCounter == 7'h37;
assign LatchByte0_d2 = InProgress & ~WriteOp & BitCounter == 7'h3F;


// Connecting the Clock Generator Module
eth_clockgen clkgen(.Clk(Clk), .Reset(Reset), .Divider(Divider[7:0]), .MdcEn(MdcEn), .MdcEn_n(MdcEn_n), .Mdc(Mdc) 
                   );

// Connecting the Shift Register Module
eth_shiftreg shftrg(.Clk(Clk), .Reset(Reset), .MdcEn_n(MdcEn_n), .Mdi(Mdi), .Fiad(Fiad), .Rgad(Rgad), 
                    .CtrlData(CtrlData), .WriteOp(WriteOp), .ByteSelect(ByteSelect), .LatchByte(LatchByte), 
                    .ShiftedBit(ShiftedBit), .Prsd(Prsd), .LinkFail(LinkFail)
                   );

// Connecting the Output Control Module
eth_outputcontrol outctrl(.Clk(Clk), .Reset(Reset), .MdcEn_n(MdcEn_n), .InProgress(InProgress), 
                          .ShiftedBit(ShiftedBit), .BitCounter(BitCounter), .WriteOp(WriteOp), .NoPre(NoPre), 
                          .Mdo(Mdo), .MdoEn(MdoEn)
                         );

endmodule

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
图片区小说区国产精品视频| 99久精品国产| 国产91露脸合集magnet| 欧美性xxxxxx少妇| 久久色在线视频| 午夜在线电影亚洲一区| 丰满亚洲少妇av| 精品国产自在久精品国产| 一区二区三区精品在线| 国产麻豆成人传媒免费观看| 欧美午夜视频网站| 亚洲欧洲成人av每日更新| 国产一区二区在线看| 欧美日韩激情一区| 一区二区三区高清不卡| 粉嫩av一区二区三区| 日韩欧美亚洲一区二区| 亚洲一区二区三区小说| 成人av在线资源网| 久久精品一区蜜桃臀影院| 美腿丝袜亚洲一区| 欧美欧美欧美欧美首页| 亚洲高清不卡在线| 91浏览器入口在线观看| 国产精品九色蝌蚪自拍| 成人性生交大片免费看视频在线 | 国产午夜精品一区二区三区嫩草 | 一区二区三区中文字幕在线观看| 国产福利精品导航| 久久精品欧美一区二区三区麻豆| 国产一区二区美女| 久久免费偷拍视频| 国产精品99久久久久久似苏梦涵| 精品国产一二三区| 久久国产精品无码网站| 亚洲精品在线电影| 国产一区二区调教| 国产欧美一区二区精品秋霞影院| 国产一区二区在线看| 国产女人aaa级久久久级 | 蜜桃av噜噜一区二区三区小说| 欧美美女直播网站| 日本视频一区二区三区| 精品少妇一区二区三区免费观看| 国产在线播放一区二区三区| 久久色中文字幕| www.成人在线| 一级中文字幕一区二区| 欧美四级电影网| 免费成人美女在线观看| 久久免费美女视频| 91免费版在线| 亚洲超丰满肉感bbw| 欧美精品一区视频| 成人免费毛片app| 一区二区三区不卡视频| 日韩一级片在线观看| 成人一二三区视频| 亚洲第一电影网| 国产亚洲精品资源在线26u| av电影一区二区| 亚洲午夜电影在线| 日韩久久久久久| 成人黄色电影在线 | 欧美一级久久久久久久大片| 精品一区二区三区在线观看| 中文一区在线播放| 欧美福利一区二区| 国产99久久久精品| 日韩专区中文字幕一区二区| 国产午夜亚洲精品羞羞网站| 欧美影院精品一区| 国产在线不卡视频| 亚洲bdsm女犯bdsm网站| 久久精品欧美日韩精品| 欧美日韩午夜精品| 国产91精品入口| 日韩中文字幕1| 国产精品久久久久久久蜜臀 | 日韩成人免费看| 国产午夜精品一区二区三区嫩草 | 精品国产一区二区在线观看| 91麻豆免费看片| 黄一区二区三区| 亚洲高清免费视频| 国产蜜臀97一区二区三区 | 91蜜桃婷婷狠狠久久综合9色| 免费xxxx性欧美18vr| 亚洲欧洲国产日本综合| 2023国产精华国产精品| 555夜色666亚洲国产免| bt7086福利一区国产| 国产老妇另类xxxxx| 青青草国产成人av片免费| 亚洲欧美电影一区二区| 国产亚洲成av人在线观看导航| 欧美一区午夜精品| 欧美日韩国产大片| 97aⅴ精品视频一二三区| 国产精品一二二区| 久久精品国产久精国产爱| 亚洲va韩国va欧美va精品| 中文字幕亚洲一区二区va在线| 久久女同性恋中文字幕| 精品精品国产高清一毛片一天堂| 欧美撒尿777hd撒尿| 在线中文字幕不卡| 91久久国产综合久久| 91在线丨porny丨国产| 99精品热视频| av在线不卡免费看| 成人福利视频网站| 99re热这里只有精品视频| 国产成人综合视频| 国产99久久久国产精品潘金网站| 国产制服丝袜一区| 精彩视频一区二区| 国精产品一区一区三区mba桃花 | 久久美女艺术照精彩视频福利播放 | 欧洲精品一区二区| 在线一区二区视频| 欧美日本一区二区三区| 91精品在线麻豆| 日韩午夜中文字幕| 精品国产成人系列| 国产日韩欧美精品综合| 中文无字幕一区二区三区| 中文字幕久久午夜不卡| 国产精品国产三级国产a| 日韩毛片精品高清免费| 一区二区三区在线不卡| 亚欧色一区w666天堂| 毛片一区二区三区| 国产精品一区一区| 99免费精品视频| 欧美精品三级日韩久久| xf在线a精品一区二区视频网站| 久久精品欧美一区二区三区不卡 | 欧美群妇大交群的观看方式| 日韩欧美国产一区二区在线播放| 久久综合九色综合欧美亚洲| 日本一区二区成人| 亚洲成人av一区| 激情综合色丁香一区二区| 国产精品18久久久久久久久 | 男女男精品网站| 国产一区二区在线看| 成a人片亚洲日本久久| 欧美日韩国产一级| 久久久久久久久免费| 亚洲激情中文1区| 久久99久久精品| 一道本成人在线| 日韩精品在线网站| 亚洲免费资源在线播放| 免费看欧美美女黄的网站| 成人国产精品免费| 欧美丰满一区二区免费视频| 欧美极品xxx| 五月婷婷色综合| 成人免费不卡视频| 日韩精品一区二| 亚洲日本va在线观看| 蜜桃视频在线一区| 一本到高清视频免费精品| 精品99久久久久久| 午夜视频在线观看一区| 99久久国产综合精品女不卡| 日韩美女一区二区三区四区| 亚洲裸体xxx| 国产一区免费电影| 欧美日韩一区在线观看| 国产精品久久久久久久久免费樱桃 | 麻豆久久久久久| 在线观看免费亚洲| 国产欧美日韩精品一区| 美女脱光内衣内裤视频久久网站 | 99久久久精品| 久久久综合精品| 美女视频一区二区| 欧美日本在线播放| 一卡二卡三卡日韩欧美| jlzzjlzz国产精品久久| 久久久国产精品午夜一区ai换脸| 免费高清成人在线| 9191国产精品| 午夜视频在线观看一区| 欧美视频完全免费看| 一区二区三区加勒比av| 一本一道久久a久久精品| 国产精品久久毛片a| 国产·精品毛片| 久久嫩草精品久久久久| 激情综合色播五月| 久久综合色鬼综合色| 狠狠色丁香久久婷婷综合丁香| 日韩片之四级片| 蜜桃精品视频在线| 欧美成人精品1314www| 久久不见久久见中文字幕免费|