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

Switch statement going to wrong case...
Goto page 1, 2  Next
 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
DonWare



Joined: 18 Jan 2006
Posts: 43

View user's profile Send private message

Switch statement going to wrong case...
PostPosted: Tue May 25, 2010 8:08 am     Reply with quote

Hi, I've been working on code for a PIC18F6527 with no problems. I'm using an int8 in a switch statement and constants numbered 1 thru 6 in the case statements. If I break at the top of the switch, I can see that the int8 = 3 but the code steps to the constant which = 4.

I've tried "clean" and "build all" and "make", deleted all but the C and h files.

Any ideas ? Thanks.
Humberto



Joined: 08 Sep 2003
Posts: 1215
Location: Buenos Aires, La Reina del Plata

View user's profile Send private message

PostPosted: Tue May 25, 2010 8:32 am     Reply with quote

Are you asking regarding C code? What if you post your code in order to understand your point.

Regards,

Humberto
Wayne_



Joined: 10 Oct 2007
Posts: 681

View user's profile Send private message

PostPosted: Tue May 25, 2010 8:33 am     Reply with quote

Thats nice ;) Maybe posting the actual code will help us tell you what is wrong ? And, for this post the .lst segment for your switch statement.

It would be nice if there is enough code so we can compile it.

Also your CCS version number would be useful.
SherpaDoug



Joined: 07 Sep 2003
Posts: 1640
Location: Cape Cod Mass USA

View user's profile Send private message

PostPosted: Tue May 25, 2010 12:05 pm     Reply with quote

Do you have a break statement so when it finishes case #3 it doesn't go on to case #4? That is a common error in switch case statements.
_________________
The search for better is endless. Instead simply find very good and get the job done.
DonWare



Joined: 18 Jan 2006
Posts: 43

View user's profile Send private message

Solved for now
PostPosted: Tue May 25, 2010 4:48 pm     Reply with quote

Yes this was in C and I had break statements. For now, as best I can tell, removing a call to another possibly un-needed routine during the init got rid of this problem. Something was getting clobbered. I simplified the switch statement as much as possible and still had the problem. Not sure what it's about yet but I don't have time to look into it right now.

Thanks for the replies.
Wayne_



Joined: 10 Oct 2007
Posts: 681

View user's profile Send private message

PostPosted: Wed May 26, 2010 1:50 am     Reply with quote

So you are still not going to post it. Do you want us to help ?
DonWare



Joined: 18 Jan 2006
Posts: 43

View user's profile Send private message

PostPosted: Wed May 26, 2010 7:04 am     Reply with quote

For now I'm going to let it sit. Like I said, I may not even need the part of code that seems to be causing the problem.

So no I don't need any further help for now. Thanks.
MikeW



Joined: 15 Sep 2003
Posts: 184
Location: Warrington UK

View user's profile Send private message

PostPosted: Wed May 26, 2010 7:35 am     Reply with quote

Donware,

that's an extremely selfish, and bad attitude.

You ask for help, people try to help, and then you say

"So no I don't need any further help for now, thanks"

I would suggest you dont ask me for any help in the future !!!!

Mike
DonWare



Joined: 18 Jan 2006
Posts: 43

View user's profile Send private message

PostPosted: Wed May 26, 2010 7:42 am     Reply with quote

Geez are you kidding ?

The reason I'm not going further with this is because I'm in a hurry to do other things and this may not turn out to be a problem anyway. So why waste everybody's time ? I'd love to know the answer but I just don't have time right now.

I'm sorry I didn't post extensive code in the first message. I know how frustrating it is to try to help somebody with minimal information. I get that all the time at work here.

That's the only constructive thing I can say.
MikeW



Joined: 15 Sep 2003
Posts: 184
Location: Warrington UK

View user's profile Send private message

PostPosted: Wed May 26, 2010 8:12 am     Reply with quote

I refer you to my previous post


obviously, my standards are different to yours.


Mike
meereck



Joined: 09 Nov 2006
Posts: 173

View user's profile Send private message

PostPosted: Wed May 26, 2010 9:37 am     Reply with quote

// OT START
// I don't think that posting a part of .lst file takes too much time and effort.
// The knowledge of potential compiler bug might be useful for all of us including CCS.
// OT END
Wayne_



Joined: 10 Oct 2007
Posts: 681

View user's profile Send private message

PostPosted: Fri May 28, 2010 2:24 am     Reply with quote

DonWare wrote:
Geez are you kidding ?
I'm sorry I didn't post extensive code in the first message. I know how frustrating it is to try to help somebody with minimal information. I get that all the time at work here.


The problem is you didn't post ANY code!
let alone the compiler version.
SET



Joined: 15 Nov 2005
Posts: 161
Location: Glasgow, UK

View user's profile Send private message Send e-mail Visit poster's website

PostPosted: Fri May 28, 2010 8:55 am     Reply with quote

I used to get problems like this, although I think it was with pretty old versions of the compiler - not seen any issues for years now. Would be good to know if this is still 'lurking' in newer versions too?
Ttelmah



Joined: 11 Mar 2010
Posts: 19539

View user's profile Send private message

PostPosted: Fri May 28, 2010 9:39 am     Reply with quote

I'd refer the original poster to the recent thread about a person having problems with a simple delay statement.
It was because he had 'XINST' selected. This is just about the only current 'code' thing likely to cause really unexpected behaviour.
He showed exactly 'how' to get an answer, posting a nice small compilable program that had the problem.
As it currently stands, the question is a bit like a person learning to drive, posting 'my car won't go in a straight line'. Possible answers range from driving on bumpy/canted surfaces, through simply having the wheel turned, to possible actual mechanical faults.
Generally though I have not seen a switch problem, with literally hundreds of programs, except :
1) Very early V4 compilers - trust these as far as you can spit backwards...
2) Very early CCS compilers - probably ten years or more ago now.
3) Specific things like XINST - which an example would have allowed us to see.
4) Some problems with specific simulators, rather than the compiler.

Best Wishes
DonWare



Joined: 18 Jan 2006
Posts: 43

View user's profile Send private message

Let's try this again.
PostPosted: Fri Jun 04, 2010 8:31 am     Reply with quote

OK I'm having the same kind of problem but in another switch statement.

MPLAB version is 8.3.0.0 CCS compiler version is PCH 3.249

In the routine below, I break at the top of the switch and rpc=9. But it steps to case 1.

Sorry the code format looks like crap below but can be pasted and viewed OK. If there's a better way please let me know rather than attack.

Code----------------

int1 performRPC(int8 rpc){
// Depending on rpc number passed, execute code for that rpc.
int1 flag=false;
// int i;

tx_block=FALSE; // Can be set below by 'set' cmd. # 128

switch (rpc){

case 1: // LCD is ready. Not functional on amulet.
// no action
break;
case 2: // Increase procedure select list 4x
inc_sel_list();
break;
case 3: // Decrease procedure select list 4x
dec_sel_list();
break;
case 5: // Stop sequence (stir and heat)
tx_blk_timer=TX_BLOCK_LOAD; // reset timeout timer.
tx_block=TRUE;
break;
case 6: // Save Manual entries: rpm, time, deg C, switch to new procedure mode.
save_man_entries();
break;
case 7: // Increase displayed sequence 1x
show_next_seq();
break;
case 8: // Decrease displayed sequence 1x
show_prev_seq();
break;

case 9: // Save current sequence entries: rpm, time, deg C
flag=save_procedure(); // check entries and save, flag value has no meaning here
break;

case 0x0A: // Save Config screen entries ?????????????
save_config_entries();
break;

case 0x0B: // "New" screen opening
clear_eeprom_dat(); // set all to 0
entry_error=false;
seq_idx[ENTRY_DATA]=1; // seq = 1 of 1

seq_total[ENTRY_DATA]=1;
seq_update(); // send "Seq 1 of 1" to Amulet
proc_saved=false;
seq_saved=false;
break;
//----------------------------------------------------------------------------------------------
case 0x0E: // Select Procedure 1 from list to run
run_procedure(1); // run first procedure in displayed list
break;
case 0x0F: // Select Procedure 2 from list to run
run_procedure(2); // run second procedure in displayed list
break;
case 0x10: // Select Procedure 3 from list to run
run_procedure(3); // run third procedure in displayed list
break;
case 0x11: // Select Procedure 4 from list to run
run_procedure(4); // run fourth procedure in displayed list
break;
//----------------------------------------------------------------------------------------------

case 0x13: // Select Procedure 1 from list to edit
edit_procedure(1); // edit first procedure in displayed list
break;
case 0x14: // Select Procedure 2 from list to edit
edit_procedure(2); // edit second procedure in displayed list
break;
case 0x15: // Select Procedure 3 from list to edit
edit_procedure(3); // edit third procedure in displayed list
break;
case 0x16: // Select Procedure 4 from list to edit
edit_procedure(4); // edit fourth procedure in displayed list
break;
//----------------------------------------------------------------------------------------------
case 0x17: // Delete Current Sequence
delete_current_seq();
break;

case 0x18: // Delete Current Procedure
delete_current_proc();
break;

case 0x21: // Start button in manual.htm
break;

case 0x80: // block xmit during amulet screen change
tx_blk_timer=TX_BLOCK_LOAD; // reset timeout timer.
tx_block=TRUE;
break;

case 0x81: // Un-block xmit after amulet screen change

// may need to add code based on err_source value.

err_source=0; // clear who opened the pop-up screen
tx_block=FALSE;
pop_up_open=false;
break;

case 0x82: // Send serial # and printer headings to amulet
break;

case 0x84: // "OK" button pressed on Pop-Up screen
break;

case 0x86: // send Manual screen elements for display.
break;

case 0x8A: // send procedure names for display on Amulet (to edit)

send_procedure_list(1); // send first 4 active procedure names to amulet
break;

case 0x8B: // send procedure names for display on Amulet (to run)
queue_string(0x28,&proc_list[0][0]);
queue_string(0x29,&proc_list[1][0]);
queue_string(0x2A,&proc_list[2][0]);
queue_string(0x2B,&proc_list[3][0]);
break;

case 0x8C: // 8C: send status screen elements to be displayed.
// and enable automatic updating until
// RPC 80h is set when exiting status screen
break;
default:

return(false); // command not recognized

break;
}

return(true); // OK, command recognized
}[/code]
Display posts from previous:   
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion All times are GMT - 6 Hours
Goto page 1, 2  Next
Page 1 of 2

 
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