aboutsummaryrefslogtreecommitdiff
path: root/winsup/cygwin/fhandler_tty.cc
diff options
context:
space:
mode:
authorChristopher Faylor <me@cgf.cx>2000-03-12 04:44:37 +0000
committerChristopher Faylor <me@cgf.cx>2000-03-12 04:44:37 +0000
commit774ea162116fcb08278c5efbe287848f5b5dd431 (patch)
treea124392461f0c8f99c127a7c5b6d880e85d145fd /winsup/cygwin/fhandler_tty.cc
parent1e8b88023ceb35d74f74640bb5109f7b2a5f34e5 (diff)
downloadnewlib-774ea162116fcb08278c5efbe287848f5b5dd431.zip
newlib-774ea162116fcb08278c5efbe287848f5b5dd431.tar.gz
newlib-774ea162116fcb08278c5efbe287848f5b5dd431.tar.bz2
* fhandler_console.cc (fhandler_console::read): Don't even think about breaking
on interrupt if executing in a "cygwin" thread. * fhandler_tty.cc (fhandler_pty_master::process_slave_output): Streamline, simplify code. * sigproc.cc (sig_send): Remove debugging statement.
Diffstat (limited to 'winsup/cygwin/fhandler_tty.cc')
-rw-r--r--winsup/cygwin/fhandler_tty.cc226
1 files changed, 119 insertions, 107 deletions
diff --git a/winsup/cygwin/fhandler_tty.cc b/winsup/cygwin/fhandler_tty.cc
index 3261ea2..14da2bb 100644
--- a/winsup/cygwin/fhandler_tty.cc
+++ b/winsup/cygwin/fhandler_tty.cc
@@ -154,7 +154,8 @@ void
fhandler_pty_master::doecho (const void *str, DWORD len)
{
acquire_output_mutex (INFINITE);
- WriteFile (get_ttyp ()->to_master, str, len, &len, NULL);
+ if (!WriteFile (get_ttyp ()->to_master, str, len, &len, NULL))
+ termios_printf ("Write to %p failed, %E", get_ttyp ()->to_master);
// WaitForSingleObject (output_done_event, INFINITE);
release_output_mutex ();
}
@@ -219,135 +220,144 @@ fhandler_pty_master::process_slave_output (char *buf, size_t len)
char outbuf[OUT_BUFFER_SIZE];
DWORD n;
int column = 0;
-
-again:
+ int rc = 0;
if (len == 0)
- return 0;
+ goto out;
- if (neednl_)
+ for (;;)
{
- /* We need to return a left over \n character, resulting from
- \r\n conversion. Note that we already checked for FLUSHO and
- OutputStopped at the time that we read the character, so we
- don't check again here. */
- buf[0] = '\n';
- neednl_ = 0;
- return 1;
- }
+ if (neednl_)
+ {
+ /* We need to return a left over \n character, resulting from
+ \r\n conversion. Note that we already checked for FLUSHO and
+ OutputStopped at the time that we read the character, so we
+ don't check again here. */
+ buf[0] = '\n';
+ neednl_ = 0;
+ rc = 1;
+ break;
+ }
- /* Set RLEN to the number of bytes to read from the pipe. */
- rlen = len;
- if (get_ttyp ()->ti.c_oflag & OPOST && get_ttyp ()->ti.c_oflag & ONLCR)
- {
- /* We are going to expand \n to \r\n, so don't read more than
- half of the number of bytes requested. */
- rlen /= 2;
- if (rlen == 0)
- rlen = 1;
- }
- if (rlen > sizeof outbuf)
- rlen = sizeof outbuf;
+ /* Set RLEN to the number of bytes to read from the pipe. */
+ rlen = len;
+ if (get_ttyp ()->ti.c_oflag & OPOST && get_ttyp ()->ti.c_oflag & ONLCR)
+ {
+ /* We are going to expand \n to \r\n, so don't read more than
+ half of the number of bytes requested. */
+ rlen /= 2;
+ if (rlen == 0)
+ rlen = 1;
+ }
+ if (rlen > sizeof outbuf)
+ rlen = sizeof outbuf;
- HANDLE handle = get_io_handle ();
+ HANDLE handle = get_io_handle ();
- /* Doing a busy wait like this is quite inefficient, but nothing
- else seems to work completely. Windows should provide some sort
- of overlapped I/O for pipes, or something, but it doesn't. */
- DWORD avail;
- while (1)
- {
- if (! PeekNamedPipe (handle, NULL, 0, NULL, &avail, NULL))
+ /* Doing a busy wait like this is quite inefficient, but nothing
+ else seems to work completely. Windows should provide some sort
+ of overlapped I/O for pipes, or something, but it doesn't. */
+ while (1)
{
- if (GetLastError () == ERROR_BROKEN_PIPE)
- return 0;
- __seterrno ();
- return -1;
+ DWORD avail;
+ if (!PeekNamedPipe (handle, NULL, 0, NULL, &avail, NULL))
+ goto err;
+ if (avail > 0)
+ break;
+ if (hit_eof ())
+ goto out;
+ Sleep (10);
}
- if (avail > 0)
- break;
- if (hit_eof ())
- return 0;
- Sleep (10);
- }
- if (ReadFile (handle, outbuf, rlen, &n, NULL) == FALSE)
- {
- if (GetLastError () == ERROR_BROKEN_PIPE)
- return 0;
- __seterrno ();
- return -1;
- }
+ if (ReadFile (handle, outbuf, rlen, &n, NULL) == FALSE)
+ goto err;
- termios_printf ("len=%u", n);
+ termios_printf ("rlen %u", n);
- if (get_ttyp ()->ti.c_lflag & FLUSHO)
- {
- get_ttyp ()->write_retval = n;
- if (output_done_event != NULL)
- SetEvent (output_done_event);
- goto again;
- }
-
- if (get_ttyp ()->OutputStopped)
- {
- termios_printf ("waiting for restart_output_event");
- WaitForSingleObject (restart_output_event, INFINITE);
- }
+ if (get_ttyp ()->ti.c_lflag & FLUSHO)
+ {
+ get_ttyp ()->write_retval = n;
+ if (output_done_event != NULL)
+ SetEvent (output_done_event);
+ continue;
+ }
- if (get_ttyp ()->ti.c_oflag & OPOST) // post-process output
- {
- char *iptr = outbuf, *optr = buf;
+ if (get_ttyp ()->OutputStopped)
+ {
+ termios_printf ("waiting for restart_output_event");
+ WaitForSingleObject (restart_output_event, INFINITE);
+ termios_printf ("done waiting for restart_output_event");
+ }
- while (n--)
+ if (!(get_ttyp ()->ti.c_oflag & OPOST)) // post-process output
+ {
+ memcpy (buf, outbuf, n);
+ rc = n;
+ }
+ else // raw output mode
{
- switch (*iptr)
+ char *iptr = outbuf, *optr = buf;
+
+ while (n--)
{
- case '\r':
- if ((get_ttyp ()->ti.c_oflag & ONOCR) && column == 0)
+ switch (*iptr)
{
- iptr++;
- continue;
+ case '\r':
+ if ((get_ttyp ()->ti.c_oflag & ONOCR) && column == 0)
+ {
+ iptr++;
+ continue;
+ }
+ if (get_ttyp ()->ti.c_oflag & OCRNL)
+ *iptr = '\n';
+ else
+ column = 0;
+ break;
+ case '\n':
+ if (get_ttyp ()->ti.c_oflag & ONLCR)
+ {
+ *optr++ = '\r';
+ column = 0;
+ }
+ if (get_ttyp ()->ti.c_oflag & ONLRET)
+ column = 0;
+ break;
+ default:
+ column++;
+ break;
}
- if (get_ttyp ()->ti.c_oflag & OCRNL)
- *iptr = '\n';
- else
- column = 0;
- break;
- case '\n':
- if (get_ttyp ()->ti.c_oflag & ONLCR)
+
+ /* Don't store data past the end of the user's buffer. This
+ can happen if the user requests a read of 1 byte when
+ doing \r\n expansion. */
+ if (optr - buf >= (int) len)
{
- *optr++ = '\r';
- column = 0;
+ neednl_ = 1;
+ if (*iptr != '\n' || n != 0)
+ system_printf ("internal error: %d unexpected characters", n);
+ break;
}
- if (get_ttyp ()->ti.c_oflag & ONLRET)
- column = 0;
- break;
- default:
- column++;
- break;
- }
- /* Don't store data past the end of the user's buffer. This
- can happen if the user requests a read of 1 byte when
- doing \r\n expansion. */
- if (optr - buf >= (int) len)
- {
- neednl_ = 1;
- if (*iptr != '\n' || n != 0)
- system_printf ("internal error: %d unexpected characters", n);
- break;
+ *optr++ = *iptr++;
}
+ rc = optr - buf;
+ }
+ break;
- *optr++ = *iptr++;
+ err:
+ if (GetLastError () == ERROR_BROKEN_PIPE)
+ rc = 0;
+ else
+ {
+ __seterrno ();
+ rc = -1;
}
- return optr - buf;
- }
- else // raw output mode
- {
- memcpy (buf, outbuf, n);
- return n;
+ break;
}
+
+out:
+ termios_printf ("returning %d", rc);
+ return rc;
}
static DWORD WINAPI
@@ -546,8 +556,10 @@ fhandler_tty_slave::write (const void *ptr, size_t len)
if (output_done_event != NULL)
{
- termios_printf("tty%d waiting for output_done", ttynum);
- WaitForSingleObject (output_done_event, n * 1000);
+ DWORD rc;
+ DWORD x = n * 1000;
+ rc = WaitForSingleObject (output_done_event, x);
+ termios_printf("waited %d ms for output_done_event, WFSO %d", x, rc);
}
if (get_ttyp ()->write_retval < 0)