From owner-freebsd-hackers Fri Mar 31 08:05:20 1995 Return-Path: hackers-owner Received: (from majordom@localhost) by freefall.cdrom.com (8.6.10/8.6.6) id IAA24589 for hackers-outgoing; Fri, 31 Mar 1995 08:05:20 -0800 Received: from godzilla.zeta.org.au (godzilla.zeta.org.au [203.2.228.34]) by freefall.cdrom.com (8.6.10/8.6.6) with ESMTP id IAA24549 for ; Fri, 31 Mar 1995 08:04:42 -0800 Received: (from bde@localhost) by godzilla.zeta.org.au (8.6.9/8.6.9) id BAA04177; Sat, 1 Apr 1995 01:59:22 +1000 Date: Sat, 1 Apr 1995 01:59:22 +1000 From: Bruce Evans Message-Id: <199503311559.BAA04177@godzilla.zeta.org.au> To: davidg@Root.COM, terry@cs.weber.edu Subject: Re: help with splbio, splnet, spl... Cc: freebsd-hackers@FreeBSD.org, nate@trout.sri.mt.net Sender: hackers-owner@FreeBSD.org Precedence: bulk >> Interrupts are blocked via software in FreeBSD - the interrupt controller >> isn't messed with (the interrupts are always enabled). I think you're Further interrupts are also blocked in the interrupt controller if one occurs while it is blocked in software. This has to be done if interrupts are level triggered, but it can probably be avoided (saving 2+ usec per interrupt) if interrupts are edge triggered. >> confusing its arbitration priority with the classic unix spl "tiering" that >> Terry thought we had. When presented with multiple simultaneous interrupts, >> the interrupt controller does have an arbitration priority scheme that is >> based on the interrupt number...but this nothing to do with spl tiering. Correct. The interrupt controller by default also blocks interrupts of lower (arbitration) priority than the one(s) it is servicing, but this is not under software control so it can't be used to implement spl, and it has other problems (e.g., wrong priorities) so it is not used in FreeBSD. >Unless the splbio/splclock blocking of everything else but fast wasn't >true, it's at least partiall tiered (jury still out on that, since you >haven't had time to reply to the posting I made immediately before this >one). It's partially ordered by the relation "is a subset of" on the bitmap masks considered as subsets of {0,1,..,15}. >The question I then have is why is it still called "spl" which stands >for "set priority level" if what it is really doing is blocking a >particular class of interrupts instead of all interrupts at or below >a particular level? Because lots of "machine-independent" code calls it that. Bruce