Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 09 Dec 2008 10:14:01 -0700
From:      Scott Long <scottl@samsco.org>
To:        Mike Tancsa <mike@sentex.net>
Cc:        Marcel Moolenaar <xcllnt@mac.com>, freebsd-current@freebsd.org
Subject:   Re: uart vs sio differences ?
Message-ID:  <493EA759.4000504@samsco.org>
In-Reply-To: <200812091457.mB9EvLSD047534@lava.sentex.ca>
References:  <200812081621.mB8GLMxB041498@lava.sentex.ca>	<ED8BC24F-EAC3-4266-AF54-4C6262DDC156@mac.com>	<200812081906.mB8J6oha042222@lava.sentex.ca>	<CF6E0ACA-CCFA-4A35-A88F-C95484309A78@mac.com>	<200812082049.mB8KnHSN042710@lava.sentex.ca>	<84A7F176-5A74-48AC-859A-C0D4C7CBCB48@mac.com>	<7.1.0.9.0.20081208173515.13f62e88@sentex.net> <200812091457.mB9EvLSD047534@lava.sentex.ca>

next in thread | previous in thread | raw e-mail | index | archive | help
Mike Tancsa wrote:
> At 05:39 PM 12/8/2008, Mike Tancsa wrote:
> 
>> What it appears to be is that as long as data is coming in, even at 
>> 1200bps, the ioctl FIONREAD returns zero and an actual read does not 
>> return any data until there is either a pause in the data coming in or 
>> possibly when we do a xmit/write at which point the accumulated data 
>> is available for us to read.
>>
>> We dont know if this is due to the hardware fifo or something in the 
>> driver itself.
> 
> OK, I think we found the issue!
> 
> http://www.freebsd.org/cgi/query-pr.cgi?pr=121421
> 
> Not sure if the semantics are exactly right, but adding
> 
> hint.uart.0.flags="0x100"
> hint.uart.1.flags="0x100"
> hint.uart.2.flags="0x100"
> hint.uart.3.flags="0x100"
> 
> to device.hints fixed the issue!
> 
> The next question-- is there a way to do this with the ucom driver as 
> well ?  We are seeing the same issue with it.
> 
>         ---Mike

It's pretty sad that the uart driver can't keep up with the 16550 at
full FIFO depth, though I can see exactly why.  Even though the driver
will normally use a fast interrupt handler, that handler does nothing
but schedule the sio swi thread.  Well, I shouldn't say that that's the
only thing it does; it also does a spinwait on a home-rolled semaphore
with the swi thread, something that I'm not sure I understand.  Maybe
the author thought that there was a risk of missed wakeups of the swi?

That aside, I think what needs to happen is for the driver to use the
interrupt handler to pull the bytes out of the hardware and into an
internal lockless ring buffer, then schedule the swi to process the ring
buffer.  I'll see if I can come up with some code for this today.  Not
sure if the same can be done for ucom since the USB stack below it
presents a lot more complications and overhead.

Scott



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?493EA759.4000504>