Hi Greg,

In message <20110824070826.gk92...@core.byshenk.net>, Greg Byshenk <free...@byshenk.net> writes
On Mon, Aug 22, 2011 at 11:59:11AM +0100, David Wood wrote:

In message <20110822094756.gj92...@core.byshenk.net>, Greg Byshenk
<free...@byshenk.net> writes
>It doesn't seem to matter; both cuau?.lock and cuau?.init produce the
>error (for both ports), and cuau? itself remains a no-op.

You could try
hint.uart.2.baud="115200"

in /boot/device.hints - making the relevant changes to port number and
speed according to your needs.

This does not help; speed remains set to 9600.

It was worth a go.


>Now that I can see that the card is working (at least minimally), it
>begins to look as if there might be a problem somewhere in 9.x. I'll
>try to install 8.x and see if the results are different.

It will be interesting to see if there is a difference between 8.x and
9.x.

Yes, there is.

Using 8-STABLE (with sources from 17 August 2011) and inbuilt puc,
the controller works as expected. It defaults to 9600, but setting
the speed on the cuaa?.lock and cuaa?.init devices works.

Interestingly, setting the speed in device.hints does _not_ work.

It could be that setting speed in /boot/device.hints only works with ports directly handled by uart(4), not ports that uart(4) handles via puc(4).

As 8-STABLE works, the support code I wrote and contributed works for your card, which is encouraging.


So, it appears that there is something wrong (or at least different)
with 9.x

The best course of action is likely to be bringing up this problem on freebsd-current (as 9.x is not yet -stable) and filing a PR, noting the regression between 8-STABLE and 9-BETA.

I'm fairly sure that the problem is likely to be in uart(4) or in something on which uart(4) rests, such as the tty layer. Even in 9-BETA puc(4) appears to be doing its job of identifying and configuring the ports before invoking uart(4) - so puc(4) doesn't appear to be to blame.


Doing some poking around, I see that, in 9.x, termios.h is not
included in dev/uart/uart_core.c and dev/uart/uart_tty.c. While
it is included under 8.x.

The commit logs for HEAD show that the inclusion of termios headers was removed as unnecessary (see r199872). I doubt that the problem is merely a missing header, not least as missing headers normally result in compilation failure.

The "isn't a terminal" error you are getting indicates that the attempt to call tcgetaddr(3) on a file descriptor opened on the device is failing. Unfortunately, I am not familiar enough with the tty code to understand why that call is failing on 9.x.


If posting on freebsd-current and filing a PR don't produce an answer, ed@ or kib@ may be able to throw some light. Those two committers are responsible for most of the relevant code, especially the tty layer.

It may also be interesting to try 9.x on a machine with a serial port that operates directly with uart(4). Does stty(4) throw up "isn't a terminal" errors against the .init and .lock devices relating to those ports? I would try this myself, but am very short of time at present.


Though there is probably little more that I can add, please keep me cc'd on all relevant e-mails, especially as I do not follow freebsd-current.



With best wishes,




David
--
David Wood
da...@wood2.org.uk
_______________________________________________
freebsd-stable@freebsd.org mailing list
http://lists.freebsd.org/mailman/listinfo/freebsd-stable
To unsubscribe, send any mail to "freebsd-stable-unsubscr...@freebsd.org"

Reply via email to