From owner-freebsd-hackers Fri Feb 12 01:02:58 1999 Return-Path: Received: (from majordom@localhost) by hub.freebsd.org (8.8.8/8.8.8) id BAA11474 for freebsd-hackers-outgoing; Fri, 12 Feb 1999 01:02:58 -0800 (PST) (envelope-from owner-freebsd-hackers@FreeBSD.ORG) Received: from ns1.yes.no (ns1.yes.no [195.204.136.10]) by hub.freebsd.org (8.8.8/8.8.8) with ESMTP id BAA11466 for ; Fri, 12 Feb 1999 01:02:53 -0800 (PST) (envelope-from eivind@bitbox.follo.net) Received: from bitbox.follo.net (bitbox.follo.net [195.204.143.218]) by ns1.yes.no (8.9.1a/8.9.1) with ESMTP id KAA12297; Fri, 12 Feb 1999 10:02:47 +0100 (CET) Received: (from eivind@localhost) by bitbox.follo.net (8.8.8/8.8.6) id KAA13382; Fri, 12 Feb 1999 10:02:43 +0100 (MET) Date: Fri, 12 Feb 1999 10:02:39 +0100 From: Eivind Eklund To: Dag-Erling Smorgrav Cc: hackers@FreeBSD.ORG Subject: Re: Regarding tcpdump and plip Message-ID: <19990212100238.N96008@bitbox.follo.net> References: <199902080148.RAA09054@dingo.cdrom.com> <19990208195855.56187@breizh.prism.uvsq.fr> <19990208222829.53422@breizh.prism.uvsq.fr> <19990211225037.40571@breizh.prism.uvsq.fr> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii X-Mailer: Mutt 0.95.1i In-Reply-To: ; from Dag-Erling Smorgrav on Fri, Feb 12, 1999 at 01:54:16AM +0100 Sender: owner-freebsd-hackers@FreeBSD.ORG Precedence: bulk X-Loop: FreeBSD.ORG On Fri, Feb 12, 1999 at 01:54:16AM +0100, Dag-Erling Smorgrav wrote: > (BTW, I wouldn't mind if one of you superhero programmers wrote a > short introduction to interrupt masks "for the rest of us") I'll try to get this right, even though it is incomplete, but no guarantee: Interrupt masks are, well, interrupt masks. There are a bit for each interrupt; this bit control whether the interrupt in question will be serviced or delayed. Each of the spl()'s has a connected mask, _imask. This mask contains the actual masks of interrupts that are to be suspended by an spl(). Normally, an interrupt end up in the imask through a register_intr call - here is an example from the clock code: register_intr(/* irq */ apic_8254_intr, /* XXX id */ 0, /* flags */ 0, /* XXX */ (inthand2_t *)clkintr, &clk_imask, /* unit */ 0); INTREN(1 << apic_8254_intr); Note that the cast to inthand2_t seems bogus; inthand_t and inthand2_t are for taking a void * or an int as an argument to the interrupt functions. We're moving from unit numbers to actual softc (soft configuration) structures. INTREN() is a macro to enable the interrupt (in the APIC, I think, but I'm not quite clear on where/how it is used). The call that finally register the interrupt is usually done by the bus controlling code, anyway, so you won't see this. The imasks is the sole thing that controls which interrupts are blocked; this is why you sometimes see code like this tty_imask |= softnet_imask; /* spltty() block spl[soft]net() */ (from /sys/net/ppp_tty.c). Do Not Write Code Like This Unless You Really, Really Know What You Are Doing. Note that parts of the registration system will change as we switch to the new bus architecture - so don't depend too much on how it is done right now. Eivind. To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-hackers" in the body of the message