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

Problem with arrays
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
filjoa



Joined: 04 May 2008
Posts: 260

View user's profile Send private message

Problem with arrays
PostPosted: Thu May 16, 2013 7:56 pm     Reply with quote

Hi

I write a program to read strings from GPS, but I don't know what happens with arrays...
Code:

void read_protocol(void)
{
int i=0, result1 = 0, result2 = 0;
char str1[7], str2[7], prot[7];

str1 = "$GPRMC";
str2 = "$GPGGA";

   while(c!='$');

do {
      while (data_available==FALSE);
      data_available = FALSE;
      prot[i]=c;
      i++;
   }while (c!=',');
     
   result1 = strncmp  (str1, prot, 5);
   result2 = strncmp  (str2, prot, 5);
 
   if (result1 == 0) readgps1();                   
   if (result2 == 0) readgps2();
   if (result1 != 0 || result2 !=0) break;   
}

   
   //protocolo GPRMC ##
void readgps1(void)
{
char speedstr[10], auxstr[62];
int8 i = 0, speed = 0;

   do {
      while (data_available==FALSE);
      data_available = FALSE;
      auxstr[i]=c;
      i++;
   }while (c!='\r');


   fprintf(outport,"%s",auxstr);   
   fprintf(outport,"\n\r");
}


   //protocolo GPRMC ##
void readgps2(void)
{
char auxstr[71];
int8 i = 0;

   do {
      while (data_available==FALSE);
      data_available = FALSE;
      auxstr[i]=c;
      i++;
   }while (c!='\r');



   fprintf(outport,"%s",auxstr);   
   fprintf(outport,"\n\r");
}

For example, I need know exactly size of my string, this don´t work if I put an array like this "auxstr[150]" or "auxstr[]", if I put this, I can't see correct string on terminal.
The same happens if I change on function readgps1(), "char speedstr[10], auxstr[62];" to "char auxstr[62], speedstr[10];", only change order.

Some one can explain where stay my error?

best regards
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Thu May 16, 2013 8:16 pm     Reply with quote

Quote:

For example, I need know exactly size of my string, this don't work if I
put an array like this "auxstr[150]" or "auxstr[]", if I put this, I can't see
correct string on terminal.

You are probably doing this, from a previous post:
Code:
 
#int_rda
void rda_isr(void)
   {
   c = getc(gpsport);
   data_available=TRUE;
   }
   

This is not the correct way to do it. You should wait for a start-of-
message character, which is the '$' character. Then start saving
the incoming characters in an array. When you get the end of message
character, you should write a 0x00 to the array, at the end of the
message.

I think it's very likely that you are not writing a 0x00 at the end of
the message. A string is only a string if it has 0x00 at the end of the text.


Quote:
auxstr[]

This doesn't allocate any RAM for the array. It will not work.
ezflyr



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

View user's profile Send private message

PostPosted: Thu May 16, 2013 8:28 pm     Reply with quote

Hi,

I'm not really sure what problem what you are reporting, but you are trying to print a 'string' that is not really a string. Keep in mind that a 'C' string is an array of characters that has been 'Null' terminated. Just before you attempt to print the string, add '\0' as the last character in the array (following your character data).

John
filjoa



Joined: 04 May 2008
Posts: 260

View user's profile Send private message

PostPosted: Tue May 21, 2013 3:51 pm     Reply with quote

Hi

if I try find '\0' program don't work... I need find '\r'

if I don't allocate RAM on my arrays I can't print my string...

Code:

#int_rda
void rda_isr(void)
   {
   c = getc(gpsport);
   data_available=TRUE;
   }
   
   //## escolha e identificação do protocolo GPRMC ##
void read_protocol(void)
{
int i=0, result1 = 0, result2 = 0;
char str1[], str2[], prot[];

str1 = "$GPRMC";
str2 = "$GPGGA";

   while(c!='$');

do {
      while (data_available==FALSE);
      data_available = FALSE;
      prot[i]=c;
      i++;
   }while (c!=',');
     
   result1 = strncmp  (str1, prot, 5);
   result2 = strncmp  (str2, prot, 5);
 
   if (result1 == 0) readgps1();       
   if (result2 == 0) readgps2();
   if (result1 != 0 || result2 !=0) break;     
}

   
   //## LER DO GPS protocolo GPRMC ##
void readgps1(void)
{
char auxstr[];
int8 i = 0, speed = 0;

   do {
      while (data_available==FALSE);
      data_available = FALSE;
      auxstr[i]=c;
      i++;
   }while (c!='\r');


// ##### TRATAMENTO DOS DADOS #####
       
         fprintf(outport,"%s", auxstr);
         fprintf(outport,"\n\r");
}



With this code I detect protocol "$GPRMC" and "$GPGGA", but when I try print it on terminal, my string don't appear correct.

I need save correct string to separate it.


Hi

for example... if I make this:

Quote:

void readgps1(void)
{
char auxstr[];
int8 i = 0, speed = 0;

do {
while (data_available==FALSE);
data_available = FALSE;
auxstr[i]=c;
i++;
}while (c!= '\r');

speed = i;
// ##### TRATAMENTO DOS DADOS #####

fprintf(outport,"$GPRMC\n\r");
for (i=0;i<speed;i++)
{
fprintf(outport,"%c",auxstr[i]);
}
fprintf(outport,"\n\r");
}



resulte is this:

Quote:

$GPRMC
AccAGPRMC2qp0G000,A,4031.2765GPGGA,223,06,03,01,16,19,22,21,07,18,11,08,,1.17,
0.90,0.76*03
$GPRMC
AccAGPRMC2qp0G000,A,4031.2765GPGGA,223,06,03,01,16,19,22,21,07,18,11,08,,1.17,
0.90,0.76*03
$GPRMC
AccAGPRMC2qp0G000,A,4031.2765GPGGA,223,06,03,01,16,19,22,21,07,18,11,08,,1.17,
0.90,0.76*03
$GPRMC
3iiAGPRMC2qp0G000,A,4031.2765GPGGA,223,12,07,19,294,33,21,14,055,19,01,11,238,
26,08,10,323,19*7B
$GPRMC
AccAGPRMC2qp0G000,A,4031.2765GPGGA,223,06,03,01,16,19,22,21,07,18,11,08,,1.17,
0.90,0.76*03
$GPRMC
AaaAGPRMC2qp0G000,A,4031.2765GPGGA,223,06,03,01,16,19,22,21,07,18,11,,,1.28,1.
03,0.77*0D
$GPRMC
2zzAGPRMC2qp0G000,A,4031.2765GPGGA,223,06,02221.000,4031.2737,N,00825.6803,W,2
,10,1.03,42.7,M,51.1,M,0000,0000*4C


some suggestions?

best regards


Last edited by filjoa on Tue May 21, 2013 4:23 pm; edited 1 time in total
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Tue May 21, 2013 4:17 pm     Reply with quote

Quote:
void read_protocol(void)
{
int i=0, result1 = 0, result2 = 0;
char str1[], str2[], prot[];

str1 = "$GPRMC";
str2 = "$GPGGA";

Why do you do this when you know it doesn't work ?

Make a test program. Look what the compiler does.
Code:
#include <18F4520.h>
#fuses INTRC_IO,NOWDT,BROWNOUT,PUT,NOLVP
#use delay(clock=4M) 

//=========================
void main()
{
char str1[], str2[];

str1 = "$GPRMC";
str2 = "$GPGGA";

while(1);
}


Here is the .LST file. You don't have arrays. You didn't declare the
size of the arrays. So the compiler just takes the first byte of each
string ( the '$' byte) and puts it into str1 and str2.
Code:
.................... void main()
.................... {
0004:  CLRF   TBLPTRU
0006:  BCF    RCON.IPEN
0008:  CLRF   FSR0H
000A:  CLRF   FSR0L
000C:  MOVLW  60
000E:  MOVWF  OSCCON
0010:  MOVF   OSCCON,W
0012:  MOVF   ADCON1,W
0014:  ANDLW  C0
0016:  IORLW  0F
0018:  MOVWF  ADCON1
001A:  MOVLW  07
001C:  MOVWF  CMCON
.................... char str1[], str2[]; 
.................... 
.................... str1 = "$GPRMC"; 
001E:  MOVLW  24        <==  First character '$' is put into 'str'
0020:  MOVWF  str1
.................... str2 = "$GPGGA"; 
0022:  MOVWF  str2   <==  Same thing here.
.................... 
.................... while(1);
0024:  BRA    0024
.................... }
0026:  SLEEP


Look at the symbol table below. The compiler makes this file in your
project directory. Look for the .SYM file. Notice your "arrays" are not
arrays. They only have 1 byte of RAM allocated to them. They don't
hold your $GPRMC or $GPGGA strings.
Code:

000     @SCRATCH
001     @SCRATCH
001     _RETURN_
002     @SCRATCH
003     @SCRATCH
005     main.str1   <== Only 1 byte of RAM allocated to 'str1'
006     main.str2   <== Same thing with 'str2'
007     main.@SCRATCH1
008     main.@SCRATCH2
009     main.@SCRATCH3
00A     main.@SCRATCH4


You know this. You have been on the forum for years.
filjoa



Joined: 04 May 2008
Posts: 260

View user's profile Send private message

PostPosted: Tue May 21, 2013 4:31 pm     Reply with quote

Hi, thanks...

with this example I print my string correct:

Code:

void read_protocol(void)
{
int i=0, result1 = 0, result2 = 0;
char str1[7], str2[7], prot[7];

str1 = "$GPRMC";
str2 = "$GPGGA";

   while(c!='$');

do {
      while (data_available==FALSE);
      data_available = FALSE;
      prot[i]=c;
      i++;
   }while (c!=',');
     
   result1 = strncmp  (str1, prot, 5);
   result2 = strncmp  (str2, prot, 5);
 
   if (result1 == 0) readgps1();                    //apresenta o protocolo escolhido
   if (result2 == 0) readgps2();
   if (result1 != 0 || result2 !=0) break;          //retorna ao main
}

   
   //## LER DO GPS protocolo GPRMC ##
void readgps1(void)
{
char auxstr[150];
int8 i = 0, speed = 0;

   do {
      while (data_available==FALSE);
      data_available = FALSE;
      auxstr[i]=c;
      i++;
   }while (c!= '\r');

speed = i;
// ##### TRATAMENTO DOS DADOS #####
       
        fprintf(outport,"$GPRMC\n\r");
        for (i=0;i<speed;i++)
         {
        fprintf(outport,"%c",auxstr[i]);
         }
         fprintf(outport,"\n\r");
}


   //## LER DO GPS protocolo GPGGA ##
void readgps2(void)
{
char auxstr[150];
int8 i = 0, speed = 0;

   do {
      while (data_available==FALSE);
      data_available = FALSE;
      auxstr[i]=c;
      i++;
   }while (c!='\r');

// ##### TRATAMENTO DOS DADOS #####

speed = i;

 fprintf(outport,"$GPGGA\n\r");
        for (i=0;i<speed;i++)
         {
        fprintf(outport,"%c",auxstr[i]);
         }
         fprintf(outport,"\n\r");
}
filjoa



Joined: 04 May 2008
Posts: 260

View user's profile Send private message

PostPosted: Tue May 21, 2013 6:07 pm     Reply with quote

Hi

I'll try separate different information of my string

each information have an ','

Code:

   //## LER DO GPS protocolo GPRMC ##
void readgps1(void)
{
char auxstr[150] ;
int8 i = 0, aux;
int8 horas = 0;

   do {
      while (data_available==FALSE);
      data_available = FALSE;
      auxstr[i]=c;
      i++;
   }while (c!= '\r');


// ##### TRATAMENTO DOS DADOS #####

 
fprintf(outport,"Horas: %s",auxstr);

         fprintf(outport,"\n\r");

}


result on terminal:
Quote:

Horas: 010456.000,A,4031.2722,N,00825.6777,W,0.07,62.36,220513,,,A*47


some times appear:
1º character stay wrong.

Quote:

0oras: 001332.000,A,4031.2710,N,00825.6773,W,0.61,65.02,220513,,,A*46
3oras: 001333.000,A,4031.2710,N,00825.6771,W,0.65,67.77,220513,,,A*41
Doras: 001334.000,A,4031.2709,N,00825.6770,W,0.64,72.83,220513,,,A*41
Eoras: 001335.000,A,4031.2709,N,00825.6772,W,0.42,72.83,220513,,,A*46
Doras: 001336.000,A,4031.2709,N,00825.6772,W,0.41,72.83,220513,,,A*46
Doras: 001337.000,A,4031.2709,N,00825.6772,W,0.39,72.83,220513,,,A*48
8oras: 001338.000,A,4031.2710,N,00825.6773,W,0.37,72.83,220513,,,A*40
9oras: 001339.000,A,4031.2711,N,00825.6772,W,0.34,72.83,220513,,,A*42
7oras: 001340.000,A,4031.2711,N,00825.6772,W,0.44,72.83,220513,,,A*4B
7oras: 001341.000,A,4031.2712,N,00825.6770,W,0.50,72.83,220513,,,A*4E
Doras: 001342.000,A,4031.2713,N,00825.6769,W,0.52,72.83,220513,,,A*46



some one can have an ideia how I can separate information, Hours, coordinates, speed?

best regards
filjoa



Joined: 04 May 2008
Posts: 260

View user's profile Send private message

PostPosted: Tue May 21, 2013 6:27 pm     Reply with quote

if I put this

Quote:

void read_protocol(void)
{
int i=0, result1 = 0, result2 = 0;
char str1[7], str2[7], prot[10];


result:
1º character stay wrong...
Quote:

31414 002357.000,A,4031.2684,N,00825.6829,W,0.15,227.43,220513,,,A*78
31414 002358.000,A,4031.2685,N,00825.6827,W,0.12,227.43,220513,,,A*7F
31414 002359.000,A,4031.2686,N,00825.6827,W,0.17,227.43,220513,,,A*78
31414 002400.000,A,4031.2685,N,00825.6828,W,0.49,227.43,220513,,,A*74


if I put:

Quote:

void read_protocol(void)
{
int i=0, result1 = 0, result2 = 0;
char str1[7], str2[7], prot[7];


result:
is the same like previous post.

this array make me confuse.... but ok.. with "for" cicle I write string correct on terminal...

principal question is: How I can find "," on my array?
filjoa



Joined: 04 May 2008
Posts: 260

View user's profile Send private message

PostPosted: Wed May 22, 2013 1:31 am     Reply with quote

Hi

now I have this code to try find and separate my string:

Code:

   //## LER DO GPS protocolo GPRMC ##
void readgps1(void)
{
char auxstr[150], horas [10], val[5] ,lat[15];
char coord[5];
int8 i = 0, aux = 0;

   do {
      while (data_available==FALSE);
      data_available = FALSE;
      auxstr[i]=c;
      i++;
   }while (c!= '\r');

////////////// A funcionar
   aux = i;
   fprintf(outport,"String: ");
   for (i=0;i<aux;i++)
      {
         fprintf(outport,"%c",auxstr[i]);     
      }
fprintf(outport,"\n\r");


// HORAS

   i=0;
   do {
   horas[i]=auxstr[i];
   i++;
   } while (auxstr[i]!=',');

   aux = i;
   fprintf(outport,"Horas: ");
   for (i=0;i<aux;i++)
      {
         fprintf(outport,"%c",horas[i]);     
      }

//Validade
   i=0;
   do {
   val[i]=auxstr[i+aux];
   i++;
   } while (auxstr[i+aux]!=',');

   aux = i;
   fprintf(outport," - Validade: ");
   for (i=1;i<aux;i++)
      {
         fprintf(outport,"%c",val[i]);
      }

//LATITUDE
   i=0;
   do {
   lat[i]=auxstr[i+aux];
   i++;
   } while (auxstr[i+aux]!=',');

   aux = i;
   fprintf(outport," - Latitude: ");
   for (i=0;i<aux;i++)
      {
         fprintf(outport,"%c",lat[i]);
      }


//LAT COORDENATES
   i=0;
   do {
   coord[i]=auxstr[i+aux];
   i++;
   } while (auxstr[i+aux]!=',');

   aux = i;
   fprintf(outport," - : ");
   for (i=0;i<aux;i++)
      {
         fprintf(outport,"%c",coord[i]);
      }


But I think it don't stay correct... my idea is put each part on a string variable, not on array..

is possible?

how I can put this program more efficiently?

best regards
Ttelmah



Joined: 11 Mar 2010
Posts: 19546

View user's profile Send private message

PostPosted: Wed May 22, 2013 2:22 am     Reply with quote

Get on thing clear. 'C' does not have an inherent 'string' type. In 'C', a 'string', _is_ an array of characters, _with a terminating null_. This is the basic 'what a string is' in C. Nothing else.

Second thing. You still have the basic "I'm going to lose as much incoming data as possible" approach. The UART has just two characters of buffering in each direction. No more. Now you stop receiving, and go off sending stuff to outport, and parsing the received data, and while this is happening, more data will be arriving, and being lost. Look at ex_sisr.c, for how the receive interrupt should be handled. Then instead of testing 'data_available', use while(!bkbhit()), and instead of just loading the character 'c', use bgetc.

Now, you are using the title 'auxstr' for your character array, and call it a string when you print it, but then don't null terminate it, so it is not a 'string'. If it was a string, you could save yourself line upon line of code, by first simply printing it with fprintf as a string, rather than doing this character by character, then finding the ',' using strstr, etc..
Get a basic C textbook, and read.

Then there is the ongoing problem of sizes. You try to pull the latitude out of the array into 'val[]', and allow five characters for this. The standard for GPRMC, is the coordinates are "xxxxxx.xx". Three digits for the degrees, then two digits more for the decimal minutes, then the decimal point, then two to four digits for the fractional minutes. A total of eleven characters (and to work with this as a string, you would then need a twelth character to store the null). You at this point will have overwritten the next variable in memory.... Look at how many characters there are between the commas in your examples....
ezflyr



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

View user's profile Send private message

PostPosted: Wed May 22, 2013 7:43 am     Reply with quote

filjoa wrote:
Hi
if I try find '\0' program don't work... I need find '\r'


Hi,

You completely misunderstood my comment about '\0'..... I never said to search for this character, I said to use it to 'Null Terminate' your character array to make the array a 'C' string. Again, in 'C' a string is nothing more than an array of characters that has '\0' as the final character. So, instead of printing your character array, character by character, you can do this instead:

Code:

         auxstr[i++] = '\0';     //Null terminate the character array
         fprintf(outport,"%s\n\r",auxstr);   


As others have pointed out, you really need to receive the GPS data using an interrupt-driven circular buffer. Start with the CCS example program 'ex_sisr.c', and build on it from there. Inside your serial interrupt routine (int rda), you can 'filter' the incoming data using a 'state machine' to only allow the desired NMEA data strings into your receive buffer. Then, inside your Main routine, you can extract the individual NMEA strings and parse them. Separating the NMEA strings into their individual parameters, because of the comma delimiters, and the fact that each parameter appears at a known position each time.

John
filjoa



Joined: 04 May 2008
Posts: 260

View user's profile Send private message

PostPosted: Tue May 28, 2013 5:57 am     Reply with quote

Hi

thanks... for this explanation, now I understand.

I'll make this modification on my code and try it...

best regards
filjoa



Joined: 04 May 2008
Posts: 260

View user's profile Send private message

PostPosted: Wed Jun 26, 2013 3:07 pm     Reply with quote

Hi

I have some problem with interrupts, I think...

This program read some GPS parameters and a temperature.

If I uncomment "readtemp();" in main function, program printing stupid string on terminal.
Code:

#include <18F458.h>
#device adc=10                                        //adc com 10bits
#fuses HS,NOWDT,NOPROTECT,NOLVP,BROWNOUT,STVREN
#use delay(clock=20000000)
#use rs232(baud=9600,parity=N,xmit=PIN_C6,rcv=PIN_C7,bits=8, stream=gpsport, Errors)
#use rs232(baud=9600,parity=N,xmit=PIN_C4,rcv=PIN_C5,bits=8, stream=outport, Errors)

#include<string.h>
#include<stdlib.h>

   //## Variaveis Globais ##
   
   int1 data_available=FALSE;   
   char c;
   char time[20], lat[20], PNS[10], longi[20], PEW[10], speed[20], alt[20];
   int16 temperatura;
   
   //## Declaração de funções ##
   void rda_isr();
   void read_protocol(void);
   void readgps1(void);
   void readgps2(void);
   void readtemp(void);
   

#int_rda
void rda_isr(void)
   {
   c = getc(gpsport);
   data_available=TRUE;
   }
   
   //## escolha e identificação do protocolo GPRMC ##
void read_protocol(void)
{
int i=0, result1 = 0, result2 = 0;
char str1[7], str2[7], prot[9];

strcpy (str1, "$GPRMC");
strcpy (str2, "$GPGGA");

   while(c!='$');

do {
      while (data_available==FALSE);
      data_available = FALSE;
      prot[i]=c;
      i++;
   }while (c!=',');
     
   result1 = strncmp  (str1, prot, 5);
   result2 = strncmp  (str2, prot, 5);
 
   if (result1 == 0) readgps1();                    //apresenta o protocolo escolhido
   if (result2 == 0) readgps2();
   if (result1 != 0 || result2 !=0) break;          //retorna ao main
}

   
   //## LER DO GPS protocolo GPRMC ##
void readgps1(void)
{
char auxstr[150], auxtime [20];
int8 i = 0, x = 0, virg = 0, x2 =0, numspeed = 0;

   do {
      while (data_available==FALSE);
      data_available = FALSE;
      auxstr[i]=c;
      i++;
   }while (c!= '\r');
   auxstr[i]='\0';               //para transformar o array numa string

////////////// A funcionar
   
//fprintf(outport," %s \n\r",auxstr);

// ##### TRATAMENTO DOS DADOS #####

for(i=0;i<20;i++){ time[i]=0;}
for(i=0;i<20;i++){ lat[i]=0;}
for(i=0;i<10;i++){ PNS[i]=0;}
for(i=0;i<20;i++){ longi[i]=0;}
for(i=0;i<10;i++){ PEW[i]=0;}
for(i=0;i<20;i++){ speed[i]=0;}


i=0;
x=0;
x2=0;
 while(auxstr[i]!='\0') {
             
             if(auxstr[i]==','){ virg++; x=0; i++; }
//HORAS             
             if (virg==0){ time[x]=auxstr[i];  x++; x2=x; }
             if (virg==1){ time[x2]='\0';}
//LATITUDE             
             if (virg==2){ lat[x]=auxstr[i]; x++; x2=x; }
             if (virg==3){ lat[x2]='\0';}
//POSIÇÃO N/S             
             if (virg==3){ PNS[x]=auxstr[i];  x++; x2=x; }
             if (virg==4){ PNS[x2]='\0';}
//LONGITUDE             
             if (virg==4){ longi[x]=auxstr[i]; x++; x2=x; }
             if (virg==5){ longi[x2]='\0';}
//POSIÇÃO E/W             
             if (virg==5){ PEW[x]=auxstr[i]; x++; x2=x; }
             if (virg==6){ PEW[x2]='\0';}
//VELOCIDADE km/h             
             if (virg==6){ speed[x]=auxstr[i];  x++; x2=x; }
             if (virg==7){ speed[x2]='\0';
                           numspeed = 1.852*atof(speed);       //converter velocidade de nós para kilometros
                           itoa(numspeed,10,speed);
                         }             
             i++;
                     }

//#### FORMATO HORARIO hh:mm:ss ####
i=0;
x=0;
for(i=0;i<20;i++){ auxtime[i]=0;}

for (i=0;i<=10;i++)
   {
      if (time[x] == '.') { auxtime[i]='\0'; i=10;}
   
      auxtime[i]=time[x];
     
      if (i == 2) { auxtime[i]=':'; x--;}
      if (i == 5) { auxtime[i]=':'; x--;}
     
      x++;
   }

   strcpy(time, auxtime);
}


   //## LER DO GPS protocolo GPGGA ##
void readgps2(void)

{
char auxstr[150];
int8 i = 0, x = 0, x2 = 0, virg = 0;

   do {
      while (data_available==FALSE);
      data_available = FALSE;
      auxstr[i]=c;
      i++;
   }while (c!='\r');
   auxstr[i]='\0';               //para transformar o array numa string

////////////// A funcionar
     
//fprintf(outport," %s \n\r",auxstr);

// ##### TRATAMENTO DOS DADOS #####

for(i=0;i<20;i++) { alt[i]=0;}

i=0;
 while(auxstr[i]!='\0') {
             
             if(auxstr[i]==','){ virg++; x=0; i++; }
             
//ALTURA A PARTIR DO MAR EM (m)             
             if (virg==8){ alt[x]=auxstr[i];  x++; x2=x; }
             if (virg==9){ alt[x2]='\0';}

                        i++;
                        }
}

void readtemp(void)
{
int16 aux1 =0 , value1 = 0, aux2 =0 , value2 = 0, i = 0;
int16 lm35 = 0, termop = 0;

// ## TEMP LM35

   for (i=0;i<30;i++)
      {
         set_adc_channel(0);  //Porta a ler da ADC RA0
         delay_ms(10);
         aux1=read_adc();     //ler valor da ADC
         value1=value1+aux1;
      }
   value1 = value1 / i; 

   lm35 = 0.64+0.26*value1;   //y=0.64+0.26*x


// ## TEMP Termopar

   aux2=0;
   for (i=0;i<30;i++)
      {
         set_adc_channel(1);  //Porta a ler da ADC RA1
         delay_ms(10);
         aux2=read_adc();     //ler valor da ADC
         value2=value2+aux2;
      }
   value2 = value2 / i;

   termop = 8.83+0.19*value2+0.0002*(value2*value2);//y=8.83+0.19*x+0.0002*x^2

   //### RESULTADO DA TEMPERATURA ###
   temperatura = lm35 + termop;

}


void main(void)
{

   //## Configurações ##
   
   enable_interrupts(GLOBAL);       //activar interrupts
   enable_interrupts(INT_RDA);      //activar interrupts porta serie
   setup_adc_ports(AN0_AN1_AN3);    //escolher portas ADC   
   setup_adc(ADC_CLOCK_INTERNAL);   //activar o modo da ADC


while(TRUE)
{
read_protocol();
//readtemp();
//########### OUT STRING #############

fprintf(outport,"* %s # %s # %s # %s # %s # %s # %s # %lu\n\r",time, PNS, lat, PEW, longi, speed, alt, temperatura);

}
}


I need stop interrupts somewhere?
I can't put ADC and INTERRUPTS work at same time Confused
Someone can help me where stay error?
filjoa



Joined: 04 May 2008
Posts: 260

View user's profile Send private message

PostPosted: Wed Jun 26, 2013 6:35 pm     Reply with quote

Hi

problem SOLVED, I need stop and start interrupts....

so, now I need compare my received string with checksum.

some one know how I can make it?

best regards
FvM



Joined: 27 Aug 2008
Posts: 2337
Location: Germany

View user's profile Send private message

PostPosted: Wed Jun 26, 2013 11:40 pm     Reply with quote

Quote:
problem SOLVED, I need stop and start interrupts...

Surprizing conclusion. I don't believe that it solves a substantial problem.

Do you know what #int_rda is made for? As used in your code, polling getc() in the readgps functions would
give exactly the same result: Multiple characters received while not waiting in readgps will overflow the
UART and get lost.

To use #int_rda in a reasonable way, you need to implement a receive buffer. Fortunately CCS provides
an example EX_SISR.C that shows how.

Many comments could be added about effective string processing, e.g. parsing for tokens, copying,
decoding numerical values. But as long as your code serves it's purpose, I'll stay with the maxim
of the Prussian king Frederik the Great "Let every man seek heaven in his own fashion".

Best regards,
Frank
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