CCS C Software and Maintenance Offers
FAQFAQ   FAQForum Help   FAQOfficial CCS Support   SearchSearch  RegisterRegister 

ProfileProfile   Log in to check your private messagesLog in to check your private messages   Log inLog in 

CCS does not monitor this forum on a regular basis.

Please do not post bug reports on this forum. Send them to CCS Technical Support

Does rs232 accept long data and char together?

 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
dxsdxs



Joined: 11 Nov 2013
Posts: 5

View user's profile Send private message

Does rs232 accept long data and char together?
PostPosted: Tue Nov 12, 2013 8:53 am     Reply with quote

Hi, I have a program about motor control, which is connected with labview and pic16f88. I tried to use rs232 to send command by letter(char) and distance by number(int). This program can do the movement correctly, but I can't find a way out of giving the distance. For now it just moves in constant how can I give the number by “getc” while I need the command too. Does anyone have a good idea about that? I don‘t need an exact code, just some ideas or tips.
Thanks for any reply.
dyeatman



Joined: 06 Sep 2003
Posts: 1934
Location: Norman, OK

View user's profile Send private message

PostPosted: Tue Nov 12, 2013 10:26 am     Reply with quote

For numbers you have to perform and Int to ASCII conversion
before transmit then convert back on the other end.
_________________
Google and Forum Search are some of your best tools!!!!
temtronic



Joined: 01 Jul 2010
Posts: 9229
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Tue Nov 12, 2013 11:37 am     Reply with quote

With any serial reception it's best to use an ISR and buffer. CCS provides a very good working example called ex_sisr.c in the examples folder.
You'll have to parse the data based on your input data format.

hth
jay
gpsmikey



Joined: 16 Nov 2010
Posts: 588
Location: Kirkland, WA

View user's profile Send private message

PostPosted: Tue Nov 12, 2013 2:12 pm     Reply with quote

You should convert all your information you are sending to ascii characters and unless you are very sure what the receiving side is doing, as a general rule, make sure they are in the printable range (if you send characters that are in the control character range (0x0D for example, the receiving side may think it is indeed a CR and deal with it that way instead of as intended. Even Microsoft got bitten with that one years ago with their backup utility to floppies - when it hit floppy 0x0d, it crashed the backup program). The digit 0 is 0x30 - you need to convert your data to ascii digits then convert it back again on the other end.

mikey
_________________
mikey
-- you can't have too many gadgets or too much disk space !
old engineering saying: 1+1 = 3 for sufficiently large values of 1 or small values of 3
Ttelmah



Joined: 11 Mar 2010
Posts: 19520

View user's profile Send private message

PostPosted: Wed Nov 13, 2013 4:57 am     Reply with quote

I think it may be worth elucidating a little:

The async serial connection just handles bytes (assuming you have 8bits selected). Nothing else.

What you 'do' with these, is down to you.

It is (for instance), possible to send the contents of a block of memory, containing numbers, strings etc., as just the 'raw' data from this memory, byte by byte. However the problem is 'what happens if something goes slightly out of sync'. So Just as a piece of paper, where you could draw loads of different hieroglyphic symbols, but the more complex these get the easier it is to misinterpret one, we tend to 'simplify' and use a limited set of standard symbols. Generally the English alphabet. The same happens in computer communication, with the commonest 'set' used, being ASCII (American Standard Code for Information Interchange). This gives every common letter/number in the alphabet, and some special 'control' values, standardised values. So '0' (the digit zero), has the code 0x30 etc.. So one could then send your 'character', and 'number', as codes 0x4E 0x30 0x31 0x32, which are the codes for "N012". Key thing is that serial receive programs understand these codes, so a program like Hyperterminal, would display N012 when these codes are received. Normally you'd standardise on certain things, so (for instance), it is common to separate values with commas, and end the line with a line feed or carriage return (codes 0x10, and 0x13). Now, 'C' contains a number of standard functions to convert internal numbers into 'ASCII' representations, and convert ASCII back.

printf("%Ld",variable);

will output the ASCII text representation of the decimal value of the 'long' number stored in 'variable'.

printf("%04LX", variable);

will output the same number in _hex_, with leading zeros.

There are several different format strings, and 'modifiers' (like 'L' for 'long'), and you really need to get a basic C textbook.

Then going to other way, there are functions like 'atol' (ASCII to long), which will take a string comprising a number of ASCII characters, and convert it to a 'long' to store in the PIC.

So realistically I'd say you need to do some very basic C reading, on the commands to convert to/from ASCII for output.input. The manual at the least.

Sending values separated using commas, is normally called CSV format, and I know labview can be set to handle this.

Now the earlier posters have basically said exactly what you have to do both to actually receive the data, and the key pointers for the translation needed.

Best Wishes
SherpaDoug



Joined: 07 Sep 2003
Posts: 1640
Location: Cape Cod Mass USA

View user's profile Send private message

PostPosted: Wed Nov 13, 2013 4:10 pm     Reply with quote

Your title says long data and you mention ints. I hope you realize that CCS ints default to 8 bits.
_________________
The search for better is endless. Instead simply find very good and get the job done.
dxsdxs



Joined: 11 Nov 2013
Posts: 5

View user's profile Send private message

PostPosted: Fri Nov 15, 2013 8:33 am     Reply with quote

dyeatman wrote:
For numbers you have to perform and Int to ASCII conversion
before transmit then convert back on the other end.


Thx for your reply,
Seems like this is the best solution for now。
dxsdxs



Joined: 11 Nov 2013
Posts: 5

View user's profile Send private message

PostPosted: Fri Nov 15, 2013 8:40 am     Reply with quote

gpsmikey wrote:
You should convert all your information you are sending to ascii characters and unless you are very sure what the receiving side is doing, as a general rule, make sure they are in the printable range (if you send characters that are in the control character range (0x0D for example, the receiving side may think it is indeed a CR and deal with it that way instead of as intended. Even Microsoft got bitten with that one years ago with their backup utility to floppies - when it hit floppy 0x0d, it crashed the backup program). The digit 0 is 0x30 - you need to convert your data to ascii digits then convert it back again on the other end.

mikey


That's really helpful, maybe I could set a range of minimum and maximum numbers to avoid the control character range.
dxsdxs



Joined: 11 Nov 2013
Posts: 5

View user's profile Send private message

PostPosted: Fri Nov 15, 2013 8:47 am     Reply with quote

Ttelmah wrote:
I think it may be worth elucidating a little:

The async serial connection just handles bytes (assuming you have 8bits selected). Nothing else.

What you 'do' with these, is down to you.

It is (for instance), possible to send the contents of a block of memory, containing numbers, strings etc., as just the 'raw' data from this memory, byte by byte. However the problem is 'what happens if something goes slightly out of sync'. So Just as a piece of paper, where you could draw loads of different hieroglyphic symbols, but the more complex these get the easier it is to misinterpret one, we tend to 'simplify' and use a limited set of standard symbols. Generally the English alphabet. The same happens in computer communication, with the commonest 'set' used, being ASCII (American Standard Code for Information Interchange). This gives every common letter/number in the alphabet, and some special 'control' values, standardised values. So '0' (the digit zero), has the code 0x30 etc.. So one could then send your 'character', and 'number', as codes 0x4E 0x30 0x31 0x32, which are the codes for "N012". Key thing is that serial receive programs understand these codes, so a program like Hyperterminal, would display N012 when these codes are received. Normally you'd standardise on certain things, so (for instance), it is common to separate values with commas, and end the line with a line feed or carriage return (codes 0x10, and 0x13). Now, 'C' contains a number of standard functions to convert internal numbers into 'ASCII' representations, and convert ASCII back.

printf("%Ld",variable);

will output the ASCII text representation of the decimal value of the 'long' number stored in 'variable'.

printf("%04LX", variable);

will output the same number in _hex_, with leading zeros.

There are several different format strings, and 'modifiers' (like 'L' for 'long'), and you really need to get a basic C textbook.

Then going to other way, there are functions like 'atol' (ASCII to long), which will take a string comprising a number of ASCII characters, and convert it to a 'long' to store in the PIC.

So realistically I'd say you need to do some very basic C reading, on the commands to convert to/from ASCII for output.input. The manual at the least.

Sending values separated using commas, is normally called CSV format, and I know labview can be set to handle this.

Now the earlier posters have basically said exactly what you have to do both to actually receive the data, and the key pointers for the translation needed.

Best Wishes


Thx for your lesson.
dxsdxs



Joined: 11 Nov 2013
Posts: 5

View user's profile Send private message

PostPosted: Fri Nov 15, 2013 9:03 am     Reply with quote

temtronic wrote:
With any serial reception it's best to use an ISR and buffer. CCS provides a very good working example called ex_sisr.c in the examples folder.
You'll have to parse the data based on your input data format.

hth
jay


Well, it's a good alternative solution, just the interrupt should be from labview or somewhere to separate two format. Sorry I haven't read the example file yet, if the answer is in that example, just ignore me. Smile
Ttelmah



Joined: 11 Mar 2010
Posts: 19520

View user's profile Send private message

PostPosted: Fri Nov 15, 2013 12:42 pm     Reply with quote

The key point here is that the PIC can only do one thing at a time.
Unlike 99% of modern PC's, there is no multiprocessing. The serial has less than two characters of hardware buffering, so what happens if data is arriving, while you are doing something else?. This is what ex_sisr.c handles. It allows you to expand the buffering using an interrupt driven circular buffer, so data is not lost, while you are doing other things. This is exactly how serial is handled on the PC, where there is a little more hardware buffering on modern chipsets, but it is still worth having more software buffering, so data is not lost while you are doing disk I/O, writing to the screen etc..
Your code still has to keep up, and still has to do the decoding, but if it falls behind a little, at places, the software buffer gives a little extra margin.

I doubt if any of the 'long term' professional programmers here design _without_ buffers....

Best Wishes
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum


Powered by phpBB © 2001, 2005 phpBB Group