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

Parsing string to function.. what am i doing wrong?

 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
Jody



Joined: 08 Sep 2006
Posts: 182

View user's profile Send private message Send e-mail

Parsing string to function.. what am i doing wrong?
PostPosted: Wed Dec 02, 2015 4:27 pm     Reply with quote

Hello,
Want to parse a string to a function..
The function is in another file and it looks like that that is the problem...
I have include all mine files... anyone a idea??

Main.c:
Code:

#include <main.h>
#include <commands.c>
#include <stdlib.h>
#include <string.h>
#include <stddef.h>


char slave_1[3] = "323";
char slave_2[5] = "green";
char slave_3[3] = "on";

void main()
{

      setup_adc_ports(sAN15);
      setup_timer_4(T4_DISABLED,0,1);
      setup_comparator(NC_NC_NC_NC);// This device COMP currently not supported by the PICWizard
   while(1)
   {
       commands(&slave_1, &slave_2, &slave_3);
   }
}


Commands.c:
Code:
#include <string.h>
#include <stdlib.h>

char    string_rs485[MAXINPUTBUF];



/* The following typedef's should be adjusted for the particular platform.
 * CRC-8     x^8  + x^2 + x + 1
 * prototypes */
int generate_8bit_crc(char* data, int16 length, int pattern)
{
   int   *current_data;
   int   crc_byte;
   int16 byte_counter;
   int   bit_counter;

   current_data = data;
   crc_byte = *current_data++;

   for(byte_counter=0; byte_counter < (length-1); byte_counter++)
   {
      for(bit_counter=0; bit_counter < 8; bit_counter++)
      {
         if(!bit_test(crc_byte,7))
         {
            crc_byte <<= 1;
            bit_test(*current_data, 7 - bit_counter) ?
               bit_set(crc_byte,0) : bit_clear(crc_byte,0);
            continue;
         }
         crc_byte <<= 1;
         bit_test(*current_data, 7 - bit_counter) ?
            bit_set(crc_byte,0) : bit_clear(crc_byte,0);
         crc_byte ^= pattern;
      }
      current_data++;
   }
   for(bit_counter=0; bit_counter < 8; bit_counter++)
   {
      if(!bit_test(crc_byte,7))
      {
         crc_byte <<= 1;
         continue;
      }
      crc_byte <<= 1;
      crc_byte ^= pattern;
   }
   return crc_byte;
}


 
/*
    |*****|**************|********|*****|
    |Addr |   commando   | status | CRC |
    |*****|**************|********|*****|
   | 001 |   groen      |  off   | 034 |
   |*****|**************|********|*****|   */
void commands(char *slave_address, char *slave_commando, char *slave_status)
{
   char space[1], slash_n[2], crc_string[3];
   int16 crc_calculated, lengte;
   strcpy(space, " ");
   strcpy(slash_n, "\n ");
   
   strcat(string_rs485, *slave_address);
   strcat(string_rs485, space);
   strcat(string_rs485, slave_commando);
   strcat(string_rs485, space);
   strcat(string_rs485, slave_status);
   strcat(string_rs485, space);
   crc_calculated = generate_8bit_crc(string_rs485, lengte, 0x107);
   ITOA(crc_calculated, 10, crc_string );
   strcat(string_rs485, crc_calculated);
   strcat(string_rs485, slash_n);
}


Main.h:
Code:

#include <18F87J50.h>
#device adc=16
#device PASS_STRINGS=IN_RAM

#define   MAXINPUTBUF   20

#FUSES NOWDT                    //No Watch Dog Timer
#FUSES WDT128                   //Watch Dog Timer uses 1:128 Postscale
#FUSES NOXINST                  //Extended set extension and Indexed Addressing mode disabled (Legacy mode)

#use delay(clock=20000000)



Regards,
Jody
jeremiah



Joined: 20 Jul 2010
Posts: 1358

View user's profile Send private message

PostPosted: Wed Dec 02, 2015 5:54 pm     Reply with quote

I haven't looked through the rest of your code, but right off the bat there is some C programming 101 stuff:

Code:

char slave_1[3] = "323";
char slave_2[5] = "green";
char slave_3[3] = "on";


The string "323" is 4 characters long and "green" is 6 characters long.

Possible solutions:
Code:

char slave_1[4] = "323";
char slave_2[6] = "green";
char slave_3[3] = "on";


or

Code:

char slave_1[] = "323";
char slave_2[] = "green";
char slave_3[] = "on";
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Wed Dec 02, 2015 5:58 pm     Reply with quote

In addition to that,

The first line below has a bug. A pointer is passed by name, not
by *name. Remove the * on the first line:
Quote:
strcat(string_rs485, *slave_address);
strcat(string_rs485, space);
strcat(string_rs485, slave_commando);
strcat(string_rs485, space);
strcat(string_rs485, slave_status);
strcat(string_rs485, space);


Also, this line is wrong. Pointers to arrays are passed by name, and
not with &name. Remove all the & from the line below:
Quote:
commands(&slave_1, &slave_2, &slave_3);
Jody



Joined: 08 Sep 2006
Posts: 182

View user's profile Send private message Send e-mail

PostPosted: Thu Dec 03, 2015 4:09 am     Reply with quote

Yes!!
That did it...
Now reading it it all make sense.
I was fiddling half a day with it!
Thanks for pointing me in the right direction!!!

Regards,
Jody
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Page 1 of 1

 
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