1
0
mirror of https://github.com/arduino/Arduino.git synced 2025-01-19 08:52:15 +01:00

1710 lines
71 KiB
Plaintext
Raw Normal View History

1 .file "timer.c"
2 .arch atmega8
3 __SREG__ = 0x3f
4 __SP_H__ = 0x3e
5 __SP_L__ = 0x3d
6 __tmp_reg__ = 0
7 __zero_reg__ = 1
8 .global __do_copy_data
9 .global __do_clear_bss
12 .text
13 .Ltext0:
94 .global TimerRTCPrescaleFactor
95 .section .progmem.data,"a",@progbits
98 TimerRTCPrescaleFactor:
99 0000 0000 .word 0
100 0002 0100 .word 1
101 0004 0800 .word 8
102 0006 2000 .word 32
103 0008 4000 .word 64
104 000a 8000 .word 128
105 000c 0001 .word 256
106 000e 0004 .word 1024
107 .global TimerPrescaleFactor
110 TimerPrescaleFactor:
111 0010 0000 .word 0
112 0012 0100 .word 1
113 0014 0800 .word 8
114 0016 4000 .word 64
115 0018 0001 .word 256
116 001a 0004 .word 1024
117 .text
120 .global delay_us
122 delay_us:
1:../avrlib/timer.c **** /*! \file timer.c \brief System Timer function library. */
2:../avrlib/timer.c **** //*****************************************************************************
3:../avrlib/timer.c **** //
4:../avrlib/timer.c **** // File Name : 'timer.c'
5:../avrlib/timer.c **** // Title : System Timer function library
6:../avrlib/timer.c **** // Author : Pascal Stang - Copyright (C) 2000-2002
7:../avrlib/timer.c **** // Created : 11/22/2000
8:../avrlib/timer.c **** // Revised : 07/09/2003
9:../avrlib/timer.c **** // Version : 1.1
10:../avrlib/timer.c **** // Target MCU : Atmel AVR Series
11:../avrlib/timer.c **** // Editor Tabs : 4
12:../avrlib/timer.c **** //
13:../avrlib/timer.c **** // This code is distributed under the GNU Public License
14:../avrlib/timer.c **** // which can be found at http://www.gnu.org/licenses/gpl.txt
15:../avrlib/timer.c **** //
16:../avrlib/timer.c **** //*****************************************************************************
17:../avrlib/timer.c ****
18:../avrlib/timer.c **** #ifndef WIN32
19:../avrlib/timer.c **** #include <avr/io.h>
20:../avrlib/timer.c **** #include <avr/signal.h>
21:../avrlib/timer.c **** #include <avr/interrupt.h>
22:../avrlib/timer.c **** #include <avr/pgmspace.h>
23:../avrlib/timer.c **** #include <avr/sleep.h>
24:../avrlib/timer.c **** #endif
25:../avrlib/timer.c ****
26:../avrlib/timer.c **** #include "global.h"
27:../avrlib/timer.c **** #include "timer.h"
28:../avrlib/timer.c ****
29:../avrlib/timer.c **** #include "rprintf.h"
30:../avrlib/timer.c ****
31:../avrlib/timer.c **** // Program ROM constants
32:../avrlib/timer.c **** // the prescale division values stored in order of timer control register index
33:../avrlib/timer.c **** // STOP, CLK, CLK/8, CLK/64, CLK/256, CLK/1024
34:../avrlib/timer.c **** unsigned short __attribute__ ((progmem)) TimerPrescaleFactor[] = {0,1,8,64,256,1024};
35:../avrlib/timer.c **** // the prescale division values stored in order of timer control register index
36:../avrlib/timer.c **** // STOP, CLK, CLK/8, CLK/32, CLK/64, CLK/128, CLK/256, CLK/1024
37:../avrlib/timer.c **** unsigned short __attribute__ ((progmem)) TimerRTCPrescaleFactor[] = {0,1,8,32,64,128,256,1024};
38:../avrlib/timer.c ****
39:../avrlib/timer.c **** // Global variables
40:../avrlib/timer.c **** // time registers
41:../avrlib/timer.c **** volatile unsigned long TimerPauseReg;
42:../avrlib/timer.c **** volatile unsigned long Timer0Reg0;
43:../avrlib/timer.c **** volatile unsigned long Timer2Reg0;
44:../avrlib/timer.c ****
45:../avrlib/timer.c **** typedef void (*voidFuncPtr)(void);
46:../avrlib/timer.c **** volatile static voidFuncPtr TimerIntFunc[TIMER_NUM_INTERRUPTS];
47:../avrlib/timer.c ****
48:../avrlib/timer.c **** // delay for a minimum of <us> microseconds
49:../avrlib/timer.c **** // the time resolution is dependent on the time the loop takes
50:../avrlib/timer.c **** // e.g. with 4Mhz and 5 cycles per loop, the resolution is 1.25 us
51:../avrlib/timer.c **** void delay_us(unsigned short time_us)
52:../avrlib/timer.c **** {
124 .LM1:
125 /* prologue: frame size=0 */
126 /* prologue end (size=0) */
53:../avrlib/timer.c **** unsigned short delay_loops;
54:../avrlib/timer.c **** register unsigned short i;
55:../avrlib/timer.c ****
56:../avrlib/timer.c **** delay_loops = (time_us+3)/5*CYCLES_PER_US; // +3 for rounding up (dirty)
128 .LM2:
129 0000 0396 adiw r24,3
130 0002 65E0 ldi r22,lo8(5)
131 0004 70E0 ldi r23,hi8(5)
132 0006 00D0 rcall __udivmodhi4
133 0008 CB01 movw r24,r22
134 000a AA27 clr r26
135 000c BB27 clr r27
136 000e 24E0 ldi r18,4
137 0010 880F 1: lsl r24
138 0012 991F rol r25
139 0014 AA1F rol r26
140 0016 BB1F rol r27
141 0018 2A95 dec r18
142 001a D1F7 brne 1b
143 .L8:
57:../avrlib/timer.c ****
58:../avrlib/timer.c **** // one loop takes 5 cpu cycles
59:../avrlib/timer.c **** for (i=0; i < delay_loops; i++) {};
145 .LM3:
146 001c 0097 sbiw r24,0
147 001e 11F0 breq .L7
148 0020 0197 sbiw r24,1
149 0022 FCCF rjmp .L8
150 .L7:
151 0024 0895 ret
152 /* epilogue: frame size=0 */
153 /* epilogue: noreturn */
154 /* epilogue end (size=0) */
155 /* function delay_us size 19 (19) */
161 .Lscope0:
165 .global timerDetach
167 timerDetach:
60:../avrlib/timer.c **** }
61:../avrlib/timer.c **** /*
62:../avrlib/timer.c **** void delay_ms(unsigned char time_ms)
63:../avrlib/timer.c **** {
64:../avrlib/timer.c **** unsigned short delay_count = F_CPU / 4000;
65:../avrlib/timer.c ****
66:../avrlib/timer.c **** unsigned short cnt;
67:../avrlib/timer.c **** asm volatile ("\n"
68:../avrlib/timer.c **** "L_dl1%=:\n\t"
69:../avrlib/timer.c **** "mov %A0, %A2\n\t"
70:../avrlib/timer.c **** "mov %B0, %B2\n"
71:../avrlib/timer.c **** "L_dl2%=:\n\t"
72:../avrlib/timer.c **** "sbiw %A0, 1\n\t"
73:../avrlib/timer.c **** "brne L_dl2%=\n\t"
74:../avrlib/timer.c **** "dec %1\n\t" "brne L_dl1%=\n\t":"=&w" (cnt)
75:../avrlib/timer.c **** :"r"(time_ms), "r"((unsigned short) (delay_count))
76:../avrlib/timer.c **** );
77:../avrlib/timer.c **** }
78:../avrlib/timer.c **** */
79:../avrlib/timer.c **** void timerInit(void)
80:../avrlib/timer.c **** {
81:../avrlib/timer.c **** u08 intNum;
82:../avrlib/timer.c **** // detach all user functions from interrupts
83:../avrlib/timer.c **** for(intNum=0; intNum<TIMER_NUM_INTERRUPTS; intNum++)
84:../avrlib/timer.c **** timerDetach(intNum);
85:../avrlib/timer.c ****
86:../avrlib/timer.c **** // initialize all timers
87:../avrlib/timer.c **** timer0Init();
88:../avrlib/timer.c **** timer1Init();
89:../avrlib/timer.c **** #ifdef TCNT2 // support timer2 only if it exists
90:../avrlib/timer.c **** timer2Init();
91:../avrlib/timer.c **** #endif
92:../avrlib/timer.c **** // enable interrupts
93:../avrlib/timer.c **** sei();
94:../avrlib/timer.c **** }
95:../avrlib/timer.c ****
96:../avrlib/timer.c **** void timer0Init()
97:../avrlib/timer.c **** {
98:../avrlib/timer.c **** // initialize timer 0
99:../avrlib/timer.c **** timer0SetPrescaler( TIMER0PRESCALE ); // set prescaler
100:../avrlib/timer.c **** outb(TCNT0, 0); // reset TCNT0
101:../avrlib/timer.c **** sbi(TIMSK, TOIE0); // enable TCNT0 overflow interrupt
102:../avrlib/timer.c ****
103:../avrlib/timer.c **** timer0ClearOverflowCount(); // initialize time registers
104:../avrlib/timer.c **** }
105:../avrlib/timer.c ****
106:../avrlib/timer.c **** void timer1Init(void)
107:../avrlib/timer.c **** {
108:../avrlib/timer.c **** // initialize timer 1
109:../avrlib/timer.c **** timer1SetPrescaler( TIMER1PRESCALE ); // set prescaler
110:../avrlib/timer.c **** outb(TCNT1H, 0); // reset TCNT1
111:../avrlib/timer.c **** outb(TCNT1L, 0);
112:../avrlib/timer.c **** sbi(TIMSK, TOIE1); // enable TCNT1 overflow
113:../avrlib/timer.c **** }
114:../avrlib/timer.c ****
115:../avrlib/timer.c **** #ifdef TCNT2 // support timer2 only if it exists
116:../avrlib/timer.c **** void timer2Init(void)
117:../avrlib/timer.c **** {
118:../avrlib/timer.c **** // initialize timer 2
119:../avrlib/timer.c **** timer2SetPrescaler( TIMER2PRESCALE ); // set prescaler
120:../avrlib/timer.c **** outb(TCNT2, 0); // reset TCNT2
121:../avrlib/timer.c **** sbi(TIMSK, TOIE2); // enable TCNT2 overflow
122:../avrlib/timer.c ****
123:../avrlib/timer.c **** timer2ClearOverflowCount(); // initialize time registers
124:../avrlib/timer.c **** }
125:../avrlib/timer.c **** #endif
126:../avrlib/timer.c ****
127:../avrlib/timer.c **** void timer0SetPrescaler(u08 prescale)
128:../avrlib/timer.c **** {
129:../avrlib/timer.c **** // set prescaler on timer 0
130:../avrlib/timer.c **** outb(TCCR0, (inb(TCCR0) & ~TIMER_PRESCALE_MASK) | prescale);
131:../avrlib/timer.c **** }
132:../avrlib/timer.c ****
133:../avrlib/timer.c **** void timer1SetPrescaler(u08 prescale)
134:../avrlib/timer.c **** {
135:../avrlib/timer.c **** // set prescaler on timer 1
136:../avrlib/timer.c **** outb(TCCR1B, (inb(TCCR1B) & ~TIMER_PRESCALE_MASK) | prescale);
137:../avrlib/timer.c **** }
138:../avrlib/timer.c ****
139:../avrlib/timer.c **** #ifdef TCNT2 // support timer2 only if it exists
140:../avrlib/timer.c **** void timer2SetPrescaler(u08 prescale)
141:../avrlib/timer.c **** {
142:../avrlib/timer.c **** // set prescaler on timer 2
143:../avrlib/timer.c **** outb(TCCR2, (inb(TCCR2) & ~TIMER_PRESCALE_MASK) | prescale);
144:../avrlib/timer.c **** }
145:../avrlib/timer.c **** #endif
146:../avrlib/timer.c ****
147:../avrlib/timer.c **** u16 timer0GetPrescaler(void)
148:../avrlib/timer.c **** {
149:../avrlib/timer.c **** // get the current prescaler setting
150:../avrlib/timer.c **** return (pgm_read_word(TimerPrescaleFactor+(inb(TCCR0) & TIMER_PRESCALE_MASK)));
151:../avrlib/timer.c **** }
152:../avrlib/timer.c ****
153:../avrlib/timer.c **** u16 timer1GetPrescaler(void)
154:../avrlib/timer.c **** {
155:../avrlib/timer.c **** // get the current prescaler setting
156:../avrlib/timer.c **** return (pgm_read_word(TimerPrescaleFactor+(inb(TCCR1B) & TIMER_PRESCALE_MASK)));
157:../avrlib/timer.c **** }
158:../avrlib/timer.c ****
159:../avrlib/timer.c **** #ifdef TCNT2 // support timer2 only if it exists
160:../avrlib/timer.c **** u16 timer2GetPrescaler(void)
161:../avrlib/timer.c **** {
162:../avrlib/timer.c **** //TODO: can we assume for all 3-timer AVR processors,
163:../avrlib/timer.c **** // that timer2 is the RTC timer?
164:../avrlib/timer.c ****
165:../avrlib/timer.c **** // get the current prescaler setting
166:../avrlib/timer.c **** return (pgm_read_word(TimerRTCPrescaleFactor+(inb(TCCR2) & TIMER_PRESCALE_MASK)));
167:../avrlib/timer.c **** }
168:../avrlib/timer.c **** #endif
169:../avrlib/timer.c ****
170:../avrlib/timer.c **** void timerAttach(u08 interruptNum, void (*userFunc)(void) )
171:../avrlib/timer.c **** {
172:../avrlib/timer.c **** // make sure the interrupt number is within bounds
173:../avrlib/timer.c **** if(interruptNum < TIMER_NUM_INTERRUPTS)
174:../avrlib/timer.c **** {
175:../avrlib/timer.c **** // set the interrupt function to run
176:../avrlib/timer.c **** // the supplied user's function
177:../avrlib/timer.c **** TimerIntFunc[interruptNum] = userFunc;
178:../avrlib/timer.c **** }
179:../avrlib/timer.c **** }
180:../avrlib/timer.c ****
181:../avrlib/timer.c **** void timerDetach(u08 interruptNum)
182:../avrlib/timer.c **** {
169 .LM4:
170 /* prologue: frame size=0 */
171 /* prologue end (size=0) */
183:../avrlib/timer.c **** // make sure the interrupt number is within bounds
184:../avrlib/timer.c **** if(interruptNum < TIMER_NUM_INTERRUPTS)
173 .LM5:
174 0026 8730 cpi r24,lo8(7)
175 0028 40F4 brsh .L9
185:../avrlib/timer.c **** {
186:../avrlib/timer.c **** // set the interrupt function to run nothing
187:../avrlib/timer.c **** TimerIntFunc[interruptNum] = 0;
177 .LM6:
178 002a E82F mov r30,r24
179 002c FF27 clr r31
180 002e EE0F add r30,r30
181 0030 FF1F adc r31,r31
182 0032 E050 subi r30,lo8(-(TimerIntFunc))
183 0034 F040 sbci r31,hi8(-(TimerIntFunc))
184 0036 1082 st Z,__zero_reg__
185 0038 1182 std Z+1,__zero_reg__
186 .L9:
187 003a 0895 ret
188 /* epilogue: frame size=0 */
189 003c 0895 ret
190 /* epilogue end (size=1) */
191 /* function timerDetach size 12 (11) */
193 .Lscope1:
197 .global timer0SetPrescaler
199 timer0SetPrescaler:
201 .LM7:
202 /* prologue: frame size=0 */
203 /* prologue end (size=0) */
205 .LM8:
206 003e 93B7 in r25,83-0x20
207 0040 987F andi r25,lo8(-8)
208 0042 982B or r25,r24
209 0044 93BF out 83-0x20,r25
210 /* epilogue: frame size=0 */
211 0046 0895 ret
212 /* epilogue end (size=1) */
213 /* function timer0SetPrescaler size 5 (4) */
215 .Lscope2:
218 .global timer0ClearOverflowCount
220 timer0ClearOverflowCount:
188:../avrlib/timer.c **** }
189:../avrlib/timer.c **** }
190:../avrlib/timer.c **** /*
191:../avrlib/timer.c **** u32 timerMsToTics(u16 ms)
192:../avrlib/timer.c **** {
193:../avrlib/timer.c **** // calculate the prescaler division rate
194:../avrlib/timer.c **** u16 prescaleDiv = 1<<(pgm_read_byte(TimerPrescaleFactor+inb(TCCR0)));
195:../avrlib/timer.c **** // calculate the number of timer tics in x milliseconds
196:../avrlib/timer.c **** return (ms*(F_CPU/(prescaleDiv*256)))/1000;
197:../avrlib/timer.c **** }
198:../avrlib/timer.c ****
199:../avrlib/timer.c **** u16 timerTicsToMs(u32 tics)
200:../avrlib/timer.c **** {
201:../avrlib/timer.c **** // calculate the prescaler division rate
202:../avrlib/timer.c **** u16 prescaleDiv = 1<<(pgm_read_byte(TimerPrescaleFactor+inb(TCCR0)));
203:../avrlib/timer.c **** // calculate the number of milliseconds in x timer tics
204:../avrlib/timer.c **** return (tics*1000*(prescaleDiv*256))/F_CPU;
205:../avrlib/timer.c **** }
206:../avrlib/timer.c **** */
207:../avrlib/timer.c **** void timerPause(unsigned short pause_ms)
208:../avrlib/timer.c **** {
209:../avrlib/timer.c **** // pauses for exactly <pause_ms> number of milliseconds
210:../avrlib/timer.c **** u08 timerThres;
211:../avrlib/timer.c **** u32 ticRateHz;
212:../avrlib/timer.c **** u32 pause;
213:../avrlib/timer.c ****
214:../avrlib/timer.c **** // capture current pause timer value
215:../avrlib/timer.c **** timerThres = inb(TCNT0);
216:../avrlib/timer.c **** // reset pause timer overflow count
217:../avrlib/timer.c **** TimerPauseReg = 0;
218:../avrlib/timer.c **** // calculate delay for [pause_ms] milliseconds
219:../avrlib/timer.c **** // prescaler division = 1<<(pgm_read_byte(TimerPrescaleFactor+inb(TCCR0)))
220:../avrlib/timer.c **** ticRateHz = F_CPU/timer0GetPrescaler();
221:../avrlib/timer.c **** // precision management
222:../avrlib/timer.c **** // prevent overflow and precision underflow
223:../avrlib/timer.c **** // -could add more conditions to improve accuracy
224:../avrlib/timer.c **** if( ((ticRateHz < 429497) && (pause_ms <= 10000)) )
225:../avrlib/timer.c **** pause = (pause_ms*ticRateHz)/1000;
226:../avrlib/timer.c **** else
227:../avrlib/timer.c **** pause = pause_ms*(ticRateHz/1000);
228:../avrlib/timer.c ****
229:../avrlib/timer.c **** // loop until time expires
230:../avrlib/timer.c **** while( ((TimerPauseReg<<8) | inb(TCNT0)) < (pause+timerThres) )
231:../avrlib/timer.c **** {
232:../avrlib/timer.c **** if( TimerPauseReg < (pause>>8));
233:../avrlib/timer.c **** {
234:../avrlib/timer.c **** // save power by idling the processor
235:../avrlib/timer.c **** set_sleep_mode(SLEEP_MODE_IDLE);
236:../avrlib/timer.c **** sleep_mode();
237:../avrlib/timer.c **** }
238:../avrlib/timer.c **** }
239:../avrlib/timer.c ****
240:../avrlib/timer.c **** /* old inaccurate code, for reference
241:../avrlib/timer.c ****
242:../avrlib/timer.c **** // calculate delay for [pause_ms] milliseconds
243:../avrlib/timer.c **** u16 prescaleDiv = 1<<(pgm_read_byte(TimerPrescaleFactor+inb(TCCR0)));
244:../avrlib/timer.c **** u32 pause = (pause_ms*(F_CPU/(prescaleDiv*256)))/1000;
245:../avrlib/timer.c ****
246:../avrlib/timer.c **** TimerPauseReg = 0;
247:../avrlib/timer.c **** while(TimerPauseReg < pause);
248:../avrlib/timer.c ****
249:../avrlib/timer.c **** */
250:../avrlib/timer.c **** }
251:../avrlib/timer.c ****
252:../avrlib/timer.c **** void timer0ClearOverflowCount(void)
253:../avrlib/timer.c **** {
222 .LM9:
223 /* prologue: frame size=0 */
224 /* prologue end (size=0) */
254:../avrlib/timer.c **** // clear the timer overflow counter registers
255:../avrlib/timer.c **** Timer0Reg0 = 0; // initialize time registers
226 .LM10:
227 0048 1092 0000 sts Timer0Reg0,__zero_reg__
228 004c 1092 0000 sts (Timer0Reg0)+1,__zero_reg__
229 0050 1092 0000 sts (Timer0Reg0)+2,__zero_reg__
230 0054 1092 0000 sts (Timer0Reg0)+3,__zero_reg__
231 /* epilogue: frame size=0 */
232 0058 0895 ret
233 /* epilogue end (size=1) */
234 /* function timer0ClearOverflowCount size 9 (8) */
236 .Lscope3:
239 .global timer0Init
241 timer0Init:
243 .LM11:
244 /* prologue: frame size=0 */
245 /* prologue end (size=0) */
247 .LM12:
248 005a 82E0 ldi r24,lo8(2)
249 005c F0DF rcall timer0SetPrescaler
251 .LM13:
252 005e 12BE out 82-0x20,__zero_reg__
254 .LM14:
255 0060 89B7 in r24,89-0x20
256 0062 8160 ori r24,lo8(1)
257 0064 89BF out 89-0x20,r24
259 .LM15:
260 0066 F0DF rcall timer0ClearOverflowCount
261 /* epilogue: frame size=0 */
262 0068 0895 ret
263 /* epilogue end (size=1) */
264 /* function timer0Init size 8 (7) */
266 .Lscope4:
270 .global timer1SetPrescaler
272 timer1SetPrescaler:
274 .LM16:
275 /* prologue: frame size=0 */
276 /* prologue end (size=0) */
278 .LM17:
279 006a 9EB5 in r25,78-0x20
280 006c 987F andi r25,lo8(-8)
281 006e 982B or r25,r24
282 0070 9EBD out 78-0x20,r25
283 /* epilogue: frame size=0 */
284 0072 0895 ret
285 /* epilogue end (size=1) */
286 /* function timer1SetPrescaler size 5 (4) */
288 .Lscope5:
291 .global timer1Init
293 timer1Init:
295 .LM18:
296 /* prologue: frame size=0 */
297 /* prologue end (size=0) */
299 .LM19:
300 0074 83E0 ldi r24,lo8(3)
301 0076 F9DF rcall timer1SetPrescaler
303 .LM20:
304 0078 1DBC out 77-0x20,__zero_reg__
306 .LM21:
307 007a 1CBC out 76-0x20,__zero_reg__
309 .LM22:
310 007c 89B7 in r24,89-0x20
311 007e 8460 ori r24,lo8(4)
312 0080 89BF out 89-0x20,r24
313 /* epilogue: frame size=0 */
314 0082 0895 ret
315 /* epilogue end (size=1) */
316 /* function timer1Init size 8 (7) */
318 .Lscope6:
322 .global timer2SetPrescaler
324 timer2SetPrescaler:
326 .LM23:
327 /* prologue: frame size=0 */
328 /* prologue end (size=0) */
330 .LM24:
331 0084 95B5 in r25,69-0x20
332 0086 987F andi r25,lo8(-8)
333 0088 982B or r25,r24
334 008a 95BD out 69-0x20,r25
335 /* epilogue: frame size=0 */
336 008c 0895 ret
337 /* epilogue end (size=1) */
338 /* function timer2SetPrescaler size 5 (4) */
340 .Lscope7:
343 .global timer2ClearOverflowCount
345 timer2ClearOverflowCount:
256:../avrlib/timer.c **** }
257:../avrlib/timer.c ****
258:../avrlib/timer.c **** long timer0GetOverflowCount(void)
259:../avrlib/timer.c **** {
260:../avrlib/timer.c **** // return the current timer overflow count
261:../avrlib/timer.c **** // (this is since the last timer0ClearOverflowCount() command was called)
262:../avrlib/timer.c **** return Timer0Reg0;
263:../avrlib/timer.c **** }
264:../avrlib/timer.c ****
265:../avrlib/timer.c **** #ifdef TCNT2 // support timer2 only if it exists
266:../avrlib/timer.c **** void timer2ClearOverflowCount(void)
267:../avrlib/timer.c **** {
347 .LM25:
348 /* prologue: frame size=0 */
349 /* prologue end (size=0) */
268:../avrlib/timer.c **** // clear the timer overflow counter registers
269:../avrlib/timer.c **** Timer2Reg0 = 0; // initialize time registers
351 .LM26:
352 008e 1092 0000 sts Timer2Reg0,__zero_reg__
353 0092 1092 0000 sts (Timer2Reg0)+1,__zero_reg__
354 0096 1092 0000 sts (Timer2Reg0)+2,__zero_reg__
355 009a 1092 0000 sts (Timer2Reg0)+3,__zero_reg__
356 /* epilogue: frame size=0 */
357 009e 0895 ret
358 /* epilogue end (size=1) */
359 /* function timer2ClearOverflowCount size 9 (8) */
361 .Lscope8:
364 .global timer2Init
366 timer2Init:
368 .LM27:
369 /* prologue: frame size=0 */
370 /* prologue end (size=0) */
372 .LM28:
373 00a0 84E0 ldi r24,lo8(4)
374 00a2 F0DF rcall timer2SetPrescaler
376 .LM29:
377 00a4 14BC out 68-0x20,__zero_reg__
379 .LM30:
380 00a6 89B7 in r24,89-0x20
381 00a8 8064 ori r24,lo8(64)
382 00aa 89BF out 89-0x20,r24
384 .LM31:
385 00ac F0DF rcall timer2ClearOverflowCount
386 /* epilogue: frame size=0 */
387 00ae 0895 ret
388 /* epilogue end (size=1) */
389 /* function timer2Init size 8 (7) */
391 .Lscope9:
394 .global timerInit
396 timerInit:
398 .LM32:
399 /* prologue: frame size=0 */
400 00b0 CF93 push r28
401 /* prologue end (size=1) */
403 .LM33:
404 00b2 C0E0 ldi r28,lo8(0)
405 .L23:
407 .LM34:
408 00b4 8C2F mov r24,r28
409 00b6 B7DF rcall timerDetach
411 .LM35:
412 00b8 CF5F subi r28,lo8(-(1))
413 00ba C730 cpi r28,lo8(7)
414 00bc D8F3 brlo .L23
416 .LM36:
417 00be CDDF rcall timer0Init
419 .LM37:
420 00c0 D9DF rcall timer1Init
422 .LM38:
423 00c2 EEDF rcall timer2Init
425 .LM39:
426 /* #APP */
427 00c4 7894 sei
428 /* #NOAPP */
429 /* epilogue: frame size=0 */
430 00c6 CF91 pop r28
431 00c8 0895 ret
432 /* epilogue end (size=2) */
433 /* function timerInit size 14 (11) */
438 .Lscope10:
441 .global timer0GetPrescaler
443 timer0GetPrescaler:
445 .LM40:
446 /* prologue: frame size=0 */
447 /* prologue end (size=0) */
448 .LBB2:
450 .LM41:
451 00ca 83B7 in r24,83-0x20
452 00cc E82F mov r30,r24
453 00ce FF27 clr r31
454 00d0 E770 andi r30,lo8(7)
455 00d2 F070 andi r31,hi8(7)
456 00d4 EE0F add r30,r30
457 00d6 FF1F adc r31,r31
458 00d8 E050 subi r30,lo8(-(TimerPrescaleFactor))
459 00da F040 sbci r31,hi8(-(TimerPrescaleFactor))
460 .LBE2:
462 .LM42:
463 /* #APP */
464 00dc 8591 lpm r24, Z+
465 00de 9491 lpm r25, Z
466
467 /* #NOAPP */
468 /* epilogue: frame size=0 */
469 00e0 0895 ret
470 /* epilogue end (size=1) */
471 /* function timer0GetPrescaler size 16 (15) */
476 .Lscope11:
479 .global timer1GetPrescaler
481 timer1GetPrescaler:
483 .LM43:
484 /* prologue: frame size=0 */
485 /* prologue end (size=0) */
486 .LBB3:
488 .LM44:
489 00e2 8EB5 in r24,78-0x20
490 00e4 E82F mov r30,r24
491 00e6 FF27 clr r31
492 00e8 E770 andi r30,lo8(7)
493 00ea F070 andi r31,hi8(7)
494 00ec EE0F add r30,r30
495 00ee FF1F adc r31,r31
496 00f0 E050 subi r30,lo8(-(TimerPrescaleFactor))
497 00f2 F040 sbci r31,hi8(-(TimerPrescaleFactor))
498 .LBE3:
500 .LM45:
501 /* #APP */
502 00f4 8591 lpm r24, Z+
503 00f6 9491 lpm r25, Z
504
505 /* #NOAPP */
506 /* epilogue: frame size=0 */
507 00f8 0895 ret
508 /* epilogue end (size=1) */
509 /* function timer1GetPrescaler size 16 (15) */
514 .Lscope12:
517 .global timer2GetPrescaler
519 timer2GetPrescaler:
521 .LM46:
522 /* prologue: frame size=0 */
523 /* prologue end (size=0) */
524 .LBB4:
526 .LM47:
527 00fa 85B5 in r24,69-0x20
528 00fc E82F mov r30,r24
529 00fe FF27 clr r31
530 0100 E770 andi r30,lo8(7)
531 0102 F070 andi r31,hi8(7)
532 0104 EE0F add r30,r30
533 0106 FF1F adc r31,r31
534 0108 E050 subi r30,lo8(-(TimerRTCPrescaleFactor))
535 010a F040 sbci r31,hi8(-(TimerRTCPrescaleFactor))
536 .LBE4:
538 .LM48:
539 /* #APP */
540 010c 8591 lpm r24, Z+
541 010e 9491 lpm r25, Z
542
543 /* #NOAPP */
544 /* epilogue: frame size=0 */
545 0110 0895 ret
546 /* epilogue end (size=1) */
547 /* function timer2GetPrescaler size 16 (15) */
552 .Lscope13:
557 .global timerAttach
559 timerAttach:
561 .LM49:
562 /* prologue: frame size=0 */
563 /* prologue end (size=0) */
565 .LM50:
566 0112 8730 cpi r24,lo8(7)
567 0114 40F4 brsh .L29
569 .LM51:
570 0116 E82F mov r30,r24
571 0118 FF27 clr r31
572 011a EE0F add r30,r30
573 011c FF1F adc r31,r31
574 011e E050 subi r30,lo8(-(TimerIntFunc))
575 0120 F040 sbci r31,hi8(-(TimerIntFunc))
576 0122 6083 st Z,r22
577 0124 7183 std Z+1,r23
578 .L29:
579 0126 0895 ret
580 /* epilogue: frame size=0 */
581 0128 0895 ret
582 /* epilogue end (size=1) */
583 /* function timerAttach size 12 (11) */
585 .Lscope14:
589 .global timerPause
591 timerPause:
593 .LM52:
594 /* prologue: frame size=0 */
595 012a DF92 push r13
596 012c EF92 push r14
597 012e FF92 push r15
598 0130 0F93 push r16
599 0132 1F93 push r17
600 0134 CF93 push r28
601 0136 DF93 push r29
602 /* prologue end (size=7) */
603 0138 EC01 movw r28,r24
605 .LM53:
606 013a D2B6 in r13,82-0x20
608 .LM54:
609 013c 1092 0000 sts TimerPauseReg,__zero_reg__
610 0140 1092 0000 sts (TimerPauseReg)+1,__zero_reg__
611 0144 1092 0000 sts (TimerPauseReg)+2,__zero_reg__
612 0148 1092 0000 sts (TimerPauseReg)+3,__zero_reg__
614 .LM55:
615 014c BEDF rcall timer0GetPrescaler
616 014e 9C01 movw r18,r24
617 0150 4427 clr r20
618 0152 5527 clr r21
619 0154 60E0 ldi r22,lo8(16000000)
620 0156 74E2 ldi r23,hi8(16000000)
621 0158 84EF ldi r24,hlo8(16000000)
622 015a 90E0 ldi r25,hhi8(16000000)
623 015c 00D0 rcall __divmodsi4
625 .LM56:
626 015e 293B cpi r18,lo8(429497)
627 0160 8DE8 ldi r24,hi8(429497)
628 0162 3807 cpc r19,r24
629 0164 86E0 ldi r24,hlo8(429497)
630 0166 4807 cpc r20,r24
631 0168 80E0 ldi r24,hhi8(429497)
632 016a 5807 cpc r21,r24
633 016c B0F4 brsh .L32
635 .LM57:
636 016e 87E2 ldi r24,hi8(10001)
637 0170 C131 cpi r28,lo8(10001)
638 0172 D807 cpc r29,r24
639 0174 90F4 brsh .L32
641 .LM58:
642 0176 CE01 movw r24,r28
643 0178 AA27 clr r26
644 017a BB27 clr r27
645 017c BC01 movw r22,r24
646 017e CD01 movw r24,r26
647 0180 00D0 rcall __mulsi3
648 0182 DC01 movw r26,r24
649 0184 CB01 movw r24,r22
650 0186 BC01 movw r22,r24
651 0188 CD01 movw r24,r26
652 018a 28EE ldi r18,lo8(1000)
653 018c 33E0 ldi r19,hi8(1000)
654 018e 40E0 ldi r20,hlo8(1000)
655 0190 50E0 ldi r21,hhi8(1000)
656 0192 00D0 rcall __udivmodsi4
657 0194 FA01 movw r30,r20
658 0196 E901 movw r28,r18
659 0198 0FC0 rjmp .L33
660 .L32:
662 .LM59:
663 019a 7E01 movw r14,r28
664 019c 0027 clr r16
665 019e 1127 clr r17
666 01a0 CA01 movw r24,r20
667 01a2 B901 movw r22,r18
668 01a4 28EE ldi r18,lo8(1000)
669 01a6 33E0 ldi r19,hi8(1000)
670 01a8 40E0 ldi r20,hlo8(1000)
671 01aa 50E0 ldi r21,hhi8(1000)
672 01ac 00D0 rcall __udivmodsi4
673 01ae C801 movw r24,r16
674 01b0 B701 movw r22,r14
675 01b2 00D0 rcall __mulsi3
676 01b4 FC01 movw r30,r24
677 01b6 EB01 movw r28,r22
678 .L33:
680 .LM60:
681 01b8 8091 0000 lds r24,TimerPauseReg
682 01bc 9091 0000 lds r25,(TimerPauseReg)+1
683 01c0 A091 0000 lds r26,(TimerPauseReg)+2
684 01c4 B091 0000 lds r27,(TimerPauseReg)+3
685 01c8 2227 clr r18
686 01ca 382F mov r19,r24
687 01cc 492F mov r20,r25
688 01ce 5A2F mov r21,r26
689 01d0 82B7 in r24,82-0x20
690 01d2 9927 clr r25
691 01d4 AA27 clr r26
692 01d6 BB27 clr r27
693 01d8 282B or r18,r24
694 01da 392B or r19,r25
695 01dc 4A2B or r20,r26
696 01de 5B2B or r21,r27
697 01e0 CD0D add r28,r13
698 01e2 D11D adc r29,__zero_reg__
699 01e4 E11D adc r30,__zero_reg__
700 01e6 F11D adc r31,__zero_reg__
701 01e8 2C17 cp r18,r28
702 01ea 3D07 cpc r19,r29
703 01ec 4E07 cpc r20,r30
704 01ee 5F07 cpc r21,r31
705 01f0 58F5 brsh .L41
706 .L39:
708 .LM61:
709 01f2 8091 0000 lds r24,TimerPauseReg
710 01f6 9091 0000 lds r25,(TimerPauseReg)+1
711 01fa A091 0000 lds r26,(TimerPauseReg)+2
712 01fe B091 0000 lds r27,(TimerPauseReg)+3
714 .LM62:
715 0202 85B7 in r24,85-0x20
716 0204 8F78 andi r24,lo8(-113)
717 0206 85BF out 85-0x20,r24
719 .LM63:
720 0208 85B7 in r24,85-0x20
721 020a 8068 ori r24,lo8(-128)
722 020c 85BF out 85-0x20,r24
723 /* #APP */
724 020e 8895 sleep
725
726 /* #NOAPP */
727 0210 85B7 in r24,85-0x20
728 0212 8F77 andi r24,lo8(127)
729 0214 85BF out 85-0x20,r24
730 0216 8091 0000 lds r24,TimerPauseReg
731 021a 9091 0000 lds r25,(TimerPauseReg)+1
732 021e A091 0000 lds r26,(TimerPauseReg)+2
733 0222 B091 0000 lds r27,(TimerPauseReg)+3
734 0226 BA2F mov r27,r26
735 0228 A92F mov r26,r25
736 022a 982F mov r25,r24
737 022c 8827 clr r24
738 022e 22B7 in r18,82-0x20
739 0230 3327 clr r19
740 0232 4427 clr r20
741 0234 5527 clr r21
742 0236 822B or r24,r18
743 0238 932B or r25,r19
744 023a A42B or r26,r20
745 023c B52B or r27,r21
746 023e 8C17 cp r24,r28
747 0240 9D07 cpc r25,r29
748 0242 AE07 cpc r26,r30
749 0244 BF07 cpc r27,r31
750 0246 A8F2 brlo .L39
751 .L41:
752 /* epilogue: frame size=0 */
753 0248 DF91 pop r29
754 024a CF91 pop r28
755 024c 1F91 pop r17
756 024e 0F91 pop r16
757 0250 FF90 pop r15
758 0252 EF90 pop r14
759 0254 DF90 pop r13
760 0256 0895 ret
761 /* epilogue end (size=8) */
762 /* function timerPause size 154 (139) */
769 .Lscope15:
772 .global timer0GetOverflowCount
774 timer0GetOverflowCount:
776 .LM64:
777 /* prologue: frame size=0 */
778 /* prologue end (size=0) */
780 .LM65:
781 0258 8091 0000 lds r24,Timer0Reg0
782 025c 9091 0000 lds r25,(Timer0Reg0)+1
783 0260 A091 0000 lds r26,(Timer0Reg0)+2
784 0264 B091 0000 lds r27,(Timer0Reg0)+3
786 .LM66:
787 0268 BC01 movw r22,r24
788 026a CD01 movw r24,r26
789 /* epilogue: frame size=0 */
790 026c 0895 ret
791 /* epilogue end (size=1) */
792 /* function timer0GetOverflowCount size 11 (10) */
794 .Lscope16:
797 .global timer2GetOverflowCount
799 timer2GetOverflowCount:
270:../avrlib/timer.c **** }
271:../avrlib/timer.c ****
272:../avrlib/timer.c **** long timer2GetOverflowCount(void)
273:../avrlib/timer.c **** {
801 .LM67:
802 /* prologue: frame size=0 */
803 /* prologue end (size=0) */
274:../avrlib/timer.c **** // return the current timer overflow count
275:../avrlib/timer.c **** // (this is since the last timer2ClearOverflowCount() command was called)
276:../avrlib/timer.c **** return Timer2Reg0;
805 .LM68:
806 026e 8091 0000 lds r24,Timer2Reg0
807 0272 9091 0000 lds r25,(Timer2Reg0)+1
808 0276 A091 0000 lds r26,(Timer2Reg0)+2
809 027a B091 0000 lds r27,(Timer2Reg0)+3
277:../avrlib/timer.c **** }
811 .LM69:
812 027e BC01 movw r22,r24
813 0280 CD01 movw r24,r26
814 /* epilogue: frame size=0 */
815 0282 0895 ret
816 /* epilogue end (size=1) */
817 /* function timer2GetOverflowCount size 11 (10) */
819 .Lscope17:
823 .global timer1PWMInit
825 timer1PWMInit:
278:../avrlib/timer.c **** #endif
279:../avrlib/timer.c ****
280:../avrlib/timer.c **** void timer1PWMInit(u08 bitRes)
281:../avrlib/timer.c **** {
827 .LM70:
828 /* prologue: frame size=0 */
829 /* prologue end (size=0) */
282:../avrlib/timer.c **** // configures timer1 for use with PWM output
283:../avrlib/timer.c **** // on OC1A and OC1B pins
284:../avrlib/timer.c ****
285:../avrlib/timer.c **** // enable timer1 as 8,9,10bit PWM
286:../avrlib/timer.c **** if(bitRes == 9)
831 .LM71:
832 0284 8930 cpi r24,lo8(9)
833 0286 31F4 brne .L45
287:../avrlib/timer.c **** { // 9bit mode
288:../avrlib/timer.c **** sbi(TCCR1A,PWM11);
835 .LM72:
836 0288 8FB5 in r24,79-0x20
837 028a 8260 ori r24,lo8(2)
838 028c 8FBD out 79-0x20,r24
289:../avrlib/timer.c **** cbi(TCCR1A,PWM10);
840 .LM73:
841 028e 8FB5 in r24,79-0x20
842 0290 8E7F andi r24,lo8(-2)
843 0292 0AC0 rjmp .L50
844 .L45:
290:../avrlib/timer.c **** }
291:../avrlib/timer.c **** else if( bitRes == 10 )
846 .LM74:
847 0294 8A30 cpi r24,lo8(10)
848 0296 19F4 brne .L47
292:../avrlib/timer.c **** { // 10bit mode
293:../avrlib/timer.c **** sbi(TCCR1A,PWM11);
850 .LM75:
851 0298 8FB5 in r24,79-0x20
852 029a 8260 ori r24,lo8(2)
853 029c 02C0 rjmp .L49
854 .L47:
294:../avrlib/timer.c **** sbi(TCCR1A,PWM10);
295:../avrlib/timer.c **** }
296:../avrlib/timer.c **** else
297:../avrlib/timer.c **** { // default 8bit mode
298:../avrlib/timer.c **** cbi(TCCR1A,PWM11);
856 .LM76:
857 029e 8FB5 in r24,79-0x20
858 02a0 8D7F andi r24,lo8(-3)
859 .L49:
860 02a2 8FBD out 79-0x20,r24
299:../avrlib/timer.c **** sbi(TCCR1A,PWM10);
862 .LM77:
863 02a4 8FB5 in r24,79-0x20
864 02a6 8160 ori r24,lo8(1)
865 .L50:
866 02a8 8FBD out 79-0x20,r24
300:../avrlib/timer.c **** }
301:../avrlib/timer.c ****
302:../avrlib/timer.c **** // clear output compare value A
303:../avrlib/timer.c **** outb(OCR1AH, 0);
868 .LM78:
869 02aa 1BBC out 75-0x20,__zero_reg__
304:../avrlib/timer.c **** outb(OCR1AL, 0);
871 .LM79:
872 02ac 1ABC out 74-0x20,__zero_reg__
305:../avrlib/timer.c **** // clear output compare value B
306:../avrlib/timer.c **** outb(OCR1BH, 0);
874 .LM80:
875 02ae 19BC out 73-0x20,__zero_reg__
307:../avrlib/timer.c **** outb(OCR1BL, 0);
877 .LM81:
878 02b0 18BC out 72-0x20,__zero_reg__
879 /* epilogue: frame size=0 */
880 02b2 0895 ret
881 /* epilogue end (size=1) */
882 /* function timer1PWMInit size 24 (23) */
884 .Lscope18:
888 .global timer1PWMInitICR
890 timer1PWMInitICR:
308:../avrlib/timer.c **** }
309:../avrlib/timer.c ****
310:../avrlib/timer.c **** #ifdef WGM10
311:../avrlib/timer.c **** // include support for arbitrary top-count PWM
312:../avrlib/timer.c **** // on new AVR processors that support it
313:../avrlib/timer.c **** void timer1PWMInitICR(u16 topcount)
314:../avrlib/timer.c **** {
892 .LM82:
893 /* prologue: frame size=0 */
894 /* prologue end (size=0) */
895 02b4 9C01 movw r18,r24
315:../avrlib/timer.c **** // set PWM mode with ICR top-count
316:../avrlib/timer.c **** cbi(TCCR1A,WGM10);
897 .LM83:
898 02b6 8FB5 in r24,79-0x20
899 02b8 8E7F andi r24,lo8(-2)
900 02ba 8FBD out 79-0x20,r24
317:../avrlib/timer.c **** sbi(TCCR1A,WGM11);
902 .LM84:
903 02bc 8FB5 in r24,79-0x20
904 02be 8260 ori r24,lo8(2)
905 02c0 8FBD out 79-0x20,r24
318:../avrlib/timer.c **** sbi(TCCR1B,WGM12);
907 .LM85:
908 02c2 8EB5 in r24,78-0x20
909 02c4 8860 ori r24,lo8(8)
910 02c6 8EBD out 78-0x20,r24
319:../avrlib/timer.c **** sbi(TCCR1B,WGM13);
912 .LM86:
913 02c8 8EB5 in r24,78-0x20
914 02ca 8061 ori r24,lo8(16)
915 02cc 8EBD out 78-0x20,r24
320:../avrlib/timer.c ****
321:../avrlib/timer.c **** // set top count value
322:../avrlib/timer.c **** ICR1 = topcount;
917 .LM87:
918 02ce 37BD out (70)+1-0x20,r19
919 02d0 26BD out 70-0x20,r18
323:../avrlib/timer.c ****
324:../avrlib/timer.c **** // clear output compare value A
325:../avrlib/timer.c **** OCR1A = 0;
921 .LM88:
922 02d2 1BBC out (74)+1-0x20,__zero_reg__
923 02d4 1ABC out 74-0x20,__zero_reg__
326:../avrlib/timer.c **** // clear output compare value B
327:../avrlib/timer.c **** OCR1B = 0;
925 .LM89:
926 02d6 19BC out (72)+1-0x20,__zero_reg__
927 02d8 18BC out 72-0x20,__zero_reg__
928 /* epilogue: frame size=0 */
929 02da 0895 ret
930 /* epilogue end (size=1) */
931 /* function timer1PWMInitICR size 20 (19) */
933 .Lscope19:
936 .global timer1PWMAOff
938 timer1PWMAOff:
328:../avrlib/timer.c ****
329:../avrlib/timer.c **** }
330:../avrlib/timer.c **** #endif
331:../avrlib/timer.c ****
332:../avrlib/timer.c **** void timer1PWMOff(void)
333:../avrlib/timer.c **** {
334:../avrlib/timer.c **** // turn off timer1 PWM mode
335:../avrlib/timer.c **** cbi(TCCR1A,PWM11);
336:../avrlib/timer.c **** cbi(TCCR1A,PWM10);
337:../avrlib/timer.c **** // set PWM1A/B (OutputCompare action) to none
338:../avrlib/timer.c **** timer1PWMAOff();
339:../avrlib/timer.c **** timer1PWMBOff();
340:../avrlib/timer.c **** }
341:../avrlib/timer.c ****
342:../avrlib/timer.c **** void timer1PWMAOn(void)
343:../avrlib/timer.c **** {
344:../avrlib/timer.c **** // turn on channel A (OC1A) PWM output
345:../avrlib/timer.c **** // set OC1A as non-inverted PWM
346:../avrlib/timer.c **** sbi(TCCR1A,COM1A1);
347:../avrlib/timer.c **** cbi(TCCR1A,COM1A0);
348:../avrlib/timer.c **** }
349:../avrlib/timer.c ****
350:../avrlib/timer.c **** void timer1PWMBOn(void)
351:../avrlib/timer.c **** {
352:../avrlib/timer.c **** // turn on channel B (OC1B) PWM output
353:../avrlib/timer.c **** // set OC1B as non-inverted PWM
354:../avrlib/timer.c **** sbi(TCCR1A,COM1B1);
355:../avrlib/timer.c **** cbi(TCCR1A,COM1B0);
356:../avrlib/timer.c **** }
357:../avrlib/timer.c ****
358:../avrlib/timer.c **** void timer1PWMAOff(void)
359:../avrlib/timer.c **** {
940 .LM90:
941 /* prologue: frame size=0 */
942 /* prologue end (size=0) */
360:../avrlib/timer.c **** // turn off channel A (OC1A) PWM output
361:../avrlib/timer.c **** // set OC1A (OutputCompare action) to none
362:../avrlib/timer.c **** cbi(TCCR1A,COM1A1);
944 .LM91:
945 02dc 8FB5 in r24,79-0x20
946 02de 8F77 andi r24,lo8(127)
947 02e0 8FBD out 79-0x20,r24
363:../avrlib/timer.c **** cbi(TCCR1A,COM1A0);
949 .LM92:
950 02e2 8FB5 in r24,79-0x20
951 02e4 8F7B andi r24,lo8(-65)
952 02e6 8FBD out 79-0x20,r24
953 /* epilogue: frame size=0 */
954 02e8 0895 ret
955 /* epilogue end (size=1) */
956 /* function timer1PWMAOff size 7 (6) */
958 .Lscope20:
961 .global timer1PWMBOff
963 timer1PWMBOff:
364:../avrlib/timer.c **** }
365:../avrlib/timer.c ****
366:../avrlib/timer.c **** void timer1PWMBOff(void)
367:../avrlib/timer.c **** {
965 .LM93:
966 /* prologue: frame size=0 */
967 /* prologue end (size=0) */
368:../avrlib/timer.c **** // turn off channel B (OC1B) PWM output
369:../avrlib/timer.c **** // set OC1B (OutputCompare action) to none
370:../avrlib/timer.c **** cbi(TCCR1A,COM1B1);
969 .LM94:
970 02ea 8FB5 in r24,79-0x20
971 02ec 8F7D andi r24,lo8(-33)
972 02ee 8FBD out 79-0x20,r24
371:../avrlib/timer.c **** cbi(TCCR1A,COM1B0);
974 .LM95:
975 02f0 8FB5 in r24,79-0x20
976 02f2 8F7E andi r24,lo8(-17)
977 02f4 8FBD out 79-0x20,r24
978 /* epilogue: frame size=0 */
979 02f6 0895 ret
980 /* epilogue end (size=1) */
981 /* function timer1PWMBOff size 7 (6) */
983 .Lscope21:
986 .global timer1PWMOff
988 timer1PWMOff:
990 .LM96:
991 /* prologue: frame size=0 */
992 /* prologue end (size=0) */
994 .LM97:
995 02f8 8FB5 in r24,79-0x20
996 02fa 8D7F andi r24,lo8(-3)
997 02fc 8FBD out 79-0x20,r24
999 .LM98:
1000 02fe 8FB5 in r24,79-0x20
1001 0300 8E7F andi r24,lo8(-2)
1002 0302 8FBD out 79-0x20,r24
1004 .LM99:
1005 0304 EBDF rcall timer1PWMAOff
1007 .LM100:
1008 0306 F1DF rcall timer1PWMBOff
1009 /* epilogue: frame size=0 */
1010 0308 0895 ret
1011 /* epilogue end (size=1) */
1012 /* function timer1PWMOff size 9 (8) */
1014 .Lscope22:
1017 .global timer1PWMAOn
1019 timer1PWMAOn:
1021 .LM101:
1022 /* prologue: frame size=0 */
1023 /* prologue end (size=0) */
1025 .LM102:
1026 030a 8FB5 in r24,79-0x20
1027 030c 8068 ori r24,lo8(-128)
1028 030e 8FBD out 79-0x20,r24
1030 .LM103:
1031 0310 8FB5 in r24,79-0x20
1032 0312 8F7B andi r24,lo8(-65)
1033 0314 8FBD out 79-0x20,r24
1034 /* epilogue: frame size=0 */
1035 0316 0895 ret
1036 /* epilogue end (size=1) */
1037 /* function timer1PWMAOn size 7 (6) */
1039 .Lscope23:
1042 .global timer1PWMBOn
1044 timer1PWMBOn:
1046 .LM104:
1047 /* prologue: frame size=0 */
1048 /* prologue end (size=0) */
1050 .LM105:
1051 0318 8FB5 in r24,79-0x20
1052 031a 8062 ori r24,lo8(32)
1053 031c 8FBD out 79-0x20,r24
1055 .LM106:
1056 031e 8FB5 in r24,79-0x20
1057 0320 8F7E andi r24,lo8(-17)
1058 0322 8FBD out 79-0x20,r24
1059 /* epilogue: frame size=0 */
1060 0324 0895 ret
1061 /* epilogue end (size=1) */
1062 /* function timer1PWMBOn size 7 (6) */
1064 .Lscope24:
1068 .global timer1PWMASet
1070 timer1PWMASet:
372:../avrlib/timer.c **** }
373:../avrlib/timer.c ****
374:../avrlib/timer.c **** void timer1PWMASet(u16 pwmDuty)
375:../avrlib/timer.c **** {
1072 .LM107:
1073 /* prologue: frame size=0 */
1074 /* prologue end (size=0) */
376:../avrlib/timer.c **** // set PWM (output compare) duty for channel A
377:../avrlib/timer.c **** // this PWM output is generated on OC1A pin
378:../avrlib/timer.c **** // NOTE: pwmDuty should be in the range 0-255 for 8bit PWM
379:../avrlib/timer.c **** // pwmDuty should be in the range 0-511 for 9bit PWM
380:../avrlib/timer.c **** // pwmDuty should be in the range 0-1023 for 10bit PWM
381:../avrlib/timer.c **** //outp( (pwmDuty>>8), OCR1AH); // set the high 8bits of OCR1A
382:../avrlib/timer.c **** //outp( (pwmDuty&0x00FF), OCR1AL); // set the low 8bits of OCR1A
383:../avrlib/timer.c **** OCR1A = pwmDuty;
1076 .LM108:
1077 0326 9BBD out (74)+1-0x20,r25
1078 0328 8ABD out 74-0x20,r24
1079 /* epilogue: frame size=0 */
1080 032a 0895 ret
1081 /* epilogue end (size=1) */
1082 /* function timer1PWMASet size 3 (2) */
1084 .Lscope25:
1088 .global timer1PWMBSet
1090 timer1PWMBSet:
384:../avrlib/timer.c **** }
385:../avrlib/timer.c ****
386:../avrlib/timer.c **** void timer1PWMBSet(u16 pwmDuty)
387:../avrlib/timer.c **** {
1092 .LM109:
1093 /* prologue: frame size=0 */
1094 /* prologue end (size=0) */
388:../avrlib/timer.c **** // set PWM (output compare) duty for channel B
389:../avrlib/timer.c **** // this PWM output is generated on OC1B pin
390:../avrlib/timer.c **** // NOTE: pwmDuty should be in the range 0-255 for 8bit PWM
391:../avrlib/timer.c **** // pwmDuty should be in the range 0-511 for 9bit PWM
392:../avrlib/timer.c **** // pwmDuty should be in the range 0-1023 for 10bit PWM
393:../avrlib/timer.c **** //outp( (pwmDuty>>8), OCR1BH); // set the high 8bits of OCR1B
394:../avrlib/timer.c **** //outp( (pwmDuty&0x00FF), OCR1BL); // set the low 8bits of OCR1B
395:../avrlib/timer.c **** OCR1B = pwmDuty;
1096 .LM110:
1097 032c 99BD out (72)+1-0x20,r25
1098 032e 88BD out 72-0x20,r24
1099 /* epilogue: frame size=0 */
1100 0330 0895 ret
1101 /* epilogue end (size=1) */
1102 /* function timer1PWMBSet size 3 (2) */
1104 .Lscope26:
1107 .global __vector_9
1109 __vector_9:
396:../avrlib/timer.c **** }
397:../avrlib/timer.c ****
398:../avrlib/timer.c **** //! Interrupt handler for tcnt0 overflow interrupt
399:../avrlib/timer.c **** TIMER_INTERRUPT_HANDLER(SIG_OVERFLOW0)
400:../avrlib/timer.c **** {
1111 .LM111:
1112 /* prologue: frame size=0 */
1113 0332 1F92 push __zero_reg__
1114 0334 0F92 push __tmp_reg__
1115 0336 0FB6 in __tmp_reg__,__SREG__
1116 0338 0F92 push __tmp_reg__
1117 033a 1124 clr __zero_reg__
1118 033c 2F93 push r18
1119 033e 3F93 push r19
1120 0340 4F93 push r20
1121 0342 5F93 push r21
1122 0344 6F93 push r22
1123 0346 7F93 push r23
1124 0348 8F93 push r24
1125 034a 9F93 push r25
1126 034c AF93 push r26
1127 034e BF93 push r27
1128 0350 EF93 push r30
1129 0352 FF93 push r31
1130 /* prologue end (size=17) */
401:../avrlib/timer.c **** Timer0Reg0++; // increment low-order counter
1132 .LM112:
1133 0354 8091 0000 lds r24,Timer0Reg0
1134 0358 9091 0000 lds r25,(Timer0Reg0)+1
1135 035c A091 0000 lds r26,(Timer0Reg0)+2
1136 0360 B091 0000 lds r27,(Timer0Reg0)+3
1137 0364 0196 adiw r24,1
1138 0366 A11D adc r26,__zero_reg__
1139 0368 B11D adc r27,__zero_reg__
1140 036a 8093 0000 sts Timer0Reg0,r24
1141 036e 9093 0000 sts (Timer0Reg0)+1,r25
1142 0372 A093 0000 sts (Timer0Reg0)+2,r26
1143 0376 B093 0000 sts (Timer0Reg0)+3,r27
402:../avrlib/timer.c ****
403:../avrlib/timer.c **** // increment pause counter
404:../avrlib/timer.c **** TimerPauseReg++;
1145 .LM113:
1146 037a 8091 0000 lds r24,TimerPauseReg
1147 037e 9091 0000 lds r25,(TimerPauseReg)+1
1148 0382 A091 0000 lds r26,(TimerPauseReg)+2
1149 0386 B091 0000 lds r27,(TimerPauseReg)+3
1150 038a 0196 adiw r24,1
1151 038c A11D adc r26,__zero_reg__
1152 038e B11D adc r27,__zero_reg__
1153 0390 8093 0000 sts TimerPauseReg,r24
1154 0394 9093 0000 sts (TimerPauseReg)+1,r25
1155 0398 A093 0000 sts (TimerPauseReg)+2,r26
1156 039c B093 0000 sts (TimerPauseReg)+3,r27
405:../avrlib/timer.c ****
406:../avrlib/timer.c **** // if a user function is defined, execute it too
407:../avrlib/timer.c **** if(TimerIntFunc[TIMER0OVERFLOW_INT])
1158 .LM114:
1159 03a0 8091 0000 lds r24,TimerIntFunc
1160 03a4 9091 0000 lds r25,(TimerIntFunc)+1
1161 03a8 892B or r24,r25
1162 03aa 29F0 breq .L59
408:../avrlib/timer.c **** TimerIntFunc[TIMER0OVERFLOW_INT]();
1164 .LM115:
1165 03ac E091 0000 lds r30,TimerIntFunc
1166 03b0 F091 0000 lds r31,(TimerIntFunc)+1
1167 03b4 0995 icall
1168 .L59:
1169 /* epilogue: frame size=0 */
1170 03b6 FF91 pop r31
1171 03b8 EF91 pop r30
1172 03ba BF91 pop r27
1173 03bc AF91 pop r26
1174 03be 9F91 pop r25
1175 03c0 8F91 pop r24
1176 03c2 7F91 pop r23
1177 03c4 6F91 pop r22
1178 03c6 5F91 pop r21
1179 03c8 4F91 pop r20
1180 03ca 3F91 pop r19
1181 03cc 2F91 pop r18
1182 03ce 0F90 pop __tmp_reg__
1183 03d0 0FBE out __SREG__,__tmp_reg__
1184 03d2 0F90 pop __tmp_reg__
1185 03d4 1F90 pop __zero_reg__
1186 03d6 1895 reti
1187 /* epilogue end (size=17) */
1188 /* function __vector_9 size 83 (49) */
1190 .Lscope27:
1193 .global __vector_8
1195 __vector_8:
409:../avrlib/timer.c **** }
410:../avrlib/timer.c ****
411:../avrlib/timer.c **** //! Interrupt handler for tcnt1 overflow interrupt
412:../avrlib/timer.c **** TIMER_INTERRUPT_HANDLER(SIG_OVERFLOW1)
413:../avrlib/timer.c **** {
1197 .LM116:
1198 /* prologue: frame size=0 */
1199 03d8 1F92 push __zero_reg__
1200 03da 0F92 push __tmp_reg__
1201 03dc 0FB6 in __tmp_reg__,__SREG__
1202 03de 0F92 push __tmp_reg__
1203 03e0 1124 clr __zero_reg__
1204 03e2 2F93 push r18
1205 03e4 3F93 push r19
1206 03e6 4F93 push r20
1207 03e8 5F93 push r21
1208 03ea 6F93 push r22
1209 03ec 7F93 push r23
1210 03ee 8F93 push r24
1211 03f0 9F93 push r25
1212 03f2 AF93 push r26
1213 03f4 BF93 push r27
1214 03f6 EF93 push r30
1215 03f8 FF93 push r31
1216 /* prologue end (size=17) */
414:../avrlib/timer.c **** // if a user function is defined, execute it
415:../avrlib/timer.c **** if(TimerIntFunc[TIMER1OVERFLOW_INT])
1218 .LM117:
1219 03fa 8091 0000 lds r24,TimerIntFunc+2
1220 03fe 9091 0000 lds r25,(TimerIntFunc+2)+1
1221 0402 892B or r24,r25
1222 0404 29F0 breq .L61
416:../avrlib/timer.c **** TimerIntFunc[TIMER1OVERFLOW_INT]();
1224 .LM118:
1225 0406 E091 0000 lds r30,TimerIntFunc+2
1226 040a F091 0000 lds r31,(TimerIntFunc+2)+1
1227 040e 0995 icall
1228 .L61:
1229 /* epilogue: frame size=0 */
1230 0410 FF91 pop r31
1231 0412 EF91 pop r30
1232 0414 BF91 pop r27
1233 0416 AF91 pop r26
1234 0418 9F91 pop r25
1235 041a 8F91 pop r24
1236 041c 7F91 pop r23
1237 041e 6F91 pop r22
1238 0420 5F91 pop r21
1239 0422 4F91 pop r20
1240 0424 3F91 pop r19
1241 0426 2F91 pop r18
1242 0428 0F90 pop __tmp_reg__
1243 042a 0FBE out __SREG__,__tmp_reg__
1244 042c 0F90 pop __tmp_reg__
1245 042e 1F90 pop __zero_reg__
1246 0430 1895 reti
1247 /* epilogue end (size=17) */
1248 /* function __vector_8 size 45 (11) */
1250 .Lscope28:
1253 .global __vector_4
1255 __vector_4:
417:../avrlib/timer.c **** }
418:../avrlib/timer.c ****
419:../avrlib/timer.c **** #ifdef TCNT2 // support timer2 only if it exists
420:../avrlib/timer.c **** //! Interrupt handler for tcnt2 overflow interrupt
421:../avrlib/timer.c **** TIMER_INTERRUPT_HANDLER(SIG_OVERFLOW2)
422:../avrlib/timer.c **** {
1257 .LM119:
1258 /* prologue: frame size=0 */
1259 0432 1F92 push __zero_reg__
1260 0434 0F92 push __tmp_reg__
1261 0436 0FB6 in __tmp_reg__,__SREG__
1262 0438 0F92 push __tmp_reg__
1263 043a 1124 clr __zero_reg__
1264 043c 2F93 push r18
1265 043e 3F93 push r19
1266 0440 4F93 push r20
1267 0442 5F93 push r21
1268 0444 6F93 push r22
1269 0446 7F93 push r23
1270 0448 8F93 push r24
1271 044a 9F93 push r25
1272 044c AF93 push r26
1273 044e BF93 push r27
1274 0450 EF93 push r30
1275 0452 FF93 push r31
1276 /* prologue end (size=17) */
423:../avrlib/timer.c **** Timer2Reg0++; // increment low-order counter
1278 .LM120:
1279 0454 8091 0000 lds r24,Timer2Reg0
1280 0458 9091 0000 lds r25,(Timer2Reg0)+1
1281 045c A091 0000 lds r26,(Timer2Reg0)+2
1282 0460 B091 0000 lds r27,(Timer2Reg0)+3
1283 0464 0196 adiw r24,1
1284 0466 A11D adc r26,__zero_reg__
1285 0468 B11D adc r27,__zero_reg__
1286 046a 8093 0000 sts Timer2Reg0,r24
1287 046e 9093 0000 sts (Timer2Reg0)+1,r25
1288 0472 A093 0000 sts (Timer2Reg0)+2,r26
1289 0476 B093 0000 sts (Timer2Reg0)+3,r27
424:../avrlib/timer.c ****
425:../avrlib/timer.c **** // if a user function is defined, execute it
426:../avrlib/timer.c **** if(TimerIntFunc[TIMER2OVERFLOW_INT])
1291 .LM121:
1292 047a 8091 0000 lds r24,TimerIntFunc+10
1293 047e 9091 0000 lds r25,(TimerIntFunc+10)+1
1294 0482 892B or r24,r25
1295 0484 29F0 breq .L63
427:../avrlib/timer.c **** TimerIntFunc[TIMER2OVERFLOW_INT]();
1297 .LM122:
1298 0486 E091 0000 lds r30,TimerIntFunc+10
1299 048a F091 0000 lds r31,(TimerIntFunc+10)+1
1300 048e 0995 icall
1301 .L63:
1302 /* epilogue: frame size=0 */
1303 0490 FF91 pop r31
1304 0492 EF91 pop r30
1305 0494 BF91 pop r27
1306 0496 AF91 pop r26
1307 0498 9F91 pop r25
1308 049a 8F91 pop r24
1309 049c 7F91 pop r23
1310 049e 6F91 pop r22
1311 04a0 5F91 pop r21
1312 04a2 4F91 pop r20
1313 04a4 3F91 pop r19
1314 04a6 2F91 pop r18
1315 04a8 0F90 pop __tmp_reg__
1316 04aa 0FBE out __SREG__,__tmp_reg__
1317 04ac 0F90 pop __tmp_reg__
1318 04ae 1F90 pop __zero_reg__
1319 04b0 1895 reti
1320 /* epilogue end (size=17) */
1321 /* function __vector_4 size 64 (30) */
1323 .Lscope29:
1326 .global __vector_6
1328 __vector_6:
428:../avrlib/timer.c **** }
429:../avrlib/timer.c **** #endif
430:../avrlib/timer.c ****
431:../avrlib/timer.c **** #ifdef OCR0
432:../avrlib/timer.c **** // include support for Output Compare 0 for new AVR processors that support it
433:../avrlib/timer.c **** //! Interrupt handler for OutputCompare0 match (OC0) interrupt
434:../avrlib/timer.c **** TIMER_INTERRUPT_HANDLER(SIG_OUTPUT_COMPARE0)
435:../avrlib/timer.c **** {
436:../avrlib/timer.c **** // if a user function is defined, execute it
437:../avrlib/timer.c **** if(TimerIntFunc[TIMER0OUTCOMPARE_INT])
438:../avrlib/timer.c **** TimerIntFunc[TIMER0OUTCOMPARE_INT]();
439:../avrlib/timer.c **** }
440:../avrlib/timer.c **** #endif
441:../avrlib/timer.c ****
442:../avrlib/timer.c **** //! Interrupt handler for CutputCompare1A match (OC1A) interrupt
443:../avrlib/timer.c **** TIMER_INTERRUPT_HANDLER(SIG_OUTPUT_COMPARE1A)
444:../avrlib/timer.c **** {
1330 .LM123:
1331 /* prologue: frame size=0 */
1332 04b2 1F92 push __zero_reg__
1333 04b4 0F92 push __tmp_reg__
1334 04b6 0FB6 in __tmp_reg__,__SREG__
1335 04b8 0F92 push __tmp_reg__
1336 04ba 1124 clr __zero_reg__
1337 04bc 2F93 push r18
1338 04be 3F93 push r19
1339 04c0 4F93 push r20
1340 04c2 5F93 push r21
1341 04c4 6F93 push r22
1342 04c6 7F93 push r23
1343 04c8 8F93 push r24
1344 04ca 9F93 push r25
1345 04cc AF93 push r26
1346 04ce BF93 push r27
1347 04d0 EF93 push r30
1348 04d2 FF93 push r31
1349 /* prologue end (size=17) */
445:../avrlib/timer.c **** // if a user function is defined, execute it
446:../avrlib/timer.c **** if(TimerIntFunc[TIMER1OUTCOMPAREA_INT])
1351 .LM124:
1352 04d4 8091 0000 lds r24,TimerIntFunc+4
1353 04d8 9091 0000 lds r25,(TimerIntFunc+4)+1
1354 04dc 892B or r24,r25
1355 04de 29F0 breq .L65
447:../avrlib/timer.c **** TimerIntFunc[TIMER1OUTCOMPAREA_INT]();
1357 .LM125:
1358 04e0 E091 0000 lds r30,TimerIntFunc+4
1359 04e4 F091 0000 lds r31,(TimerIntFunc+4)+1
1360 04e8 0995 icall
1361 .L65:
1362 /* epilogue: frame size=0 */
1363 04ea FF91 pop r31
1364 04ec EF91 pop r30
1365 04ee BF91 pop r27
1366 04f0 AF91 pop r26
1367 04f2 9F91 pop r25
1368 04f4 8F91 pop r24
1369 04f6 7F91 pop r23
1370 04f8 6F91 pop r22
1371 04fa 5F91 pop r21
1372 04fc 4F91 pop r20
1373 04fe 3F91 pop r19
1374 0500 2F91 pop r18
1375 0502 0F90 pop __tmp_reg__
1376 0504 0FBE out __SREG__,__tmp_reg__
1377 0506 0F90 pop __tmp_reg__
1378 0508 1F90 pop __zero_reg__
1379 050a 1895 reti
1380 /* epilogue end (size=17) */
1381 /* function __vector_6 size 45 (11) */
1383 .Lscope30:
1386 .global __vector_7
1388 __vector_7:
448:../avrlib/timer.c **** }
449:../avrlib/timer.c ****
450:../avrlib/timer.c **** //! Interrupt handler for OutputCompare1B match (OC1B) interrupt
451:../avrlib/timer.c **** TIMER_INTERRUPT_HANDLER(SIG_OUTPUT_COMPARE1B)
452:../avrlib/timer.c **** {
1390 .LM126:
1391 /* prologue: frame size=0 */
1392 050c 1F92 push __zero_reg__
1393 050e 0F92 push __tmp_reg__
1394 0510 0FB6 in __tmp_reg__,__SREG__
1395 0512 0F92 push __tmp_reg__
1396 0514 1124 clr __zero_reg__
1397 0516 2F93 push r18
1398 0518 3F93 push r19
1399 051a 4F93 push r20
1400 051c 5F93 push r21
1401 051e 6F93 push r22
1402 0520 7F93 push r23
1403 0522 8F93 push r24
1404 0524 9F93 push r25
1405 0526 AF93 push r26
1406 0528 BF93 push r27
1407 052a EF93 push r30
1408 052c FF93 push r31
1409 /* prologue end (size=17) */
453:../avrlib/timer.c **** // if a user function is defined, execute it
454:../avrlib/timer.c **** if(TimerIntFunc[TIMER1OUTCOMPAREB_INT])
1411 .LM127:
1412 052e 8091 0000 lds r24,TimerIntFunc+6
1413 0532 9091 0000 lds r25,(TimerIntFunc+6)+1
1414 0536 892B or r24,r25
1415 0538 29F0 breq .L67
455:../avrlib/timer.c **** TimerIntFunc[TIMER1OUTCOMPAREB_INT]();
1417 .LM128:
1418 053a E091 0000 lds r30,TimerIntFunc+6
1419 053e F091 0000 lds r31,(TimerIntFunc+6)+1
1420 0542 0995 icall
1421 .L67:
1422 /* epilogue: frame size=0 */
1423 0544 FF91 pop r31
1424 0546 EF91 pop r30
1425 0548 BF91 pop r27
1426 054a AF91 pop r26
1427 054c 9F91 pop r25
1428 054e 8F91 pop r24
1429 0550 7F91 pop r23
1430 0552 6F91 pop r22
1431 0554 5F91 pop r21
1432 0556 4F91 pop r20
1433 0558 3F91 pop r19
1434 055a 2F91 pop r18
1435 055c 0F90 pop __tmp_reg__
1436 055e 0FBE out __SREG__,__tmp_reg__
1437 0560 0F90 pop __tmp_reg__
1438 0562 1F90 pop __zero_reg__
1439 0564 1895 reti
1440 /* epilogue end (size=17) */
1441 /* function __vector_7 size 45 (11) */
1443 .Lscope31:
1446 .global __vector_5
1448 __vector_5:
456:../avrlib/timer.c **** }
457:../avrlib/timer.c ****
458:../avrlib/timer.c **** //! Interrupt handler for InputCapture1 (IC1) interrupt
459:../avrlib/timer.c **** TIMER_INTERRUPT_HANDLER(SIG_INPUT_CAPTURE1)
460:../avrlib/timer.c **** {
1450 .LM129:
1451 /* prologue: frame size=0 */
1452 0566 1F92 push __zero_reg__
1453 0568 0F92 push __tmp_reg__
1454 056a 0FB6 in __tmp_reg__,__SREG__
1455 056c 0F92 push __tmp_reg__
1456 056e 1124 clr __zero_reg__
1457 0570 2F93 push r18
1458 0572 3F93 push r19
1459 0574 4F93 push r20
1460 0576 5F93 push r21
1461 0578 6F93 push r22
1462 057a 7F93 push r23
1463 057c 8F93 push r24
1464 057e 9F93 push r25
1465 0580 AF93 push r26
1466 0582 BF93 push r27
1467 0584 EF93 push r30
1468 0586 FF93 push r31
1469 /* prologue end (size=17) */
461:../avrlib/timer.c **** // if a user function is defined, execute it
462:../avrlib/timer.c **** if(TimerIntFunc[TIMER1INPUTCAPTURE_INT])
1471 .LM130:
1472 0588 8091 0000 lds r24,TimerIntFunc+8
1473 058c 9091 0000 lds r25,(TimerIntFunc+8)+1
1474 0590 892B or r24,r25
1475 0592 29F0 breq .L69
463:../avrlib/timer.c **** TimerIntFunc[TIMER1INPUTCAPTURE_INT]();
1477 .LM131:
1478 0594 E091 0000 lds r30,TimerIntFunc+8
1479 0598 F091 0000 lds r31,(TimerIntFunc+8)+1
1480 059c 0995 icall
1481 .L69:
1482 /* epilogue: frame size=0 */
1483 059e FF91 pop r31
1484 05a0 EF91 pop r30
1485 05a2 BF91 pop r27
1486 05a4 AF91 pop r26
1487 05a6 9F91 pop r25
1488 05a8 8F91 pop r24
1489 05aa 7F91 pop r23
1490 05ac 6F91 pop r22
1491 05ae 5F91 pop r21
1492 05b0 4F91 pop r20
1493 05b2 3F91 pop r19
1494 05b4 2F91 pop r18
1495 05b6 0F90 pop __tmp_reg__
1496 05b8 0FBE out __SREG__,__tmp_reg__
1497 05ba 0F90 pop __tmp_reg__
1498 05bc 1F90 pop __zero_reg__
1499 05be 1895 reti
1500 /* epilogue end (size=17) */
1501 /* function __vector_5 size 45 (11) */
1503 .Lscope32:
1506 .global __vector_3
1508 __vector_3:
464:../avrlib/timer.c **** }
465:../avrlib/timer.c ****
466:../avrlib/timer.c **** //! Interrupt handler for OutputCompare2 match (OC2) interrupt
467:../avrlib/timer.c **** TIMER_INTERRUPT_HANDLER(SIG_OUTPUT_COMPARE2)
468:../avrlib/timer.c **** {
1510 .LM132:
1511 /* prologue: frame size=0 */
1512 05c0 1F92 push __zero_reg__
1513 05c2 0F92 push __tmp_reg__
1514 05c4 0FB6 in __tmp_reg__,__SREG__
1515 05c6 0F92 push __tmp_reg__
1516 05c8 1124 clr __zero_reg__
1517 05ca 2F93 push r18
1518 05cc 3F93 push r19
1519 05ce 4F93 push r20
1520 05d0 5F93 push r21
1521 05d2 6F93 push r22
1522 05d4 7F93 push r23
1523 05d6 8F93 push r24
1524 05d8 9F93 push r25
1525 05da AF93 push r26
1526 05dc BF93 push r27
1527 05de EF93 push r30
1528 05e0 FF93 push r31
1529 /* prologue end (size=17) */
469:../avrlib/timer.c **** // if a user function is defined, execute it
470:../avrlib/timer.c **** if(TimerIntFunc[TIMER2OUTCOMPARE_INT])
1531 .LM133:
1532 05e2 8091 0000 lds r24,TimerIntFunc+12
1533 05e6 9091 0000 lds r25,(TimerIntFunc+12)+1
1534 05ea 892B or r24,r25
1535 05ec 29F0 breq .L71
471:../avrlib/timer.c **** TimerIntFunc[TIMER2OUTCOMPARE_INT]();
1537 .LM134:
1538 05ee E091 0000 lds r30,TimerIntFunc+12
1539 05f2 F091 0000 lds r31,(TimerIntFunc+12)+1
1540 05f6 0995 icall
1541 .L71:
1542 /* epilogue: frame size=0 */
1543 05f8 FF91 pop r31
1544 05fa EF91 pop r30
1545 05fc BF91 pop r27
1546 05fe AF91 pop r26
1547 0600 9F91 pop r25
1548 0602 8F91 pop r24
1549 0604 7F91 pop r23
1550 0606 6F91 pop r22
1551 0608 5F91 pop r21
1552 060a 4F91 pop r20
1553 060c 3F91 pop r19
1554 060e 2F91 pop r18
1555 0610 0F90 pop __tmp_reg__
1556 0612 0FBE out __SREG__,__tmp_reg__
1557 0614 0F90 pop __tmp_reg__
1558 0616 1F90 pop __zero_reg__
1559 0618 1895 reti
1560 /* epilogue end (size=17) */
1561 /* function __vector_3 size 45 (11) */
1563 .Lscope33:
1565 .comm TimerPauseReg,4,1
1566 .comm Timer0Reg0,4,1
1567 .comm Timer2Reg0,4,1
1568 .lcomm TimerIntFunc,14
1575 .text
1577 Letext:
1578 /* File "../avrlib/timer.c": code 797 = 0x031d ( 517), prologues 127, epilogues 153 */
DEFINED SYMBOLS
*ABS*:00000000 timer.c
*ABS*:0000003f __SREG__
*ABS*:0000003e __SP_H__
*ABS*:0000003d __SP_L__
*ABS*:00000000 __tmp_reg__
*ABS*:00000001 __zero_reg__
/var/tmp//cca6lG7e.s:98 .progmem.data:00000000 TimerRTCPrescaleFactor
/var/tmp//cca6lG7e.s:110 .progmem.data:00000010 TimerPrescaleFactor
/var/tmp//cca6lG7e.s:122 .text:00000000 delay_us
/var/tmp//cca6lG7e.s:167 .text:00000026 timerDetach
.bss:00000000 TimerIntFunc
/var/tmp//cca6lG7e.s:199 .text:0000003e timer0SetPrescaler
/var/tmp//cca6lG7e.s:220 .text:00000048 timer0ClearOverflowCount
*COM*:00000004 Timer0Reg0
/var/tmp//cca6lG7e.s:241 .text:0000005a timer0Init
/var/tmp//cca6lG7e.s:272 .text:0000006a timer1SetPrescaler
/var/tmp//cca6lG7e.s:293 .text:00000074 timer1Init
/var/tmp//cca6lG7e.s:324 .text:00000084 timer2SetPrescaler
/var/tmp//cca6lG7e.s:345 .text:0000008e timer2ClearOverflowCount
*COM*:00000004 Timer2Reg0
/var/tmp//cca6lG7e.s:366 .text:000000a0 timer2Init
/var/tmp//cca6lG7e.s:396 .text:000000b0 timerInit
/var/tmp//cca6lG7e.s:443 .text:000000ca timer0GetPrescaler
/var/tmp//cca6lG7e.s:481 .text:000000e2 timer1GetPrescaler
/var/tmp//cca6lG7e.s:519 .text:000000fa timer2GetPrescaler
/var/tmp//cca6lG7e.s:559 .text:00000112 timerAttach
/var/tmp//cca6lG7e.s:591 .text:0000012a timerPause
*COM*:00000004 TimerPauseReg
/var/tmp//cca6lG7e.s:774 .text:00000258 timer0GetOverflowCount
/var/tmp//cca6lG7e.s:799 .text:0000026e timer2GetOverflowCount
/var/tmp//cca6lG7e.s:825 .text:00000284 timer1PWMInit
/var/tmp//cca6lG7e.s:890 .text:000002b4 timer1PWMInitICR
/var/tmp//cca6lG7e.s:938 .text:000002dc timer1PWMAOff
/var/tmp//cca6lG7e.s:963 .text:000002ea timer1PWMBOff
/var/tmp//cca6lG7e.s:988 .text:000002f8 timer1PWMOff
/var/tmp//cca6lG7e.s:1019 .text:0000030a timer1PWMAOn
/var/tmp//cca6lG7e.s:1044 .text:00000318 timer1PWMBOn
/var/tmp//cca6lG7e.s:1070 .text:00000326 timer1PWMASet
/var/tmp//cca6lG7e.s:1090 .text:0000032c timer1PWMBSet
/var/tmp//cca6lG7e.s:1109 .text:00000332 __vector_9
/var/tmp//cca6lG7e.s:1195 .text:000003d8 __vector_8
/var/tmp//cca6lG7e.s:1255 .text:00000432 __vector_4
/var/tmp//cca6lG7e.s:1328 .text:000004b2 __vector_6
/var/tmp//cca6lG7e.s:1388 .text:0000050c __vector_7
/var/tmp//cca6lG7e.s:1448 .text:00000566 __vector_5
/var/tmp//cca6lG7e.s:1508 .text:000005c0 __vector_3
/var/tmp//cca6lG7e.s:1577 .text:0000061a Letext
UNDEFINED SYMBOLS
__do_copy_data
__do_clear_bss
__udivmodhi4
__divmodsi4
__mulsi3
__udivmodsi4