RTEMS CPU Kit with SuperCore  4.11.3
iom48p.h
Go to the documentation of this file.
1 
9 /*
10  * Copyright (c) 2007 Atmel Corporation
11  * All rights reserved.
12  *
13  * Redistribution and use in source and binary forms, with or without
14  * modification, are permitted provided that the following conditions are met:
15  *
16  * * Redistributions of source code must retain the above copyright
17  * notice, this list of conditions and the following disclaimer.
18  *
19  * * Redistributions in binary form must reproduce the above copyright
20  * notice, this list of conditions and the following disclaimer in
21  * the documentation and/or other materials provided with the
22  * distribution.
23  *
24  * * Neither the name of the copyright holders nor the names of
25  * contributors may be used to endorse or promote products derived
26  * from this software without specific prior written permission.
27  *
28  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
29  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
30  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
31  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
32  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
33  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
34  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
35  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
36  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
37  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
38  * POSSIBILITY OF SUCH DAMAGE.
39  */
40 
41 #ifndef _AVR_IO_H_
42 # error "Include <avr/io.h> instead of this file."
43 #endif
44 
45 #ifndef _AVR_IOXXX_H_
46 # define _AVR_IOXXX_H_ "iom48p.h"
47 #else
48 # error "Attempt to include more than one <avr/ioXXX.h> file."
49 #endif
50 
51 
52 #ifndef _AVR_IOM48P_H_
53 #define _AVR_IOM48P_H_ 1
54 
62 /* Registers and associated bit numbers */
63 
64 #define PINB _SFR_IO8(0x03)
65 #define PINB0 0
66 #define PINB1 1
67 #define PINB2 2
68 #define PINB3 3
69 #define PINB4 4
70 #define PINB5 5
71 #define PINB6 6
72 #define PINB7 7
73 
74 #define DDRB _SFR_IO8(0x04)
75 #define DDB0 0
76 #define DDB1 1
77 #define DDB2 2
78 #define DDB3 3
79 #define DDB4 4
80 #define DDB5 5
81 #define DDB6 6
82 #define DDB7 7
83 
84 #define PORTB _SFR_IO8(0x05)
85 #define PORTB0 0
86 #define PORTB1 1
87 #define PORTB2 2
88 #define PORTB3 3
89 #define PORTB4 4
90 #define PORTB5 5
91 #define PORTB6 6
92 #define PORTB7 7
93 
94 #define PINC _SFR_IO8(0x06)
95 #define PINC0 0
96 #define PINC1 1
97 #define PINC2 2
98 #define PINC3 3
99 #define PINC4 4
100 #define PINC5 5
101 #define PINC6 6
102 
103 #define DDRC _SFR_IO8(0x07)
104 #define DDC0 0
105 #define DDC1 1
106 #define DDC2 2
107 #define DDC3 3
108 #define DDC4 4
109 #define DDC5 5
110 #define DDC6 6
111 
112 #define PORTC _SFR_IO8(0x08)
113 #define PORTC0 0
114 #define PORTC1 1
115 #define PORTC2 2
116 #define PORTC3 3
117 #define PORTC4 4
118 #define PORTC5 5
119 #define PORTC6 6
120 
121 #define PIND _SFR_IO8(0x09)
122 #define PIND0 0
123 #define PIND1 1
124 #define PIND2 2
125 #define PIND3 3
126 #define PIND4 4
127 #define PIND5 5
128 #define PIND6 6
129 #define PIND7 7
130 
131 #define DDRD _SFR_IO8(0x0A)
132 #define DDD0 0
133 #define DDD1 1
134 #define DDD2 2
135 #define DDD3 3
136 #define DDD4 4
137 #define DDD5 5
138 #define DDD6 6
139 #define DDD7 7
140 
141 #define PORTD _SFR_IO8(0x0B)
142 #define PORTD0 0
143 #define PORTD1 1
144 #define PORTD2 2
145 #define PORTD3 3
146 #define PORTD4 4
147 #define PORTD5 5
148 #define PORTD6 6
149 #define PORTD7 7
150 
151 #define TIFR0 _SFR_IO8(0x15)
152 #define TOV0 0
153 #define OCF0A 1
154 #define OCF0B 2
155 
156 #define TIFR1 _SFR_IO8(0x16)
157 #define TOV1 0
158 #define OCF1A 1
159 #define OCF1B 2
160 #define ICF1 5
161 
162 #define TIFR2 _SFR_IO8(0x17)
163 #define TOV2 0
164 #define OCF2A 1
165 #define OCF2B 2
166 
167 #define PCIFR _SFR_IO8(0x1B)
168 #define PCIF0 0
169 #define PCIF1 1
170 #define PCIF2 2
171 
172 #define EIFR _SFR_IO8(0x1C)
173 #define INTF0 0
174 #define INTF1 1
175 
176 #define EIMSK _SFR_IO8(0x1D)
177 #define INT0 0
178 #define INT1 1
179 
180 #define GPIOR0 _SFR_IO8(0x1E)
181 #define GPIOR00 0
182 #define GPIOR01 1
183 #define GPIOR02 2
184 #define GPIOR03 3
185 #define GPIOR04 4
186 #define GPIOR05 5
187 #define GPIOR06 6
188 #define GPIOR07 7
189 
190 #define EECR _SFR_IO8(0x1F)
191 #define EERE 0
192 #define EEPE 1
193 #define EEMPE 2
194 #define EERIE 3
195 #define EEPM0 4
196 #define EEPM1 5
197 
198 #define EEDR _SFR_IO8(0x20)
199 #define EEDR0 0
200 #define EEDR1 1
201 #define EEDR2 2
202 #define EEDR3 3
203 #define EEDR4 4
204 #define EEDR5 5
205 #define EEDR6 6
206 #define EEDR7 7
207 
208 #define EEARL _SFR_IO8(0x21)
209 #define EEAR0 0
210 #define EEAR1 1
211 #define EEAR2 2
212 #define EEAR3 3
213 #define EEAR4 4
214 #define EEAR5 5
215 #define EEAR6 6
216 #define EEAR7 7
217 
218 /* Only valid for ATmega88P-168P-328P */
219 /* EEARH _SFR_IO8(0x22) */
220 
221 #define EEPROM_REG_LOCATIONS 1F2021
222 
223 #define GTCCR _SFR_IO8(0x23)
224 #define PSRSYNC 0
225 #define PSRASY 1
226 #define TSM 7
227 
228 #define TCCR0A _SFR_IO8(0x24)
229 #define WGM00 0
230 #define WGM01 1
231 #define COM0B0 4
232 #define COM0B1 5
233 #define COM0A0 6
234 #define COM0A1 7
235 
236 #define TCCR0B _SFR_IO8(0x25)
237 #define CS00 0
238 #define CS01 1
239 #define CS02 2
240 #define WGM02 3
241 #define FOC0B 6
242 #define FOC0A 7
243 
244 #define TCNT0 _SFR_IO8(0x26)
245 #define TCNT0_0 0
246 #define TCNT0_1 1
247 #define TCNT0_2 2
248 #define TCNT0_3 3
249 #define TCNT0_4 4
250 #define TCNT0_5 5
251 #define TCNT0_6 6
252 #define TCNT0_7 7
253 
254 #define OCR0A _SFR_IO8(0x27)
255 #define OCR0A_0 0
256 #define OCR0A_1 1
257 #define OCR0A_2 2
258 #define OCR0A_3 3
259 #define OCR0A_4 4
260 #define OCR0A_5 5
261 #define OCR0A_6 6
262 #define OCR0A_7 7
263 
264 #define OCR0B _SFR_IO8(0x28)
265 #define OCR0B_0 0
266 #define OCR0B_1 1
267 #define OCR0B_2 2
268 #define OCR0B_3 3
269 #define OCR0B_4 4
270 #define OCR0B_5 5
271 #define OCR0B_6 6
272 #define OCR0B_7 7
273 
274 #define GPIOR1 _SFR_IO8(0x2A)
275 #define GPIOR10 0
276 #define GPIOR11 1
277 #define GPIOR12 2
278 #define GPIOR13 3
279 #define GPIOR14 4
280 #define GPIOR15 5
281 #define GPIOR16 6
282 #define GPIOR17 7
283 
284 #define GPIOR2 _SFR_IO8(0x2B)
285 #define GPIOR20 0
286 #define GPIOR21 1
287 #define GPIOR22 2
288 #define GPIOR23 3
289 #define GPIOR24 4
290 #define GPIOR25 5
291 #define GPIOR26 6
292 #define GPIOR27 7
293 
294 #define SPCR _SFR_IO8(0x2C)
295 #define SPR0 0
296 #define SPR1 1
297 #define CPHA 2
298 #define CPOL 3
299 #define MSTR 4
300 #define DORD 5
301 #define SPE 6
302 #define SPIE 7
303 
304 #define SPSR _SFR_IO8(0x2D)
305 #define SPI2X 0
306 #define WCOL 6
307 #define SPIF 7
308 
309 #define SPDR _SFR_IO8(0x2E)
310 #define SPDR0 0
311 #define SPDR1 1
312 #define SPDR2 2
313 #define SPDR3 3
314 #define SPDR4 4
315 #define SPDR5 5
316 #define SPDR6 6
317 #define SPDR7 7
318 
319 #define ACSR _SFR_IO8(0x30)
320 #define ACIS0 0
321 #define ACIS1 1
322 #define ACIC 2
323 #define ACIE 3
324 #define ACI 4
325 #define ACO 5
326 #define ACBG 6
327 #define ACD 7
328 
329 #define SMCR _SFR_IO8(0x33)
330 #define SE 0
331 #define SM0 1
332 #define SM1 2
333 #define SM2 3
334 
335 #define MCUSR _SFR_IO8(0x34)
336 #define PORF 0
337 #define EXTRF 1
338 #define BORF 2
339 #define WDRF 3
340 
341 #define MCUCR _SFR_IO8(0x35)
342 #define PUD 4
343 #define BODSE 5
344 #define BODS 6
345 
346 #define SPMCSR _SFR_IO8(0x37)
347 #define SELFPRGEN 0
348 #define PGERS 1
349 #define PGWRT 2
350 #define BLBSET 3
351 #define RWWSRE 4
352 #define RWWSB 6
353 #define SPMIE 7
354 
355 #define WDTCSR _SFR_MEM8(0x60)
356 #define WDP0 0
357 #define WDP1 1
358 #define WDP2 2
359 #define WDE 3
360 #define WDCE 4
361 #define WDP3 5
362 #define WDIE 6
363 #define WDIF 7
364 
365 #define CLKPR _SFR_MEM8(0x61)
366 #define CLKPS0 0
367 #define CLKPS1 1
368 #define CLKPS2 2
369 #define CLKPS3 3
370 #define CLKPCE 7
371 
372 #define PRR _SFR_MEM8(0x64)
373 #define PRADC 0
374 #define PRUSART0 1
375 #define PRSPI 2
376 #define PRTIM1 3
377 #define PRTIM0 5
378 #define PRTIM2 6
379 #define PRTWI 7
380 
381 #define OSCCAL _SFR_MEM8(0x66)
382 #define CAL0 0
383 #define CAL1 1
384 #define CAL2 2
385 #define CAL3 3
386 #define CAL4 4
387 #define CAL5 5
388 #define CAL6 6
389 #define CAL7 7
390 
391 #define PCICR _SFR_MEM8(0x68)
392 #define PCIE0 0
393 #define PCIE1 1
394 #define PCIE2 2
395 
396 #define EICRA _SFR_MEM8(0x69)
397 #define ISC00 0
398 #define ISC01 1
399 #define ISC10 2
400 #define ISC11 3
401 
402 #define PCMSK0 _SFR_MEM8(0x6B)
403 #define PCINT0 0
404 #define PCINT1 1
405 #define PCINT2 2
406 #define PCINT3 3
407 #define PCINT4 4
408 #define PCINT5 5
409 #define PCINT6 6
410 #define PCINT7 7
411 
412 #define PCMSK1 _SFR_MEM8(0x6C)
413 #define PCINT8 0
414 #define PCINT9 1
415 #define PCINT10 2
416 #define PCINT11 3
417 #define PCINT12 4
418 #define PCINT13 5
419 #define PCINT14 6
420 
421 #define PCMSK2 _SFR_MEM8(0x6D)
422 #define PCINT16 0
423 #define PCINT17 1
424 #define PCINT18 2
425 #define PCINT19 3
426 #define PCINT20 4
427 #define PCINT21 5
428 #define PCINT22 6
429 #define PCINT23 7
430 
431 #define TIMSK0 _SFR_MEM8(0x6E)
432 #define TOIE0 0
433 #define OCIE0A 1
434 #define OCIE0B 2
435 
436 #define TIMSK1 _SFR_MEM8(0x6F)
437 #define TOIE1 0
438 #define OCIE1A 1
439 #define OCIE1B 2
440 #define ICIE1 5
441 
442 #define TIMSK2 _SFR_MEM8(0x70)
443 #define TOIE2 0
444 #define OCIE2A 1
445 #define OCIE2B 2
446 
447 #ifndef __ASSEMBLER__
448 #define ADC _SFR_MEM16(0x78)
449 #endif
450 #define ADCW _SFR_MEM16(0x78)
451 
452 #define ADCL _SFR_MEM8(0x78)
453 #define ADCL0 0
454 #define ADCL1 1
455 #define ADCL2 2
456 #define ADCL3 3
457 #define ADCL4 4
458 #define ADCL5 5
459 #define ADCL6 6
460 #define ADCL7 7
461 
462 #define ADCH _SFR_MEM8(0x79)
463 #define ADCH0 0
464 #define ADCH1 1
465 #define ADCH2 2
466 #define ADCH3 3
467 #define ADCH4 4
468 #define ADCH5 5
469 #define ADCH6 6
470 #define ADCH7 7
471 
472 #define ADCSRA _SFR_MEM8(0x7A)
473 #define ADPS0 0
474 #define ADPS1 1
475 #define ADPS2 2
476 #define ADIE 3
477 #define ADIF 4
478 #define ADATE 5
479 #define ADSC 6
480 #define ADEN 7
481 
482 #define ADCSRB _SFR_MEM8(0x7B)
483 #define ADTS0 0
484 #define ADTS1 1
485 #define ADTS2 2
486 #define ACME 6
487 
488 #define ADMUX _SFR_MEM8(0x7C)
489 #define MUX0 0
490 #define MUX1 1
491 #define MUX2 2
492 #define MUX3 3
493 #define ADLAR 5
494 #define REFS0 6
495 #define REFS1 7
496 
497 #define DIDR0 _SFR_MEM8(0x7E)
498 #define ADC0D 0
499 #define ADC1D 1
500 #define ADC2D 2
501 #define ADC3D 3
502 #define ADC4D 4
503 #define ADC5D 5
504 
505 #define DIDR1 _SFR_MEM8(0x7F)
506 #define AIN0D 0
507 #define AIN1D 1
508 
509 #define TCCR1A _SFR_MEM8(0x80)
510 #define WGM10 0
511 #define WGM11 1
512 #define COM1B0 4
513 #define COM1B1 5
514 #define COM1A0 6
515 #define COM1A1 7
516 
517 #define TCCR1B _SFR_MEM8(0x81)
518 #define CS10 0
519 #define CS11 1
520 #define CS12 2
521 #define WGM12 3
522 #define WGM13 4
523 #define ICES1 6
524 #define ICNC1 7
525 
526 #define TCCR1C _SFR_MEM8(0x82)
527 #define FOC1B 6
528 #define FOC1A 7
529 
530 #define TCNT1 _SFR_MEM16(0x84)
531 
532 #define TCNT1L _SFR_MEM8(0x84)
533 #define TCNT1L0 0
534 #define TCNT1L1 1
535 #define TCNT1L2 2
536 #define TCNT1L3 3
537 #define TCNT1L4 4
538 #define TCNT1L5 5
539 #define TCNT1L6 6
540 #define TCNT1L7 7
541 
542 #define TCNT1H _SFR_MEM8(0x85)
543 #define TCNT1H0 0
544 #define TCNT1H1 1
545 #define TCNT1H2 2
546 #define TCNT1H3 3
547 #define TCNT1H4 4
548 #define TCNT1H5 5
549 #define TCNT1H6 6
550 #define TCNT1H7 7
551 
552 #define ICR1 _SFR_MEM16(0x86)
553 
554 #define ICR1L _SFR_MEM8(0x86)
555 #define ICR1L0 0
556 #define ICR1L1 1
557 #define ICR1L2 2
558 #define ICR1L3 3
559 #define ICR1L4 4
560 #define ICR1L5 5
561 #define ICR1L6 6
562 #define ICR1L7 7
563 
564 #define ICR1H _SFR_MEM8(0x87)
565 #define ICR1H0 0
566 #define ICR1H1 1
567 #define ICR1H2 2
568 #define ICR1H3 3
569 #define ICR1H4 4
570 #define ICR1H5 5
571 #define ICR1H6 6
572 #define ICR1H7 7
573 
574 #define OCR1A _SFR_MEM16(0x88)
575 
576 #define OCR1AL _SFR_MEM8(0x88)
577 #define OCR1AL0 0
578 #define OCR1AL1 1
579 #define OCR1AL2 2
580 #define OCR1AL3 3
581 #define OCR1AL4 4
582 #define OCR1AL5 5
583 #define OCR1AL6 6
584 #define OCR1AL7 7
585 
586 #define OCR1AH _SFR_MEM8(0x89)
587 #define OCR1AH0 0
588 #define OCR1AH1 1
589 #define OCR1AH2 2
590 #define OCR1AH3 3
591 #define OCR1AH4 4
592 #define OCR1AH5 5
593 #define OCR1AH6 6
594 #define OCR1AH7 7
595 
596 #define OCR1B _SFR_MEM16(0x8A)
597 
598 #define OCR1BL _SFR_MEM8(0x8A)
599 #define OCR1BL0 0
600 #define OCR1BL1 1
601 #define OCR1BL2 2
602 #define OCR1BL3 3
603 #define OCR1BL4 4
604 #define OCR1BL5 5
605 #define OCR1BL6 6
606 #define OCR1BL7 7
607 
608 #define OCR1BH _SFR_MEM8(0x8B)
609 #define OCR1BH0 0
610 #define OCR1BH1 1
611 #define OCR1BH2 2
612 #define OCR1BH3 3
613 #define OCR1BH4 4
614 #define OCR1BH5 5
615 #define OCR1BH6 6
616 #define OCR1BH7 7
617 
618 #define TCCR2A _SFR_MEM8(0xB0)
619 #define WGM20 0
620 #define WGM21 1
621 #define COM2B0 4
622 #define COM2B1 5
623 #define COM2A0 6
624 #define COM2A1 7
625 
626 #define TCCR2B _SFR_MEM8(0xB1)
627 #define CS20 0
628 #define CS21 1
629 #define CS22 2
630 #define WGM22 3
631 #define FOC2B 6
632 #define FOC2A 7
633 
634 #define TCNT2 _SFR_MEM8(0xB2)
635 #define TCNT2_0 0
636 #define TCNT2_1 1
637 #define TCNT2_2 2
638 #define TCNT2_3 3
639 #define TCNT2_4 4
640 #define TCNT2_5 5
641 #define TCNT2_6 6
642 #define TCNT2_7 7
643 
644 #define OCR2A _SFR_MEM8(0xB3)
645 #define OCR2_0 0
646 #define OCR2_1 1
647 #define OCR2_2 2
648 #define OCR2_3 3
649 #define OCR2_4 4
650 #define OCR2_5 5
651 #define OCR2_6 6
652 #define OCR2_7 7
653 
654 #define OCR2B _SFR_MEM8(0xB4)
655 #define OCR2_0 0
656 #define OCR2_1 1
657 #define OCR2_2 2
658 #define OCR2_3 3
659 #define OCR2_4 4
660 #define OCR2_5 5
661 #define OCR2_6 6
662 #define OCR2_7 7
663 
664 #define ASSR _SFR_MEM8(0xB6)
665 #define TCR2BUB 0
666 #define TCR2AUB 1
667 #define OCR2BUB 2
668 #define OCR2AUB 3
669 #define TCN2UB 4
670 #define AS2 5
671 #define EXCLK 6
672 
673 #define TWBR _SFR_MEM8(0xB8)
674 #define TWBR0 0
675 #define TWBR1 1
676 #define TWBR2 2
677 #define TWBR3 3
678 #define TWBR4 4
679 #define TWBR5 5
680 #define TWBR6 6
681 #define TWBR7 7
682 
683 #define TWSR _SFR_MEM8(0xB9)
684 #define TWPS0 0
685 #define TWPS1 1
686 #define TWS3 3
687 #define TWS4 4
688 #define TWS5 5
689 #define TWS6 6
690 #define TWS7 7
691 
692 #define TWAR _SFR_MEM8(0xBA)
693 #define TWGCE 0
694 #define TWA0 1
695 #define TWA1 2
696 #define TWA2 3
697 #define TWA3 4
698 #define TWA4 5
699 #define TWA5 6
700 #define TWA6 7
701 
702 #define TWDR _SFR_MEM8(0xBB)
703 #define TWD0 0
704 #define TWD1 1
705 #define TWD2 2
706 #define TWD3 3
707 #define TWD4 4
708 #define TWD5 5
709 #define TWD6 6
710 #define TWD7 7
711 
712 #define TWCR _SFR_MEM8(0xBC)
713 #define TWIE 0
714 #define TWEN 2
715 #define TWWC 3
716 #define TWSTO 4
717 #define TWSTA 5
718 #define TWEA 6
719 #define TWINT 7
720 
721 #define TWAMR _SFR_MEM8(0xBD)
722 #define TWAM0 0
723 #define TWAM1 1
724 #define TWAM2 2
725 #define TWAM3 3
726 #define TWAM4 4
727 #define TWAM5 5
728 #define TWAM6 6
729 
730 #define UCSR0A _SFR_MEM8(0xC0)
731 #define MPCM0 0
732 #define U2X0 1
733 #define UPE0 2
734 #define DOR0 3
735 #define FE0 4
736 #define UDRE0 5
737 #define TXC0 6
738 #define RXC0 7
739 
740 #define UCSR0B _SFR_MEM8(0xC1)
741 #define TXB80 0
742 #define RXB80 1
743 #define UCSZ02 2
744 #define TXEN0 3
745 #define RXEN0 4
746 #define UDRIE0 5
747 #define TXCIE0 6
748 #define RXCIE0 7
749 
750 #define UCSR0C _SFR_MEM8(0xC2)
751 #define UCPOL0 0
752 #define UCSZ00 1
753 #define UCPHA0 1
754 #define UCSZ01 2
755 #define UDORD0 2
756 #define USBS0 3
757 #define UPM00 4
758 #define UPM01 5
759 #define UMSEL00 6
760 #define UMSEL01 7
761 
762 #define UBRR0 _SFR_MEM16(0xC4)
763 
764 #define UBRR0L _SFR_MEM8(0xC4)
765 #define UBRR0_0 0
766 #define UBRR0_1 1
767 #define UBRR0_2 2
768 #define UBRR0_3 3
769 #define UBRR0_4 4
770 #define UBRR0_5 5
771 #define UBRR0_6 6
772 #define UBRR0_7 7
773 
774 #define UBRR0H _SFR_MEM8(0xC5)
775 #define UBRR0_8 0
776 #define UBRR0_9 1
777 #define UBRR0_10 2
778 #define UBRR0_11 3
779 
780 #define UDR0 _SFR_MEM8(0xC6)
781 #define UDR0_0 0
782 #define UDR0_1 1
783 #define UDR0_2 2
784 #define UDR0_3 3
785 #define UDR0_4 4
786 #define UDR0_5 5
787 #define UDR0_6 6
788 #define UDR0_7 7
789 
790 
791 
792 /* Interrupt Vectors */
793 /* Interrupt Vector 0 is the reset vector. */
794 #define INT0_vect _VECTOR(1) /* External Interrupt Request 0 */
795 #define INT1_vect _VECTOR(2) /* External Interrupt Request 1 */
796 #define PCINT0_vect _VECTOR(3) /* Pin Change Interrupt Request 0 */
797 #define PCINT1_vect _VECTOR(4) /* Pin Change Interrupt Request 0 */
798 #define PCINT2_vect _VECTOR(5) /* Pin Change Interrupt Request 1 */
799 #define WDT_vect _VECTOR(6) /* Watchdog Time-out Interrupt */
800 #define TIMER2_COMPA_vect _VECTOR(7) /* Timer/Counter2 Compare Match A */
801 #define TIMER2_COMPB_vect _VECTOR(8) /* Timer/Counter2 Compare Match A */
802 #define TIMER2_OVF_vect _VECTOR(9) /* Timer/Counter2 Overflow */
803 #define TIMER1_CAPT_vect _VECTOR(10) /* Timer/Counter1 Capture Event */
804 #define TIMER1_COMPA_vect _VECTOR(11) /* Timer/Counter1 Compare Match A */
805 #define TIMER1_COMPB_vect _VECTOR(12) /* Timer/Counter1 Compare Match B */
806 #define TIMER1_OVF_vect _VECTOR(13) /* Timer/Counter1 Overflow */
807 #define TIMER0_COMPA_vect _VECTOR(14) /* TimerCounter0 Compare Match A */
808 #define TIMER0_COMPB_vect _VECTOR(15) /* TimerCounter0 Compare Match B */
809 #define TIMER0_OVF_vect _VECTOR(16) /* Timer/Couner0 Overflow */
810 #define SPI_STC_vect _VECTOR(17) /* SPI Serial Transfer Complete */
811 #define USART_RX_vect _VECTOR(18) /* USART Rx Complete */
812 #define USART_UDRE_vect _VECTOR(19) /* USART, Data Register Empty */
813 #define USART_TX_vect _VECTOR(20) /* USART Tx Complete */
814 #define ADC_vect _VECTOR(21) /* ADC Conversion Complete */
815 #define EE_READY_vect _VECTOR(22) /* EEPROM Ready */
816 #define ANALOG_COMP_vect _VECTOR(23) /* Analog Comparator */
817 #define TWI_vect _VECTOR(24) /* Two-wire Serial Interface */
818 #define SPM_READY_vect _VECTOR(25) /* Store Program Memory Read */
819 
820 #define _VECTORS_SIZE (26 * 2)
821 
822 
823 
824 /* Constants */
825 #define SPM_PAGESIZE 64
826 #define RAMEND 0x2FF /* Last On-Chip SRAM Location */
827 #define XRAMSIZE 0
828 #define XRAMEND RAMEND
829 #define E2END 0xFF
830 #define E2PAGESIZE 4
831 #define FLASHEND 0xFFF
832 
833 
834 
835 /* Fuses */
836 #define FUSE_MEMORY_SIZE 3
837 
838 /* Low Fuse Byte */
839 #define FUSE_CKSEL0 (unsigned char)~_BV(0) /* Select Clock Source */
840 #define FUSE_CKSEL1 (unsigned char)~_BV(1) /* Select Clock Source */
841 #define FUSE_CKSEL2 (unsigned char)~_BV(2) /* Select Clock Source */
842 #define FUSE_CKSEL3 (unsigned char)~_BV(3) /* Select Clock Source */
843 #define FUSE_SUT0 (unsigned char)~_BV(4) /* Select start-up time */
844 #define FUSE_SUT1 (unsigned char)~_BV(5) /* Select start-up time */
845 #define FUSE_CKOUT (unsigned char)~_BV(6) /* Clock output */
846 #define FUSE_CKDIV8 (unsigned char)~_BV(7) /* Divide clock by 8 */
847 #define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
848 
849 /* High Fuse Byte */
850 #define FUSE_BODLEVEL0 (unsigned char)~_BV(0) /* Brown-out Detector trigger level */
851 #define FUSE_BODLEVEL1 (unsigned char)~_BV(1) /* Brown-out Detector trigger level */
852 #define FUSE_BODLEVEL2 (unsigned char)~_BV(2) /* Brown-out Detector trigger level */
853 #define FUSE_EESAVE (unsigned char)~_BV(3) /* EEPROM memory is preserved through chip erase */
854 #define FUSE_WDTON (unsigned char)~_BV(4) /* Watchdog Timer Always On */
855 #define FUSE_SPIEN (unsigned char)~_BV(5) /* Enable Serial programming and Data Downloading */
856 #define FUSE_DWEN (unsigned char)~_BV(6) /* debugWIRE Enable */
857 #define FUSE_RSTDISBL (unsigned char)~_BV(7) /* External reset disable */
858 #define HFUSE_DEFAULT (FUSE_SPIEN)
859 
860 /* Extended Fuse Byte */
861 #define FUSE_SELFPRGEN (unsigned char)~_BV(0) /* Self Programming Enable */
862 #define EFUSE_DEFAULT (0xFF)
863 
864 
865 
866 /* Lock Bits */
867 #define __LOCK_BITS_EXIST
868 #define __BOOT_LOCK_BITS_0_EXIST
869 #define __BOOT_LOCK_BITS_1_EXIST
870 
871 
872 /* Signature */
873 #define SIGNATURE_0 0x1E
874 #define SIGNATURE_1 0x92
875 #define SIGNATURE_2 0x0A
876 
877 
879 #endif /* _AVR_IOM48P_H_ */