delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2003/03/21/17:22:18

Mailing-List: contact cygwin-help AT cygwin DOT com; run by ezmlm
List-Subscribe: <mailto:cygwin-subscribe AT cygwin DOT com>
List-Archive: <http://sources.redhat.com/ml/cygwin/>
List-Post: <mailto:cygwin AT cygwin DOT com>
List-Help: <mailto:cygwin-help AT cygwin DOT com>, <http://sources.redhat.com/ml/#faqs>
Sender: cygwin-owner AT cygwin DOT com
Mail-Followup-To: cygwin AT cygwin DOT com
Delivered-To: mailing list cygwin AT cygwin DOT com
Message-ID: <3E7B9077.3090902@lynx-technik.com>
Date: Fri, 21 Mar 2003 23:21:43 +0100
From: "H. Henning Schmidt" <Henning DOT Schmidt AT lynx-technik DOT com>
Organization: LYNX Technik AG
User-Agent: Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.0.1) Gecko/20020823 Netscape/7.0
X-Accept-Language: en-us, en
MIME-Version: 1.0
To: cygwin AT cygwin DOT com
Subject: memory corruption when serial input overflows

I have run into a problem with the serial input (e.g. "COM1").
This is on WinXp Pro and cygwin 1.3.22.
In the archives there are some references to this (or a similar?) issue. 
I got the idea that it is known that there are issues ... but nobody is 
working on them at this time.

Here is a testcase that easily provokes an error, which to my 
understanding is some form of memory corruption around the data 
associated with the open file descriptor.
You need to run this testcase and connect the RX and TX lines of the 
serial port COM1. This will make all the data written out by this 
program be re-directed to the serial input. The program never calls 
read() on the input though and thus provokes an overflow.

Now that I have identified the problem I can work around it (basically 
by providing a separate thread that does nothing but pulling bytes off 
the channel and putting them into some private fifo of mine). Just 
thought I might just as well share my test-case with you. Maybe someone 
has an idea how to *really* fix this. I guess loosing/dropping some data 
on overflow would be preferrable to corrupting the memory ...

;Henning

// file main.cpp ---------------------------------------------------
#include <stdio.h>
#include <termios.h>
#include <unistd.h>
#include <fcntl.h>

int
main (int argc, char *argv[])
{
   // open serial port
   int fd = open ("/dev/com1", O_RDWR);

   // set baud rate
   struct termios _termios;
   cfsetospeed (&_termios, B38400);
   cfsetispeed (&_termios, B38400);
   tcsetattr (fd, TCSANOW, &_termios);

   while (1)
   {
      // verification of "loop still looping"
      fprintf (stderr, ".");

      // don't toast my CPU ...
      usleep (100);

      // write some data to the serial output
      char data = 0x00;
      ::write (fd, &data, 1);

      // never read from the serial input.
      //
      // if you connect the RX/TX lines (pin 2 and 3 on the COM SubD9
      // connector), this will generate some kind of overflow and
      // result in memory corruption
      //
      // on my machine this is easily recognizable by the fact that
      // (a) the "loop still running" does pump anymore and (b) the
      // "Windows Task Manager" (CTRL-ALT-DEL on WinXP) shows CPU
      // activity of 100%. This is somewhere around 10% while running
      // normally (RX/TX not connected).
   }
}
// end of file ----------------------------

# file Makefile ---------------------------
bustSerialPort: main.o
    g++ -o $@ $^

%.o : %.cpp
    g++ -o $@ -c $^
# end of file -----------------------------




--
Unsubscribe info:      http://cygwin.com/ml/#unsubscribe-simple
Bug reporting:         http://cygwin.com/bugs.html
Documentation:         http://cygwin.com/docs.html
FAQ:                   http://cygwin.com/faq/

- Raw text -


  webmaster     delorie software   privacy  
  Copyright © 2019   by DJ Delorie     Updated Jul 2019