From owner-freebsd-questions@FreeBSD.ORG Thu Feb 14 18:37:30 2008 Return-Path: Delivered-To: freebsd-questions@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 067A016A41B for ; Thu, 14 Feb 2008 18:37:30 +0000 (UTC) (envelope-from derek@computinginnovations.com) Received: from betty.computinginnovations.com (mail.computinginnovations.com [64.81.227.250]) by mx1.freebsd.org (Postfix) with ESMTP id B31C713C469 for ; Thu, 14 Feb 2008 18:37:29 +0000 (UTC) (envelope-from derek@computinginnovations.com) Received: from p28.computinginnovations.com (dhcp-10-20-30-100.computinginnovations.com [10.20.30.100]) (authenticated bits=0) by betty.computinginnovations.com (8.14.2/8.13.8) with ESMTP id m1EIbEO1065226; Thu, 14 Feb 2008 12:37:15 -0600 (CST) (envelope-from derek@computinginnovations.com) Message-Id: <6.0.0.22.2.20080214122616.0244c9d0@mail.computinginnovations.com> X-Sender: derek@mail.computinginnovations.com X-Mailer: QUALCOMM Windows Eudora Version 6.0.0.22 Date: Thu, 14 Feb 2008 12:37:07 -0600 To: Martin McCormick , freebsd-questions@freebsd.org From: Derek Ragona In-Reply-To: <200802141755.m1EHtZoA095349@m.it.okstate.edu> References: <200802141755.m1EHtZoA095349@m.it.okstate.edu> Mime-Version: 1.0 X-ComputingInnovations-MailScanner-Information: Please contact the ISP for more information X-ComputingInnovations-MailScanner: Found to be clean X-ComputingInnovations-MailScanner-From: derek@computinginnovations.com X-Spam-Status: No Content-Type: text/plain; charset="us-ascii"; format=flowed X-Content-Filtered-By: Mailman/MimeDel 2.1.5 Cc: Subject: Re: FreeBSD6.2 What is the easiest Way to Capture RS-232 Serial Data? X-BeenThere: freebsd-questions@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: User questions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Thu, 14 Feb 2008 18:37:30 -0000 At 11:55 AM 2/14/2008, Martin McCormick wrote: > I wrote a C program several years ago that works and >logs output from a telephone switch to a file and runs in >FreeBSD4.x. > > I just opened /dev/ttyd0 for reading and it has run for >up to 1,000 days at a time, but it also >has issues as one might expect. > > It can be killed if one of the incoming characters >happens to be an EOF (4) which is quite possible if somebody >umplugs or plugs in the cable and creates garbage on the line. If you use fread to read the stream, you can test using feof or ferror and conditionally keep reading depending on the condition. You should add signal handling so the program is only killed when you want it to be. > The data from the switch is ASCII with carriage >return/linefeed sequences so nothing really harsh goes on, but I >need to make it as bullet-proof as possible. > > In addition, the actual data are 7-bit, odd parity with >1 stop. I basically ignored that fact last time and masked off >the MSB of each character and that's how it has been for 5 >years. > > Now, I am writing a similar program to log different >data from that same telephone switch and I want to do better >this time, but not reen vent any wheels I don't have to. > > What is the best way to use as much of the existing UNIX >environment as possible to listen to /dev/ttyd[x] with no >interpretation of incoming data? > > The data will be dumped at the end of each line, stored >in a file, and other action may be taken but normally, the >program will just be in a receive-blocked mode, waiting to hear >something new. > > About the only thing I am doing differently this time is >trying to set the tty such that it doesn't look for any EOF or >other control codes in the data. The data will be treated as raw >and what ever comes across is okay. The program will clean it up >to make it good for the file. You still need to handle when the cord is unplugged, or put the server in a secure location away from other people. > As I stated, the standard /dev/ttyd device has done >amazingly well in FreeBSD4.7, but some of that has been dumb >luck. We shouldn't have to warn people in the area that they >could kill the logger by unplugging the cable since they >wouldn't be aware that they stopped it until we found out later >when there was nothing in the file. > > Searching archives dealing with serial communications >produced good information about dialup lines and terminals, but >this is actually less complex. > > Many thanks for any good advice about stty or anything >else that will allow one to use standard devices for this >project. If you want the program to be more capable of staying running you can have the program fork a child and if the child dies, fork a new child. This is the method used for many running services. Just be sure if the child dies the log file is closed and that same file is opened by the new child. -Derek -- This message has been scanned for viruses and dangerous content by MailScanner, and is believed to be clean.