Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 7 Dec 2007 20:26:42 +0100
From:      Erik Trulsson <ertr1013@student.uu.se>
To:        Nikolay Pavlov <qpadla@gmail.com>
Cc:        freebsd-current@freebsd.org
Subject:   Re: Strange IRQ number
Message-ID:  <20071207192642.GA65135@owl.midgard.homeip.net>
In-Reply-To: <200712072114.01360.qpadla@gmail.com>
References:  <200712072114.01360.qpadla@gmail.com>

next in thread | previous in thread | raw e-mail | index | archive | help
On Fri, Dec 07, 2007 at 09:13:57PM +0200, Nikolay Pavlov wrote:
> I see some strange IRQ number for my em0 card on BETA4:
> root@cassini:~# vmstat -i                                                                                                                                                    
> interrupt                          total       rate
> irq1: atkbd0                           6          0
> irq6: fdc0                             1          0
> irq14: ata0                       184947         16
> irq15: ata1                       184946         16
> cpu0: timer                     22110598       1999
> irq256: em0                      6945039        628
> ^^^^^^^^^^^^^^^^
> cpu1: timer                     22110396       1999
> Total                           51535933       4661
> 
> On 6.2 it was shared with uhci. Now all uhci controllers gone from the 
> vmstat but not from the system:

'vmstat -i' only shows those interrupts that have generated at least one
interrupt.  Use 'vmstat -ia' to see all the interrupts (I suspect that you
will find the uhci* devices there.)

> 
> root@cassini:~# usbdevs                                                                                                                                                      
> addr 1: UHCI root hub, Intel
> addr 1: UHCI root hub, Intel
> addr 1: UHCI root hub, Intel
> addr 1: UHCI root hub, Intel
> addr 1: EHCI root hub, Intel
> 
> root@cassini:~# dmesg | grep em0                                                                                                                                             
> em0: <Intel(R) PRO/1000 Network Connection Version - 6.7.3> port 
> 0x4000-0x401f mem 0xd0100000-0xd011ffff irq 16 at device 0.0 on pci6
> em0: Using MSI interrupt

   ^^^^^^^^^^^^^^^^^^^^^^

This is the magic information.  On 7.x MSI/MSI-X interrupts are enabled by
default (which is not the case on 6.x).
MSI/MSI-X is a new interrupt delivery mechanism that can be used by all
PCI-E devices (although not all device drivers in FreeBSD take
advantage of this yet) and some PCI-X devices, that essentially assigns a
separate interrupt for each device - thus no need for sharing interrupts.


> em0: Ethernet address: 00:30:48:91:c0:90
> em0: [FILTER]
> 
> The entire system work ok.

As expected. What you see is simply the em0 NIC (apparently a PCI-E device)
using MSI instead of the old interrupt method.  
FreeBSD assigns such devices a "virtual" interrupt number starting at 256.


Short version:  It is not a bug, it is a feature. :-)


-- 
<Insert your favourite quote here.>
Erik Trulsson
ertr1013@student.uu.se



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20071207192642.GA65135>