grep 5 seconds of input from the serial port inside a shell-script

Posted by pica on Stack Overflow See other posts from Stack Overflow or by pica
Published on 2009-12-29T22:01:36Z Indexed on 2010/04/09 8:43 UTC
Read the original article Hit count: 327

Filed under:
|
|
|

I've got a device that I'm operating next to my PC and as it runs it's spitting log lines out it's serial port. I have this wired to my PC and I can see the log lines fine if I'm using either minicom or something like:

ttylog -b 115200 -d /dev/ttyS0

I want to write 5 seconds of the device serial output to a temp file (or assign it to a variable) and then later grep that file for keywords that will let me know how the device is operating. I've already tried redirecting the output to a file while running the command in the background, and then sleeping 5 seconds and killing the process, but the log lines never get written to my temp file. Example:

touch tempFile
ttylog -b 115200 -d /dev/ttyS0 >> tempFile &
serialPID=$!
sleep 5
#kill ${serialPID} #does not work, gets wrong PID
killall ttylog
cat tempFile

The file gets created but never filled with any data. I can also replace the ttylog line with:

ttylog -b 115200 -d /dev/ttyS0 |tee -a tempFile & 

In neither case do I ever see any log lines logged to stdout or the log file unless I have multiple versions of ttylog running by mistake (see commented out line, D'oh).

I have no idea what's going on here. It seems to be a failure of redirection within my script.

Am I on the right track? Is there a better way to sample 5 seconds of the serial port?

© Stack Overflow or respective owner

Related posts about serial-port

Related posts about bash