software en lenguaje c

Iniciado por GAWAIN2010, 26 Abril 2015, 04:28 AM

0 Miembros y 1 Visitante están viendo este tema.

GAWAIN2010

Hola a todos:

Un compañero me envio el codigo fuente de un software hecho en C para revisarlo, verificar su funcionamiento y de ser necesario modificarlo. El caso es que al tratar de compilarlo por el PIC CCS (quen es el mismo utilizado por el creador del software), me salen una serie de errores y quien me envio el programa, me indica que a él no le aparece ningun tipo de error y le corre perfectamente. Debo aclarar que sé muy poco de lenguaje C y su forma de operar ya que me he especializado en Basic.

Por lo anterior les consulto que debo hacer para corregir esto.

Agradezco su ayuda.

Saludos,

GAWAIN

Mod: No escribir en mayúsculas mensajes ni títulos

engel lex

con esa información podría ser desde un software mal instalado, hasta un código mal copiado....

muestra el codigo (si es muy largo usa pastebin) muestra los errores y tendríamos algo para empezar

antes de escribir algo, porfa lee estos 2 temas
10 pasos para plantear una duda informática
FAQ : Como hacer preguntas "inteligentes"
El problema con la sociedad actualmente radica en que todos creen que tienen el derecho de tener una opinión, y que esa opinión sea validada por todos, cuando lo correcto es que todos tengan derecho a una opinión, siempre y cuando esa opinión pueda ser ignorada, cuestionada, e incluso ser sujeta a burla, particularmente cuando no tiene sentido alguno.

GAWAIN2010

#2
Buenas Tardes engel:

Gracias por tu respuesta. Como soy nuevo acá no sé lo que quieres decir con pastebin, sin embargo como el codigo no es muy largo, te lo anexo por aca.

Algunos de los errores que me dan son Error 51 que es la declaracion de todas las variables lo cual no veo logico por cuanto la sintaxis y logica estan bien.

El codigo es el siguiente (y mucho agradezco tu ayuda). El PIC asociado es el 18F2520 con un oscilador de 4 MHz.

//OMAR DAVILA - BLADIMIR VERGARA - JOSE DIAZ
//CONFIGURACION DE PUERTO SERIAL

#use rs232(baud=9600,parity=N,xmit=PIN_C6,rcv=PIN_C7,bits=8)//9600


//DECLARACION DE VARIABLES  
  int ret=500,ret_alrm=400;//200:1min

**********   int ret_env=8000;//RETARDO DE ENVIO 1000=1S

  int f1=0,f2=0,f3=0,f4=0,f5=0,f6=0;//BANDERAS DE ALARMAS
  int16 uptime,retardo1,retardo2;//CONTADORES DE TIEMPO
  int e,n,cap=0,fn,lf=0,lfe,in=0,ie=0,ip=0,inr=0,sms=0,posi=0,hist=0,seg=0,min=0,rep;//OTRAS VARIABLES
  int alrm1=pin_C0,alrm2=pin_C1,alrm3=pin_C2,alrm4=pin_C3,alrm5=pin_C4,alrm6=pin_C5,s1=pin_A4,s2=pin_A5;//PINES DE ENTRADA
  int ca1=0,ca2=0,ca3=0,ca4=0,ca5=0,ca6=0;//CONTADORES DE ALARMA
  int pwr=pin_B0,led_senal=pin_B7,salida1=pin_A0,salida2=pin_A2,alarm_salida1=0,alarm_salida2=0,record=0,alrmH,alrmT;//PINES DE SALIDA
  int const nros=12;//NRO MAXIMO DE CONTACTOS A LEER EN SIM
  int const etqs=7;//NRO MAXIMO DE SMS DE ETIQUETAS A LEER EN SIM
  char c,l;//VARIABLES PARA CARACTER DE ENTRADA Y CODIGO DE SMS ENTRANTE RESPECTIVAMENTE
  char ctrlz=26;//combinacion de teclas "ctrl+z"
  char pos[2];//POSICION DEL SMS ENTTRANTE
  char intentos[2];//INTENTOS DE ENCENDIDO ANTES DE BLOQUEAR LUEGO DE NO DETECTAR PRESENCIA DE MODULO GSM
  char NUM[nros][14];//MATRIX DE PARA ALMACENAR CONTACTOS
  char ETQ[etqs][21]={"_s/nombre", "_a1", "_a2", "_a3", "_a4", "_a5", "_a6"};//MATRIX PARA LAS ETIQUETAS
  char NREM[14];//PARA ALMACENAR TEMPORALMENTE EL NRO DE REMITENTE
  void mensaje_etqX_listcontactos (unsigned int etiq,unsigned int cnd);
  void fcn_int_rda (void);
  void reset(unsigned int x);
  void capturar (void);
  void ext_nros (void);
  void ext_etqs (void);
  void inic_nrem (void);
  void inic_nrem (void);
  void enviar_reporte (unsigned int x);
  void check_sal(void);
  unsigned int ident_nrem (void);

  void leer_nvosms (unsigned int x);
 
  void mensaje_etqX_listcontactos (unsigned int etiq,unsigned int cnd);
  void capturar (void);
  void encender_modem (void);
  void config_modem (void);


//AUTO RESET  
void reset(unsigned int x){
  switch (x){
  case 0:
  reset_cpu();  
  case 1:
  write_eeprom(0x00,'1');reset_cpu();
  }
  }
 


//BUCLE DE ESPERA DE CAPTURA  
void capturar(void)
{

while(cap==0){}

delay_ms(ret_env);

}
 
//FUNCION DE BLOQUEO  
void bloqueo(unsigned int x)
{
switch (x)
{
case 1:
     while(true){output_high (led_senal);delay_ms(150);output_low (led_senal);delay_ms(2000);}
   
case 2:
     while(true){output_high (led_senal);delay_ms(150);output_low (led_senal);delay_ms(150);output_high (led_senal);delay_ms(150);output_low (led_senal);delay_ms(2000);}
     
}
}


//FUNCION DE CAPTURA DINAMICA POR PUERTO SERIAL
void fcn_int_rda(void)
{
 
  c=0x00;
  if (kbhit () )
  {
     c=getc ();
     
     switch (fn)
     {
        case 0: if (c=='+')
           fn=5;
       
        break;
       
       
        case 1: if (c==('K' || 'R'))
        {
           NUM[n-1][0]=NULL;
           lfe=1;
           fn=100;
        }
        if (c==',')
           fn=2;
       
        break;
       
        case 2:
        if (c!=',')NUM[n-1][in++]=c;
        else
        {
           NUM[n-1][in++]=NULL;
           in=0;
           lfe=3;
           fn=100;
        }
        break;
        case 3:
        if (c=='\n')
           lf++;
        if (lf==2)
        {
           lf=0;
           fn=4;
        }
       
        if (c==('K' || 'R'))
        {
           lf=0;
           lfe=1;
           fn=100;
        }
       
        break;
       
        case 4:
        if (c!='\r')ETQ[e-1][ie++]=c;
        else
        {
           ETQ[e-1][ie++]=NULL;
           ie=0;
           lfe=3;
           fn=100;
        }
        break;
       
        case 5:
        if (c==',')fn=6;
       
        break;
        case 6:
        if (c!='\r')pos[ip++]=c;
        else
        {
           pos[ip++]=NULL;
           sms=1;
           fn=99;
        }
        break;
        case 7:
        if (c==',')fn=12;
       
        if (c==('K' || 'R'))
        {
         lfe=1;
         fn=100;
        }
       
        /*
        if (c=='R')
        {
        if(err<4)
        {
           err++;
           lfe=1;
           fn=101;
        }
        }
        */
        break;
       
        case 12: if (c=='2'||c=='4')
           {
           NREM[inr++]=0x22;
           NREM[inr++]='0';
           NREM[inr++]=c;
           fn=8;
           }
        break;
       
        case 8: if (c!=',')
           NREM[inr++]=c;
        else
        {
           NREM[inr++]=NULL;
           fn=9;
        }
        break;
        case 9: if (c=='\n')
           fn=10;
       
        break;
       
        case 10: if (c!='\r')
        {
           l=c;
        }
        else
        {
           lfe=3;
           fn=100;
        }
        break;
        case 11:
        if (c=='+')
        {
           lfe=3;
           fn=100;
        }
       
        if (c=='R')
        {
           lfe=1;
           fn=100;
       
        /*if(err<3)
        {
           err++;
           lfe=1;
           fn=101;
        }
        else{
           err=0;
           lfe=1;
           fn=100;
            }*/
        }
        break;
       
        case 20: if (c=='K')
        {
           lfe=1;
           fn=100;
        }
                 
        break;
        case 100: if (c=='\n')
           lf++;
        if (lf==lfe)
        {
           lf=0;
           lfe=0;
           fn=99;
           cap=1;
        }
       
        break;
       
        case 101: if (c=='\n')
           lf++;
        if (lf==lfe)
        {
           lf=0;
           lfe=0;
           fn=99;
           cap=2;
        }
       
        break;
       
        default: c=0x00;
       
        break;
     }
  }
}

//INTERRUPCION DE CAPTURA DE CARACTERES POR RX DE PUERTO SERIAL
#int_rda
void serial_isr()
{
  fcn_int_rda () ;
}

///////////////////////////////////////////////////

//INTERRUPCION DE TIEMPO REAL
#int_RTCC
void RTCC_isr(void)
{
  retardo1++;
  retardo2++;
  uptime++;
  if (uptime==120){uptime=0; seg++; }
  if (seg==60){min++; seg=0; }
}

//FUNCION PARA EXTRAER NROS DESDE LA SIM
void ext_nros(void)
{
  int x=0;
  n=0;
  while (x==0&&n<nros)
  {
     fn=1;
     n++;
     printf ("AT+CPBR=%u\r\n",n);
     //while (cap==0){}
     //cap=0;
     capturar();
     if (NUM[0][0]== NULL)bloqueo(2);
     if (NUM[n-1][0]== NULL)
     {
        n--;
        x=1;
     }
     delay_ms (ret);
  }
}

//FUNCION PARA EXTRAER SMS DE ETIQUETAS DESDE LA SIM
void ext_etqs(void)
{
  int x=0;
  e=0;
  while (x==0 && e<etqs)
  {
     fn=3;
     e++;
     printf ("AT+CMGR=%u\r\n",e);
     capturar();
     if (ETQ[e-1][0]=='_')
     {
        if(e>1)e--;
        x=1;
     }
     delay_ms (ret);
  }alrmH=e-1;alrmT=etqs-1;
}


//FUNCION PARA LIMPIAR VECTOR DE ALMACENAMIENTO DE NRO DE REMITENTE
void inic_nrem(void)
{
  for (int i=0; i<=13; i++)
  {

     NREM[i]=0x00;
  }
  inr=0x00;
}
void inic_pos(void)
{
  pos[0]=0;
  pos[1]=0;
  ip=0;
  posi=0;
}

//FUNCION PARA ENVIO DE SMS DE REPORTES
void enviar_reporte(unsigned int x)
{
 
  printf ("AT+CNMI=0\r\n");
  delay_ms (ret);

  if (x==0)
  {
     for (int M=0; M<n; M++)
     {
     
        printf ("AT+CMGS=%s\r\n",NUM[M]);
        delay_ms (ret);
        printf ("SCEMA Ex MERIDA DVD\r\n");
        printf ("\r\nESTACION: %s\r\n",ETQ[0]);
        printf ("Alarmas: %u/%u\r\nContactos: %u/%u\r\n",alrmH,alrmT,n,nros);
        printf ("\r\nCOMANDOS ACEPTADOS:\r\nI: Info\r\nR: Reporte\r\n1: PulsoSalida1\r\n2: PulsoSalida2%c\r\n",ctrlz);
        //printf ("%c\r\n",ctrlz);

        fn=11;
        capturar();
        delay_ms (ret);
     }
  }

  if (x==3)
  {    
 
        printf ("AT+CMGS=%s\r\n",NREM);
        delay_ms (ret);
        printf ("SCEMA Ex MERIDA DVD\r\n");
        printf ("\r\nESTACION: %s\r\n",ETQ[0]);
        printf ("Alarmas: %u/%u\r\nContactos: %u/%u\r\n",alrmH,alrmT,n,nros);
        printf ("\r\nCOMANDOS ACEPTADOS:\r\nI: Info\r\nR: Reporte\r\n1: PulsoSalida1\r\n2: PulsoSalida2%c\r\n",ctrlz);
        //printf ("%c\r\n",ctrlz);

        fn=11;
        capturar();
        delay_ms (ret);
  }


  if (f1==0&&f2==0&&f3==0&&f4==0&&f5==0&&f6==0)
  {
     
     if (x==1)
     {
     
        printf ("AT+CMGS=%s\r\n",NREM);
        delay_ms (ret);
        printf ("Reporte General:\r\n\r\nTOTAL_ALARMAS=0%c\r\n",ctrlz);

        fn=11;
        capturar();
        delay_ms (ret);
     }
     if (x==2)
     {
        for (int M=0; M<n; M++)
        {
       
           printf ("AT+CMGS=%s\r\n",NUM[M]);
           delay_ms (ret);
           printf ("Reporte General:\r\n\r\nTOTAL_ALARMAS=0%c\r\n",ctrlz);

           fn=11;

           capturar();

 
           delay_ms (ret);
        }
     }
  }
 
  else
  {
     if (x==1)
     {
     
           printf ("AT+CMGS=%s\r\n",NREM);
           delay_ms (ret);
           printf ("Reporte General:\r\n\r\n");
           printf ("%s=%u\r\n%s=%u\r\n%s=%u\r\n",ETQ[1],f1,ETQ[2],f2,ETQ[3],f3);
           printf ("%s=%u\r\n%s=%u\r\n%s=%u%c\r\n",ETQ[4],f4,ETQ[5],f5,ETQ[6],f6,ctrlz);
           //printf ("%c\r\n",ctrlz);

           fn=11;
           capturar();


           delay_ms (ret);
     }
     if (x==2)
     {
        for (int M=0; M<n; M++)
        {
           printf ("AT+CMGS=%s\r\n",NUM[M]);
           delay_ms (ret);
           printf ("Reporte General:\r\n\r\n");            
           printf ("%s=%u\r\n%s=%u\r\n%s=%u\r\n",ETQ[1],f1,ETQ[2],f2,ETQ[3],f3);
           printf ("%s=%u\r\n%s=%u\r\n%s=%u%c\r\n",ETQ[4],f4,ETQ[5],f5,ETQ[6],f6,ctrlz);
           //printf ("%c\r\n",ctrlz);
           
           fn=11;
       
           capturar();

           delay_ms (ret);
        }
     }
  }

  delay_ms (ret);

 
}


//FUNCION PARA IDENTIFICAR REMITENTE
unsigned int ident_nrem(void)
{
  int cmp,res=0,k=0,j=0;
  while (res==0)
  {
     if (NREM[k]==NUM[j][k])
     {
        if (k==12)
        {
           cmp=1; res=1;
        }
        else k++;
     }
     else
     {
        if (j==n)
        {
           cmp=0; res=1;
        }
        else
        {
           k=0;
           j++;
        }
     }
  }return (cmp);
}


//FUNCION PARA CHEQUEAR EL ESTADO DE LAS SALIDAS
void check_sal(void)
  {
        if (alarm_salida1==1&&retardo1>TE_SALIDA1)
     {
        output_low (salida1);
        alarm_salida1=0;
        if(record==0&&alarm_salida2==0)
           disable_interrupts (int_RTCC);
     }
     
     
     if (alarm_salida2==1&&retardo2>TE_SALIDA2)
     {
        output_low (salida2);
        alarm_salida2=0;
        if(record==0&&alarm_salida1==0)
           disable_interrupts (int_RTCC);
     }

  }


//FUNCION PARA PROCESAR LOS SMS ENTRANTES SEGUN LA VALIDEZ DEL REMITENTE
void leer_nvosms (unsigned int x)
  {

 
  delay_ms (ret);
  fn=7;
  printf ("AT+CMGR=%u\r\n",x);


  capturar();
  delay_ms (ret);
 
  if (ident_nrem () ==1)
  {
     switch (l)
     {

        case 0x49:
        enviar_reporte (3);
       
        break;

        case 0x52:
        enviar_reporte (1);
       
        break;
       
        case 0x31:
        if(alarm_salida1==0)
        {
        setup_timer_0 (RTCC_INTERNAL|RTCC_DIV_32|RTCC_8_bit);
        enable_interrupts (int_RTCC);
        alarm_salida1=1;
        retardo1=0;
        output_high (salida1);
       
        for (int M=0; M<n; M++)
        {
         
           printf ("AT+CMGS=%s\r\n",NUM[M]);
           delay_ms (500);
           printf ("Pulso SALIDA1 activado por:\r\n%s%c\r\n",NREM,ctrlz);
           //printf ("%c\r\n",ctrlz);
           
           fn=11;
           capturar();
           delay_ms (ret);  
           check_sal();
           
        }
        }
        break;
       
        case 0x32:
        if(alarm_salida2==0)
        {
        setup_timer_0 (RTCC_INTERNAL|RTCC_DIV_32|RTCC_8_bit);
        enable_interrupts (int_RTCC);
        alarm_salida2=1;
        retardo2=0;
        output_high (salida2);
        for (int M=0; M<n; M++)
        {
           printf ("AT+CMGS=%s\r\n",NUM[M]);
           delay_ms (500);
           printf ("Pulso SALIDA2 activado por:\r\n%s%c\r\n",NREM,ctrlz);
           //printf ("%c\r\n",ctrlz);
           
           fn=11;
           capturar();
           delay_ms (ret);
           check_sal();
       
        }
        }
        break;
       
        default:
        break;
     }
  }
  l=NULL;
  inic_nrem ();
  delay_ms (ret);
  }


//REPORTE INDIVIDUAL DE ACTIVACION O DESACTIVACION DE ENTRADA DE ALARMA A TODOS LOS CONTACTOS
void mensaje_etqX_listcontactos(unsigned int etiq,unsigned int cnd)
{
  if (read_eeprom(0x00)!='1')//VERIFICO QUE NO VENGA DE UN AUTO RESET
  {
  printf ("AT+CNMI=0\r\n");
  delay_ms (ret);

  for (int M=0; M<n; M++)
  {
     printf ("AT+CMGS=%s\r\n",NUM[M]);
     delay_ms (ret);
     printf ("%s",ETQ[etiq]);
     if (cnd==1){printf ("=1"); }
     if (cnd==0){printf ("=0"); }
     printf ("%c\r\n",ctrlz);
     
     fn=11;
     capturar();
     delay_ms (ret);
  }
 
  fn=0;
  delay_ms (5000);
  printf ("AT+CNMI=2\r\n");
  }
}

//FUNCION PARA ENCENDER MODULO
void encender_modem(void)
{
  output_low (pwr) ;
  delay_ms (1000) ;
  output_high (pwr) ;
  delay_ms (2000) ;
  output_low (pwr) ;
  delay_ms (8000) ;
  int s=0;
  fn=20;
  printf ("AT\r\n");
  while (cap==0)
     {output_high (led_senal);
     delay_ms(100);
     s++;
     if(s==50){bloqueo(1);}
     }
  cap=0;
  //write_eeprom(0x01,NULL);
  output_low (led_senal) ;
}


//COMANDO BASICOS DE CONFIGURACION
void config_modem(void)
{
  printf ("AT+CMGF=1\r\n");
  delay_ms (ret);
  printf ("AT+CNMI=0\r\n");
  delay_ms (ret);
  printf ("AT+CSMP=17,167,0,1\r\n");
  delay_ms (ret);
  printf ("ATE0\r\n");
  delay_ms (ret);
}

//FUNCION PRINCIPAL
void main(void)
{
  enable_interrupts (int_RDA);
  enable_interrupts (GLOBAL);
 

  encender_modem ();
  config_modem ();
  ext_nros ();
  delay_ms (500);
  ext_etqs ();
  delay_ms (500);
  for(int p=e+1;p<=15;p++)
  {
  printf ("AT+CMGD=%u\r\n",p);//PARA BORRAR LOS POSIBLES MENSAJES PRESENTES DE LA POSICION 8 EN ADELANTE
  delay_ms (ret);
  }
 
  if (read_eeprom(0x00)!='1')enviar_reporte (0);//ASI VERIFICO SI VENGO DE UN AUTO RESETEO
 

  fn=0;
  delay_ms(5000);
  printf ("AT+CNMI=2\r\n");//ACTIVAR EL AVISO DE NVOS SMS ENTRANTES

  while (TRUE)
  {
     check_sal();//VERIFICO ESTADO DE SALIDAS      
     output_toggle (led_senal);//LED DE SEÑAL QUE PARPADEA INDICANDO ESTADO DEL SMC
     delay_ms (300);

     if (sms==1)//VERIFICO SI HAY NUEVOS SMS DE ENTRADA
     {
        printf ("AT+CNMI=0\r\n");
        posi=atoi (pos);
        if (posi==e+1){leer_nvosms (posi);delay_ms (5000);printf ("AT+CMGD=%u\r\n",posi);}
        if (posi>e+1){for(int q=e+1;q<=posi;q++){leer_nvosms (q);delay_ms (5000);printf ("AT+CMGD=%u\r\n",q);}}
        inic_pos (); sms=0;fn=0;  delay_ms (5000);printf ("AT+CNMI=2\r\n");}


        if (input (alrm1)==0&&f1==0)//ACTIVACION DE ALARMA 1
        {  
           ca1++;//RETARDO PARA EVITAR FALSAS ALARMAS
              if(ca1==ret_alrm)
              {
              ca1=0;
              f1=1;
              mensaje_etqX_listcontactos (1,1);//MANDAR A ENVIAR ACTIVACION DE LA ETIQUETA 1
              }
        }

        if ((input (alrm1)==1&&f1==0)||(input (alrm1)==0&&f1==1))ca1=0;//DESACTIVACION DE ALARMA SIN CUMPLIRSE EL TIEMPO DE RETARDO

        if (input (alrm2)==0&&f2==0)
        {  
           ca2++;
              if(ca2==ret_alrm)
              {
              ca2=0;
              f2=1;
              mensaje_etqX_listcontactos (2,1);
              }
        }
       
        if ((input (alrm2)==1&&f2==0)||(input (alrm2)==0&&f2==1))ca2=0;
       
        if (input (alrm3)==0&&f3==0)
        {  
           ca3++;
              if(ca3==ret_alrm)
              {
              ca3=0;
              f3=1;
              mensaje_etqX_listcontactos (3,1);
              }
        }

        if ((input (alrm3)==1&&f3==0)||(input (alrm3)==0&&f3==1))ca3=0;

        if (input (alrm4)==0&&f4==0)
        {  
           ca4++;
              if(ca4==ret_alrm)
              {
              ca4=0;
              f4=1;
              mensaje_etqX_listcontactos (4,1);
              }
        }
     
        if ((input (alrm4)==1&&f4==0)||(input (alrm4)==0&&f4==1))ca4=0;
     
        if (input (alrm5)==0&&f5==0)
        {  
           ca5++;
              if(ca5==ret_alrm)
              {
              ca5=0;
              f5=1;
              mensaje_etqX_listcontactos (5,1);
              }
        }

        if ((input (alrm5)==1&&f5==0)||(input (alrm5)==0&&f5==1))ca5=0;

        if (input (alrm6)==0&&f6==0)
        {  
           ca6++;
              if(ca6==ret_alrm)
              {
              ca6=0;
              f6=1;
              mensaje_etqX_listcontactos (6,1);
              }
        }


     
        if ((input (alrm6)==1&&f6==0)||(input (alrm6)==0&&f6==1))ca6=0;




//////////////////////////////////////////////////////////////////////////////////





     if (f1==1||f2==1||f3==1||f4==1||f5==1||f6==1)//PARA INDICAR LA ACTIVACION DE CUALQUIER ALARMA PARA EL ENVIO DE REPORTES
        hist=1;


////////////////////////////////////////////////////////DESACTIVACION DE ALARMAS


     if (input (alrm1)==1&&f1==1)//
     {  
           ca1++;
              if(ca1==ret_alrm)
              {
              ca1=0;
              f1=0;
              mensaje_etqX_listcontactos (1,0);//PARA ENVIAR AVISO DE DESACTIVACION DE ALARMA 1
              }
     }
   
     if (input (alrm2)==1&&f2==1)
     {  
           ca2++;
              if(ca2==ret_alrm)
              {
              ca2=0;
              f2=0;
              mensaje_etqX_listcontactos (2,0);
              }
     }

     if (input (alrm3)==1&&f3==1)
     {  
           ca3++;
              if(ca3==ret_alrm)
              {
              ca3=0;
              f3=0;
              mensaje_etqX_listcontactos (3,0);
              }
     }

     if (input (alrm4)==1&&f4==1)
     {  
           ca4++;
              if(ca4==ret_alrm)
              {
              ca4=0;
              f4=0;
              mensaje_etqX_listcontactos (4,0);
              }
     }

     if (input (alrm5)==1&&f5==1)
     {  
           ca5++;
              if(ca5==ret_alrm)
              {
              ca5=0;
              f5=0;
              mensaje_etqX_listcontactos (5,0);
              }
     }
   
     if (input (alrm6)==1&&f6==1)
     {  
           ca6++;
              if(ca6==ret_alrm)
              {
              ca6=0;
              f6=0;
              mensaje_etqX_listcontactos (6,0);
              }
     }



///////////////////ENVIO DE REPORTES AUTOMATICOS
     if ( (input (s1)==0||input (s2)==0) && (f1==1||f2==1||f3==1||f4==1||f5==1||f6==1))
     {
        setup_timer_0 (RTCC_INTERNAL|RTCC_DIV_32|RTCC_8_bit);
        enable_interrupts (int_RTCC);
       
        if (input (s1)==0&&input (s2)==1) rep=10;        
        if (input (s1)==1&&input (s2)==0) rep=20;
        if (input (s1)==0&&input (s2)==0) rep=30;
           record=1;
        if (min>=rep&&seg==0){enviar_reporte (2); seg=0; min=0;fn=0; delay_ms(5000); printf ("AT+CNMI=2\r\n");}
     }


     if (f1==0&&f2==0&&f3==0&&f4==0&&f5==0&&f6==0&&hist==1)
     {
     enviar_reporte (2);
     hist=0;
     fn=0;
     delay_ms(5000);
     printf ("AT+CNMI=2\r\n");
     }
      if ( (input (s1)==1&&input (s2)==1)|| (f1==0&&f2==0&&f3==0&&f4==0&&f5==0&&f6==0))
     {
     record=0;
     uptime=0;seg=0; min=0;
     if(alarm_salida1==0&&alarm_salida2==0)
        disable_interrupts (int_RTCC);

     }
 
///////////


  if (read_eeprom(0x00)=='1')
  {
  enviar_reporte (2);fn=0;delay_ms(5000);printf ("AT+CNMI=2\r\n");write_eeprom(0x00,NULL);
  }
  }
}



Mod: Los codigos deben ir en etiquetas GeSHi

engel lex

coloca los errores exactamente como los da el compilador...

error de la linea 51
reset_cpu();

no tienes tal función en el código...

un código de 1000 lineas se asume largo XD

sobre pastebin... esto es pastebin.com
El problema con la sociedad actualmente radica en que todos creen que tienen el derecho de tener una opinión, y que esa opinión sea validada por todos, cuando lo correcto es que todos tengan derecho a una opinión, siempre y cuando esa opinión pueda ser ignorada, cuestionada, e incluso ser sujeta a burla, particularmente cuando no tiene sentido alguno.

T. Collins

#4
Quita los nombres del código  :-\

GAWAIN2010

Buenas tardes nuevamente:

Los errores que aparecen al intentar compilar son los siguientes:

***Error 51 "ALARMA GSM.c" Line 29 (4,7): A numeric expression must appear here

***Error 51 "ALARMA GSM.c" Line 31 (14,17): A numeric expression must appear here

***Error 51 "ALARMA GSM.c" Line 33 (4,7): A numeric expression must appear here

Este error se repite y observo que espara toda la declaracion de variables.

Tambien aparece una vez:

***Error 76 "ALARMA GSM.c" Line 46 (77,78): A numeric expression must appear here

Otro error que se repite es:

***Error 12 "ALARMA GSM.c" Line 70 (12,13): A numeric expression must appear here

Nuevamente aprecio su ayuda.

Saludos,

GAWAIN

engel lex

tu codigo se llama "ALARMA GSM.c"?

porque hay un montón de funciones declaradas que no aparecen en el código
El problema con la sociedad actualmente radica en que todos creen que tienen el derecho de tener una opinión, y que esa opinión sea validada por todos, cuando lo correcto es que todos tengan derecho a una opinión, siempre y cuando esa opinión pueda ser ignorada, cuestionada, e incluso ser sujeta a burla, particularmente cuando no tiene sentido alguno.

GAWAIN2010

Si, ese fue el nombre que coloque al iniciar con el PIC WIZARD.

Debo aclararte que el procedimiento que segui fue el siguiente (lo coloco porque recuerda que apenas estoy comenzando):

Arranque el CCS y oprimi el PIC WIZARD, le coloque el nombre que me pedia como ALARMA GSM y cuando coloco el encabezado en la pagina, abajo coloque el codigo del programa que me hicieron llegar.

Aprecio tu ayuda.

Saludos,

GAWAIN

engel lex

corrijo... la función si está definida...

revisando el código bien veo variables no definidas como n en la linea 306, me imagino que por eso es...
El problema con la sociedad actualmente radica en que todos creen que tienen el derecho de tener una opinión, y que esa opinión sea validada por todos, cuando lo correcto es que todos tengan derecho a una opinión, siempre y cuando esa opinión pueda ser ignorada, cuestionada, e incluso ser sujeta a burla, particularmente cuando no tiene sentido alguno.

SrCooper

#9
Cita de: engel lex en 27 Abril 2015, 04:19 AM
revisando el código bien veo variables no definidas como n en la linea 306, me imagino que por eso es...

La variable n está definida en la linea 14. Además, la función inic_nrem(void) está definida dos veces en la línea 34. No se me ocurre que más puede ser, habría que revisarlo cuidadosamente para encontrar los errores.

De todas maneras creo que la mejor manera de detectar un error sería probar a compilarlo con otro compilador (el gcc por ejemplo) y comparar el mensaje de error con el del CCS.

Un saludo

PD: Por cierto, no utilices void main() por favor. Utiliza int main() en su lugar.