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

How to check timer flag without enabling interrupt?

 
Post new topic   Reply to topic    CCS Forum Index -> General CCS C Discussion
View previous topic :: View next topic  
Author Message
mayur.k.vadukul



Joined: 07 Jul 2022
Posts: 40

View user's profile Send private message

How to check timer flag without enabling interrupt?
PostPosted: Wed Feb 07, 2024 10:26 am     Reply with quote

Hi,

I am writing a code whereby I am using timer1 without interrupt. i.e. I am loading a value in the Timer1 but not enabling interrupt.

How can I check whether my Timer1 flag in CCS compiler whether it has overflown or not?
_________________
MVadukul
temtronic



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

View user's profile Send private message

PostPosted: Wed Feb 07, 2024 10:30 am     Reply with quote

You can just read whatever register the flag is in, mask off the other bits (or 'bit test' )
Ttelmah



Joined: 11 Mar 2010
Posts: 19535

View user's profile Send private message

PostPosted: Wed Feb 07, 2024 10:38 am     Reply with quote

The timer flag sets even if the interrupt is not enabled.
Code:

if (interrupt_active(INT_TIMER1))
{
    clear_interrupt(INT_TIMER1); //clear the flag
    //do what you want
}
mayur.k.vadukul



Joined: 07 Jul 2022
Posts: 40

View user's profile Send private message

PostPosted: Wed Feb 07, 2024 10:43 am     Reply with quote

I am writing as follows:-

setup_timer_1(T1_DISABLED);
setup_timer_1 (T1_INTERNAL|T1_DIV_BY_8);
set_timer1(DELAY_300USEC);

DELAY_300USEC = 0xff95
System Clock is 4MHz
Cycles required = 0.0003/0.00000025 = 1200
To make 1200 we can have division by 8 and 16 bit counter of 150 so we will load 65535-150 = 65385.

But for some reason when I am doing following after above it is not entering the loop below:-

if (interrupt_active(INT_TIMER1))
{
setup_timer_1(T1_DISABLED);
clear_interrupt(INT_TIMER1);
output_bit (CLK2, temp_flag_bit);
temp_flag_bit = ~temp_flag_bit;
setup_timer_1 (T1_INTERNAL|T1_DIV_BY_8);
set_timer1(DELAY_300USEC);
}

When I debug, it reaches the if loop but doesn't go in. i.e. my timer does not seem to be running.
_________________
MVadukul
temtronic



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

View user's profile Send private message

PostPosted: Wed Feb 07, 2024 10:55 am     Reply with quote

if I'm reading your code right,

the first thing you do is disable the timer....

so if don't enable the timer you'll never get the 'flag' set.
mayur.k.vadukul



Joined: 07 Jul 2022
Posts: 40

View user's profile Send private message

PostPosted: Wed Feb 07, 2024 10:59 am     Reply with quote

I have picked this code form the CCS help file.

When I check I understood as when I disable it, it should stop as you said.

However, when the next line of code executes, it should enable the timer. should it not?

setup_timer_1(T1_DISABLED);
setup_timer_1 (T1_INTERNAL|T1_DIV_BY_8);
set_timer1(DELAY_300USEC);
_________________
MVadukul
temtronic



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

View user's profile Send private message

PostPosted: Wed Feb 07, 2024 11:50 am     Reply with quote

I would say no.


There's a specific option to disable the timer
setup_timer_1(T1_DISABLED);
this command 'stops' the timer from operating

setup_timer_1 (T1_INTERNAL|T1_DIV_BY_8);
this command says to connect Timer one internally to a clock source AND divide the rate by a factor of 8.

It does not specifically say 'enable' the timer

You should post which PIC though, as options for timers have changed over the decades. Some timers can have 'gates' to allow when the clock signal to actually be counted.

here's an example that I've cut/pasted the following from the PIC16F877C datasheet, Timer1 chapter...

TMR1ON: Timer1 On bit
1 = Enables Timer1
0 = Stops Timer1

.....
so in this old PIC, you CAN 'start/stop' the action of timer1 by set/clr the TMR1ON bit.

You can think of it this way.Your car has a standard transmission
You can say 'setup_timer_1 (T1_INTERNAL|T1_DIV_BY_8); ' runs the engine and puts transmission into 1st gear...

Nothing happens...you don't go anywhere

Now 'setup_timer_1(T1_enabled)' engages the clutch (connects engine to transmission ) and you drive down the road.
mayur.k.vadukul



Joined: 07 Jul 2022
Posts: 40

View user's profile Send private message

PostPosted: Thu Feb 08, 2024 2:51 am     Reply with quote

Thanks for your help.

The issues are in the device's .h files whereby the constants they defined do not tie up with the datasheet's register. T1_INTERNAL should turn on the Timer and place it under the internal source as well. The value it has is 0x07. i.e. 0000 0111. But when I looked at the datasheet to select internal source, it should be 0000 0001 and the LSB is actually to turn ON the timer.

Once I define my own value as below, it started working how it should do.

#define TIMER1ON 0x81
setup_timer_1 (T1_DIV_BY_8|TIMER1ON);
set_timer1(DELAY_300USEC);

The issue is in 18F65J11.h file.

Many thanks for your comments.
_________________
MVadukul
temtronic



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

View user's profile Send private message

PostPosted: Thu Feb 08, 2024 7:00 am     Reply with quote

happy you got it working !!

email CCS about it, they can update that header in new compiler version.
Ttelmah



Joined: 11 Mar 2010
Posts: 19535

View user's profile Send private message

PostPosted: Thu Feb 08, 2024 8:45 am     Reply with quote

Yes. It actually wants to be 0x81 (the compiler assumes 16bit reads and
writes).
leach67



Joined: 13 Feb 2024
Posts: 3

View user's profile Send private message

Re: How to check timer flag without enabling interrupt?
PostPosted: Fri Feb 16, 2024 5:46 am     Reply with quote

mayur.k.vadukul wrote:
Hi,

I am writing a code whereby I am using timer1 without interrupt. i.e. I am loading a value in the Timer1 but not enabling interrupt.

How can I check whether my Timer1 flag in CCS compiler whether it has overflown or not?

hello
check if timer1 has overflowed by monitoring the corresponding flag bit in timer 1 control register.
thanks!!!
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