File: timer_16bit.c

package info (click to toggle)
simulavr 1.0.0%2Bgit20160221.e53413b-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 6,740 kB
  • sloc: cpp: 35,491; python: 6,995; ansic: 3,567; makefile: 1,075; sh: 653; asm: 414; tcl: 320; javascript: 32
file content (56 lines) | stat: -rw-r--r-- 1,018 bytes parent folder | download | duplicates (2)
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
/* timer test programm for timer1: 16bit with normal mode */
#include <avr/interrupt.h>

volatile int timer_ticks;

#ifdef T3TEST
ISR(TIMER3_OVF_vect) {
   timer_ticks++;
}
ISR(TIMER3_COMPB_vect) {
   timer_ticks++;
}
#else
ISR(TIMER1_OVF_vect) {
   timer_ticks++;
}
#endif

int main(void) {
  volatile int tmp;

#ifdef T3TEST
  TCNT3H = 0;    /* Timer 3 by CLK/1 */
  TCNT3L = 0;
  OCR3AH = 0x06;
  OCR3AL = 0x3f; /* factor = 1600, PWM frequency = 5kHz */
  OCR3BH = 0x02;
  OCR3BL = 0x7f; /* duty factor 40% = 640 */
  DDRE   = 0x10; /* PE4 = out */
  TCCR3A = 0x30 + 0x03; /* comB = 3, wgm = 15 */
  TCCR3B = 0x18 + 0x01; /* wgm = 15, cs=1 */
  ETIMSK = _BV(TOIE3) + _BV(OCIE3B);
#else
  TCNT1H = 0;    /* Timer 1 by CLK/1 */
  TCNT1L = 0;
  TCCR1B = 0x01; /* 16,384ms on 4MHz, normal mode */
#ifdef PROC_atmega48
  TIMSK1 = _BV(TOIE1);
#else
  TIMSK = _BV(TOIE1);
#endif
#endif

  sei();

  tmp = timer_ticks;
  while(1) {
    if(tmp != timer_ticks) {
      tmp = timer_ticks;
    } 
  }

  return 0;
}

/* EOF */