Asynchronous RS-232 Help Question
CarSta
Posts: 16
Hi All,
I am using a BS2p24 to send and receive RS-232 signals to a scientific device.· The device echos the
commands back.· I use a serout at 9600 baud inverted, no parity, 8 bits, 1 stop and expect to receive
the same.· The problem is when I send the command, the echo is returned before I am in the serin routine
which is the next line of code.· I am getting some of the echo plus the data sometimes and other times
I appear to be bit shifted across the entire transmission and the data appears garbled.·
Here is an example:
'SEROUT Tpin {\Fpin}, Baudmode, {Pace,} {Timeout, Tlabel,} [noparse][[/noparse]OutputData]
cmdlen = 10
SEROUT 0, baud, 10,[noparse][[/noparse]"v"]
SERIN 1, baud, Bad_Data, 1500, No_Data, [noparse][[/noparse]STR serstr\cmdlen]
Sometimes I end up in the No_Data (Timeout) routine and sometimes I get part of the
response.
I am sure I am not the first to run into this.· How have you solved this problem.· Is a UART the answer?? Many thanks for your kind assistance.
Sincerely,
Carey (CarSta)
·
I am using a BS2p24 to send and receive RS-232 signals to a scientific device.· The device echos the
commands back.· I use a serout at 9600 baud inverted, no parity, 8 bits, 1 stop and expect to receive
the same.· The problem is when I send the command, the echo is returned before I am in the serin routine
which is the next line of code.· I am getting some of the echo plus the data sometimes and other times
I appear to be bit shifted across the entire transmission and the data appears garbled.·
Here is an example:
'SEROUT Tpin {\Fpin}, Baudmode, {Pace,} {Timeout, Tlabel,} [noparse][[/noparse]OutputData]
cmdlen = 10
SEROUT 0, baud, 10,[noparse][[/noparse]"v"]
SERIN 1, baud, Bad_Data, 1500, No_Data, [noparse][[/noparse]STR serstr\cmdlen]
Sometimes I end up in the No_Data (Timeout) routine and sometimes I get part of the
response.
I am sure I am not the first to run into this.· How have you solved this problem.· Is a UART the answer?? Many thanks for your kind assistance.
Sincerely,
Carey (CarSta)
·
Comments
There does exist a small, 8-pin device (the sMT, I think it's called) which implements a recieve-only UART. This UART can run independently of your BS2, so it will get the return message and hold it until your BS2 has time to get it from the sMT.
You're right, this is an on-going issue for any BS2 design.
I don't think an external UART will solve this problem -- you'll have to flush the unwanted data out of it as well.
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
Jon Williams
Applications Engineer, Parallax
The scientific device does NOT support handshaking, either hardware or software, and
responds at a time of its choosing.· I do not have the ability to cause it to delay responding.
I would love more information on the sMT chip or whatever if that will cure the problem.
Again thanks for your assistance,
Carey (CarSta)
·· What data does the device return?· Does it preceed it's data with a known header or byte?· If so, Jon has given you a possible way to do this.· Let us know what type of data the device sends back.
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
Chris Savage
Parallax Tech Support
csavage@parallax.com
While you can't delay the device's response, you can delay when you start listening for it by inserting a PAUSE before your SERIN. To do this, though, you'll need to be sure that the timing is consistent.
Some users have employed the MAX3110 UART in projects. Here's one: http://devices.sapp.org/micro/stamp2sx/max3110/
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
Jon Williams
Applications Engineer, Parallax
·Q>· What data does the device return?· Does it preceed it's data with a known header or byte?· If so, Jon has given you a possible way to do this.· Let us know what type of data the device sends back.
The data does not have a consistent header or byte.· It responds differently to the command sent to it.· It is a ultraviolet spectrometer and is sending 2048 bytes of 12-bit resolution data (0-4094) in full scan mode.· If I ask it for something simple, such as the integration time, it only responds with a single word (which I miss) or in some cases just a single byte (which I almost never get).· If it doesn't understand the command or I have a syntax error in the command (hopefully all weeded out by now) it only returns a NAK (ascii 21) which again I miss as well.
Hi Jon,
Q> While you can't delay the device's response, you can delay when you start listening for it by inserting a PAUSE before your SERIN. To do this, though, you'll need to be sure that the timing is consistent.
Some users have employed the MAX3110 UART in projects. Here's one: http://devices.sapp.org/micro/stamp2sx/max3110/
I have tried using the pause before a serin just after the serout, but that seems to make matters worse in that then I always get a no_data timeout error and I receive nothing back.· I assume since I wasn't reading the port the data has just been dumped into the big bit bucket in the sky.
I will definitely look into the MAX3110 UART and goto the reference you gave.
Thanks again guys for all your help.
If you have any other ideas please leave a message.
Sincerely,
Carey (CarSta)
I solved the problem by buying a standard "printer buffer" from the Black Box company, as I remember, and it worked perfectly. The buffer absorbed the burst of RS232 from the spectrometer and fed it back to my PC with handshaking.
Don Leuenberger
▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔▔
·
Steve
http://ca.geocities.com/steve.brady@rogers.com/index.html
"Inside each and every one of us is our one, true authentic swing. Something we was born with. Something that's ours and ours alone. Something that can't be learned... something that's got to be remembered."
If you have any other ideas please leave a message"
Use·the SX microcontroller - it can handle this task with minimal effort.
Nate