mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-09 17:38:32 -04:00
ffba37d599
this adds register level emulation of the ADS7844 and the RC input/output hardware on the APM1, allowing for SITL testing without enabling HIL in the code
1564 lines
31 KiB
C
1564 lines
31 KiB
C
/* Copyright (c) 2005 Anatoly Sokolov
|
|
All rights reserved.
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
modification, are permitted provided that the following conditions are met:
|
|
|
|
* Redistributions of source code must retain the above copyright
|
|
notice, this list of conditions and the following disclaimer.
|
|
|
|
* Redistributions in binary form must reproduce the above copyright
|
|
notice, this list of conditions and the following disclaimer in
|
|
the documentation and/or other materials provided with the
|
|
distribution.
|
|
|
|
* Neither the name of the copyright holders nor the names of
|
|
contributors may be used to endorse or promote products derived
|
|
from this software without specific prior written permission.
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
|
LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
POSSIBILITY OF SUCH DAMAGE. */
|
|
|
|
/* $Id: iomxx0_1.h,v 1.12 2007/12/12 14:00:49 arcanum Exp $ */
|
|
|
|
/* avr/iomxx0_1.h - definitions for ATmega640, Atmega1280, ATmega1281,
|
|
ATmega2560 and ATmega2561. */
|
|
|
|
#ifndef _AVR_IOMXX0_1_H_
|
|
#define _AVR_IOMXX0_1_H_ 1
|
|
|
|
/* This file should only be included from <avr/io.h>, never directly. */
|
|
|
|
#ifndef _AVR_IO_H_
|
|
# error "Include <avr/io.h> instead of this file."
|
|
#endif
|
|
|
|
#ifndef _AVR_IOXXX_H_
|
|
# define _AVR_IOXXX_H_ "iomxx0_1.h"
|
|
#else
|
|
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
|
#endif
|
|
|
|
#if defined(__AVR_ATmega640__) || defined(__AVR_ATmega1280__) || defined(__AVR_ATmega2560__)
|
|
# define __ATmegaxx0__
|
|
#elif defined(__AVR_ATmega1281__) || defined(__AVR_ATmega2561__)
|
|
# define __ATmegaxx1__
|
|
#endif
|
|
|
|
/* Registers and associated bit numbers */
|
|
|
|
#define PINA _SFR_IO8(0X00)
|
|
#define PINA7 7
|
|
#define PINA6 6
|
|
#define PINA5 5
|
|
#define PINA4 4
|
|
#define PINA3 3
|
|
#define PINA2 2
|
|
#define PINA1 1
|
|
#define PINA0 0
|
|
|
|
#define DDRA _SFR_IO8(0X01)
|
|
#define DDA7 7
|
|
#define DDA6 6
|
|
#define DDA5 5
|
|
#define DDA4 4
|
|
#define DDA3 3
|
|
#define DDA2 2
|
|
#define DDA1 1
|
|
#define DDA0 0
|
|
|
|
#define PORTA _SFR_IO8(0X02)
|
|
#define PA7 7
|
|
#define PA6 6
|
|
#define PA5 5
|
|
#define PA4 4
|
|
#define PA3 3
|
|
#define PA2 2
|
|
#define PA1 1
|
|
#define PA0 0
|
|
|
|
#define PINB _SFR_IO8(0X03)
|
|
#define PINB7 7
|
|
#define PINB6 6
|
|
#define PINB5 5
|
|
#define PINB4 4
|
|
#define PINB3 3
|
|
#define PINB2 2
|
|
#define PINB1 1
|
|
#define PINB0 0
|
|
|
|
#define DDRB _SFR_IO8(0x04)
|
|
#define DDB7 7
|
|
#define DDB6 6
|
|
#define DDB5 5
|
|
#define DDB4 4
|
|
#define DDB3 3
|
|
#define DDB2 2
|
|
#define DDB1 1
|
|
#define DDB0 0
|
|
|
|
#define PORTB _SFR_IO8(0x05)
|
|
#define PB7 7
|
|
#define PB6 6
|
|
#define PB5 5
|
|
#define PB4 4
|
|
#define PB3 3
|
|
#define PB2 2
|
|
#define PB1 1
|
|
#define PB0 0
|
|
|
|
#define PINC _SFR_IO8(0x06)
|
|
#define PINC7 7
|
|
#define PINC6 6
|
|
#define PINC5 5
|
|
#define PINC4 4
|
|
#define PINC3 3
|
|
#define PINC2 2
|
|
#define PINC1 1
|
|
#define PINC0 0
|
|
|
|
#define DDRC _SFR_IO8(0x07)
|
|
#define DDC7 7
|
|
#define DDC6 6
|
|
#define DDC5 5
|
|
#define DDC4 4
|
|
#define DDC3 3
|
|
#define DDC2 2
|
|
#define DDC1 1
|
|
#define DDC0 0
|
|
|
|
#define PORTC _SFR_IO8(0x08)
|
|
#define PC7 7
|
|
#define PC6 6
|
|
#define PC5 5
|
|
#define PC4 4
|
|
#define PC3 3
|
|
#define PC2 2
|
|
#define PC1 1
|
|
#define PC0 0
|
|
|
|
#define PIND _SFR_IO8(0x09)
|
|
#define PIND7 7
|
|
#define PIND6 6
|
|
#define PIND5 5
|
|
#define PIND4 4
|
|
#define PIND3 3
|
|
#define PIND2 2
|
|
#define PIND1 1
|
|
#define PIND0 0
|
|
|
|
#define DDRD _SFR_IO8(0x0A)
|
|
#define DDD7 7
|
|
#define DDD6 6
|
|
#define DDD5 5
|
|
#define DDD4 4
|
|
#define DDD3 3
|
|
#define DDD2 2
|
|
#define DDD1 1
|
|
#define DDD0 0
|
|
|
|
#define PORTD _SFR_IO8(0x0B)
|
|
#define PD7 7
|
|
#define PD6 6
|
|
#define PD5 5
|
|
#define PD4 4
|
|
#define PD3 3
|
|
#define PD2 2
|
|
#define PD1 1
|
|
#define PD0 0
|
|
|
|
#define PINE _SFR_IO8(0x0C)
|
|
#define PINE7 7
|
|
#define PINE6 6
|
|
#define PINE5 5
|
|
#define PINE4 4
|
|
#define PINE3 3
|
|
#define PINE2 2
|
|
#define PINE1 1
|
|
#define PINE0 0
|
|
|
|
#define DDRE _SFR_IO8(0x0D)
|
|
#define DDE7 7
|
|
#define DDE6 6
|
|
#define DDE5 5
|
|
#define DDE4 4
|
|
#define DDE3 3
|
|
#define DDE2 2
|
|
#define DDE1 1
|
|
#define DDE0 0
|
|
|
|
#define PORTE _SFR_IO8(0x0E)
|
|
#define PE7 7
|
|
#define PE6 6
|
|
#define PE5 5
|
|
#define PE4 4
|
|
#define PE3 3
|
|
#define PE2 2
|
|
#define PE1 1
|
|
#define PE0 0
|
|
|
|
#define PINF _SFR_IO8(0x0F)
|
|
#define PINF7 7
|
|
#define PINF6 6
|
|
#define PINF5 5
|
|
#define PINF4 4
|
|
#define PINF3 3
|
|
#define PINF2 2
|
|
#define PINF1 1
|
|
#define PINF0 0
|
|
|
|
#define DDRF _SFR_IO8(0x10)
|
|
#define DDF7 7
|
|
#define DDF6 6
|
|
#define DDF5 5
|
|
#define DDF4 4
|
|
#define DDF3 3
|
|
#define DDF2 2
|
|
#define DDF1 1
|
|
#define DDF0 0
|
|
|
|
#define PORTF _SFR_IO8(0x11)
|
|
#define PF7 7
|
|
#define PF6 6
|
|
#define PF5 5
|
|
#define PF4 4
|
|
#define PF3 3
|
|
#define PF2 2
|
|
#define PF1 1
|
|
#define PF0 0
|
|
|
|
#define PING _SFR_IO8(0x12)
|
|
#define PING5 5
|
|
#define PING4 4
|
|
#define PING3 3
|
|
#define PING2 2
|
|
#define PING1 1
|
|
#define PING0 0
|
|
|
|
#define DDRG _SFR_IO8(0x13)
|
|
#define DDG5 5
|
|
#define DDG4 4
|
|
#define DDG3 3
|
|
#define DDG2 2
|
|
#define DDG1 1
|
|
#define DDG0 0
|
|
|
|
#define PORTG _SFR_IO8(0x14)
|
|
#define PG5 5
|
|
#define PG4 4
|
|
#define PG3 3
|
|
#define PG2 2
|
|
#define PG1 1
|
|
#define PG0 0
|
|
|
|
#define TIFR0 _SFR_IO8(0x15)
|
|
#define OCF0B 2
|
|
#define OCF0A 1
|
|
#define TOV0 0
|
|
|
|
#define TIFR1 _SFR_IO8(0x16)
|
|
#define ICF1 5
|
|
#define OCF1C 3
|
|
#define OCF1B 2
|
|
#define OCF1A 1
|
|
#define TOV1 0
|
|
|
|
#define TIFR2 _SFR_IO8(0x17)
|
|
#define OCF2B 2
|
|
#define OCF2A 1
|
|
#define TOV2 0
|
|
|
|
#define TIFR3 _SFR_IO8(0x18)
|
|
#define ICF3 5
|
|
#define OCF3C 3
|
|
#define OCF3B 2
|
|
#define OCF3A 1
|
|
#define TOV3 0
|
|
|
|
#define TIFR4 _SFR_IO8(0x19)
|
|
#define ICF4 5
|
|
#define OCF4C 3
|
|
#define OCF4B 2
|
|
#define OCF4A 1
|
|
#define TOV4 0
|
|
|
|
#define TIFR5 _SFR_IO8(0x1A)
|
|
#define ICF5 5
|
|
#define OCF5C 3
|
|
#define OCF5B 2
|
|
#define OCF5A 1
|
|
#define TOV5 0
|
|
|
|
#define PCIFR _SFR_IO8(0x1B)
|
|
#if defined(__ATmegaxx0__)
|
|
# define PCIF2 2
|
|
#endif /* __ATmegaxx0__ */
|
|
#define PCIF1 1
|
|
#define PCIF0 0
|
|
|
|
#define EIFR _SFR_IO8(0x1C)
|
|
#define INTF7 7
|
|
#define INTF6 6
|
|
#define INTF5 5
|
|
#define INTF4 4
|
|
#define INTF3 3
|
|
#define INTF2 2
|
|
#define INTF1 1
|
|
#define INTF0 0
|
|
|
|
#define EIMSK _SFR_IO8(0x1D)
|
|
#define INT7 7
|
|
#define INT6 6
|
|
#define INT5 5
|
|
#define INT4 4
|
|
#define INT3 3
|
|
#define INT2 2
|
|
#define INT1 1
|
|
#define INT0 0
|
|
|
|
#define GPIOR0 _SFR_IO8(0x1E)
|
|
|
|
#define EECR _SFR_IO8(0x1F)
|
|
#define EEPM1 5
|
|
#define EEPM0 4
|
|
#define EERIE 3
|
|
#define EEMPE 2
|
|
#define EEPE 1
|
|
#define EERE 0
|
|
|
|
#define EEDR _SFR_IO8(0X20)
|
|
|
|
/* Combine EEARL and EEARH */
|
|
#define EEAR _SFR_IO16(0x21)
|
|
|
|
#define EEARL _SFR_IO8(0x21)
|
|
#define EEARH _SFR_IO8(0X22)
|
|
|
|
/* 6-char sequence denoting where to find the EEPROM registers in memory space.
|
|
Adresses denoted in hex syntax with uppercase letters. Used by the EEPROM
|
|
subroutines.
|
|
First two letters: EECR address.
|
|
Second two letters: EEDR address.
|
|
Last two letters: EEAR address. */
|
|
#define __EEPROM_REG_LOCATIONS__ 1F2021
|
|
|
|
#define GTCCR _SFR_IO8(0x23)
|
|
#define TSM 7
|
|
#define PSRASY 1
|
|
#define PSRSYNC 0
|
|
|
|
#define TCCR0A _SFR_IO8(0x24)
|
|
#define COM0A1 7
|
|
#define COM0A0 6
|
|
#define COM0B1 5
|
|
#define COM0B0 4
|
|
#define WGM01 1
|
|
#define WGM00 0
|
|
|
|
#define TCCR0B _SFR_IO8(0x25)
|
|
#define FOC0A 7
|
|
#define FOC0B 6
|
|
#define WGM02 3
|
|
#define CS02 2
|
|
#define CS01 1
|
|
#define CS00 0
|
|
|
|
#define TCNT0 _SFR_IO8(0X26)
|
|
|
|
#define OCR0A _SFR_IO8(0X27)
|
|
|
|
#define OCR0B _SFR_IO8(0X28)
|
|
|
|
/* Reserved [0x29] */
|
|
|
|
#define GPIOR1 _SFR_IO8(0x2A)
|
|
|
|
#define GPIOR2 _SFR_IO8(0x2B)
|
|
|
|
#define SPCR _SFR_IO8(0x2C)
|
|
#define SPIE 7
|
|
#define SPE 6
|
|
#define DORD 5
|
|
#define MSTR 4
|
|
#define CPOL 3
|
|
#define CPHA 2
|
|
#define SPR1 1
|
|
#define SPR0 0
|
|
|
|
#define SPSR _SFR_IO8(0x2D)
|
|
#define SPIF 7
|
|
#define WCOL 6
|
|
#define SPI2X 0
|
|
|
|
#define SPDR _SFR_IO8(0X2E)
|
|
|
|
/* Reserved [0x2F] */
|
|
|
|
#define ACSR _SFR_IO8(0x30)
|
|
#define ACD 7
|
|
#define ACBG 6
|
|
#define ACO 5
|
|
#define ACI 4
|
|
#define ACIE 3
|
|
#define ACIC 2
|
|
#define ACIS1 1
|
|
#define ACIS0 0
|
|
|
|
#define MONDR _SFR_IO8(0x31)
|
|
#define OCDR _SFR_IO8(0x31)
|
|
#define IDRD 7
|
|
#define OCDR7 7
|
|
#define OCDR6 6
|
|
#define OCDR5 5
|
|
#define OCDR4 4
|
|
#define OCDR3 3
|
|
#define OCDR2 2
|
|
#define OCDR1 1
|
|
#define OCDR0 0
|
|
|
|
/* Reserved [0x32] */
|
|
|
|
#define SMCR _SFR_IO8(0x33)
|
|
#define SM2 3
|
|
#define SM1 2
|
|
#define SM0 1
|
|
#define SE 0
|
|
|
|
#define MCUSR _SFR_IO8(0x34)
|
|
#define JTRF 4
|
|
#define WDRF 3
|
|
#define BORF 2
|
|
#define EXTRF 1
|
|
#define PORF 0
|
|
|
|
#define MCUCR _SFR_IO8(0X35)
|
|
#define JTD 7
|
|
#define PUD 4
|
|
#define IVSEL 1
|
|
#define IVCE 0
|
|
|
|
/* Reserved [0x36] */
|
|
|
|
#define SPMCSR _SFR_IO8(0x37)
|
|
#define SPMIE 7
|
|
#define RWWSB 6
|
|
#define SIGRD 5
|
|
#define RWWSRE 4
|
|
#define BLBSET 3
|
|
#define PGWRT 2
|
|
#define PGERS 1
|
|
#define SPMEN 0
|
|
|
|
/* Reserved [0x38..0x3A] */
|
|
|
|
#define RAMPZ _SFR_IO8(0X3B)
|
|
#define RAMPZ0 0
|
|
|
|
#define EIND _SFR_IO8(0X3C)
|
|
#define EIND0 0
|
|
|
|
/* SP [0x3D..0x3E] */
|
|
/* SREG [0x3F] */
|
|
|
|
#define WDTCSR _SFR_MEM8(0x60)
|
|
#define WDIF 7
|
|
#define WDIE 6
|
|
#define WDP3 5
|
|
#define WDCE 4
|
|
#define WDE 3
|
|
#define WDP2 2
|
|
#define WDP1 1
|
|
#define WDP0 0
|
|
|
|
#define CLKPR _SFR_MEM8(0x61)
|
|
#define CLKPCE 7
|
|
#define CLKPS3 3
|
|
#define CLKPS2 2
|
|
#define CLKPS1 1
|
|
#define CLKPS0 0
|
|
|
|
/* Reserved [0x62..0x63] */
|
|
|
|
#define PRR0 _SFR_MEM8(0x64)
|
|
#define PRTWI 7
|
|
#define PRTIM2 6
|
|
#define PRTIM0 5
|
|
#define PRTIM1 3
|
|
#define PRSPI 2
|
|
#define PRUSART0 1
|
|
#define PRADC 0
|
|
|
|
#define PRR1 _SFR_MEM8(0x65)
|
|
#define PRTIM5 5
|
|
#define PRTIM4 4
|
|
#define PRTIM3 3
|
|
#define PRUSART3 2
|
|
#define PRUSART2 1
|
|
#define PRUSART1 0
|
|
|
|
#define OSCCAL _SFR_MEM8(0x66)
|
|
|
|
/* Reserved [0x67] */
|
|
|
|
#define PCICR _SFR_MEM8(0x68)
|
|
#if defined(__ATmegaxx0__)
|
|
# define PCIE2 2
|
|
#endif /* __ATmegaxx0__ */
|
|
#define PCIE1 1
|
|
#define PCIE0 0
|
|
|
|
#define EICRA _SFR_MEM8(0x69)
|
|
#define ISC31 7
|
|
#define ISC30 6
|
|
#define ISC21 5
|
|
#define ISC20 4
|
|
#define ISC11 3
|
|
#define ISC10 2
|
|
#define ISC01 1
|
|
#define ISC00 0
|
|
|
|
#define EICRB _SFR_MEM8(0x6A)
|
|
#define ISC71 7
|
|
#define ISC70 6
|
|
#define ISC61 5
|
|
#define ISC60 4
|
|
#define ISC51 3
|
|
#define ISC50 2
|
|
#define ISC41 1
|
|
#define ISC40 0
|
|
|
|
#define PCMSK0 _SFR_MEM8(0x6B)
|
|
#define PCINT7 7
|
|
#define PCINT6 6
|
|
#define PCINT5 5
|
|
#define PCINT4 4
|
|
#define PCINT3 3
|
|
#define PCINT2 2
|
|
#define PCINT1 1
|
|
#define PCINT0 0
|
|
|
|
#define PCMSK1 _SFR_MEM8(0x6C)
|
|
#define PCINT15 7
|
|
#define PCINT14 6
|
|
#define PCINT13 5
|
|
#define PCINT12 4
|
|
#define PCINT11 3
|
|
#define PCINT10 2
|
|
#define PCINT9 1
|
|
#define PCINT8 0
|
|
|
|
#if defined(__ATmegaxx0__)
|
|
# define PCMSK2 _SFR_MEM8(0x6D)
|
|
# define PCINT23 7
|
|
# define PCINT22 6
|
|
# define PCINT21 5
|
|
# define PCINT20 4
|
|
# define PCINT19 3
|
|
# define PCINT18 2
|
|
# define PCINT17 1
|
|
# define PCINT16 0
|
|
#endif /* __ATmegaxx0__ */
|
|
|
|
#define TIMSK0 _SFR_MEM8(0x6E)
|
|
#define OCIE0B 2
|
|
#define OCIE0A 1
|
|
#define TOIE0 0
|
|
|
|
#define TIMSK1 _SFR_MEM8(0x6F)
|
|
#define ICIE1 5
|
|
#define OCIE1C 3
|
|
#define OCIE1B 2
|
|
#define OCIE1A 1
|
|
#define TOIE1 0
|
|
|
|
#define TIMSK2 _SFR_MEM8(0x70)
|
|
#define OCIE2B 2
|
|
#define OCIE2A 1
|
|
#define TOIE2 0
|
|
|
|
#define TIMSK3 _SFR_MEM8(0x71)
|
|
#define ICIE3 5
|
|
#define OCIE3C 3
|
|
#define OCIE3B 2
|
|
#define OCIE3A 1
|
|
#define TOIE3 0
|
|
|
|
#define TIMSK4 _SFR_MEM8(0x72)
|
|
#define ICIE4 5
|
|
#define OCIE4C 3
|
|
#define OCIE4B 2
|
|
#define OCIE4A 1
|
|
#define TOIE4 0
|
|
|
|
#define TIMSK5 _SFR_MEM8(0x73)
|
|
#define ICIE5 5
|
|
#define OCIE5C 3
|
|
#define OCIE5B 2
|
|
#define OCIE5A 1
|
|
#define TOIE5 0
|
|
|
|
#define XMCRA _SFR_MEM8(0x74)
|
|
#define SRE 7
|
|
#define SRL2 6
|
|
#define SRL1 5
|
|
#define SRL0 4
|
|
#define SRW11 3
|
|
#define SRW10 2
|
|
#define SRW01 1
|
|
#define SRW00 0
|
|
|
|
#define XMCRB _SFR_MEM8(0x75)
|
|
#define XMBK 7
|
|
#define XMM2 2
|
|
#define XMM1 1
|
|
#define XMM0 0
|
|
|
|
/* Reserved [0x76..0x77] */
|
|
|
|
/* Combine ADCL and ADCH */
|
|
#ifndef __ASSEMBLER__
|
|
#define ADC _SFR_MEM16(0x78)
|
|
#endif
|
|
#define ADCW _SFR_MEM16(0x78)
|
|
#define ADCL _SFR_MEM8(0x78)
|
|
#define ADCH _SFR_MEM8(0x79)
|
|
|
|
#define ADCSRA _SFR_MEM8(0x7A)
|
|
#define ADEN 7
|
|
#define ADSC 6
|
|
#define ADATE 5
|
|
#define ADIF 4
|
|
#define ADIE 3
|
|
#define ADPS2 2
|
|
#define ADPS1 1
|
|
#define ADPS0 0
|
|
|
|
#define ADCSRB _SFR_MEM8(0x7B)
|
|
#define ACME 6
|
|
#if defined(__ATmegaxx0__)
|
|
# define MUX5 3
|
|
#endif /* __ATmegaxx0__ */
|
|
#define ADTS2 2
|
|
#define ADTS1 1
|
|
#define ADTS0 0
|
|
|
|
#define ADMUX _SFR_MEM8(0x7C)
|
|
#define REFS1 7
|
|
#define REFS0 6
|
|
#define ADLAR 5
|
|
#define MUX4 4
|
|
#define MUX3 3
|
|
#define MUX2 2
|
|
#define MUX1 1
|
|
#define MUX0 0
|
|
|
|
#define DIDR2 _SFR_MEM8(0x7D)
|
|
#define ADC15D 7
|
|
#define ADC14D 6
|
|
#define ADC13D 5
|
|
#define ADC12D 4
|
|
#define ADC11D 3
|
|
#define ADC10D 2
|
|
#define ADC9D 1
|
|
#define ADC8D 0
|
|
|
|
#define DIDR0 _SFR_MEM8(0x7E)
|
|
#define ADC7D 7
|
|
#define ADC6D 6
|
|
#define ADC5D 5
|
|
#define ADC4D 4
|
|
#define ADC3D 3
|
|
#define ADC2D 2
|
|
#define ADC1D 1
|
|
#define ADC0D 0
|
|
|
|
#define DIDR1 _SFR_MEM8(0x7F)
|
|
#define AIN1D 1
|
|
#define AIN0D 0
|
|
|
|
#define TCCR1A _SFR_MEM8(0x80)
|
|
#define COM1A1 7
|
|
#define COM1A0 6
|
|
#define COM1B1 5
|
|
#define COM1B0 4
|
|
#define COM1C1 3
|
|
#define COM1C0 2
|
|
#define WGM11 1
|
|
#define WGM10 0
|
|
|
|
#define TCCR1B _SFR_MEM8(0x81)
|
|
#define ICNC1 7
|
|
#define ICES1 6
|
|
#define WGM13 4
|
|
#define WGM12 3
|
|
#define CS12 2
|
|
#define CS11 1
|
|
#define CS10 0
|
|
|
|
#define TCCR1C _SFR_MEM8(0x82)
|
|
#define FOC1A 7
|
|
#define FOC1B 6
|
|
#define FOC1C 5
|
|
|
|
/* Reserved [0x83] */
|
|
|
|
/* Combine TCNT1L and TCNT1H */
|
|
#define TCNT1 _SFR_MEM16(0x84)
|
|
|
|
#define TCNT1L _SFR_MEM8(0x84)
|
|
#define TCNT1H _SFR_MEM8(0x85)
|
|
|
|
/* Combine ICR1L and ICR1H */
|
|
#define ICR1 _SFR_MEM16(0x86)
|
|
|
|
#define ICR1L _SFR_MEM8(0x86)
|
|
#define ICR1H _SFR_MEM8(0x87)
|
|
|
|
/* Combine OCR1AL and OCR1AH */
|
|
#define OCR1A _SFR_MEM16(0x88)
|
|
|
|
#define OCR1AL _SFR_MEM8(0x88)
|
|
#define OCR1AH _SFR_MEM8(0x89)
|
|
|
|
/* Combine OCR1BL and OCR1BH */
|
|
#define OCR1B _SFR_MEM16(0x8A)
|
|
|
|
#define OCR1BL _SFR_MEM8(0x8A)
|
|
#define OCR1BH _SFR_MEM8(0x8B)
|
|
|
|
/* Combine OCR1CL and OCR1CH */
|
|
#define OCR1C _SFR_MEM16(0x8C)
|
|
|
|
#define OCR1CL _SFR_MEM8(0x8C)
|
|
#define OCR1CH _SFR_MEM8(0x8D)
|
|
|
|
/* Reserved [0x8E..0x8F] */
|
|
|
|
#define TCCR3A _SFR_MEM8(0x90)
|
|
#define COM3A1 7
|
|
#define COM3A0 6
|
|
#define COM3B1 5
|
|
#define COM3B0 4
|
|
#define COM3C1 3
|
|
#define COM3C0 2
|
|
#define WGM31 1
|
|
#define WGM30 0
|
|
|
|
#define TCCR3B _SFR_MEM8(0x91)
|
|
#define ICNC3 7
|
|
#define ICES3 6
|
|
#define WGM33 4
|
|
#define WGM32 3
|
|
#define CS32 2
|
|
#define CS31 1
|
|
#define CS30 0
|
|
|
|
#define TCCR3C _SFR_MEM8(0x92)
|
|
#define FOC3A 7
|
|
#define FOC3B 6
|
|
#define FOC3C 5
|
|
|
|
/* Reserved [0x93] */
|
|
|
|
/* Combine TCNT3L and TCNT3H */
|
|
#define TCNT3 _SFR_MEM16(0x94)
|
|
|
|
#define TCNT3L _SFR_MEM8(0x94)
|
|
#define TCNT3H _SFR_MEM8(0x95)
|
|
|
|
/* Combine ICR3L and ICR3H */
|
|
#define ICR3 _SFR_MEM16(0x96)
|
|
|
|
#define ICR3L _SFR_MEM8(0x96)
|
|
#define ICR3H _SFR_MEM8(0x97)
|
|
|
|
/* Combine OCR3AL and OCR3AH */
|
|
#define OCR3A _SFR_MEM16(0x98)
|
|
|
|
#define OCR3AL _SFR_MEM8(0x98)
|
|
#define OCR3AH _SFR_MEM8(0x99)
|
|
|
|
/* Combine OCR3BL and OCR3BH */
|
|
#define OCR3B _SFR_MEM16(0x9A)
|
|
|
|
#define OCR3BL _SFR_MEM8(0x9A)
|
|
#define OCR3BH _SFR_MEM8(0x9B)
|
|
|
|
/* Combine OCR3CL and OCR3CH */
|
|
#define OCR3C _SFR_MEM16(0x9C)
|
|
|
|
#define OCR3CL _SFR_MEM8(0x9C)
|
|
#define OCR3CH _SFR_MEM8(0x9D)
|
|
|
|
/* Reserved [0x9E..0x9F] */
|
|
|
|
#define TCCR4A _SFR_MEM8(0xA0)
|
|
#define COM4A1 7
|
|
#define COM4A0 6
|
|
#define COM4B1 5
|
|
#define COM4B0 4
|
|
#define COM4C1 3
|
|
#define COM4C0 2
|
|
#define WGM41 1
|
|
#define WGM40 0
|
|
|
|
#define TCCR4B _SFR_MEM8(0xA1)
|
|
#define ICNC4 7
|
|
#define ICES4 6
|
|
#define WGM43 4
|
|
#define WGM42 3
|
|
#define CS42 2
|
|
#define CS41 1
|
|
#define CS40 0
|
|
|
|
#define TCCR4C _SFR_MEM8(0xA2)
|
|
#define FOC4A 7
|
|
#define FOC4B 6
|
|
#define FOC4C 5
|
|
|
|
/* Reserved [0xA3] */
|
|
|
|
/* Combine TCNT4L and TCNT4H */
|
|
#define TCNT4 _SFR_MEM16(0xA4)
|
|
|
|
#define TCNT4L _SFR_MEM8(0xA4)
|
|
#define TCNT4H _SFR_MEM8(0xA5)
|
|
|
|
/* Combine ICR4L and ICR4H */
|
|
#ifdef DESKTOP_BUILD
|
|
#include "../support/sitl_rc.h"
|
|
extern struct RC_ICR4 ICR4;
|
|
#else
|
|
#define ICR4 _SFR_MEM16(0xA6)
|
|
#endif
|
|
|
|
#define ICR4L _SFR_MEM8(0xA6)
|
|
#define ICR4H _SFR_MEM8(0xA7)
|
|
|
|
/* Combine OCR4AL and OCR4AH */
|
|
#define OCR4A _SFR_MEM16(0xA8)
|
|
|
|
#define OCR4AL _SFR_MEM8(0xA8)
|
|
#define OCR4AH _SFR_MEM8(0xA9)
|
|
|
|
/* Combine OCR4BL and OCR4BH */
|
|
#define OCR4B _SFR_MEM16(0xAA)
|
|
|
|
#define OCR4BL _SFR_MEM8(0xAA)
|
|
#define OCR4BH _SFR_MEM8(0xAB)
|
|
|
|
/* Combine OCR4CL and OCR4CH */
|
|
#define OCR4C _SFR_MEM16(0xAC)
|
|
|
|
#define OCR4CL _SFR_MEM8(0xAC)
|
|
#define OCR4CH _SFR_MEM8(0xAD)
|
|
|
|
/* Reserved [0xAE..0xAF] */
|
|
|
|
#define TCCR2A _SFR_MEM8(0xB0)
|
|
#define COM2A1 7
|
|
#define COM2A0 6
|
|
#define COM2B1 5
|
|
#define COM2B0 4
|
|
#define WGM21 1
|
|
#define WGM20 0
|
|
|
|
#define TCCR2B _SFR_MEM8(0xB1)
|
|
#define FOC2A 7
|
|
#define FOC2B 6
|
|
#define WGM22 3
|
|
#define CS22 2
|
|
#define CS21 1
|
|
#define CS20 0
|
|
|
|
#define TCNT2 _SFR_MEM8(0xB2)
|
|
|
|
#define OCR2A _SFR_MEM8(0xB3)
|
|
|
|
#define OCR2B _SFR_MEM8(0xB4)
|
|
|
|
/* Reserved [0xB5] */
|
|
|
|
#define ASSR _SFR_MEM8(0xB6)
|
|
#define EXCLK 6
|
|
#define AS2 5
|
|
#define TCN2UB 4
|
|
#define OCR2AUB 3
|
|
#define OCR2BUB 2
|
|
#define TCR2AUB 1
|
|
#define TCR2BUB 0
|
|
|
|
/* Reserved [0xB7] */
|
|
|
|
#define TWBR _SFR_MEM8(0xB8)
|
|
|
|
#define TWSR _SFR_MEM8(0xB9)
|
|
#define TWS7 7
|
|
#define TWS6 6
|
|
#define TWS5 5
|
|
#define TWS4 4
|
|
#define TWS3 3
|
|
#define TWPS1 1
|
|
#define TWPS0 0
|
|
|
|
#define TWAR _SFR_MEM8(0xBA)
|
|
#define TWA6 7
|
|
#define TWA5 6
|
|
#define TWA4 5
|
|
#define TWA3 4
|
|
#define TWA2 3
|
|
#define TWA1 2
|
|
#define TWA0 1
|
|
#define TWGCE 0
|
|
|
|
#define TWDR _SFR_MEM8(0xBB)
|
|
|
|
#define TWCR _SFR_MEM8(0xBC)
|
|
#define TWINT 7
|
|
#define TWEA 6
|
|
#define TWSTA 5
|
|
#define TWSTO 4
|
|
#define TWWC 3
|
|
#define TWEN 2
|
|
#define TWIE 0
|
|
|
|
#define TWAMR _SFR_MEM8(0xBD)
|
|
#define TWAM6 7
|
|
#define TWAM5 6
|
|
#define TWAM4 5
|
|
#define TWAM3 4
|
|
#define TWAM2 3
|
|
#define TWAM1 2
|
|
#define TWAM0 1
|
|
|
|
/* Reserved [0xBE..0xBF] */
|
|
|
|
#define UCSR0A _SFR_MEM8(0xC0)
|
|
#define RXC0 7
|
|
#define TXC0 6
|
|
#define UDRE0 5
|
|
#define FE0 4
|
|
#define DOR0 3
|
|
#define UPE0 2
|
|
#define U2X0 1
|
|
#define MPCM0 0
|
|
|
|
#define UCSR0B _SFR_MEM8(0XC1)
|
|
#define RXCIE0 7
|
|
#define TXCIE0 6
|
|
#define UDRIE0 5
|
|
#define RXEN0 4
|
|
#define TXEN0 3
|
|
#define UCSZ02 2
|
|
#define RXB80 1
|
|
#define TXB80 0
|
|
|
|
#define UCSR0C _SFR_MEM8(0xC2)
|
|
#define UMSEL01 7
|
|
#define UMSEL00 6
|
|
#define UPM01 5
|
|
#define UPM00 4
|
|
#define USBS0 3
|
|
#define UCSZ01 2
|
|
#define UCSZ00 1
|
|
#define UCPOL0 0
|
|
|
|
/* Reserved [0xC3] */
|
|
|
|
/* Combine UBRR0L and UBRR0H */
|
|
#define UBRR0 _SFR_MEM16(0xC4)
|
|
|
|
#define UBRR0L _SFR_MEM8(0xC4)
|
|
#define UBRR0H _SFR_MEM8(0xC5)
|
|
|
|
#define UDR0 _SFR_MEM8(0XC6)
|
|
|
|
/* Reserved [0xC7] */
|
|
|
|
#define UCSR1A _SFR_MEM8(0xC8)
|
|
#define RXC1 7
|
|
#define TXC1 6
|
|
#define UDRE1 5
|
|
#define FE1 4
|
|
#define DOR1 3
|
|
#define UPE1 2
|
|
#define U2X1 1
|
|
#define MPCM1 0
|
|
|
|
#define UCSR1B _SFR_MEM8(0XC9)
|
|
#define RXCIE1 7
|
|
#define TXCIE1 6
|
|
#define UDRIE1 5
|
|
#define RXEN1 4
|
|
#define TXEN1 3
|
|
#define UCSZ12 2
|
|
#define RXB81 1
|
|
#define TXB81 0
|
|
|
|
#define UCSR1C _SFR_MEM8(0xCA)
|
|
#define UMSEL11 7
|
|
#define UMSEL10 6
|
|
#define UPM11 5
|
|
#define UPM10 4
|
|
#define USBS1 3
|
|
#define UCSZ11 2
|
|
#define UCSZ10 1
|
|
#define UCPOL1 0
|
|
|
|
/* Reserved [0xCB] */
|
|
|
|
/* Combine UBRR1L and UBRR1H */
|
|
#define UBRR1 _SFR_MEM16(0xCC)
|
|
|
|
#define UBRR1L _SFR_MEM8(0xCC)
|
|
#define UBRR1H _SFR_MEM8(0xCD)
|
|
|
|
#define UDR1 _SFR_MEM8(0XCE)
|
|
|
|
/* Reserved [0xCF] */
|
|
|
|
#if defined(__ATmegaxx0__)
|
|
|
|
# define UCSR2A _SFR_MEM8(0xD0)
|
|
# define RXC2 7
|
|
# define TXC2 6
|
|
# define UDRE2 5
|
|
# define FE2 4
|
|
# define DOR2 3
|
|
# define UPE2 2
|
|
# define U2X2 1
|
|
# define MPCM2 0
|
|
|
|
# define UCSR2B _SFR_MEM8(0XD1)
|
|
# define RXCIE2 7
|
|
# define TXCIE2 6
|
|
# define UDRIE2 5
|
|
# define RXEN2 4
|
|
# define TXEN2 3
|
|
# define UCSZ22 2
|
|
# define RXB82 1
|
|
# define TXB82 0
|
|
|
|
# define UCSR2C _SFR_MEM8(0xD2)
|
|
# define UMSEL21 7
|
|
# define UMSEL20 6
|
|
# define UPM21 5
|
|
# define UPM20 4
|
|
# define USBS2 3
|
|
# define UCSZ21 2
|
|
# define UCSZ20 1
|
|
# define UCPOL2 0
|
|
|
|
/* Reserved [0xD3] */
|
|
|
|
/* Combine UBRR2L and UBRR2H */
|
|
# define UBRR2 _SFR_MEM16(0xD4)
|
|
|
|
# define UBRR2L _SFR_MEM8(0xD4)
|
|
# define UBRR2H _SFR_MEM8(0xD5)
|
|
|
|
#ifdef DESKTOP_BUILD
|
|
#include "../support/sitl_adc.h"
|
|
extern struct ADC_UDR2 UDR2;
|
|
#else
|
|
# define UDR2 _SFR_MEM8(0XD6)
|
|
#endif
|
|
|
|
#endif /* __ATmegaxx0__ */
|
|
|
|
/* Reserved [0xD7..0xFF] */
|
|
|
|
#if defined(__ATmegaxx0__)
|
|
|
|
# define PINH _SFR_MEM8(0x100)
|
|
# define PINH7 7
|
|
# define PINH6 6
|
|
# define PINH5 5
|
|
# define PINH4 4
|
|
# define PINH3 3
|
|
# define PINH2 2
|
|
# define PINH1 1
|
|
# define PINH0 0
|
|
|
|
# define DDRH _SFR_MEM8(0x101)
|
|
# define DDH7 7
|
|
# define DDH6 6
|
|
# define DDH5 5
|
|
# define DDH4 4
|
|
# define DDH3 3
|
|
# define DDH2 2
|
|
# define DDH1 1
|
|
# define DDH0 0
|
|
|
|
# define PORTH _SFR_MEM8(0x102)
|
|
# define PH7 7
|
|
# define PH6 6
|
|
# define PH5 5
|
|
# define PH4 4
|
|
# define PH3 3
|
|
# define PH2 2
|
|
# define PH1 1
|
|
# define PH0 0
|
|
|
|
# define PINJ _SFR_MEM8(0x103)
|
|
# define PINJ7 7
|
|
# define PINJ6 6
|
|
# define PINJ5 5
|
|
# define PINJ4 4
|
|
# define PINJ3 3
|
|
# define PINJ2 2
|
|
# define PINJ1 1
|
|
# define PINJ0 0
|
|
|
|
# define DDRJ _SFR_MEM8(0x104)
|
|
# define DDJ7 7
|
|
# define DDJ6 6
|
|
# define DDJ5 5
|
|
# define DDJ4 4
|
|
# define DDJ3 3
|
|
# define DDJ2 2
|
|
# define DDJ1 1
|
|
# define DDJ0 0
|
|
|
|
# define PORTJ _SFR_MEM8(0x105)
|
|
# define PJ7 7
|
|
# define PJ6 6
|
|
# define PJ5 5
|
|
# define PJ4 4
|
|
# define PJ3 3
|
|
# define PJ2 2
|
|
# define PJ1 1
|
|
# define PJ0 0
|
|
|
|
# define PINK _SFR_MEM8(0x106)
|
|
# define PINK7 7
|
|
# define PINK6 6
|
|
# define PINK5 5
|
|
# define PINK4 4
|
|
# define PINK3 3
|
|
# define PINK2 2
|
|
# define PINK1 1
|
|
# define PINK0 0
|
|
|
|
# define DDRK _SFR_MEM8(0x107)
|
|
# define DDK7 7
|
|
# define DDK6 6
|
|
# define DDK5 5
|
|
# define DDK4 4
|
|
# define DDK3 3
|
|
# define DDK2 2
|
|
# define DDK1 1
|
|
# define DDK0 0
|
|
|
|
# define PORTK _SFR_MEM8(0x108)
|
|
# define PK7 7
|
|
# define PK6 6
|
|
# define PK5 5
|
|
# define PK4 4
|
|
# define PK3 3
|
|
# define PK2 2
|
|
# define PK1 1
|
|
# define PK0 0
|
|
|
|
# define PINL _SFR_MEM8(0x109)
|
|
# define PINL7 7
|
|
# define PINL6 6
|
|
# define PINL5 5
|
|
# define PINL4 4
|
|
# define PINL3 3
|
|
# define PINL2 2
|
|
# define PINL1 1
|
|
# define PINL0 0
|
|
|
|
# define DDRL _SFR_MEM8(0x10A)
|
|
# define DDL7 7
|
|
# define DDL6 6
|
|
# define DDL5 5
|
|
# define DDL4 4
|
|
# define DDL3 3
|
|
# define DDL2 2
|
|
# define DDL1 1
|
|
# define DDL0 0
|
|
|
|
# define PORTL _SFR_MEM8(0x10B)
|
|
# define PL7 7
|
|
# define PL6 6
|
|
# define PL5 5
|
|
# define PL4 4
|
|
# define PL3 3
|
|
# define PL2 2
|
|
# define PL1 1
|
|
# define PL0 0
|
|
|
|
#endif /* __ATmegaxx0__ */
|
|
|
|
/* Reserved [0x10C..0x11F] */
|
|
|
|
#define TCCR5A _SFR_MEM8(0x120)
|
|
#define COM5A1 7
|
|
#define COM5A0 6
|
|
#define COM5B1 5
|
|
#define COM5B0 4
|
|
#define COM5C1 3
|
|
#define COM5C0 2
|
|
#define WGM51 1
|
|
#define WGM50 0
|
|
|
|
#define TCCR5B _SFR_MEM8(0x121)
|
|
#define ICNC5 7
|
|
#define ICES5 6
|
|
#define WGM53 4
|
|
#define WGM52 3
|
|
#define CS52 2
|
|
#define CS51 1
|
|
#define CS50 0
|
|
|
|
#define TCCR5C _SFR_MEM8(0x122)
|
|
#define FOC5A 7
|
|
#define FOC5B 6
|
|
#define FOC5C 5
|
|
|
|
/* Reserved [0x123] */
|
|
|
|
/* Combine TCNT5L and TCNT5H */
|
|
#define TCNT5 _SFR_MEM16(0x124)
|
|
|
|
#define TCNT5L _SFR_MEM8(0x124)
|
|
#define TCNT5H _SFR_MEM8(0x125)
|
|
|
|
/* Combine ICR5L and ICR5H */
|
|
#define ICR5 _SFR_MEM16(0x126)
|
|
|
|
#define ICR5L _SFR_MEM8(0x126)
|
|
#define ICR5H _SFR_MEM8(0x127)
|
|
|
|
/* Combine OCR5AL and OCR5AH */
|
|
#define OCR5A _SFR_MEM16(0x128)
|
|
|
|
#define OCR5AL _SFR_MEM8(0x128)
|
|
#define OCR5AH _SFR_MEM8(0x129)
|
|
|
|
/* Combine OCR5BL and OCR5BH */
|
|
#define OCR5B _SFR_MEM16(0x12A)
|
|
|
|
#define OCR5BL _SFR_MEM8(0x12A)
|
|
#define OCR5BH _SFR_MEM8(0x12B)
|
|
|
|
/* Combine OCR5CL and OCR5CH */
|
|
#define OCR5C _SFR_MEM16(0x12C)
|
|
|
|
#define OCR5CL _SFR_MEM8(0x12C)
|
|
#define OCR5CH _SFR_MEM8(0x12D)
|
|
|
|
/* Reserved [0x12E..0x12F] */
|
|
|
|
#if defined(__ATmegaxx0__)
|
|
|
|
# define UCSR3A _SFR_MEM8(0x130)
|
|
# define RXC3 7
|
|
# define TXC3 6
|
|
# define UDRE3 5
|
|
# define FE3 4
|
|
# define DOR3 3
|
|
# define UPE3 2
|
|
# define U2X3 1
|
|
# define MPCM3 0
|
|
|
|
# define UCSR3B _SFR_MEM8(0X131)
|
|
# define RXCIE3 7
|
|
# define TXCIE3 6
|
|
# define UDRIE3 5
|
|
# define RXEN3 4
|
|
# define TXEN3 3
|
|
# define UCSZ32 2
|
|
# define RXB83 1
|
|
# define TXB83 0
|
|
|
|
# define UCSR3C _SFR_MEM8(0x132)
|
|
# define UMSEL31 7
|
|
# define UMSEL30 6
|
|
# define UPM31 5
|
|
# define UPM30 4
|
|
# define USBS3 3
|
|
# define UCSZ31 2
|
|
# define UCSZ30 1
|
|
# define UCPOL3 0
|
|
|
|
/* Reserved [0x133] */
|
|
|
|
/* Combine UBRR3L and UBRR3H */
|
|
# define UBRR3 _SFR_MEM16(0x134)
|
|
|
|
# define UBRR3L _SFR_MEM8(0x134)
|
|
# define UBRR3H _SFR_MEM8(0x135)
|
|
|
|
# define UDR3 _SFR_MEM8(0X136)
|
|
|
|
#endif /* __ATmegaxx0__ */
|
|
|
|
/* Reserved [0x137..1FF] */
|
|
|
|
/* Interrupt vectors */
|
|
/* Vector 0 is the reset vector */
|
|
/* External Interrupt Request 0 */
|
|
#define INT0_vect _VECTOR(1)
|
|
#define SIG_INTERRUPT0 _VECTOR(1)
|
|
|
|
/* External Interrupt Request 1 */
|
|
#define INT1_vect _VECTOR(2)
|
|
#define SIG_INTERRUPT1 _VECTOR(2)
|
|
|
|
/* External Interrupt Request 2 */
|
|
#define INT2_vect _VECTOR(3)
|
|
#define SIG_INTERRUPT2 _VECTOR(3)
|
|
|
|
/* External Interrupt Request 3 */
|
|
#define INT3_vect _VECTOR(4)
|
|
#define SIG_INTERRUPT3 _VECTOR(4)
|
|
|
|
/* External Interrupt Request 4 */
|
|
#define INT4_vect _VECTOR(5)
|
|
#define SIG_INTERRUPT4 _VECTOR(5)
|
|
|
|
/* External Interrupt Request 5 */
|
|
#define INT5_vect _VECTOR(6)
|
|
#define SIG_INTERRUPT5 _VECTOR(6)
|
|
|
|
/* External Interrupt Request 6 */
|
|
#define INT6_vect _VECTOR(7)
|
|
#define SIG_INTERRUPT6 _VECTOR(7)
|
|
|
|
/* External Interrupt Request 7 */
|
|
#define INT7_vect _VECTOR(8)
|
|
#define SIG_INTERRUPT7 _VECTOR(8)
|
|
|
|
/* Pin Change Interrupt Request 0 */
|
|
#define PCINT0_vect _VECTOR(9)
|
|
#define SIG_PIN_CHANGE0 _VECTOR(9)
|
|
|
|
/* Pin Change Interrupt Request 1 */
|
|
#define PCINT1_vect _VECTOR(10)
|
|
#define SIG_PIN_CHANGE1 _VECTOR(10)
|
|
|
|
#if defined(__ATmegaxx0__)
|
|
/* Pin Change Interrupt Request 2 */
|
|
#define PCINT2_vect _VECTOR(11)
|
|
#define SIG_PIN_CHANGE2 _VECTOR(11)
|
|
|
|
#endif /* __ATmegaxx0__ */
|
|
|
|
/* Watchdog Time-out Interrupt */
|
|
#define WDT_vect _VECTOR(12)
|
|
#define SIG_WATCHDOG_TIMEOUT _VECTOR(12)
|
|
|
|
/* Timer/Counter2 Compare Match A */
|
|
#define TIMER2_COMPA_vect _VECTOR(13)
|
|
#define SIG_OUTPUT_COMPARE2A _VECTOR(13)
|
|
|
|
/* Timer/Counter2 Compare Match B */
|
|
#define TIMER2_COMPB_vect _VECTOR(14)
|
|
#define SIG_OUTPUT_COMPARE2B _VECTOR(14)
|
|
|
|
/* Timer/Counter2 Overflow */
|
|
#define TIMER2_OVF_vect _VECTOR(15)
|
|
#define SIG_OVERFLOW2 _VECTOR(15)
|
|
|
|
/* Timer/Counter1 Capture Event */
|
|
#define TIMER1_CAPT_vect _VECTOR(16)
|
|
#define SIG_INPUT_CAPTURE1 _VECTOR(16)
|
|
|
|
/* Timer/Counter1 Compare Match A */
|
|
#define TIMER1_COMPA_vect _VECTOR(17)
|
|
#define SIG_OUTPUT_COMPARE1A _VECTOR(17)
|
|
|
|
/* Timer/Counter1 Compare Match B */
|
|
#define TIMER1_COMPB_vect _VECTOR(18)
|
|
#define SIG_OUTPUT_COMPARE1B _VECTOR(18)
|
|
|
|
/* Timer/Counter1 Compare Match C */
|
|
#define TIMER1_COMPC_vect _VECTOR(19)
|
|
#define SIG_OUTPUT_COMPARE1C _VECTOR(19)
|
|
|
|
/* Timer/Counter1 Overflow */
|
|
#define TIMER1_OVF_vect _VECTOR(20)
|
|
#define SIG_OVERFLOW1 _VECTOR(20)
|
|
|
|
/* Timer/Counter0 Compare Match A */
|
|
#define TIMER0_COMPA_vect _VECTOR(21)
|
|
#define SIG_OUTPUT_COMPARE0A _VECTOR(21)
|
|
|
|
/* Timer/Counter0 Compare Match B */
|
|
#define TIMER0_COMPB_vect _VECTOR(22)
|
|
#define SIG_OUTPUT_COMPARE0B _VECTOR(22)
|
|
|
|
/* Timer/Counter0 Overflow */
|
|
#define TIMER0_OVF_vect _VECTOR(23)
|
|
#define SIG_OVERFLOW0 _VECTOR(23)
|
|
|
|
/* SPI Serial Transfer Complete */
|
|
#define SPI_STC_vect _VECTOR(24)
|
|
#define SIG_SPI _VECTOR(24)
|
|
|
|
/* USART0, Rx Complete */
|
|
#define USART0_RX_vect _VECTOR(25)
|
|
#define SIG_USART0_RECV _VECTOR(25)
|
|
|
|
/* USART0 Data register Empty */
|
|
#define USART0_UDRE_vect _VECTOR(26)
|
|
#define SIG_USART0_DATA _VECTOR(26)
|
|
|
|
/* USART0, Tx Complete */
|
|
#define USART0_TX_vect _VECTOR(27)
|
|
#define SIG_USART0_TRANS _VECTOR(27)
|
|
|
|
/* Analog Comparator */
|
|
#define ANALOG_COMP_vect _VECTOR(28)
|
|
#define SIG_COMPARATOR _VECTOR(28)
|
|
|
|
/* ADC Conversion Complete */
|
|
#define ADC_vect _VECTOR(29)
|
|
#define SIG_ADC _VECTOR(29)
|
|
|
|
/* EEPROM Ready */
|
|
#define EE_READY_vect _VECTOR(30)
|
|
#define SIG_EEPROM_READY _VECTOR(30)
|
|
|
|
/* Timer/Counter3 Capture Event */
|
|
#define TIMER3_CAPT_vect _VECTOR(31)
|
|
#define SIG_INPUT_CAPTURE3 _VECTOR(31)
|
|
|
|
/* Timer/Counter3 Compare Match A */
|
|
#define TIMER3_COMPA_vect _VECTOR(32)
|
|
#define SIG_OUTPUT_COMPARE3A _VECTOR(32)
|
|
|
|
/* Timer/Counter3 Compare Match B */
|
|
#define TIMER3_COMPB_vect _VECTOR(33)
|
|
#define SIG_OUTPUT_COMPARE3B _VECTOR(33)
|
|
|
|
/* Timer/Counter3 Compare Match C */
|
|
#define TIMER3_COMPC_vect _VECTOR(34)
|
|
#define SIG_OUTPUT_COMPARE3C _VECTOR(34)
|
|
|
|
/* Timer/Counter3 Overflow */
|
|
#define TIMER3_OVF_vect _VECTOR(35)
|
|
#define SIG_OVERFLOW3 _VECTOR(35)
|
|
|
|
/* USART1, Rx Complete */
|
|
#define USART1_RX_vect _VECTOR(36)
|
|
#define SIG_USART1_RECV _VECTOR(36)
|
|
|
|
/* USART1 Data register Empty */
|
|
#define USART1_UDRE_vect _VECTOR(37)
|
|
#define SIG_USART1_DATA _VECTOR(37)
|
|
|
|
/* USART1, Tx Complete */
|
|
#define USART1_TX_vect _VECTOR(38)
|
|
#define SIG_USART1_TRANS _VECTOR(38)
|
|
|
|
/* 2-wire Serial Interface */
|
|
#define TWI_vect _VECTOR(39)
|
|
#define SIG_2WIRE_SERIAL _VECTOR(39)
|
|
|
|
/* Store Program Memory Read */
|
|
#define SPM_READY_vect _VECTOR(40)
|
|
#define SIG_SPM_READY _VECTOR(40)
|
|
|
|
#if defined(__ATmegaxx0__)
|
|
/* Timer/Counter4 Capture Event */
|
|
#define TIMER4_CAPT_vect _VECTOR(41)
|
|
#define SIG_INPUT_CAPTURE4 _VECTOR(41)
|
|
|
|
#endif /* __ATmegaxx0__ */
|
|
|
|
/* Timer/Counter4 Compare Match A */
|
|
#define TIMER4_COMPA_vect _VECTOR(42)
|
|
#define SIG_OUTPUT_COMPARE4A _VECTOR(42)
|
|
|
|
/* Timer/Counter4 Compare Match B */
|
|
#define TIMER4_COMPB_vect _VECTOR(43)
|
|
#define SIG_OUTPUT_COMPARE4B _VECTOR(43)
|
|
|
|
/* Timer/Counter4 Compare Match C */
|
|
#define TIMER4_COMPC_vect _VECTOR(44)
|
|
#define SIG_OUTPUT_COMPARE4C _VECTOR(44)
|
|
|
|
/* Timer/Counter4 Overflow */
|
|
#define TIMER4_OVF_vect _VECTOR(45)
|
|
#define SIG_OVERFLOW4 _VECTOR(45)
|
|
|
|
#if defined(__ATmegaxx0__)
|
|
/* Timer/Counter5 Capture Event */
|
|
#define TIMER5_CAPT_vect _VECTOR(46)
|
|
#define SIG_INPUT_CAPTURE5 _VECTOR(46)
|
|
|
|
#endif /* __ATmegaxx0__ */
|
|
|
|
/* Timer/Counter5 Compare Match A */
|
|
#define TIMER5_COMPA_vect _VECTOR(47)
|
|
#define SIG_OUTPUT_COMPARE5A _VECTOR(47)
|
|
|
|
/* Timer/Counter5 Compare Match B */
|
|
#define TIMER5_COMPB_vect _VECTOR(48)
|
|
#define SIG_OUTPUT_COMPARE5B _VECTOR(48)
|
|
|
|
/* Timer/Counter5 Compare Match C */
|
|
#define TIMER5_COMPC_vect _VECTOR(49)
|
|
#define SIG_OUTPUT_COMPARE5C _VECTOR(49)
|
|
|
|
/* Timer/Counter5 Overflow */
|
|
#define TIMER5_OVF_vect _VECTOR(50)
|
|
#define SIG_OVERFLOW5 _VECTOR(50)
|
|
|
|
#if defined(__ATmegaxx1__)
|
|
|
|
# define _VECTORS_SIZE 204
|
|
|
|
#else
|
|
|
|
/* USART2, Rx Complete */
|
|
#define USART2_RX_vect _VECTOR(51)
|
|
#define SIG_USART2_RECV _VECTOR(51)
|
|
|
|
/* USART2 Data register Empty */
|
|
#define USART2_UDRE_vect _VECTOR(52)
|
|
#define SIG_USART2_DATA _VECTOR(52)
|
|
|
|
/* USART2, Tx Complete */
|
|
#define USART2_TX_vect _VECTOR(53)
|
|
#define SIG_USART2_TRANS _VECTOR(53)
|
|
|
|
/* USART3, Rx Complete */
|
|
#define USART3_RX_vect _VECTOR(54)
|
|
#define SIG_USART3_RECV _VECTOR(54)
|
|
|
|
/* USART3 Data register Empty */
|
|
#define USART3_UDRE_vect _VECTOR(55)
|
|
#define SIG_USART3_DATA _VECTOR(55)
|
|
|
|
/* USART3, Tx Complete */
|
|
#define USART3_TX_vect _VECTOR(56)
|
|
#define SIG_USART3_TRANS _VECTOR(56)
|
|
|
|
# define _VECTORS_SIZE 228
|
|
|
|
#endif /* __ATmegaxx1__ */
|
|
|
|
#if defined(__ATmegaxx0__)
|
|
# undef __ATmegaxx0__
|
|
#endif
|
|
|
|
#if defined(__ATmegaxx1__)
|
|
# undef __ATmegaxx1__
|
|
#endif
|
|
|
|
#endif /* _AVR_IOMXX0_1_H_ */
|