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

Pointer types do not match

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



Joined: 24 Sep 2006
Posts: 262

View user's profile Send private message AIM Address

Pointer types do not match
PostPosted: Tue Nov 22, 2016 3:24 pm     Reply with quote

A program that worked in 2013 now gives "Pointer types do not match" warnings every occurrence of:
Code:
send_str(buff);

I have edited the program to the relevant parts as below:
CCS PCM C Compiler, Version 5.055
Code:
/* Pre-processor directives */
 #include <16F884.H>
 #include <math.h>
 #fuses INTRC_IO, NOWDT, PUT, NOPROTECT, BROWNOUT, MCLR
 #use delay (clock=1000000)
 #use I2C (master, SCL=PIN_C3, SDA=PIN_C4)
 #byte portc = getenv("SFR:PORTC")
 

// define I2C address
#define LCD_WRT_ADDR 0X4E               // LCD display
#define buff_size 22                    // characters per line plus one
   
// Function prototypes
    void clear_LCD (void);                      // Clear LCD
    void text_position (int line, int column);  // set start for next text
    void set_font (char size);                  // set font size
    void send_str(char buff[buff_size]);        // Send string to LCD
       
// The main function
void main(void)
 {
// setup ports
  set_tris_c (0x00);                 // all outputs
// declare variables
  char buff[buff_size];

// Start the alphanumeric display sequence
  clear_LCD();                          // clear the LCD
  sprintf(buff, "Graphics Demo");       // place text string in buffer
  send_str(buff);                       // display text array
  delay_ms(2000);                       // for 2 seconds
 
  text_position(0,1);                   // start second line
  set_font(10);                         // change text to size 10
  sprintf(buff, "123456789012345678901"); // place text string in buffer
  send_str(buff);                       // display text array
  delay_ms(2000);                       // for 2 seconds
  text_position(0,3);                   // start of 4th line 
  sprintf(buff, "disp floating point"); // place text string in buffer
  send_str(buff);                       // display text array
       
}                        // end of main function

// Functions
// Clear Display
void clear_LCD (void)
   {
   I2C_START ();                // start I2C
   I2C_WRITE (LCD_WRT_ADDR);    // addr of LCD
   I2C_WRITE ('C');             // C CL to clear display
   I2C_WRITE ('L');             // L
   I2C_STOP ();                 // stop I2C
   }
// set position of next text
void text_position(int line, int column)
   {
   I2C_START ();                // start I2C
   I2C_WRITE (LCD_WRT_ADDR);    // addr of LCD
   I2C_WRITE ('T');            // T, TP set text position
   I2C_WRITE ('P');            // P
   I2C_WRITE (line);            // line position
   I2C_WRITE (column);          // column position
   I2C_STOP ();                 // stop I2C
   }
// Set Font Size
void set_font (char size)
   {
   I2C_START ();                // start I2C
   I2C_WRITE (LCD_WRT_ADDR);    // addr of LCD
   I2C_WRITE ('S');
   I2C_WRITE ('F');
   I2C_WRITE (size);
   I2C_STOP ();                 // stop I2C
   }
// send string to LCD
void send_str(char buff[buff_size])
   {
   int i;
   I2C_START ();                // start I2C
   I2C_WRITE (LCD_WRT_ADDR);    // addr of LCD
   I2C_WRITE('T');              // send TT for text coming
   I2C_WRITE('T');
    for (i=0; i<buff_size; i++)
   {
   I2C_WRITE(buff[i]);          // start with a Z
   }
   I2C_WRITE(0);
   I2C_STOP ();                 // stop I2C   
   }

// end

The program works but no longer displays "Graphics Demo", it displays the rest (which for the full program are various graphics). This may be another issue from using a different PIC. The original PIC works fine.
My concern is what the mis-matched pointer types means.
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Tue Nov 22, 2016 6:18 pm     Reply with quote

I was able to remove the warning by changing the function prototype
to just a simple pointer declaration as shown below in bold:
Quote:

void send_str(char *buff); // Send string to LCD

void send_str(char *buff)
{
printf("%s", buff);
}

Also you didn't show the send_str() function so I made one, and I added
a #use rs232() statement for the printf.
Ttelmah



Joined: 11 Mar 2010
Posts: 19605

View user's profile Send private message

PostPosted: Wed Nov 23, 2016 2:13 am     Reply with quote

It's worth perhaps expanding a little.

This was a change done about ten versions ago in the compiler. Prior to this, if the pointer types did not match, there was no complaint. Now it moans.
Quite sensible, since it makes you aware that the sizes of the objects involved may not be the same. However it is a little 'dumb' (so doesn't realise that - for instance, a 'char', and an 'int8' are the same size on the PIC16/18). On the first few versions, there was also not an exception for the 'void *' type (which most compilers allow you to use as a 'get out of jail free' card for passing different size pointers). The latest compilers do now have this exception.

So (for instance), imagine you have a function that wants to handle data as int8, but want to give it data from a variety of other types.
So:
Code:

//declare a function to fill a variable with zeros, handled by a void pointer
void test(void * ptr, int8 size)
{
   do //fill the variable with zeros
   {
      *(int8 *)ptr++=0; //now make the pointer the size you want
   } while (--size); //for the number of bytes involved
}

//Then you can call like:
   int16 fred;
   int32 dick;
   test(fred, sizeof(fred));
   test(dick, sizeof(dick));

Here the same function, accepts a pointer to an int16, and an int32, without complaint, by using the 'void *' type, and then casting the pointer to the type required inside the function.

If you want the 'older' behaviour, you can simply suppress this warning. However better by far to make sure that types are the same, or are 'flexible' as shown.

Smile

What is interesting in your problem is that the compiler is treating char[] as a different type to char *. These are both totally equivalent. It is just the tester is looking for one, and not matching the other.....

However It may be complaining because you are trying to give it a size. In C, when you pass a pointer to a function it does not carry the object size with it (hence my use of 'sizeof'). You are then trying to give this pointer a size limit in the function. This is generally not supported in C. C++, and some of the derivative languages (particularly on processors that support hardware bounds checking), do support the target function array having a size, but C as standard does not.
rovtech



Joined: 24 Sep 2006
Posts: 262

View user's profile Send private message AIM Address

PostPosted: Wed Nov 23, 2016 11:04 am     Reply with quote

Thanks PCM Programmer
my send_str function should be shown near the end of the functions.
I tried in every occurrence
Code:
void send_str(char *buff[buff_size]);
send_str(*buff);

It gets rid of the compile warnings but I get garbage unless I change the sprintf as well in every occurrence as below
Code:
sprint(*buff,"xxxxx");
send_str(*buff);

even with this the first display is missing "Demo" and shows "Graphics" only.
So it looks like the compiler is getting very confused with pointers as am I.
The original program without the * works well, it just gives the warnings.
Thanks Ttelmah I am still trying to understand what is happening. I thought the compiler recognized an array and took care of the pointers.
I cannot see where I am using different types. I am using a fixed length array, and doesn't sprintf take care of the null termination?
jeremiah



Joined: 20 Jul 2010
Posts: 1362

View user's profile Send private message

PostPosted: Wed Nov 23, 2016 11:18 am     Reply with quote

rovtech wrote:
Thanks PCM Programmer
my send_str function should be shown near the end of the functions.
I tried in every occurrence
Code:
void send_str(char *buff[buff_size]);
send_str(*buff);

It gets rid of the compile warnings but I get garbage unless I change the sprintf as well in every occurrence as below
Code:
sprint(*buff,"xxxxx");
send_str(*buff);



That wasn't the suggestion. The suggestion was:
Code:

void send_str(char *buff);
send_str(buff);
rovtech



Joined: 24 Sep 2006
Posts: 262

View user's profile Send private message AIM Address

PostPosted: Wed Nov 23, 2016 12:23 pm     Reply with quote

Yes that works and makes a lot more sense. Thanks.
Ttelmah



Joined: 11 Mar 2010
Posts: 19605

View user's profile Send private message

PostPosted: Wed Nov 23, 2016 3:06 pm     Reply with quote

It's also work perfectly well as:

Code:

void send_str(char buff[])



A I have already said, the problem is coming because you are trying to say that the pointer passed to the function, has a 'size' associated with it. It doesn't. It is just a pointer. A pointer passed to a function has no concept of the size of the object being pointed 'to', and the compiler is complaining because you are trying to associate a size with it.

Some later compiler (C99 and later), support the declaration of a size as:

Code:

void send_str(char buff[static size_val])



but CCS does not support this.
rovtech



Joined: 24 Sep 2006
Posts: 262

View user's profile Send private message AIM Address

PostPosted: Thu Nov 24, 2016 12:37 pm     Reply with quote

Thanks everyone. I now understand and everything works without warnings.
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