-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy path_timer.ino
36 lines (35 loc) · 1.03 KB
/
_timer.ino
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
/*
void Setup_Timer0()
{
TCCR0A = 0; // set entire TCCR2A register to 0
TCCR0B = 0; // same for TCCR2B
TCNT0 = 0; //initialize counter value to 0
// set compare match register for 1khz increments
//OCR2A = 249; // = (16*10^6) / (1000*64) - 1 (must be <256)
// turn on Fast PWM mode
TCCR0A |= (1 << COM0A1) | (1 << COM0B1) | (1 << WGM01) | (1 << WGM00);
// Set CS01 and CS00 bits for 64 prescaler
TCCR0B |= (1 << CS00);
// enable timer compare interrupt
//TIMSK2 |= (1 << OCIE2A);
OCR0B = 0;
}
*/
void Setup_Timer2()
{
TCCR2A = 0; // set entire TCCR2A register to 0
TCCR2B = 0; // same for TCCR2B
TCNT2 = 0; //initialize counter value to 0
// set compare match register for 100hz increments
OCR2A = 155; // = (16*10^6) / (100*1024) - 1 = 155(must be <256)
// turn on CTC mode
TCCR2A |= (1 << WGM21);
//Set CS21 and CS20 bits for 1024 prescaler
TCCR2B |= (1 << CS22) | (1 << CS21) | (1 << CS20);
// enable timer compare interrupt
TIMSK2 |= (1 << OCIE2A);
}
ISR(TIMER2_COMPA_vect)
{
Do = true;
}