Question about em_irq_fast

Sean Bruno sbruno at freebsd.org
Mon Aug 8 19:09:01 UTC 2016



On 08/05/16 12:01, Sreekanth Rupavatharam wrote:
> We have this code snippet in em_irq_fast
> 
>         ifp =
> adapter->ifp;                                                     
> 
>                                                                                  
> 
>         reg_icr = E1000_READ_REG(&adapter->hw,
> E1000_ICR);                      
> 
>                                                                                  
> 
>         /* Hot eject? 
> */                                                       
> 
>         if (reg_icr ==
> 0xffffffff)                                              
> 
>                 return
> FILTER_STRAY;                                            
> 
>                                                                                  
> 
>         /* Definitely not our interrupt. 
> */                                    
> 
>         if (reg_icr == 0x0)
> 
> return FILTER_STRAY;                                  
> 
> I don’t understand why the function returns if the read value is 0. From
> the programmer’s manual of Intel NIC, I see the following definition.
> 
>  
> 
>  
> 
> 	
> 
>  
> 
> 	
> 
>  
> 
> 	
> 
>  
> 
> TXDW
> 
> 	
> 
> 0
> 
> 	
> 
> 0b
> 
> 	
> 
> Transmit Descriptor Written Back
Set when hardware processes a transmit
> descriptor with the RS bit set (and possibly IDE set). If using delayed
> interrupts (IDE set), the interrupt occurs after the timer expires.
> 
> TXQE
> 
> 	
> 
> 1
> 
> 	
> 
> 0b
> 
> 	
> 
> Transmit Queue Empty
> 
> Set when the last descriptor block for a transmit queue has been used.
> 
> LSC
> 
> 	
> 
> 2
> 
> 	
> 
> 0b
> 
> 	
> 
> Link Status Change
This bit is set each time the link status changes
> (either from up to
> 
> down, or from down to up). This bit is affected by the internal link
> indication when configured for internal PHY mode.
> 
> RXSEQ
> 
> 	
> 
> 3
> 
> 	
> 
> 0b
> 
> 	
> 
> Receive Sequence Error
In TBI mode/internal SerDes1, incoming packets
> with a bad delimiter sequence set this bit. In other 802.3
> implementations, this would be classified as a framing error. A valid
> sequence consists of:
idle  SOF  data  pad (opt) EOF  fill (opt) 
> idle.
This is a reserved bit for the *82541xx*, *82547GI/EI*, and
> *82540EP/ EM*. Set to 0b.
> 
> RXDMT0
> 
> 	
> 
> 4
> 
> 	
> 
> 0b
> 
> 	
> 
> Receive Descriptor Minimum Threshold Reached
> 
> Indicates that the minimum number of receive descriptors are available
> and software should load more receive descriptors.
> 
> Reserved
> 
> 	
> 
> 5
> 
> 	
> 
> 0b
> 
> 	
> 
> Reserved Reads as 0b.
> 
> RXO
> 
> 	
> 
> 6
> 
> 	
> 
> 0b
> 
> 	
> 
> Receiver Overrun
Set on receive data FIFO overrun. Could be caused either
> 
> because there are no available receive buffers or because PCI receive
> bandwidth is inadequate.
> 
>  
> 
> If an interrupt happens due to a normal receive, shouldn’t the value of
> this register be 0 and still be valid? I am seeing this issue on a VM
> guest(QEMU hypervisor) where during a flood test, the driver starts
> rejecting packets because the register value is 0.  Can anyone tell me
> if it’s ok or not to remove the check for 0 value ?
> 
>  
> 
> Thanks,
> 
>  
> 
> -Sreekanth
> 
>  
> 


Is this with the "lem" driver or the "em" driver under QEMU?

Look for "legacy" in the boot output of your VM.

sean

-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 603 bytes
Desc: OpenPGP digital signature
URL: <http://lists.freebsd.org/pipermail/freebsd-net/attachments/20160808/5eba93dc/attachment.sig>


More information about the freebsd-net mailing list