用Verilog实现的以太网接口

源代码在线查看: eth_rxaddrcheck.v

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

相关代码

				
				
				
				`include "timescale.v"
				
				
				module eth_rxaddrcheck(MRxClk,  Reset, RxData, Broadcast ,r_Bro ,r_Pro,
				                       ByteCntEq2, ByteCntEq3, ByteCntEq4, ByteCntEq5,
				                       ByteCntEq6, ByteCntEq7, HASH0, HASH1, 
				                       CrcHash,    CrcHashGood, StateData, RxEndFrm,
				                       Multicast, MAC, RxAbort, AddressMiss, PassAll,
				                       ControlFrmAddressOK
				                      );
				
				parameter Tp = 1;
				
				  input        MRxClk; 
				  input        Reset; 
				  input [7:0]  RxData; 
				  input        Broadcast; 
				  input        r_Bro; 
				  input        r_Pro; 
				  input        ByteCntEq2;
				  input        ByteCntEq3;
				  input        ByteCntEq4;
				  input        ByteCntEq5;
				  input        ByteCntEq6;
				  input        ByteCntEq7;
				  input [31:0] HASH0; 
				  input [31:0] HASH1; 
				  input [5:0]  CrcHash; 
				  input        CrcHashGood; 
				  input        Multicast; 
				  input [47:0] MAC;
				  input [1:0]  StateData;
				  input        RxEndFrm;
				  input        PassAll;
				  input        ControlFrmAddressOK;
				  
				  output       RxAbort;
				  output       AddressMiss;
				
				 wire BroadcastOK;
				 wire ByteCntEq2;
				 wire ByteCntEq3;
				 wire ByteCntEq4; 
				 wire ByteCntEq5;
				 wire RxAddressInvalid;
				 wire RxCheckEn;
				 wire HashBit;
				 wire [31:0] IntHash;
				 reg [7:0]  ByteHash;
				 reg MulticastOK;
				 reg UnicastOK;
				 reg RxAbort;
				 reg AddressMiss;
				 
				assign RxAddressInvalid = ~(UnicastOK | BroadcastOK | MulticastOK | r_Pro);
				 
				assign BroadcastOK = Broadcast & ~r_Bro;
				 
				assign RxCheckEn   = | StateData;
				 
				 // Address Error Reported at end of address cycle
				 // RxAbort clears after one cycle
				 
				always @ (posedge MRxClk or posedge Reset)
				begin
				  if(Reset)
				    RxAbort 				  else if(RxAddressInvalid & ByteCntEq7 & RxCheckEn)
				    RxAbort 				  else
				    RxAbort 				end
				 
				
				// This ff holds the "Address Miss" information that is written to the RX BD status.
				always @ (posedge MRxClk or posedge Reset)
				begin
				  if(Reset)
				    AddressMiss 				  else if(ByteCntEq7 & RxCheckEn)
				    AddressMiss 				end
				
				
				// Hash Address Check, Multicast
				always @ (posedge MRxClk or posedge Reset)
				begin
				  if(Reset)
				    MulticastOK 				  else if(RxEndFrm | RxAbort)
				    MulticastOK 				  else if(CrcHashGood & Multicast)
				    MulticastOK 				end
				 
				 
				// Address Detection (unicast)
				// start with ByteCntEq2 due to delay of addres from RxData
				always @ (posedge MRxClk or posedge Reset)
				begin
				  if(Reset)
				    UnicastOK 				  else
				  if(RxCheckEn & ByteCntEq2)
				    UnicastOK 				  else
				  if(RxCheckEn & ByteCntEq3)
				    UnicastOK 				  else
				  if(RxCheckEn & ByteCntEq4)
				    UnicastOK 				  else
				  if(RxCheckEn & ByteCntEq5)
				    UnicastOK 				  else
				  if(RxCheckEn & ByteCntEq6)
				    UnicastOK 				  else
				  if(RxCheckEn & ByteCntEq7)
				    UnicastOK 				  else
				  if(RxEndFrm | RxAbort)
				    UnicastOK 				end
				   
				assign IntHash = (CrcHash[5])? HASH1 : HASH0;
				  
				always@(CrcHash or IntHash)
				begin
				  case(CrcHash[4:3])
				    2'b00: ByteHash = IntHash[7:0];
				    2'b01: ByteHash = IntHash[15:8];
				    2'b10: ByteHash = IntHash[23:16];
				    2'b11: ByteHash = IntHash[31:24];
				  endcase
				end
				      
				assign HashBit = ByteHash[CrcHash[2:0]];
				
				
				endmodule
							

相关资源