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

Car tracker using GPS and GSM with one hardware USART chip
Goto page 1, 2, 3  Next
 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
princejude



Joined: 07 Aug 2010
Posts: 72

View user's profile Send private message

Car tracker using GPS and GSM with one hardware USART chip
PostPosted: Fri Apr 27, 2012 6:43 am     Reply with quote

Hello Everyone,
I want to build a mini project titled: GPS Car Tracker.
The project description is as follow:
This will be designed such that the device will be attach to a vehicle so that in case of car theft, the car owner will be able to send a coded SMS to the device attached to the car, and the device will instantly reply back with an SMS to give the user information about the car’s location in terms of Longitude and Latitude. The car owner can now look up these values in a map to get the location of his/her car at any point in time.

I have worked with some GPS and GSM modem separately without any problem.
Since the GPS module transmits data continuously, I wrote the GPS data extraction section of my code in main function and the GSM code in hardware USART (#int_rda) interrupt.
I was using PIC16F887 but when I combined the gps and gsm codes, the code was not compiling due to many variables in both gps and gsm codes
The error message was "Not Enough RAM for all variables".

After I switch to high chip (PIC18F4520), the code complied but the #int_rda was not working in my simulator(Proteus). I used an LED to monitor the serial interrupt, and the LED is not comming ON with 18F but is comming with 16F.
temtronic



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

View user's profile Send private message

PostPosted: Fri Apr 27, 2012 7:03 am     Reply with quote

this...

was not working in my simulator(Proteus).

says it all..

get RID of Proteus !!

Real code in real PICs does WORK !!!

I won the 'coffee and donut' bet the other day,took about 50 minutes to cut the code.What was real impressive was the linkage to Google maps for the realtime tracking. Bloody scary what can be done with so few parts!!!
princejude



Joined: 07 Aug 2010
Posts: 72

View user's profile Send private message

PostPosted: Fri Apr 27, 2012 9:59 am     Reply with quote

Temtronic said:
Quote:
get RID of Proteus !!


Yes I have started the hardware test with my dev. kit. I just tested the GPS with hyperTerminal and the signals are ok.
I tried to extract the GPS cordinates to LCD on my kit and no success yet. I will debug it this weekend to check why the LCD is not seeing the cordinates.

My question is, Will it be possible to put the GPS code in main function using any PIC pin (using stream) to recceive the GPS signal and the GSM on the hardware USART pins (RC6 & RC7) using #int_rda interrupt to receive the sms.
Please if I am not doing it well, how will I do it. And if possible I will like to see some sample codes. I will post my code shortly.
ezflyr



Joined: 25 Oct 2010
Posts: 1019
Location: Tewksbury, MA

View user's profile Send private message

PostPosted: Fri Apr 27, 2012 1:15 pm     Reply with quote

Hi princejude,

It's funny how two people can look at the same problem, and come to opposite conclusions...... If it were me, I'd connect the GPS (which generates a lot of data asynchronously) to the hardware UART, and the GSM module (which generates a modest amount of data at predictable times) to a software UART.

One trick you can use is to connect the TxD pin of the GSM module to the external interrupt pin on the PIC, and use the INT_EXT ISR for the GSM module data reception. It's un-buffered (unlike the hardware UART), but at least each incoming character will trip the interrupt.

Another solution would be to find a PIC with two hardware UARTs.

John
princejude



Joined: 07 Aug 2010
Posts: 72

View user's profile Send private message

PostPosted: Mon Apr 30, 2012 5:53 am     Reply with quote

ezflyr wrote
Quote:
If it were me, I'd connect the GPS (which generates a lot of data asynchronously) to the hardware UART, and the GSM module (which generates a modest amount of data at predictable times) to a software UART.

Thanks for this wonderful comment. I have connected the GPS to hardware UART and I can now extract the GPS data to LCD. I don't have the GSM modem now to test in hardware(I will get it in few weeks time). Maybe I will try to use hyperterminal to emulate the GSM modem before I get the real modem.
ezflyr



Joined: 25 Oct 2010
Posts: 1019
Location: Tewksbury, MA

View user's profile Send private message

PostPosted: Mon Apr 30, 2012 7:44 am     Reply with quote

Hi,

I recently completed a project that uses a GSM module for remote power switching and telemetry. This is the GSM module I used: http://www.sparkfun.com/products/10138 and I can highly recommend it for ease of use, and excellent performance.

It's a 3.8v unit, so it helps to run your PIC at this voltage also unless you want to use level converters on all the I/O.

I also wrote a VB6 program to emulate the GSM module for use during the development of my firmware! That was a big help!
John
princejude



Joined: 07 Aug 2010
Posts: 72

View user's profile Send private message

PostPosted: Mon Apr 30, 2012 8:23 am     Reply with quote

I have used wavecom and siemens GSM modems before without GPS. I used them in some mini projects like to ON and OFF some appliances using sms. I used them with hardware UART and also did NULL modem connection(Tx of GSM to Tx of PIC and RX of GSM to Rx of PIC) through level converter(max232) circuit.

Now that I am using software UART for the GSM, will the NULL modem connection work with the software UART. And if not, what will I do ?
ezflyr



Joined: 25 Oct 2010
Posts: 1019
Location: Tewksbury, MA

View user's profile Send private message

PostPosted: Mon Apr 30, 2012 9:46 am     Reply with quote

Hi,

The electrical interface to the GSM modem will be the same regardless of whether you are using a hardware or software UART. There is a slight level sensitivity difference with the 'Rx' input on the PIC, but that won't be a factor if you use the MAX232.

Are the GSM modems you are using actually old cellphones? Do they have keypads, and displays, etc.? The module I posted is just the GSM engine, so it will fit inside a very compact package! This type of module can also be directly interfaced to your MCU without MAX232 IC's.

Did you see my suggestion to connect the GSM data input to the external interrupt on the PIC? This will give you a 'pseudo' 2nd hardware UART. Again, note there is no character buffering, so keep that in mind!

John
princejude



Joined: 07 Aug 2010
Posts: 72

View user's profile Send private message

Siemens TC35 gsm modem
PostPosted: Thu May 24, 2012 7:13 am     Reply with quote

I bought the gsm modem(SIEMENS TC35) but it was not working with my PIC. The TC35 modem works normal with hyperterminal but is not working with my PIC16f887. I don't know why.

My test code to send sms is below:

Code:
#include <16F887.h>
#device adc=8

#FUSES NOWDT                    //No Watch Dog Timer
#FUSES XT                       //High speed Osc (> 4mhz for PCM/PCH) (>10mhz for PCD)
#FUSES NOPUT                    //No Power Up Timer
#FUSES NOMCLR                     //Master Clear pin enabled
#FUSES NOPROTECT                //Code not protected from reading
#FUSES NOCPD                    //No EE protection
#FUSES NOBROWNOUT               //No brownout reset
#FUSES IESO                     //Internal External Switch Over mode enabled
#FUSES FCMEN                    //Fail-safe clock monitor enabled
#FUSES NOLVP                    //No low voltage prgming, B3(PIC16) or B5(PIC18) used for I/O
#FUSES NODEBUG                  //No Debug mode for ICD
#FUSES NOWRT                    //Program memory not write protected
#FUSES BORV40                   //Brownout reset at 4.0V

#use delay(clock=4000000)
#use rs232(baud=9600,parity=N,xmit=PIN_C6,rcv=PIN_C7,bits=8,errors)

#define CZ 26

char* SendSmsCmd = "AT+CMGS=+2348030674883";

void Outgoing_sms(void)
{
   printf("%s\n",SendSmsCmd);
   delay_ms(100);
   printf("Testing my gsm modem");
   delay_ms(100);
   printf("%c",CZ);
}

void main() //************************************

   output_A(0x00);
   delay_ms(50000);
   output_high(PIN_A0);
   Outgoing_sms();
   output_high(PIN_A1);
   
   while(true)
   {
   }
}

PLS why will this simple code not working with this TC35 and I have used it with other modem such as wavecom.
ezflyr



Joined: 25 Oct 2010
Posts: 1019
Location: Tewksbury, MA

View user's profile Send private message

PostPosted: Thu May 24, 2012 7:47 am     Reply with quote

Hi,

Are you absolutely sure that your PIC can communicate successfully with the GSM modem? Try sending a simple 'AT' command, and see if you get an 'OK' in return. This kind of a basic test is really mandatory before you go blasting off and try to start sending SMS messages.

I do note one pretty serious issue with your timing. See if this thread will help you: http://ccsinfo.com/forum/viewtopic.php?t=48274

Also, your test program is way too complicated. For a basic troubleshooting test, you should be keeping everything as simple a possible, ie. don't use pointers, don't be using subroutines needlessly, etc. Use the test program in the thread above to test your modem, and keep it simple until it works!!

Another thing is that the GSM modem needs to be powered up in a very specific way. A quick look at the documentation shows that input control signal *IGT must be held low for 100ms after powerup to activate the module. Are you doing that? Again, trying to send an SMS message is not the first thing I'd be trying to do until I was sure the modem was actually up and running!

John
princejude



Joined: 07 Aug 2010
Posts: 72

View user's profile Send private message

PostPosted: Fri May 25, 2012 9:01 am     Reply with quote

Hi John,
I have tested this (TC35) in different ways (with different codes) and no communication with my PIC16F887. I don't know if there is any setup/enable command I have to send to this stupid TC35 modem before it can listen to my PIC mcu. Funny enough, my colleague used this same modem with AVR mcu and he succeeded in sending sms from the modem to his handset. But he has not succeeded in reading and extracting the content of sms from the modem to LCD.
ezflyr



Joined: 25 Oct 2010
Posts: 1019
Location: Tewksbury, MA

View user's profile Send private message

PostPosted: Fri May 25, 2012 10:59 am     Reply with quote

Hi,

OK, you said it works with "Hyperterminal", so what's different? Are you sure the electrical interface (signal levels, polarity, GSM Tx -> PIC Rx, PIC Tx -> GSM Rx, etc) is OK?? Are you sure that you are 'enabling' the module as specified?

I can assure you that the TC35 modem is not stupid, you're just doing something incorrectly. It's all in the datasheet, but you've got to read and study it carefully. These types of projects do not lend themselves to the "dart board" approach (ie. throw a bunch of darts until you hit the bullseye), they require careful coding to adhere to the operating specifications of the device.

I may regret asking this, but can you post a schematic?

John
Gabriel



Joined: 03 Aug 2009
Posts: 1067
Location: Panama

View user's profile Send private message

PostPosted: Fri May 25, 2012 12:31 pm     Reply with quote

check for hardware flow control... and disable it on the pc and on the Cell
_________________
CCS PCM 5.078 & CCS PCH 5.093
princejude



Joined: 07 Aug 2010
Posts: 72

View user's profile Send private message

PostPosted: Mon May 28, 2012 10:14 am     Reply with quote

ezfly wrote:
Quote:
I may regret asking this, but can you post a schematic?

My schematic is simple. I am testing the modem with a development kit (with 4MHz crystal). I connected the PIC MCU's Tx pin (PIN_C6) to TC35's Tx pin, MCU's Rx pin (PIN_C7) to to TC35's Rx pin and GND to GND. That is NULL MODEM connection.

Gabriel wrote:
Quote:
check for hardware flow control... and disable it on the pc and on the Cell

How do I disable it on the PIC MCU? I thought hardware flow control is only used during serial testing using terminal windows such as hyperterminal ?
ezflyr



Joined: 25 Oct 2010
Posts: 1019
Location: Tewksbury, MA

View user's profile Send private message

PostPosted: Tue May 29, 2012 6:36 am     Reply with quote

Princejude,

I asked to see a schematic because a diagram very often clears up any ambiguities that a verbal description often introduces......

It's not at all clear to me from your description whether you've got the TC35 module wired correctly to your PIC or not. I took a quick look at the TC35 datasheet, and these are the pin-to-pin connections that I came up with. Is this how you have it wired?

GSM ---- PIC
19 <---- 17
18 -----> 18

On the GSM modem, I'd connect pins 21 and 22 to ground thru two separate resistors. These connections will disable the handshaking on the modem.

You still haven't addressed my earlier comments about "Turning On the GSM modem". Most GSM modems have a very specific startup procedure, but you seem to be totally ignoring this issue?? Have you got a handle on that? It's all in the datasheet.

John
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, 3  Next
Page 1 of 3

 
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