|
|
View previous topic :: View next topic |
Author |
Message |
NAVID
Joined: 14 Jun 2017 Posts: 28
|
sim800c |
Posted: Mon Nov 26, 2018 8:26 am |
|
|
Hello everyone I have a problem with communicates sim800c. I use pic16f877a and i can send commands to sim800 and it works correctly but i can't display its answer...
This is my code. I hope somebody can help me.
tnx
Code: |
#include <16F877A.h>
#device ADC=10
#use delay(crystal=20000000)
#use rs232(baud=9600,parity=N,xmit=PIN_c6,rcv=PIN_c7,bits=8,stream=PORT1,timeout=150)
char a[16];
#INT_RDA
void RDA_isr(void)
{
for(i=0;i<=15;i++){
a[i]=getc();
}
flag=1;}
if(flag==1){
lcd_clear();
flag=0;
lcd_gotoxy(1,1);
printf(lcd_putc,"%s ",a);
i=0;
}
|
I just send important part of the code.
I need to say that when i send strings from my computer to pic its work good but in receiving strings from sim800 i have a problem!!
Last edited by NAVID on Mon Nov 26, 2018 10:39 am; edited 4 times in total |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19537
|
|
Posted: Mon Nov 26, 2018 8:35 am |
|
|
Your approach is fundamentally flawed.
INT_RDA, means _one_ character is available to be read. Just one.
Not 32.
Then you don't show anything that would be making the SIM800 send you a reply. Presumably you are sending a command to do this?.
Then you are looking for 'o'. Why?. SIM800 replies will normally end in
'OK<CR>', but this is a capital 'O', not a lower case 'o', and you still have
two more characters needing to be received after this.
Then you don't show how 'a' is declared. If this is expecting to hold
32characters, it needs to be 33 characters long. If you expect your received
data to terminate when the 'o' is received, then the ISR needs to be adding
a NULL after this into this buffer.
The loop really should be terminated when this happens, or the ISR will sit
waiting for characters that don't arrive. Timeout will not result in the ISR
being re-triggered, so it will effectively be hung.
The receive code needs to be in the 'main' path not the ISR, or the string
needs to be built using a state machine, not a for loop. |
|
|
NAVID
Joined: 14 Jun 2017 Posts: 28
|
|
Posted: Mon Nov 26, 2018 10:37 am |
|
|
Ttelmah wrote: | Your approach is fundamentally flawed. |
:D
Ttelmah wrote: | INT_RDA, means _one_ character is available to be read. Just one.
Not 32. |
so what i must to do??!! its my receiver interrupt...
Ttelmah wrote: | Then you are looking for 'o'. Why?. SIM800 replies will normally end in
'OK<CR>', but this is a capital 'O', not a lower case 'o', and you still have
two more characters needing to be received after this. |
oh sry, i just change the code for a test and forgot to fix it again ...
Ttelmah wrote: | Then you don't show how 'a' is declared. If this is expecting to hold
32characters, it needs to be 33 characters long. If you expect your received
data to terminate when the 'o' is received, then the ISR needs to be adding
a NULL after this into this buffer. |
char a[16];
can you please explain more about "adding
a NULL..."?? i cant get it. |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19537
|
|
Posted: Mon Nov 26, 2018 11:23 am |
|
|
OK.
Look at ex_sisr.c
This is the CCS example for a receive interrupt. Creates a 'circular buffer'
to hold the characters. You main code can then test if anything is available
with 'bkbhit'.
Your 'a' delcaration is a big problem since you are looping for 32 characters...
IN C, a 'string' is an array of characters, with a terminating NULL (0)
character. So (as an example), if you decided to store up to line feed for
example in the buffer, then when you store that, you put 0 into the next
location in the buffer, so string operations can then work. Without this the
printf for example, will keep printing other stuff from memory until a 0 is
hit.
If you wanted to store a 32 character 'string', the array would therefore
need to be 33 characters long... |
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9241 Location: Greensville,Ontario
|
|
Posted: Mon Nov 26, 2018 11:42 am |
|
|
I have to ask a basic hardware question.
Is the 'sim800c' designed to operate at 5 volts? The 877 is a 5 volt PIC so if the sim800c is a 3 volt device, it cannot interface or work properly.
You should post a 'link' to what 'sim800c' device you have.
No amount of software changes can fix faulty hardware !
Jay |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19537
|
|
Posted: Mon Nov 26, 2018 11:57 am |
|
|
Fortunately, if he is using one of the standard shields designed for the Arduino, these have got FET level shifters built in, If he is not using a circuit like this, then there will be problems. |
|
|
PCM programmer
Joined: 06 Sep 2003 Posts: 21708
|
Re: sim800c |
Posted: Mon Nov 26, 2018 12:50 pm |
|
|
NAVID wrote: |
#INT_RDA
void RDA_isr(void)
{
for(i=0;i<=15;i++){
a[i]=getc();
}
flag=1;}
|
NAVID, you were told back in August 2017 not to do this.
You were told to only get one byte per interrupt, and not
to use a for() loop to get multiple bytes inside the RDA interrupt.
See the posts by ezflyr and Ttelmah:
http://www.ccsinfo.com/forum/viewtopic.php?t=56573
Why are you still doing this a year later ? |
|
|
NAVID
Joined: 14 Jun 2017 Posts: 28
|
|
|
NAVID
Joined: 14 Jun 2017 Posts: 28
|
|
Posted: Wed Nov 28, 2018 7:53 am |
|
|
Ttelmah wrote: | Fortunately, if he is using one of the standard shields designed for the Arduino, these have got FET level shifters built in, If he is not using a circuit like this, then there will be problems. |
hi.i fix it but i have new problem!! ((:
for example we i send a sms to sim800 i have some usless characters...
like this:
+CMT: "+989375091182","","18/11/28,17:21:07+14"
Hello
i just need "hello",how i can delete them and just use the sms?? |
|
|
NAVID
Joined: 14 Jun 2017 Posts: 28
|
Re: sim800c |
Posted: Wed Nov 28, 2018 8:00 am |
|
|
PCM programmer wrote: | NAVID wrote: |
#INT_RDA
void RDA_isr(void)
{
for(i=0;i<=15;i++){
a[i]=getc();
}
flag=1;}
|
NAVID, you were told back in August 2017 not to do this.
You were told to only get one byte per interrupt, and not
to use a for() loop to get multiple bytes inside the RDA interrupt.
See the posts by ezflyr and Ttelmah:
http://www.ccsinfo.com/forum/viewtopic.php?t=56573
Why are you still doing this a year later ? |
wow O-o
how u can remember?!?!
im noob at programming.so what i can do?
ex_sisr.c is enough ?? |
|
|
dluu13
Joined: 28 Sep 2018 Posts: 395 Location: Toronto, ON
|
|
Posted: Wed Nov 28, 2018 9:23 am |
|
|
There are also a few posts on this board about using the RECEIVE_BUFFER option in #use rs232
example:
#USE RS232(BAUD=115200, UART3, BITS=8, PARITY=N, STOP=1, STREAM=PC, ERRORS, RECEIVE_BUFFER=128)
It automatically sets up the RDA interrupt for you and puts characters into a circular buffer of the size you specify in RECEIVE_BUFFER. Then, you can just use kbhit() in your while loop to check if there are new characters in your buffer. Then you can use gets() or getc() to take characters out of the buffer without having to worry about staying inside an interrupt too long. Read the manual to see the differences between the flavours of gets() and getc() and their specific functions. |
|
|
temtronic
Joined: 01 Jul 2010 Posts: 9241 Location: Greensville,Ontario
|
|
Posted: Wed Nov 28, 2018 10:40 am |
|
|
and...
while your project is open, pressing F11 will open the CCS manual !! |
|
|
Ttelmah
Joined: 11 Mar 2010 Posts: 19537
|
|
Posted: Wed Nov 28, 2018 11:24 am |
|
|
NAVID wrote: | Ttelmah wrote: | Fortunately, if he is using one of the standard shields designed for the Arduino, these have got FET level shifters built in, If he is not using a circuit like this, then there will be problems. |
hi.i fix it but i have new problem!! ((:
for example we i send a sms to sim800 i have some usless characters...
like this:
+CMT: "+989375091182","","18/11/28,17:21:07+14"
Hello
i just need "hello",how i can delete them and just use the sms?? |
The first line gives who the number the SMS comes from and the time.
Then there is a line feed.
The the SMS itself followed by another line feed.
So just have your code throw away the incoming characters till it sees the
line feed, then start storing characters till the next line feed. |
|
|
NAVID
Joined: 14 Jun 2017 Posts: 28
|
|
Posted: Sat Dec 01, 2018 8:53 am |
|
|
dluu13 wrote: | There are also a few posts on this board about using the RECEIVE_BUFFER option in #use rs232
example:
#USE RS232(BAUD=115200, UART3, BITS=8, PARITY=N, STOP=1, STREAM=PC, ERRORS, RECEIVE_BUFFER=128)
It automatically sets up the RDA interrupt for you and puts characters into a circular buffer of the size you specify in RECEIVE_BUFFER. Then, you can just use kbhit() in your while loop to check if there are new characters in your buffer. Then you can use gets() or getc() to take characters out of the buffer without having to worry about staying inside an interrupt too long. Read the manual to see the differences between the flavours of gets() and getc() and their specific functions. |
hi,i have some few questions...
i must define new char variable named RECEIVE_BUFFER[128]??
like this: char RECEIVE_BUFFER[128]; ??!
or just like you write it in option??so how i can use it??
can u show me an example??
i read the ccs help about rs232 but its example does not explain that...
and what is the bkhit(); ??where i can find and how can use it??
tnx |
|
|
dluu13
Joined: 28 Sep 2018 Posts: 395 Location: Toronto, ON
|
|
Posted: Sat Dec 01, 2018 9:05 am |
|
|
You are right that unfortunately, the manual does not say much about this.
With the RECEIVE_BUFFER option, the circular buffer and the RDA interrupt for placing characters into the receive buffer are automatically generated. You don't need to declare the buffer, or write the ISR. So all you should need is something like this:
Code: | int main(void)
{
char a;
while(1)
{
if(kbhit())
{
a=getc();
// do stuff with a. You could even put your loop here.
}
}
} |
kbhit() evaluates as true if there are new characters in the buffer, and false if there are not.
The main point of this is to move the slow for loop out of the RDA interrupt because interrupt routines are meant to be fast.
Also, I just noticed you might not have found "bkhit()" because it is actually "kbhit()". It is in the manual along with the rest of the built-in functions. |
|
|
|
|
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
|