用Verilog实现的以太网接口

源代码在线查看: eth_txstatem.v

软件大小: 125 K
上传用户: xeul7957
关键词: Verilog 以太网接口
下载地址: 免注册下载 普通下载 VIP

相关代码

				
				
				
				`include "timescale.v"
				
				
				module eth_txstatem  (MTxClk, Reset, ExcessiveDefer, CarrierSense, NibCnt, IPGT, IPGR1, 
				                      IPGR2, FullD, TxStartFrm, TxEndFrm, TxUnderRun, Collision, UnderRun, 
				                      StartTxDone, TooBig, NibCntEq7, NibCntEq15, MaxFrame, Pad, CrcEn, 
				                      NibbleMinFl, RandomEq0, ColWindow, RetryMax, NoBckof, RandomEqByteCnt,
				                      StateIdle, StateIPG, StatePreamble, StateData, StatePAD, StateFCS, 
				                      StateJam, StateJam_q, StateBackOff, StateDefer, StartFCS, StartJam, 
				                      StartBackoff, StartDefer, DeferIndication, StartPreamble, StartData, StartIPG
				                     );
				
				parameter Tp = 1;
				
				input MTxClk;
				input Reset;
				input ExcessiveDefer;
				input CarrierSense;
				input [6:0] NibCnt;
				input [6:0] IPGT;
				input [6:0] IPGR1;
				input [6:0] IPGR2;
				input FullD;
				input TxStartFrm;
				input TxEndFrm;
				input TxUnderRun;
				input Collision;
				input UnderRun;
				input StartTxDone; 
				input TooBig;
				input NibCntEq7;
				input NibCntEq15;
				input MaxFrame;
				input Pad;
				input CrcEn;
				input NibbleMinFl;
				input RandomEq0;
				input ColWindow;
				input RetryMax;
				input NoBckof;
				input RandomEqByteCnt;
				
				
				output StateIdle;         // Idle state
				output StateIPG;          // IPG state
				output StatePreamble;     // Preamble state
				output [1:0] StateData;   // Data state
				output StatePAD;          // PAD state
				output StateFCS;          // FCS state
				output StateJam;          // Jam state
				output StateJam_q;        // Delayed Jam state
				output StateBackOff;      // Backoff state
				output StateDefer;        // Defer state
				
				output StartFCS;          // FCS state will be activated in next clock
				output StartJam;          // Jam state will be activated in next clock
				output StartBackoff;      // Backoff state will be activated in next clock
				output StartDefer;        // Defer state will be activated in next clock
				output DeferIndication;
				output StartPreamble;     // Preamble state will be activated in next clock
				output [1:0] StartData;   // Data state will be activated in next clock
				output StartIPG;          // IPG state will be activated in next clock
				
				wire StartIdle;           // Idle state will be activated in next clock
				wire StartPAD;            // PAD state will be activated in next clock
				
				
				reg StateIdle;
				reg StateIPG;
				reg StatePreamble;
				reg [1:0] StateData;
				reg StatePAD;
				reg StateFCS;
				reg StateJam;
				reg StateJam_q;
				reg StateBackOff;
				reg StateDefer;
				reg Rule1;
				
				
				// Defining the next state
				assign StartIPG = StateDefer & ~ExcessiveDefer & ~CarrierSense;
				
				assign StartIdle = StateIPG & (Rule1 & NibCnt[6:0] >= IPGT | ~Rule1 & NibCnt[6:0] >= IPGR2);
				
				assign StartPreamble = StateIdle & TxStartFrm & ~CarrierSense;
				
				assign StartData[0] = ~Collision & (StatePreamble & NibCntEq15 | StateData[1] & ~TxEndFrm);
				
				assign StartData[1] = ~Collision & StateData[0] & ~TxUnderRun & ~MaxFrame;
				
				assign StartPAD = ~Collision & StateData[1] & TxEndFrm & Pad & ~NibbleMinFl;
				
				assign StartFCS = ~Collision & StateData[1] & TxEndFrm & (~Pad | Pad & NibbleMinFl) & CrcEn
				                | ~Collision & StatePAD & NibbleMinFl & CrcEn;
				
				assign StartJam = (Collision | UnderRun) & ((StatePreamble & NibCntEq15) | (|StateData[1:0]) | StatePAD | StateFCS);
				
				assign StartBackoff = StateJam & ~RandomEq0 & ColWindow & ~RetryMax & NibCntEq7 & ~NoBckof;
				
				assign StartDefer = StateIPG & ~Rule1 & CarrierSense & NibCnt[6:0] 				                  | StateIdle & CarrierSense 
				                  | StateJam & NibCntEq7 & (NoBckof | RandomEq0 | ~ColWindow | RetryMax)
				                  | StateBackOff & (TxUnderRun | RandomEqByteCnt)
				                  | StartTxDone | TooBig;
				
				assign DeferIndication = StateIdle & CarrierSense;
				
				// Tx State Machine
				always @ (posedge MTxClk or posedge Reset)
				begin
				  if(Reset)
				    begin
				      StateIPG        				      StateIdle       				      StatePreamble   				      StateData[1:0]  				      StatePAD        				      StateFCS        				      StateJam        				      StateJam_q      				      StateBackOff    				      StateDefer      				    end
				  else
				    begin
				      StateData[1:0] 				      StateJam_q 				
				      if(StartDefer | StartIdle)
				        StateIPG 				      else
				      if(StartIPG)
				        StateIPG 				
				      if(StartDefer | StartPreamble)
				        StateIdle 				      else
				      if(StartIdle)
				        StateIdle 				
				      if(StartData[0] | StartJam)
				        StatePreamble 				      else
				      if(StartPreamble)
				        StatePreamble 				
				      if(StartFCS | StartJam)
				        StatePAD 				      else
				      if(StartPAD)
				        StatePAD 				
				      if(StartJam | StartDefer)
				        StateFCS 				      else
				      if(StartFCS)
				        StateFCS 				
				      if(StartBackoff | StartDefer)
				        StateJam 				      else
				      if(StartJam)
				        StateJam 				
				      if(StartDefer)
				        StateBackOff 				      else
				      if(StartBackoff)
				        StateBackOff 				
				      if(StartIPG)
				        StateDefer 				      else
				      if(StartDefer)
				        StateDefer 				    end
				end
				
				
				// This sections defines which interpack gap rule to use
				always @ (posedge MTxClk or posedge Reset)
				begin
				  if(Reset)
				    Rule1 				  else
				    begin
				      if(StateIdle | StateBackOff)
				        Rule1 				      else
				      if(StatePreamble | FullD)
				        Rule1 				    end
				end
				
				
				
				endmodule
							

相关资源