|
|
View previous topic :: View next topic |
Author |
Message |
leevise
Joined: 05 Aug 2010 Posts: 89
|
18f452 Usart question |
Posted: Wed Jul 13, 2011 1:40 am |
|
|
hello guys,
I'm run into a problem:
I want to get a function: PC send the 00--ff, when the PIC get them, then put them on the LED.
My program as follow:
Code: |
#include <18f452.h>
#fuses HS,NOWDT,PUT,NOPROTECT
#use delay(CLOCK=10000000)
#use rs232(BAUD=9600,XMIT=PIN_C6,rcv=PIN_C7)
#define PORTA 0xF80
#define PORTB 0xF81
#define PORTC 0xF82
#define PORTD 0XF83
#bit col8=PORTC.0
#byte RD=PORTD //LED display
#use fast_io(C)
#use fast_io(D)
#define uchar unsigned char
void main()
{
uchar i;
col8=1;
RD=0;
set_tris_c(0x00);
set_tris_d(0x00);
while(1)
{
if(getc())
i=getc();
RD=putc(i);
}
}
|
What wrong with my program?
How to modify it ?
Thank you very much! |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19589
|
|
Posted: Wed Jul 13, 2011 2:10 am |
|
|
Obvious thing is that 'putc', _does not return a value_. It is an output function, not an input function, return is 'undefined' (pure luck).....
Also bracketting...
getc, gets the character - once got it is gone for ever - you need to use 'kbhit' to see if a character is waiting.
Code: |
while(1) {
if(kbhit()) {
i=getc(); //character is waiting, so read it.
RD=i; //Copy to the output port
putc(i); //and to the serial
}
}
|
Best Wishes |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19589
|
|
Posted: Wed Jul 13, 2011 2:17 am |
|
|
One other problem. TRIS. You are selecting fast_io (why?.....), and setting the tris incorrectly for the serial port - read the data sheet and set the serial port bits correctly.
Simpler, let the compiler do it's job:
Code: |
#include <18f452.h>
#fuses HS,NOWDT,PUT,NOPROTECT
#use delay(CLOCK=10000000)
#use rs232(BAUD=9600,XMIT=PIN_C6,rcv=PIN_C7)
#define COL8=PIN_C0
typedef unsigned char uchar
void main(void) {
uchar i;
output_high(COL8);
output_d(0);
do {
if(kbhit()) {
i=getc(); //character is waiting, so read it.
output_d(i); //Copy to the output port
putc(i); //and to the serial
} while(TRUE); //avoids compiler error message
}
|
Best Wishes |
|
|
leevise
Joined: 05 Aug 2010 Posts: 89
|
|
Posted: Wed Jul 13, 2011 2:18 am |
|
|
Ttelmah wrote: | Obvious thing is that 'putc', _does not return a value_. It is an output function, not an input function, return is 'undefined' (pure luck).....
Also bracketting...
getc, gets the character - once got it is gone for ever - you need to use 'kbhit' to see if a character is waiting.
Code: |
while(1) {
if(kbhit()) {
i=getc(); //character is waiting, so read it.
RD=i; //Copy to the output port
putc(i); //and to the serial
}
}
|
Best Wishes |
Thank you for your advice!
but ,when i use the
RD=putc(0x01); //means LED(RD port) will light
The first LED light,that why ? |
|
|
leevise
Joined: 05 Aug 2010 Posts: 89
|
|
Posted: Wed Jul 13, 2011 2:40 am |
|
|
Ttelmah wrote: | One other problem. TRIS. You are selecting fast_io (why?.....), and setting the tris incorrectly for the serial port - read the data sheet and set the serial port bits correctly.
Simpler, let the compiler do it's job:
Code: |
#include <18f452.h>
#fuses HS,NOWDT,PUT,NOPROTECT
#use delay(CLOCK=10000000)
#use rs232(BAUD=9600,XMIT=PIN_C6,rcv=PIN_C7)
#define COL8=PIN_C0
typedef unsigned char uchar
void main(void) {
uchar i;
output_high(COL8);
output_d(0);
do {
if(kbhit()) {
i=getc(); //character is waiting, so read it.
output_d(i); //Copy to the output port
putc(i); //and to the serial
} while(TRUE); //avoids compiler error message
}
|
Best Wishes |
when I compile this code, and download the target, but I send the f --->PIC by usart PC terminal soft, the target's LED is not light.
I don't know why ? so pls help me !!!!
thank you and appreciate |
|
|
leevise
Joined: 05 Aug 2010 Posts: 89
|
|
Posted: Wed Jul 13, 2011 3:13 am |
|
|
leevise wrote: | Ttelmah wrote: | One other problem. TRIS. You are selecting fast_io (why?.....), and setting the tris incorrectly for the serial port - read the data sheet and set the serial port bits correctly.
Simpler, let the compiler do it's job:
Code: |
#include <18f452.h>
#fuses HS,NOWDT,PUT,NOPROTECT
#use delay(CLOCK=10000000)
#use rs232(BAUD=9600,XMIT=PIN_C6,rcv=PIN_C7)
#define COL8=PIN_C0
typedef unsigned char uchar
void main(void) {
uchar i;
output_high(COL8);
output_d(0);
do {
if(kbhit()) {
i=getc(); //character is waiting, so read it.
output_d(i); //Copy to the output port
putc(i); //and to the serial
} while(TRUE); //avoids compiler error message
}
|
Best Wishes |
when I compile this code ,and download the target ,but I send the f --->PIC by usart PC terminal soft ,the target's LED is not light.
I don't know why ? so pls help me !!!!
thank you and appreciate |
new code
while(1)
{
if(kbhit())
{
i=getc(); //character is waiting, so read it.
RD=i; //Copy to the output port
}
else
putc(0x0d); //and to the serial
delay_ms(500);
}
}
the PIC target doesn't work !!!!
why ????
help me ! thank you !! |
|
|
leevise
Joined: 05 Aug 2010 Posts: 89
|
|
Posted: Wed Jul 13, 2011 7:30 am |
|
|
pls help me ! appreciate |
|
|
leevise
Joined: 05 Aug 2010 Posts: 89
|
|
Posted: Wed Jul 13, 2011 7:45 am |
|
|
Check the updated code as follows, pls help me to analyse it. Because it doesn't work! Thank you for your help!!
Code: |
#include <18f452.h>
#fuses HS,NOWDT,PUT,NOPROTECT
#use delay(CLOCK=10000000)
#use rs232(baud=9600,xmit=PIN_C6,rcv=PIN_C7,parity=N,bits=8)
#define PORTA 0xF80
#define PORTB 0xF81
#define PORTC 0xF82
#define PORTD 0XF83
#define col8 PIN_C0
#define uchar unsigned char
void main()
{
uchar i;
output_high(col8);
output_d(0x00);
do {
if(kbhit())
{
i=getc(); //character is waiting, so read it.
output_d(i);
}//Copy to the output port
putc(i); //and to the serial
} while(1); //avoids compiler error message
}
|
|
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19589
|
|
Posted: Wed Jul 13, 2011 9:44 am |
|
|
Have you actually proved:
1) Your PIC is running, and running at the required frequency - LED flash program, verify flash rate is correct.
2) You can getc/putc correctly - print a line to the PC, then receive a character, and do something to it (add 1 for example), and return this. Do you then see the printed line, and when you send 'a', get back 'b'. Prove your hardware is working, before trying to code.
Best Wishes |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19589
|
|
Posted: Wed Jul 13, 2011 10:39 am |
|
|
Also, you have moved the putc(i) outside the kbhit test section of the code. It needs to be _inside_. Otherwise you will be continuously transmitting the same character again and again.
Best Wishes |
|
|
leevise
Joined: 05 Aug 2010 Posts: 89
|
|
Posted: Wed Jul 13, 2011 6:42 pm |
|
|
Ttelmah wrote: | Also, you have moved the putc(i) outside the kbhit test section of the code. It needs to be _inside_. Otherwise you will be continuously transmitting the same character again and again.
Best Wishes |
Thank you for your this advice ! I got successful!
The ok code is as follows:
Code: |
#include <18f452.h>
#fuses HS,NOWDT,PUT,NOPROTECT
#use delay(CLOCK=10000000)
#use rs232(baud=9600,xmit=PIN_C6,rcv=PIN_C7,parity=N,bits=8)
#define col8 PIN_C0
#define uchar unsigned char
void main()
{
uchar i;
output_high(col8);
output_d(0x00);
do {
if(kbhit())
{
i=getc(); //character is waiting, so read it.
output_d(i);
putc(i); //and to the serial
}
} while(1); //avoids compiler error message
}
|
|
|
|
leevise
Joined: 05 Aug 2010 Posts: 89
|
|
Posted: Wed Jul 13, 2011 8:33 pm |
|
|
Ttelmah wrote: | Have you actually proved:
1) Your PIC is running, and running at the required frequency - LED flash program, verify flash rate is correct.
2) You can getc/putc correctly - print a line to the PC, then receive a character, and do something to it (add 1 for example), and return this. Do you then see the printed line, and when you send 'a', get back 'b'. Prove your hardware is working, before trying to code.
Best Wishes |
I have an another question, why it is un-works, when I used the code as follow:
#include <18f452.h>
#fuses HS,NOWDT,PUT,NOPROTECT
#use delay(CLOCK=10000000)
#use rs232(baud=9600,xmit=PIN_C6,rcv=PIN_C7,parity=N,bits=8)
//#use i2c(MASTER,SDA=PIN_C4,SCL=PIN_C3,ADDRESS=0X9A,FORCE_HW)//I2C
#define PORTA 0xF80
#define PORTB 0xF81
#define PORTC 0xF82
#define PORTD 0XF83
#bit col8=PORTC.0
#byte RD=PORTD //equal the syntax "#byte RD=0xf83"
#define uchar unsigned char
void main()
{
uchar i;
col8=1; //equal the "output_high(col8);"
RD=0; // equal the"output_d(0x00);",but this code need decimal
set_tris_d(0x00);
do {
if(kbhit())
{
i=getc(); //character is waiting, so read it.
RD=i;
putc(i); //and to the serial
}
} while(1); //avoids compiler error message
}
PC terminal soft can receive the data,but the LED doesn't light.
why ? |
|
|
leevise
Joined: 05 Aug 2010 Posts: 89
|
|
Posted: Thu Jul 14, 2011 3:17 am |
|
|
I succeed, the code is as follow:
Code: |
// Example 2
#include <18f452.h>
#fuses HS,NOWDT,PUT,NOPROTECT
#use delay(CLOCK=10000000)
#use rs232(baud=9600,xmit=PIN_C6,rcv=PIN_C7,parity=N,bits=8)
#define PORTA 0xF80
#define PORTB 0xF81
#define PORTC 0xF82
#define PORTD 0XF83
#bit col8=PORTC.0
#byte RD=PORTD //相当于 #byte RD=0xf83
#define uchar unsigned char
void main()
{
uchar i;
col8=1; //output_high(col8);
RD=0; //output_d(0x00);
set_tris_d(0x00); //RDdirection
set_tris_c(0x80); //set PIN_C7 input
do {
if(kbhit())
{
i=getc(); //character is waiting, so read it.
putc(i); //and to the serial
RD=i;
}
} while(TRUE); //avoids compiler error message
}
|
|
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19589
|
|
Posted: Thu Jul 14, 2011 6:33 am |
|
|
output_d, doesn't care what numeric format you use.
output_d(23);
decimal number. Works just as well as
output_d(0x17);
Read some basic C manuals on numeric representations. You can use binary, decimal, hex, octal etc.. The point about using hex for port I/O, is it makes it easier to see what bits are going where on the port.
Port C0, and RD, are set as an input, if you use the #bit format as shown. Hence the outputs does nothing.
_Use_ the compiler functions. You are like a person with a motor car, trying to steer it, by sticking his foot out the door. Though it probably can be made to work (within the limitations of shoes, and leg strength), it rather misses the point of having a steering wheel.....
Best Wishes |
|
|
|
|
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
|