Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 18 Jun 2004 09:50:35 +1000 (EST)
From:      Bruce Evans <bde@zeta.org.au>
To:        Roman Kurakin <rik@cronyx.ru>
Cc:        freebsd-current@freebsd.org
Subject:   Re: How to catch interrupt
Message-ID:  <20040618093024.X1609@gamplex.bde.org>
In-Reply-To: <40D1D2A8.2070000@cronyx.ru>
References:  <40D070B7.5000009@cronyx.ru> <20040617080547.F8883@gamplex.bde.org> <40D0CABA.1020101@cronyx.ru> <20040617164703.H2144@gamplex.bde.org> <40D1D2A8.2070000@cronyx.ru>

next in thread | previous in thread | raw e-mail | index | archive | help
On Thu, 17 Jun 2004, Roman Kurakin wrote:

> Bruce Evans wrote:
> >  [using isa_irq_pending()]
> >
> So spin lock should help me in some cases but there is other cases were
> this wouldn't help or I miss
> smth?

Right.  isa_irq_pending() only works right for isa devices at boot time
(not for probing later).

> In this case if some driver will acquire interrupt while probing
> and after this it will release it
> (for example it will decide that this is wrong intr and will try other),
> and after we will try to load
> sio driver we may fail to load it case we would unable to check this
> intr line.

sio only uses this mechanism to print a helpful (?) message about which
irqs it found.  It gives priority to the irq resource.

There's really nothing better than actually setting up the irq and
seeing if one arrives.  sio doesn't do this mainly because when it was
written its probe was run before interrupts are fully unmasked (they
were blocked by splhigh() until the end of isa_configure()).  npx used
to have the same problem, but I changed it to use bus_setup_intr()
normally.  This caused new problems which were only fixed recently in
npx and are unfixed at lower levels.  The interrupt system still leaves
edge triggered interrupt active after bus_teardown_intr().

If you don't know the irq number and don't trust the irq resource to
give it, then there seems to be nothing better than trying all irq
numbers until your irq is found or bus_setup_intr() fails.  There can
be up to 193 (?) possible irq numbers on i386's.

Bruce



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