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

I need help with code which reads characters from rs232?

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







I need help with code which reads characters from rs232?
PostPosted: Fri Dec 17, 2004 5:05 am     Reply with quote

Hi, sorry my bad english Smile

I try to do program which send string to computer e.g( "$52"). When computer get string, it send back some information e.g( -12.4C). My problem is that I can't read that data and put it right format. I have tested interface and that is okay. Only problem is code.

Psuedo code:

char result[10];
int i=0;

printf("$52"): // send string to computer

while( !kbhit() ); // waits computer

while( kbhit){ //try to write data to 'result'

result[i]=getch();
i++;
}


What goes wrong?
asmallri



Joined: 12 Aug 2004
Posts: 1638
Location: Perth, Australia

View user's profile Send private message Send e-mail Visit poster's website

PostPosted: Fri Dec 17, 2004 5:46 am     Reply with quote

the pseudo code looks ok. You have not decribed the problem enough to be able to determine the possible problem. Can you post an example of your program the demonstrates the problem including the fuse statements, #use statements and which processor you are using.
_________________
Regards, Andrew

http://www.brushelectronics.com/software
Home of Ethernet, SD card and Encrypted Serial Bootloaders for PICs!!
Masa
Guest







Reply
PostPosted: Fri Dec 17, 2004 7:15 am     Reply with quote

Yes,

prosessor is pic16f877

clock=12MHz

I test different baudrates, 1200,2400,9600 but problem not solved. I just wondering is this loop too slow to read characters:

while( kbhit){ //try to write data to 'result'

result[i]=getch();
i++;
}

printf(result)

because, when I test code with terminal program, first I can see $52, that is okay and terminal wait until I send packet. My test packet was 1234. But now I can read only 12 on terminal.
asmallri



Joined: 12 Aug 2004
Posts: 1638
Location: Perth, Australia

View user's profile Send private message Send e-mail Visit poster's website

PostPosted: Fri Dec 17, 2004 7:28 am     Reply with quote

you have not posted enough code to see where the problem is. For example, I cannot tell if you are using the harware UART or the Software UART function.

Instead of the loop being too slow, it could be too fast. For example, if the #use RS232 statement is enabling the hardware UART then the program could service getch() so fast that after reading in the second character kbhit() returns false because the third character is still being serialised into the UART. When this happens you will drop out of the while loop. Another problem is that you code does not write a 0 at the end of the string in result. The printf statement could end up printing garbage.
_________________
Regards, Andrew

http://www.brushelectronics.com/software
Home of Ethernet, SD card and Encrypted Serial Bootloaders for PICs!!
Ttelmah
Guest







Re: Reply
PostPosted: Fri Dec 17, 2004 9:17 am     Reply with quote

Masa wrote:
Yes,

prosessor is pic16f877

clock=12MHz

I test different baudrates, 1200,2400,9600 but problem not solved. I just wondering is this loop too slow to read characters:

while( kbhit){ //try to write data to 'result'

result[i]=getch();
i++;
}

printf(result)

because, when I test code with terminal program, first I can see $52, that is okay and terminal wait until I send packet. My test packet was 1234. But now I can read only 12 on terminal.


As this code stands, this is a reasonable response...
The code will arrive at the 'while' line, and unless a character has already arrived, will drop through, and print what has been received. You need to either identify the 'end' of the incoming character string, with a 'marker', 'count', or implement a 'timeout', so that the routine only proceeds if characters do not arrive for some time.
Assuming this is not the 'real' code, and only another piece of psuedo code, the other thing that could apply, is that you are 'falling off the end' of the code. If (for instance), you generate:

printf("Test");

at the end of 'main', using the hardware UART, you will see:

'Te' displayed on the PC. The reason in this case, is that unless you wait for the charcters to be actually _sent_, when the processor gets to the end of main, it is put to sleep, and any characters waiting in the hardware UART, are not sent.
Post the actual code, rather than 'snippets', or 'psuedo code' sections, and somebody will probably be able to tell you what is happening.

Best Wishes
Masa
Guest







code
PostPosted: Fri Dec 17, 2004 12:05 pm     Reply with quote

I wrote new code, because old one was so long.

from headerfile:
#include <16F877A.h>
#device adc=8
#use delay(clock=12000000)
#fuses HS,NOWDT


real code:

#include "D:\\test_rcv.h"
#use rs232(baud=1200, xmit=PIN_c6, rcv=PIN_c7)

char result[10];

void main() {
int i=0;
setup_adc_ports(ANALOG_RA3_RA2_REF);
setup_adc(ADC_CLOCK_DIV_32);
setup_psp(PSP_DISABLED);
setup_spi(FALSE);
//setup_counters(RTCC_INTERNAL,RTCC_DIV_2);
setup_timer_1(T1_DISABLED);
setup_timer_2(T2_DISABLED,0,1);
setup_comparator(NC_NC_NC_NC);
setup_vref(FALSE);
SET_TRIS_D(0);
set_tris_b(0b11111101);
set_tris_c(0b10000000);
disable_interrupts(global);

while(1){

printf("$52");
while( !kbhit() ); // wait until computers send 1. character

while( kbhit() ){

result[i]=getc();
i++;
}

printf(result);
}
}

Terminal:
:$52
TX-->example<nul>
:exa$52exa$52
TX-->example<nul>
:

After that the prosessor do nothing, and terminal neither. I try to use get_string() from input.c, but that wasn't fix problem. Should I use interrupts?
Humberto



Joined: 08 Sep 2003
Posts: 1215
Location: Buenos Aires, La Reina del Plata

View user's profile Send private message

PostPosted: Fri Dec 17, 2004 1:02 pm     Reply with quote

Masa wrote:
Quote:

After that the prosessor do nothing, and terminal neither. I try to use get_string() from input.c, but that wasn't fix problem. Should I use interrupts?


Yes, for example enable_interrupts(INT_RDA) if you are using the UART.
The way you determine if you are going to use the UART or not is implicit in the directive
#use rs232(baud=1200, xmit=PIN_c6, rcv=PIN_c7)
where if you select rcv=PIN_C7, the UART is enabled and the hardware
handle the incoming chars flagging INT_RDA interrupts.
If you select another rcv PIN different that PIN_C7 (in this processor) the UART is not
active
and you must code a software handler to receive a char without interrupts.

Anyway I suggest to search in this forum all the info related RS232 and you will find
tons of code and examples to learn from.

Best wishes,

Humberto
C#R# []
Guest







RS232
PostPosted: Sat Dec 18, 2004 5:24 pm     Reply with quote

Hi.. at short time ago, I wrote a code with RS232 and work very weel.. but at begining I had some problems...well...the problem is the watchdog.
The new getc() ( that�s I named getcW() ) stoped the problem..


int getcW ()
{
while ( !(*PIR1 & 0b00100000)) restart_wdt() ;
return (*RCREG);
}

// WATCH DOG... YOU ARE SO BAD...HEHEHE !!!!

humm...that�s good for me ..and I would like to be good for you too....
don�t forget :

#define PIR1 0x0C
#define RCREG 0x1A // for PIC16F871 !!!
Mark



Joined: 07 Sep 2003
Posts: 2838
Location: Atlanta, GA

View user's profile Send private message Send e-mail

PostPosted: Sat Dec 18, 2004 6:55 pm     Reply with quote

Code:
while( kbhit() ){

result[i]=getc();
i++;
}

printf(result);


Your going to fall out of this loop after you receive the first character. The PIC is pretty fast and it takes some time to receive the next char. Also, you need to tell the printf what kind of data you are printing.
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