From owner-freebsd-hardware Wed Sep 18 14:59:38 1996 Return-Path: owner-hardware Received: (from root@localhost) by freefall.freebsd.org (8.7.5/8.7.3) id OAA16724 for hardware-outgoing; Wed, 18 Sep 1996 14:59:38 -0700 (PDT) Received: from lserver.infoworld.com (root@lserver.infoworld.com [192.216.48.4]) by freefall.freebsd.org (8.7.5/8.7.3) with ESMTP id OAA16701 for ; Wed, 18 Sep 1996 14:59:35 -0700 (PDT) Received: from ccgate.infoworld.com (ccgate.infoworld.com [192.216.49.101]) by lserver.infoworld.com (8.7.5/8.7.3) with SMTP id OAA23982 for ; Wed, 18 Sep 1996 14:59:31 -0700 (PDT) From: BRETT_GLASS@infoworld.com Received: from ccMail by ccgate.infoworld.com (SMTPLINK V2.11) id AA843083789; Wed, 18 Sep 96 16:29:40 PST Date: Wed, 18 Sep 96 16:29:40 PST Message-Id: <9608188430.AA843083789@ccgate.infoworld.com> To: hardware@freebsd.org Subject: More or fewer IRQs? Sender: owner-hardware@freebsd.org X-Loop: FreeBSD.org Precedence: bulk I'm setting up a FreeBSD system with a buncha serial ports, and the cards will allow me to share IRQs between ports. There are 5 available IRQs and 10 ports; in other words, there aren't enough IRQs to allow every port to have one of its own, so some sharing is necessary. With the hardware I have here, I have two choices. I can use up every IRQ in the machine and put two UARTS on each, or I can lump more together (there are three ISA cards, so that means I could get away with using 3 out of the 5). The latter approach has the advantage that I can add another peripheral in the remaining vacant PCI slot and would have an IRQ for it. But which would yield better performance? It seems to me that the high overhead of taking an interrupt MIGHT make it better to put many ports on one IRQ, since polling each port on the card probably still costs less than a context switch on an Intel CPU (a truly ugly process ;-). On the other hand, the source code suggests that the driver turns off interrupts as it services serial ports, so there MIGHT be a chance of starving otner devices (in particular, the system's cantankerous IDE interface) if there were many UARTs on an IRQ. What say ye? --Brett