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

Compiler warning..... [Solved]

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



Joined: 09 Aug 2004
Posts: 97

View user's profile Send private message

Compiler warning..... [Solved]
PostPosted: Mon Jun 24, 2013 7:15 am     Reply with quote

Hi All,

PCH Compiler: v4.121

I have created a function that seems to work just fine, but is generating a compiler warning at compile time. The warning is telling me that my
function is not Void (true), yet it does not return a value (not true). I have several similarly declared functions, and they result in the same
warning.

Here is the warning: Function not void and does not return a value CommTestOK

Here is how the function is defined, and how I'm returning a value.

Code:

int1 CommTestOK(void)
{


   // Here we return the COMM status!
   if (strcmp(Msg1, CMDOK) == 0)
      Return(True);
   else
      Return(False);
}


Am I doing something wrong, or is this a false warning with a function declared as a boolean?

Thanks,
_________________
John Morley


Last edited by John Morley on Tue Jun 25, 2013 9:03 pm; edited 1 time in total
Gabriel



Joined: 03 Aug 2009
Posts: 1067
Location: Panama

View user's profile Send private message

PostPosted: Mon Jun 24, 2013 7:59 am     Reply with quote

Replace:
Code:
int1 CommTestOK(void)


with:
Code:
int1 CommTestOK()


... warning goes away.

G.
_________________
CCS PCM 5.078 & CCS PCH 5.093
Ttelmah



Joined: 11 Mar 2010
Posts: 19537

View user's profile Send private message

PostPosted: Mon Jun 24, 2013 8:07 am     Reply with quote

If you do a basic 'test program' as:
Code:

#include <12F615.h>

#FUSES NOWDT //No Watch Dog Timer
#FUSES INTRC_IO //Internal RC Osc
#FUSES NOPROTECT //Code not protected from reading
#FUSES NOMCLR //Master Clear pin used for I/O
#FUSES NOPUT //No Power Up Timer
#FUSES BROWNOUT //Reset when brownout detected
//Obviously setup to suit your processor to here

#use delay(clock=8000000)

char Msg1[10];
char CMDOK[]="OK";
#include "string.h"

int1 CommTestOK(void)
{
   // Here we return the COMM status!
   if (strcmp(Msg1, CMDOK) == 0)
      Return(True);
   else
      Return(False);
}

void main(void)
{
   int val;
   while(1)
   {
      val=CommTestOK();
      val=!val;
   }
}


It compiles without warning.

I'd suspect you have something like a function prototype, without the void declaration?...

Best Wishes
John Morley



Joined: 09 Aug 2004
Posts: 97

View user's profile Send private message

PostPosted: Mon Jun 24, 2013 8:07 am     Reply with quote

Hi Gabriel,

I should have mentioned that I already tried that, and the warning still persisted!

I also tried a slightly different form for returning the desired value, and the warning still persisted:

Code:

Return True;


What compiler version do you have?
_________________
John Morley
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Mon Jun 24, 2013 8:10 am     Reply with quote

I didn't get a warning. I made a test program (which you should have
posted) and it gives no warning like that. It gives the usual warning
on the while(1) statement, but that's all:
Quote:

CCS PCH C Compiler, Version 4.121, ----- 24-Jun-13 07:06

Executing: "C:\Program Files\PICC\Ccsc.exe" +FH "PCH_Test.c" +DF +LN -T -A +M -Z +Y=9 +EA #__18F4620=TRUE
>>> Warning 203 "PCH_Test.c" Line 28(1,1): Condition always TRUE
Memory usage: ROM=0% RAM=1% - 1%
0 Errors, 1 Warnings.
Loaded C:\Program Files\PICC\Projects\PCH_Test\PCH_Test.cof.
BUILD SUCCEEDED: Mon Jun 24 07:06:45 2013

Test program:
Code:

#include <18F4620.h>
#fuses INTRC_IO,NOWDT
#use delay(clock=4M)

#include <string.h>

int8 CMDOK[4] = "OK\r";

int8 Msg1[20];

int1 CommTestOK(void)
{
   // Here we return the COMM status!
   if (strcmp(Msg1, CMDOK) == 0)
      Return(True);
   else
      Return(False);
}


//======================================
void main(void)
{
int1 result;

result = CommTestOK();

while(1);
}
Ttelmah



Joined: 11 Mar 2010
Posts: 19537

View user's profile Send private message

PostPosted: Mon Jun 24, 2013 8:19 am     Reply with quote

I tried with 4.118, 4.121, and 4.141. None gave the warning.

Best Wishes
Gabriel



Joined: 03 Aug 2009
Posts: 1067
Location: Panama

View user's profile Send private message

PostPosted: Mon Jun 24, 2013 8:22 am     Reply with quote

I had that warning problem last friday while compiling the SHT75 driver found on the library...

i removed the "void" from the functions and the warnings went away...

... compiler issue?

I use 4.135

G
_________________
CCS PCM 5.078 & CCS PCH 5.093
John Morley



Joined: 09 Aug 2004
Posts: 97

View user's profile Send private message

PostPosted: Mon Jun 24, 2013 8:28 am     Reply with quote

Hi TTelmah,

I tried to compile your small test program, and it compiles fine with no warnings. For the most part I don't use function prototypes, I just arrange
my code so that they aren't needed. In this case there is definitely no function prototype for the CommTestOK() function.

Again, this function is working as expected, and overall, the code is working well. I'm just trying to clean up a few things prior to release.....

Thanks!
_________________
John Morley
Ttelmah



Joined: 11 Mar 2010
Posts: 19537

View user's profile Send private message

PostPosted: Mon Jun 24, 2013 9:02 am     Reply with quote

I'd be suspicious of something 'else'. CCS has a habit of reporting errors because of another 'almost error' somewhere else. Perhaps another function 'in front', that is just happening to report here....

Being 'pedantic', the function is not declared as a Boolean.... C, does not 'have' a Boolean construct/type. It is declared as an int1, that you just happen to be using to return the two defines 'TRUE', and 'FALSE', which correspond to the 'Boolean' usage.

I actually wonder if anything is saved by doing this. A whole byte probably has to be returned 'anyway', so it is probably easier/safer just to use the standard 'int'....

One thing I 'dislike' slightly is your use of 'True', rather than 'TRUE'. Normally the C 'standard', is to fully capitalise all 'defines'. Mixing case like this could easily cause things to go wrong, if case significance was enabled.

I'd be 90% suspicious it is actually being caused by some tiny syntax error further up the code, that is not being reported, but is 'revealing itself' this way. One old trick used to be to put CCS code through Lint, and use this to help tidy it up.

Best Wishes
RF_Developer



Joined: 07 Feb 2011
Posts: 839

View user's profile Send private message

PostPosted: Mon Jun 24, 2013 4:20 pm     Reply with quote

Also, "Return" is a statement, not a function. Therefore the correct syntax is:

Code:

return TRUE;

// and not

Return(TRUE);

// or even

Return TRUE;  // This works with CCS C which is case insensitive by default. Other Cs are not and will not think its the same as "return TRUE".

return(TRUE); // Looks like a function, but is just a return of an expression which has brackets around it which evaluates to 1.



Also, while syntactically AND semantically correct in C (it wouldn't be in some other C derived languages such as C#), int1 is the conceptually the wrong return type for a boolean function. It would be more logical to use boolean, though in C boolean is just int. Not even int1 in fact, just int. Int1 being a special, single bit and always unsigned, version of int.

All that said, it may well be just as Ttelmah writes: the real problem is elsewhere and this is just where CCS C finally reports a problem.


Last edited by RF_Developer on Mon Jun 24, 2013 4:28 pm; edited 1 time in total
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Mon Jun 24, 2013 4:27 pm     Reply with quote

K&R says this, in chapter 4:
Quote:

The return statement is the mechanism for returning a value from
the called function to its caller. Any expression can follow return:

return expression;

The expression will be converted to the return type of the function if
necessary. Parentheses are often used around the expression,
but they are optional.

So it's certainly legal. It's a matter of style.
John Morley



Joined: 09 Aug 2004
Posts: 97

View user's profile Send private message

Compiler warning..... [Solved]
PostPosted: Tue Jun 25, 2013 2:43 pm     Reply with quote

Hi All,

I solved the issue I was having. In the subroutine in question, I had an alternate 'Return' statement in the case of a buffer overflow. This Return
did not return an argument as it should have. Some of this code was a cut-n-paste from another effort, and I didn't check it carefully enough....

Problem code:
Code:

if (ArrayIndex1 > 70)
   Return; //Msg1 buffer has overflowed, so exit the subroutine!


Corrected code:
Code:

if (ArrayIndex1 > 70)
   Return(False); //Msg1 buffer has overflowed, so exit the subroutine!


Thanks for the input on this guys! I learned something and I made it to PCM programmers 'boneheaded-post-of-the-day' list Laughing

Thanks,
_________________
John Morley
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