Subject: "soft" interrupts busted on MacPPC
To: None <port-macppc@netbsd.org>
From: Donald Lee <donlee_ppc@icompute.com>
List: port-macppc
Date: 01/25/2002 19:44:35
About a year ago, I put into production a server running NetBSD 1.5 that
has an 8 port Cyclades serial PCI card in it. I use the serial ports
to support dial in PPP. I have since upgraded to 1.5.2.
I have a special kernel that I have to run to make this work. It has several
changes. One is to the extintr.c module, and it fixes what is
pretty clearly a bug in the "soft" interrupt handling in the kernel.
Without this fix, PPP works, but is intolerably slow, because the
protocol stack effectively "loses" interrupts, and they don't get
"noticed" until another "event" comes along.
This has not been noticed in the broader community because there is almost
no way to get a working serial port on MacPPC. :-( However, the change
effectively removes an issue that causes inexplicable delays in network
response. Although I have not done extensive testing, I'll bet that you
could show performance improvements on ethernet with the patch too.
I hear that NetBSD 1.5.3 is in ALPHA. What do I have to do to get the
extintr.c changes incorporated into the kernel so I don't have to carry
the patch around? This issue fixed in 1.6, but not in the same way because
of the SMP changes in that area of the code.
The changes can be seen on my anonymous FTP server at
ftp://ftp.icompute.com/pub/donlee/extintr.c.nogo
and
ftp://ftp.icompute.com/pub/donlee/extintr.c.prod
(as in... production)
Thanks in advance,
-dgl-