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 support@ccsinfo.com

RS232 communication PIC18f4550 -- putc sending corrupt data
Goto page 1, 2  Next
 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
nidhimittalhada



Joined: 06 Sep 2010
Posts: 21

View user's profile Send private message

RS232 communication PIC18f4550 -- putc sending corrupt data
PostPosted: Mon Sep 06, 2010 4:04 am     Reply with quote

I am a newbie to microcontroller programming I am using ccsc compiler and written a program to communicate to PC thru RS232 interface
It uses users232 directive.just that ..and after that i wrote putc functions.If you say i can post code also .
But its not sending the character i mentioned in putc but any random character is coming on hyperterminal ....

please help

Things i have already tried
1)enable interrupts global and INT_RDA
2)FUSES -- not sure just copied from somewhere
3)disassembled program ...disassembled program seems okay except one thing that
disassembled program dint seem to check for TMRT bit of TXSTA ...

Kindly help
temtronic



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

View user's profile Send private message

PostPosted: Mon Sep 06, 2010 5:23 am     Reply with quote

You don't say but you need to have a MAX232 or similar TTL to RS232 convertor chip between the PIC and the PC.
Either check with the CCS C manual or 'online' for more info.
Do help us debug your program it must be a small with fuse,and compiler version (3.xxx,4.yyy).
JAy
Ttelmah



Joined: 11 Mar 2010
Posts: 19330

View user's profile Send private message

PostPosted: Mon Sep 06, 2010 7:31 am     Reply with quote

Also, the 'classic' thing would be for the clock statement, to not match the real crystal being used, or the fuses are not right for the oscillator hardware involved. Async serial, is _time critical_, so everything to do with timing on the chip, must be right for it to work.....

Best Wishes
nidhimittalhada



Joined: 06 Sep 2010
Posts: 21

View user's profile Send private message

PostPosted: Mon Sep 06, 2010 10:00 am     Reply with quote

Code:

#include <18F4550.h>
#fuses HS,NOWDT
#use delay(clock=20MHz)
#use rs232(baud=9600,parity=N,xmit=PIN_C6,rcv=PIN_C7,bits=8,BRGH1OK,STOP=1)

void main()
{
char c;

set_tris_c(0xBF);
enable_interrupts(GLOBAL);
enable_interrupts(INT_RDA);

while(TRUE)
{
c=getc(); //if getc() timeouts 0 is returned to c
delay_ms(200);
putc(c);
}
}

This is my program which gives this following o/p on hyper terminal, in echo mode in hyperterminal.

dD ddddddffffffaybzaybzddeettyyzzayayaybzbzbzc{

Where in most characters are correctly transmitted and received like dd ee ff etc but definite characters like a, b, c which are converted to definite wrong characters like

a is transmitted but received is y similarly b----> z c----> { everytime

point to be noted is
a=97 0110 0001 in ascii
y=121 0111 1001

b = 98 0110 0010
z=122 0111 1010

similar for c------>{

Please reply, I have tried for hours but not able to come out why there is problem with definite few characters.
They only come wrong everytime. It doesn't seem to be a framing error as a,b,c might be transmitted at any time they have to come out wrong only that too definite wrong output. pl help.
nidhimittalhada



Joined: 06 Sep 2010
Posts: 21

View user's profile Send private message

My specification
PostPosted: Mon Sep 06, 2010 10:06 am     Reply with quote

I have pic18F4550 rhydolabs kit, MPLAB 8.53, CCSC Compiler, HARDWARE UART with MAX232 on board.
Ttelmah



Joined: 11 Mar 2010
Posts: 19330

View user's profile Send private message

PostPosted: Mon Sep 06, 2010 10:17 am     Reply with quote

Several big problems.
1) You must _never_ enable an interrupt without an interrupt handler being present. Get rid of the lines doing this. I'm surprised it runs at all with these present.
2) The code talks about 'getc timeout', but you have not got this enabled in the USE RS232 line.
3) Get rid of BRG10K. This is only for chips that have the BRG problem.
4) _Is_ your crystal 20MHz?.
5) Don't delay after getting the character. If another two characters arrive in this time, the UART _will_ overrun. This will hang the UART with the code as written (add 'ERRORS' to the USE RS232 line - this should always be used with the hardware UART, unless _you_ are handling error conditions yourself.

Best Wishes
Douglas Kennedy



Joined: 07 Sep 2003
Posts: 755
Location: Florida

View user's profile Send private message AIM Address

PostPosted: Mon Sep 06, 2010 2:37 pm     Reply with quote

Ttelmah is right about the delay. RS232 is asynchronous and its often very smart to assume it is entirely incompatible with delays of any sort. That includes not only delay_ms but any time consuming thing like a printf. If you can't avoid using any delays then the solution is a circular buffer fed from an interrupt. The inbound int_rda is almost always needed but sometimes an output isr with a circular buffer is needed to avoid the output via rs232 blocking other processes.
bkamen



Joined: 07 Jan 2004
Posts: 1611
Location: Central Illinois, USA

View user's profile Send private message

PostPosted: Mon Sep 06, 2010 9:48 pm     Reply with quote

How about trying this:

Code:

#include <18F4550.h>
#fuses HS,NOWDT
#use delay(clock=20MHz)
#use rs232(baud=9600,parity=N,xmit=PIN_C6,rcv=PIN_C7,bits=8,STOP=1)

void main() {
   char c;

   //set_tris_c(0xBF);
   // I don't think you need this since by default, the the pins are how you want them. But verify it.

   while(TRUE) {
      if (kbhit() ) {
         c=getc();
         putc(c);
      }
   }
}


I know getc() is supposed to check for a kbhit(), but I'm a big fan of making it obvious.

This way, getc doesn't time out. The loop spins as fast as it can. and what you get in should be what you get out.

-Ben

EDIT: I removed the BRG10K -- I spaced on that one, I don't think it's needed either.
_________________
Dazed and confused? I don't think so. Just "plain lost" will do. :D


Last edited by bkamen on Tue Sep 07, 2010 9:48 am; edited 1 time in total
nidhimittalhada



Joined: 06 Sep 2010
Posts: 21

View user's profile Send private message

PostPosted: Mon Sep 06, 2010 11:00 pm     Reply with quote

Quote:

You must _never_ enable an interrupt without an interrupt handler being present. Get rid of the lines doing this. I'm surprised it runs at all with these present.

1) We didn't use it initially but while debugging only we used it ...and after using it only we started getting some output.

Quote:

The code talks about 'getc timeout', but you have not got this enabled in the USE RS232 line.

2) Sad that is also part of our debugging spree ...we used timeout then removed it .
But comment is still lingering here.

Quote:
Get rid of BRG10K. This is only for chips that have the BRG problem.

3) That I just used yesterday when someone suggested if there is some baud problem this flag deals with it .

Quote:
_Is_ your crystal 20MHz?.

4) I just know that in data sheet of pic18f4550 clock source is 20Mhz so only I used HS in fuses.

Quote:
Don't delay after getting the character. If another two characters arrive in this time, the UART _will_ overrun. This will hang the UART with the code as written (add 'ERRORS' to the USE RS232 line - this should always be used with the hardware UART, unless _you_ are handling error conditions yourself.

5) Yes that is wrong. I did that at last moment before posting post. Program was giving mentioned output without using delay only.

6) We added ERRORS but compiler gave compilation error: Sort of overrange error....so we removed ERRORS.

Please help Now
and
The program mentioned ahead we have tried that ...that doesn't give any output on H.T at all ...still I will try that today again and send you the output.

Thanks a lot for helping us to come out this confusing state.

Please note there doesn't seem to be hardware problem...as the assembly codes came with Kit are working perfectly fine.
Ttelmah



Joined: 11 Mar 2010
Posts: 19330

View user's profile Send private message

PostPosted: Tue Sep 07, 2010 1:52 am     Reply with quote

Put ERRORS back.
You will get a _warning_, not an 'error' from the compiler. This is because when 'errors' is added, the compiler generates a variable 'rs232_errors', containing the error information, and since this is not used (at this point), the compiler generates a warning, that there is an unused variable. Warnings are just to tell you that there is something perhaps wrong going on. Problem is that not having 'ERRORS', is much worse than having one unused variable.
If you don't want the warning, simply do a dummy read of the variable at the start of your code. This will get rid of the compiler warning.

When you were 'debugging', did you actually have an interrupt handler present?. If so, then this would explain how things could work. I think part of your problem, is the RS232 overrun error, if data is arriving, and not being read. Without the 'ERRORS' directive, this _will_ lockup the UART.

The PIC2550, can run from any clock source, from 0MHz (though rather pointless), up to 25MHz with a crystal, and from an external clock input up to 48MHz. You need to find out what the actual crystal is on the board you have. Unfortunately, Rhydolabz, doesn't seem to have a current website with details of their stuff, so we can't tell what you may have. If 'echoing' characters round, it is possible for it to work with some characters, if the baud rate is completely wrong. Simply get a magnifying glass, and look at the crystal on the board. This is really the vital 'first step'.

Best Wishes
nidhimittalhada



Joined: 06 Sep 2010
Posts: 21

View user's profile Send private message

PostPosted: Tue Sep 07, 2010 2:27 am     Reply with quote

Kit Spec Says ---- On Board 20 MHz Crystal Oscillator Microchip PIC 18F4550 with 20 MHz Crystal Oscillator (With Boot loader Software)
at
http://www.rhydolabz.com/index.php?main_page=product_info&cPath=99_101&
products_id=297

When I used ERRORS ...BUILD FAILED due to error not warning ... still I will try it again today.

Quote:

When you were 'debugging', did you actually have an interrupt handler present?. If so, then this would explain how things could work. I think part of your problem, is the RS232 overrun error, if data is arriving, and not being read. Without the 'ERRORS' directive, this _will_ lockup the UART.

No I had no interrupt handler. Still its working that way as I mentioned.
nidhimittalhada



Joined: 06 Sep 2010
Posts: 21

View user's profile Send private message

PostPosted: Wed Sep 08, 2010 10:55 pm     Reply with quote

Hi
My program worked because I change use delay to 48 MHz from 20 MHz.
Thanks to you all.
As it was actually a clock problem as you all hinted.
My board
http://www.rhydolabz.com/index.php?main_page=product_info&cPath=99_101&products_id=297
says
On Board 20 MHz Crystal Oscillator.
Supports Up to 48 MHz Operation.

I was using 20MHz, thinking that is master clock
but changing it to 48 worked perfectly well.
Ttelmah



Joined: 11 Mar 2010
Posts: 19330

View user's profile Send private message

PostPosted: Thu Sep 09, 2010 2:27 am     Reply with quote

You can actually run at 48MHz, from the 20MHz crystal.
Fuses needed:
Code:

#fuses HSPLL, NOWDT, PLL5, CPUDIV1, USBDIV, NOXINST
#use delay (clock=48000000)


This says to take the incoming clock, divide it by 5 (PLL5), and feed this to the master PLL. Then multiply this by 24 (the only ratio supported by the PLL), to give 96MHz. Then divide this by 2 (CPUDIV1 - totally confusing! - this fuse gives division by '1' if operating from the external clock, and by '2' if operating from the PLL - designed to really get you thinking.....). Finally sets the processor timing to run from this 48MHz clock.

Best Wishes
bkamen



Joined: 07 Jan 2004
Posts: 1611
Location: Central Illinois, USA

View user's profile Send private message

PostPosted: Thu Sep 09, 2010 8:51 am     Reply with quote

Ttelmah wrote:
You can actually run at 48MHz, from the 20MHz crystal.
Fuses needed:
Code:

#fuses HSPLL, NOWDT, PLL5, CPUDIV1, USBDIV, NOXINST
#use delay (clock=48000000)


This says to take the incoming clock, divide it by 5 (PLL5), and feed this to the master PLL. Then multiply this by 24 (the only ratio supported by the PLL), to give 96MHz. Then divide this by 2 (CPUDIV1 - totally confusing! - this fuse gives division by '1' if operating from the external clock, and by '2' if operating from the PLL - designed to really get you thinking.....). Finally sets the processor timing to run from this 48MHz clock.

Best Wishes


I was thinking about the Oscillator config last night since his original code didn't specify so many fuses what the defaults would have been. Thus getting him into the trouble he was experiencing.

I've never had problems with the 18Fx550's as I was paranoid and was always explicit about the oscillator fuses.

-Ben
_________________
Dazed and confused? I don't think so. Just "plain lost" will do. :D
nidhimittalhada



Joined: 06 Sep 2010
Posts: 21

View user's profile Send private message

No need of FUSES
PostPosted: Fri Sep 10, 2010 10:01 am     Reply with quote

My board
http://www.rhydolabz.com/index.php?main_page=product_info&cPath=99_101&products_id=297
says

On Board 20 MHz Crystal Oscillator.
Supports Up to 48 MHz Operation.


#include <18F4550.h>
#use delay (clock=48000000)
#use rs232(baud=9600,xmit=PIN_C6,rcv=PIN_C7)

void main()
{
char c;
while(TRUE)
{
c=getc();
putc(c);
}
}

See This is the program working perfectly right.
Now It seems that my crystal is 20MHz but without using any fuses as you mentioned
My program is working well.

Even i was doubtful that it was written "in use delay give master clock "
then
On Board 20 MHz Crystal Oscillator.
Supports Up to 48 MHz Operation.
which one out of these will be called master clock
as i used 20Mhz but it did not work rightly
i then changed it to 48 M Hz it worked !!!!!

pl clarify ...
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Goto page 1, 2  Next
Page 1 of 2

 
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