Date: Sun, 16 May 2004 13:27:29 +0400 From: Roman Kurakin <rik@cronyx.ru> To: Marcel Moolenaar <marcel@xcllnt.net> Cc: freebsd-current@freebsd.org Subject: Re: Sio & Puc memory mapped Message-ID: <40A73401.5010703@cronyx.ru> In-Reply-To: <20040515190413.GB9900@dhcp01.pn.xcllnt.net> References: <40A26162.9030607@cronyx.ru> <20040512.200542.09569104.imp@bsdimp.com> <20040513155109.GB6572@dhcp01.pn.xcllnt.net> <40A4E2CB.2000007@cronyx.ru> <20040515041301.O22881@gamplex.bde.org> <40A537C8.1010407@cronyx.ru> <20040515190413.GB9900@dhcp01.pn.xcllnt.net>
next in thread | previous in thread | raw e-mail | index | archive | help
Marcel Moolenaar:
[...]
><patch>
>--- asytest.c~ Fri May 14 11:50:10 2004
>+++ asytest.c Sat May 15 11:31:03 2004
>@@ -152,6 +152,7 @@
> }
>
> opt = chan[i].old_options;
>+ cfmakeraw (&opt);
> cfsetspeed (&opt, baud);
> opt.c_cflag = CREAD | CS8;
> opt.c_lflag &= ~ICANON;
>@@ -198,7 +199,7 @@
> for (c=chan; c<chan+MAXCHAN; ++c)
> if (c->fd > 0) {
> if (c->ready_to_transmit) {
>- s = write (c->fd, tbuf+it, IOSZ);
>+ s = write (c->fd, tbuf+it, IOSZ-it);
> if (s <= 0) {
> if (s < 0) {
> if (errno != EAGAIN)
></patch>
>
Works good with my card. Thanks!
>The first (the cfmakeraw() insertion) may be related to uart(4) not
>setting proper defaults, but may also be related to uart(4) setting
>different *valid* defaults. The second is a genuine test program bug
>
The only I can say that this test works fine with sio(4), cx(4),
and under linux kernels before 2.6 with serial. So this requires
additional investigation.
>triggered by write() doing partial writes. This bug too may be the
>result of uart(4) not setting the right defaults, but since the test
>program doesn't assume complete writes the bug is primarily in the
>test program by virtue of allowing partial writes.
>
>
rik
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?40A73401.5010703>
