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

Program just run in the interrupt program.

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



Joined: 25 May 2013
Posts: 7

View user's profile Send private message

Program just run in the interrupt program.
PostPosted: Sun Jun 23, 2013 8:51 am     Reply with quote

please help me know the reason why my program just run in the interrupt program, it can not perform the commands in the while(true) of the main program.

code:
Code:
#include <18f4550.h>
#include <math.h>
int16 dem;
int8 i;

//int16 dem1;

char const  gt0[12]={47,30,32,32,43,38,35,43,26,37,36,38};
char const  gtmin[12]={20,10,14,18,18,17,17,17,13,17,17,17};
char const  gtmax[12]={56,40,61,55,55,54,54,54,55,54,54,54};
char const  gocmax[12]={135,160,180,135,140,140,135,125,170,120,145,120};
char const  flagsv[12]={1,0,1,0,1,0,0,1,0,1,1,0};
char sv[12];
void dunglen();

#int_TIMER0

void  TIMER0_isr(void)
{
   set_timer0(216);
   dem++;
   
  // dem1++;
 
   //if(dem1==10000)
   //{
   //   dem1=0;
   //   sv[0]++;
   //   output_toggle(pin_c2);
   //}
   
   
   
}
int8 translate(int8 gt0,int8 gtmin, int8 gtmax,int8 gocmax,int flag,signed int8 gocset)
{
   float tam,tang;
   int8  gtri,tam1;
   int bit;
   tang=abs(gocset*((gtmax-gtmin)/gocmax));
   tam=modf(tang,&tam1);
   if (tam>=0.5){tang=tam1+1;}
   else if(tam<0.5){tam=tam1;}
   if (gocset>=0){bit=1;}
   if(gocset<0){bit=0;}
   if(flag&&bit==1){gtri=(gt0+tang);}
   else if(flag&&bit==0){gtri=(gt0-tang);}
   return gtri;
   
}
#int_TIMER1
void  TIMER1_isr(void)
{

}



void main()

   
   set_timer0(216);
   setup_timer_0(RTCC_INTERNAL|RTCC_DIV_2|RTCC_8_bit);      //128 us overflow
   setup_timer_1(T1_INTERNAL|T1_DIV_BY_1);      //16.3 ms overflow
   enable_interrupts(INT_TIMER0);
   //enable_interrupts(INT_TIMER1);
   enable_interrupts(GLOBAL);
   
   while(true)
   {
      if(dem==500)
   {
      dem=0;
      output_d(0x3f);
      output_e(0x07);
      output_high(pin_a4);
      output_b(0x30);
      output_toggle(pin_c1);
   }
   if(dem==sv[0]){output_low(pin_d0);}
   if(dem==sv[1]){output_low(pin_d1);}
   if(dem==sv[2]){output_low(pin_d2);}
   if(dem==sv[3]){output_low(pin_d3);}
   if(dem==sv[4]){output_low(pin_d4);}
   if(dem==sv[5]){output_low(pin_d5);}
   if(dem==sv[6]){output_low(pin_e2);}
   if(dem==sv[7]){output_low(pin_e1);}
   if(dem==sv[8])output_low(pin_e0);
   if(dem==sv[9])output_low(pin_a4);
   if(dem==sv[10])output_low(pin_b5);
   if(dem==sv[11])output_low(pin_b4);
      for(i=1;i<=11;i++)sv[i]=0;
      dunglen();
   
   }
}

void dunglen()

  // int8 i;
  // for(i=0;i<=11;i++)     
  // {
   sv[0]=translate(gt0[0],gtmin[0],gtmax[0],gocmax[0],flagsv[0],30);
  // sv[0]=45;
  // }
   
}
temtronic



Joined: 01 Jul 2010
Posts: 9225
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Sun Jun 23, 2013 9:57 am     Reply with quote

Well depending on the processor's speed( unknown here), it could be spending ALL of it's time within the ISR.
No where in your program do you actually set the processor speed( clock).

Kinda interesting that it actually runs.....

hth
jay
hoangtuanthien



Joined: 25 May 2013
Posts: 7

View user's profile Send private message

PostPosted: Sun Jun 23, 2013 10:49 am     Reply with quote

actually, in my program the first command is #include <timer.h> and in file timer.h set the processor speed (clock). it's here

Code:
#include <18F4550.h>

#FUSES NOWDT                    //No Watch Dog Timer
#FUSES WDT128                   //Watch Dog Timer uses 1:128 Postscale
#FUSES PLL1                     //No PLL PreScaler
#FUSES CPUDIV1                  //No System Clock Postscaler
#FUSES USBDIV                   //USB clock source comes from PLL divide by 2
#FUSES HS                       //High speed Osc (> 4mhz for PCM/PCH) (>10mhz for PCD)
#FUSES FCMEN                    //Fail-safe clock monitor enabled
#FUSES IESO                     //Internal External Switch Over mode enabled
#FUSES NOPUT                    //No Power Up Timer
#FUSES NOBROWNOUT               //No brownout reset
#FUSES BORV20                   //Brownout reset at 2.0V
#FUSES VREGEN                   //USB voltage regulator enabled
#FUSES PBADEN                   //PORTB pins are configured as analog input channels on RESET
#FUSES LPT1OSC                  //Timer1 configured for low-power operation
#FUSES MCLR                     //Master Clear pin enabled
#FUSES STVREN                   //Stack full/underflow will cause reset
#FUSES NOLVP                    //No low voltage prgming, B3(PIC16) or B5(PIC18) used for I/O
#FUSES ICPRT                    //ICPRT enabled
#FUSES NOXINST                  //Extended set extension and Indexed Addressing mode disabled (Legacy mode)
#FUSES NODEBUG                  //No Debug mode for ICD
#FUSES NOPROTECT                //Code not protected from reading
#FUSES NOCPB                    //No Boot Block code protection
#FUSES NOCPD                    //No EE protection
#FUSES NOWRT                    //Program memory not write protected
#FUSES NOWRTC                   //configuration not registers write protected
#FUSES NOWRTB                   //Boot block not write protected
#FUSES NOWRTD                   //Data EEPROM not write protected
#FUSES NOEBTR                   //Memory not protected from table reads
#FUSES NOEBTRB                  //Boot block not protected from table reads

#use delay(clock=16000000,crystal =16000000)
Mike Walne



Joined: 19 Feb 2004
Posts: 1785
Location: Boston Spa UK

View user's profile Send private message

PostPosted: Sun Jun 23, 2013 10:56 am     Reply with quote

Set up some diagnostic pin wobbles.
Then you will be able to see what's happening with a 'scope.

Ttelmah is probably pointing you in the right direction.

In your timer0 ISR you're setting timer0 to 216.
Timer0 defaults to 8 bit mode, ie counts to 255 then 0.
It's going to overflow in 80 machine cycles with div_by_2.
Same order as time to get in and out of the ISR!

Mike
Ttelmah



Joined: 11 Mar 2010
Posts: 19504

View user's profile Send private message

PostPosted: Sun Jun 23, 2013 12:36 pm     Reply with quote

Temtronic, not me.... Smile

However, exactly what I'd probably have pointed out.

Best Wishes
gpsmikey



Joined: 16 Nov 2010
Posts: 588
Location: Kirkland, WA

View user's profile Send private message

PostPosted: Sun Jun 23, 2013 12:47 pm     Reply with quote

One of the Mr. "T" guys :-) I definitely agree with the adding a "pin wobble" (never heard it described that way before, but it is perfect). Set an unused pin high at the start of the ISR, then set it low just before exiting the ISR. That allows you to see that the ISR is indeed executing as well as seeing how much time is being spent in there as opposed to in main.

mikey
_________________
mikey
-- you can't have too many gadgets or too much disk space !
old engineering saying: 1+1 = 3 for sufficiently large values of 1 or small values of 3
temtronic



Joined: 01 Jul 2010
Posts: 9225
Location: Greensville,Ontario

View user's profile Send private message

PostPosted: Sun Jun 23, 2013 12:56 pm     Reply with quote

"pin wobble", phrase, a 'blimey' term used to descibe an I/O pin that 'toggles' to give an indication that the program is running. Principally used by blokes with roots in merry old England!

cheers

Jay
on the other side of the pond
Ttelmah



Joined: 11 Mar 2010
Posts: 19504

View user's profile Send private message

PostPosted: Sun Jun 23, 2013 1:17 pm     Reply with quote

However it won't allow you to see how much time is taken in the ISR, rather than the main, since there are about 60 instructions of overhead 'outside' the handler code....

The timing will actually be that timer0, will zero, and the handler will be called. By the time it arrives at the code, the timer will have incremented to perhaps 8. The the routine sets it to 216, which reset the prescaler. It'll count from here, while the increment, clearing the interrupt flag, and resetting the registers takes place. Approximately 40 instructions, so it'll have counted to perhaps 236. So it should then have about 40 instruction times in the main before the next call. So about 25% of the time in the main.

With the processor running very slow, start by remembering that sv will all probably be 0xff at the start. Then the interrupt is executing all the time, so dem will change between the successive tests. Then the maths in dunglen, will take an age, so it'll hardly ever actually reach a test, and then the 'matching' value will almost certainly be missed.

Best Wishes
Mike Walne



Joined: 19 Feb 2004
Posts: 1785
Location: Boston Spa UK

View user's profile Send private message

PostPosted: Sun Jun 23, 2013 2:43 pm     Reply with quote

Apologies to both Mr T's.

I'm preparing to run a golf competition tomorrow, so not really paying full attention. You get the idea.
It is Sunday, and the forecast is good.

Seriously though; I was thinking in terms of putting 'wobbles' on different pins in both ISR and main, to get more 'information' out of the system.

Mike

PS. Glad the term was liked. It was the best an old guy could do.
I was typing slowly whilst the OP responded with all the fuses.
gpsmikey



Joined: 16 Nov 2010
Posts: 588
Location: Kirkland, WA

View user's profile Send private message

PostPosted: Sun Jun 23, 2013 7:10 pm     Reply with quote

I agree that setting it high at the start of the ISR then low at the end does not include the overhead code, but it will give a very good indication if a) it is being called as expected and b) if there is lots of free time for main or if you are in trouble :-) Definitely going to add the "wobble pin" definition to my vocabulary (if I can get it to stick in this old brain ! - it is the perfect descriptor)

mikey
_________________
mikey
-- you can't have too many gadgets or too much disk space !
old engineering saying: 1+1 = 3 for sufficiently large values of 1 or small values of 3
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