Skip site navigation (1)Skip section navigation (2)
Date:      Sat, 1 May 2004 09:43:32 +0200
From:      Burkard Meyendriesch <bm@malepartus.de>
To:        Bruce Evans <bde@zeta.org.au>
Cc:        freebsd-current@FreeBSD.org
Subject:   Re: sio: lots of silo overflows on Asus K8V with Moxa Smartio C104H/PCI
Message-ID:  <20040501094332.49356c55.bm@malepartus.de>
In-Reply-To: <20040501140658.F19558@gamplex.bde.org>
References:  <20040426111754.38a855c4.bm@malepartus.de> <20040426233925.Y5300@gamplex.bde.org> <20040430102504.477152ce.bm@malepartus.de> <20040501140658.F19558@gamplex.bde.org>

next in thread | previous in thread | raw e-mail | index | archive | help
On Sat, 1 May 2004 14:23:13 +1000 (EST) Bruce Evans wrote:

> On Fri, 30 Apr 2004, Burkard Meyendriesch wrote:
> 
> > On Mon, 26 Apr 2004 23:48:46 +1000 (EST) Bruce Evans wrote:
> >
> > > On Mon, 26 Apr 2004, Burkard Meyendriesch wrote:
> > >
> > > > on my Asus K8V with Moxa Smartio C104H/PCI I get lots of silo
> > > > overflows when backing up my Palm over a serial line, even at
> > > > 19.200 baud.
> > > >
> > > > What's going wrong here? And what can I do?
> > > > ...
> > >
> > > You seem to have trimmed too much from the boot messages (I
> > > trimmed the rest).  sio5 is not there.
> > > ...
> > Sorry, I forgot to send the sio's boot message (I forgot it because
> > it didn't say anything in boot -v mode). Here are the boot messages:
> > ...
> 
> Not using a fast interrupt handler may cause occasional silo
> overflows, but shouldn't cause many.  The problem is mostly elsewhere
> (Giant locking for too long), but siointr() shouldn't use Giant
> locking.  Try the following patch if you still have shared interrupts:
> 
> %%%
> Index: sio.c
> ===================================================================
> RCS file: /home/ncvs/src/sys/dev/sio/sio.c,v
> retrieving revision 1.427
> diff -u -2 -r1.427 sio.c
> --- sio.c	7 Apr 2004 21:56:20 -0000	1.427
> +++ sio.c	21 Apr 2004 14:20:17 -0000
> @@ -1162,5 +1302,6 @@
>  		if (ret) {
>  			ret = BUS_SETUP_INTR(device_get_parent(dev), dev,
> -					     com->irqres, INTR_TYPE_TTY,
> +					     com->irqres,
> +					     INTR_TYPE_TTY | INTR_MPSAFE,
>  					     siointr, com, &com->cookie);
>  			if (ret == 0)
> %%%
> 
> I don't expect this to fix your problem.

Thank you for the patch! I just installed it in a new kernel. Result:

/var/log/messages after boot -v:
..
May  1 09:07:31 Reineke kernel: puc0: <Moxa Technologies, Smartio C104H/PCI> port 0xa000-0xa00f,0xa400-0xa43f,0xa800-0xa87f irq 19 at device 14.0 on pci0
May  1 09:07:31 Reineke kernel: puc0: Reserved 0x40 bytes for rid 0x18 type 4 at 0xa400
May  1 09:07:31 Reineke kernel: sio4: <Moxa Technologies, Smartio C104H/PCI> on puc0
May  1 09:07:31 Reineke kernel: sio4: type 16550A
May  1 09:07:31 Reineke kernel: sio4: unable to activate interrupt in fast mode - using normal mode
..

> 
> > By the way: How should I set the BIOS parameters "PCPI 2.0 yes/no"
> > and"ACPI APIC yes/no"? Do they have anything to do with the PCI
> > interrupt behaviour?
> 
> Configuring APIC (and ACPI if necessary for APIC to work) in both the
> BIOS and FreeBSD is good for minimising shared interrupts.  You seem
> to already have APIC (non-APIC interrupt numbers only go up to 15, but
> you have #19).
> 
> OTOH, using the APIC may cause problems (interrupt storms), especially
> for interrupt numbers > 15.  FreeBSD now has interrupt storm avoidance
> to prevent storms from making the whole system unusable, but interrupt
> storm avoidance for irq19  would cause your problem.  It rate-limits
> the interrupt to 10Hz, but even low speeds like 19200 require much
> more than that even on buffered UARTs:
>
My Hardware is an Asus K8V Athlon64 board; in my BIOS I enabled "ACPI 2.0"
and "ACPI APIC".
> 
>     19200 bps = 1920 cps = at least 1920/16 = 120 interrupts/second
> 
> Here 16 is the input fifo size for the usual case of a 16550A UART.
> Use systat -v to see the transient interrupt rate.
> 
At 115200 bps my puc interrupt rate is at about 300 ints/s, but I see
peeks up to 1500 ints/s. iostat 10 gives me an average char input rate
of 2300 chars/s. The silo overflow rate is about 1 per 5 seconds.

At 9600 bps the puc interrupt rate is about 105 ints/s with 730 char/s
input character rate. At this low speed I don't see any silo overflows.

Btw, systat -v shows a constant high interrupt rate of 1024 0: clk;
is this normal?
 
Burkard

--
Burkard Meyendriesch
Stevern 2
D-48301 Nottuln



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