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

Does switch statement has a variable size limit?

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



Joined: 13 Apr 2011
Posts: 417

View user's profile Send private message

Does switch statement has a variable size limit?
PostPosted: Mon May 17, 2021 11:06 am     Reply with quote

I'm trying to create a new subroutine that must select between values of a 32bit unsigned integer but when the case is bigger than 65536 I get an error.

"Constant out of the valid range 2097152 is not less than 65536"

My CCS V5.091 and MPLAB 8.92
Device PIC18F67J50

Example:
Code:
unsigned int8 TestKey(unsigned int32 KeyX)
{
    switch(KeyX)
    {
         case 1: return 8;
         case 4: return 14;
         case 0x800000: return 15;//ERROR HERE
    }
}

_________________
Electric Blue
PCM programmer



Joined: 06 Sep 2003
Posts: 21708

View user's profile Send private message

PostPosted: Mon May 17, 2021 1:10 pm     Reply with quote

CCS vs. 5.103 gives this error:
Quote:
Constant out of the valid range 8388608 is not less than 65536

This implies the case values must be no greater than 0xFFFF.

If I try to use 0x10000, it gives an error.
E_Blue



Joined: 13 Apr 2011
Posts: 417

View user's profile Send private message

PostPosted: Mon May 17, 2021 1:47 pm     Reply with quote

So, I should use an if statement or split the int32 into two int16 and evaluate them in a separate switch if the value is higher than 0xFFFF.
_________________
Electric Blue
asmboy



Joined: 20 Nov 2007
Posts: 2128
Location: albany ny

View user's profile Send private message AIM Address

PostPosted: Mon May 17, 2021 5:50 pm     Reply with quote

Have you looked at the code that a switch statement generates? If you need that many switch branches - the serial code execution cycles alone are gonna crush you in the time domain for numinous arguments values, depending on the order of comparison. if you don't need a full deck of 32 bit compares consider a LUT to a smaller compare space and map your 32 bit code bits to that. But if this is linear collection of 32 bit values WTF ? You really don't care about execution speed or code bloat? Don't you have a better way to do what you want to do using indexed vars ? This feels a like C question more than a PIC one.
E_Blue



Joined: 13 Apr 2011
Posts: 417

View user's profile Send private message

PostPosted: Mon May 17, 2021 7:54 pm     Reply with quote

The branches are not that many, just about 20; but the variable can have 2^24 different values.
Anyway, I solved as mentioned above.
_________________
Electric Blue
Ttelmah



Joined: 11 Mar 2010
Posts: 19605

View user's profile Send private message

PostPosted: Tue May 18, 2021 12:29 am     Reply with quote

That is actually a 'C' limitation.

Historically CCS originally had a limit using an int8, and 256 cases.
ANSI C recommended that systems should support 1023 cases or more,
(from C89), and CCS later expanded the compiler to support int16's for the
case.

However int16, not int32's!.....

A few C's (very few, but MicroSoft in particular), don't have this limitation.
E_Blue



Joined: 13 Apr 2011
Posts: 417

View user's profile Send private message

PostPosted: Tue May 18, 2021 1:18 am     Reply with quote

I don't need 1023+ branches, I need that the switch statement handle a 32 bit case variable and just 20 branches.

Anyway, thanks for the info.
_________________
Electric Blue
Ttelmah



Joined: 11 Mar 2010
Posts: 19605

View user's profile Send private message

PostPosted: Tue May 18, 2021 1:40 am     Reply with quote

The case limit is a limit on the size of what is tested, not just the actual
cases used.

However I have to say that in your 'case', it'd actually probably be much
more efficient to just test for the values yourself (after all something
like 20 cases is a very simple number of tests). Doing a split and then using
two switches on part of the range, just adds complexity to the code, and
will probably be slower and bulkier than just testing.
Consider just something like a macro:
Code:

#define LOOK_FOR(x) if (x==KeyX)

//Then just use:
         LOOK_FOR(1)
            return 8;
         LOOK_FOR(4)
            return 14;
         LOOK_FOR(0x800000)
            return 15;
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