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

Loop problem

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



Joined: 24 Mar 2011
Posts: 2
Location: Newport, RI

View user's profile Send private message

Loop problem
PostPosted: Thu Mar 24, 2011 8:33 am     Reply with quote

I have a PIC18F6585 in use for many things. With the following code, the read works fine. If I try to make it a for loop (in comments), it doesn't work. What is up?

Code:
#INT_TIMER1
void adc_interrupt (void) //setup interrupt
{
 int16 i;
 
 i = 15;
 adc_value = 0;
 output_low(ADC_convert);             //ADC track and hold on falling edge
 
while(input(ADC_busy)){}               //wait for conversion complete
 output_high(ADC_convert);
 
/*
 for(i=15;i>=0;i--){
    output_high(ADC_clock);
    output_low(ADC_clock);
    if(input(ADC_data))
       bit_set(adc_value,i);
    }      
*/

    output_high(ADC_clock);
    output_low(ADC_clock);
      
    if(input(ADC_data))
        bit_set(adc_value,15);
    else
        bit_clear(adc_value,15);   
    
    output_high(ADC_clock);
    output_low(ADC_clock);
    if(input(ADC_data))
       bit_set(adc_value,14);
    else
        bit_clear(adc_value,14);   
    
    output_high(ADC_clock);
    output_low(ADC_clock);
    if(input(ADC_data))
       bit_set(adc_value,13);
    else
        bit_clear(adc_value,13);
       
    output_high(ADC_clock);
    output_low(ADC_clock);
    if(input(ADC_data))
       bit_set(adc_value,12);
    else
        bit_clear(adc_value,12);            
    
    output_high(ADC_clock);
    output_low(ADC_clock);
    if(input(ADC_data))
       bit_set(adc_value,11);
    else
        bit_clear(adc_value,11);

    output_high(ADC_clock);
    output_low(ADC_clock);
    if(input(ADC_data))
       bit_set(adc_value,10);
    else
        bit_clear(adc_value,10);

    output_high(ADC_clock);
    output_low(ADC_clock);
    if(input(ADC_data))
       bit_set(adc_value,9);
    else
        bit_clear(adc_value,9);
       
    output_high(ADC_clock);
    output_low(ADC_clock);
    if(input(ADC_data))
       bit_set(adc_value,8);
    else
        bit_clear(adc_value,8);                         

    output_high(ADC_clock);
    output_low(ADC_clock);
    if(input(ADC_data))
       bit_set(adc_value,7);
    else
        bit_clear(adc_value,7);

    output_high(ADC_clock);
    output_low(ADC_clock);
    if(input(ADC_data))
       bit_set(adc_value,6);
    else
        bit_clear(adc_value,6);

    output_high(ADC_clock);
    output_low(ADC_clock);
    if(input(ADC_data))
       bit_set(adc_value,5);
    else
        bit_clear(adc_value,5);                       

    output_high(ADC_clock);
    output_low(ADC_clock);
    if(input(ADC_data))
       bit_set(adc_value,4);
    else
        bit_clear(adc_value,4);

    output_high(ADC_clock);
    output_low(ADC_clock);
    if(input(ADC_data))
       bit_set(adc_value,3);
    else
        bit_clear(adc_value,3);
       
    output_high(ADC_clock);
    output_low(ADC_clock);
    if(input(ADC_data))
       bit_set(adc_value,2);
    else
        bit_clear(adc_value,2);                       

    output_high(ADC_clock);
    output_low(ADC_clock);
    if(input(ADC_data))
       bit_set(adc_value,1);
    else
        bit_clear(adc_value,1);
       
    output_high(ADC_clock);
    output_low(ADC_clock);
    if(input(ADC_data))
       bit_set(adc_value,0);
    else
        bit_clear(adc_value,0);               
}
newguy



Joined: 24 Jun 2004
Posts: 1911

View user's profile Send private message

PostPosted: Thu Mar 24, 2011 9:11 am     Reply with quote

Change

Code:
int16 i;


to

Code:
signed int16 i;


and it will work. int16's are unsigned by default, so your loop's test (is i >= 0?) will always be true.
xman_di



Joined: 24 Mar 2011
Posts: 2
Location: Newport, RI

View user's profile Send private message

PostPosted: Thu Mar 24, 2011 9:25 am     Reply with quote

Thanks! Works great now! Very Happy
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