arduino-0018-windows
This commit is contained in:
parent
157fd6f1a1
commit
f39fc49523
5182 changed files with 950586 additions and 0 deletions
Binary file not shown.
4271
arduino-0018-windows/hardware/tools/avr/WinAVR-manifest.log
Normal file
4271
arduino-0018-windows/hardware/tools/avr/WinAVR-manifest.log
Normal file
File diff suppressed because it is too large
Load diff
2090
arduino-0018-windows/hardware/tools/avr/WinAVR-user-manual.html
Normal file
2090
arduino-0018-windows/hardware/tools/avr/WinAVR-user-manual.html
Normal file
File diff suppressed because it is too large
Load diff
1314
arduino-0018-windows/hardware/tools/avr/WinAVR-user-manual.txt
Normal file
1314
arduino-0018-windows/hardware/tools/avr/WinAVR-user-manual.txt
Normal file
File diff suppressed because it is too large
Load diff
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/ar.exe
Normal file
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/ar.exe
Normal file
Binary file not shown.
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/as.exe
Normal file
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/as.exe
Normal file
Binary file not shown.
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/c++.exe
Normal file
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/c++.exe
Normal file
Binary file not shown.
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/g++.exe
Normal file
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/g++.exe
Normal file
Binary file not shown.
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/gcc.exe
Normal file
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/gcc.exe
Normal file
Binary file not shown.
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/ld.exe
Normal file
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/ld.exe
Normal file
Binary file not shown.
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/nm.exe
Normal file
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/nm.exe
Normal file
Binary file not shown.
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/objcopy.exe
Normal file
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/objcopy.exe
Normal file
Binary file not shown.
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/objdump.exe
Normal file
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/objdump.exe
Normal file
Binary file not shown.
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/ranlib.exe
Normal file
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/ranlib.exe
Normal file
Binary file not shown.
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/strip.exe
Normal file
BIN
arduino-0018-windows/hardware/tools/avr/avr/bin/strip.exe
Normal file
Binary file not shown.
59
arduino-0018-windows/hardware/tools/avr/avr/include/alloca.h
Normal file
59
arduino-0018-windows/hardware/tools/avr/avr/include/alloca.h
Normal file
|
@ -0,0 +1,59 @@
|
|||
/* Copyright (c) 2007, Dmitry Xmelkov
|
||||
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: alloca.h,v 1.2 2007/12/18 13:34:15 dmix Exp $ */
|
||||
|
||||
#ifndef _ALLOCA_H
|
||||
#define _ALLOCA_H 1
|
||||
|
||||
#include <stddef.h>
|
||||
|
||||
/** \defgroup alloca <alloca.h>: Allocate space in the stack */
|
||||
|
||||
/** \ingroup alloca
|
||||
\brief Allocate \a __size bytes of space in the stack frame of the caller.
|
||||
|
||||
This temporary space is automatically freed when the function that
|
||||
called alloca() returns to its caller. Avr-libc defines the alloca() as
|
||||
a macro, which is translated into the inlined \c __builtin_alloca()
|
||||
function. The fact that the code is inlined, means that it is impossible
|
||||
to take the address of this function, or to change its behaviour by
|
||||
linking with a different library.
|
||||
|
||||
\return alloca() returns a pointer to the beginning of the allocated
|
||||
space. If the allocation causes stack overflow, program behaviour is
|
||||
undefined.
|
||||
|
||||
\warning Avoid use alloca() inside the list of arguments of a function
|
||||
call.
|
||||
*/
|
||||
extern void *alloca (size_t __size);
|
||||
|
||||
#define alloca(size) __builtin_alloca (size)
|
||||
|
||||
#endif /* alloca.h */
|
112
arduino-0018-windows/hardware/tools/avr/avr/include/assert.h
Normal file
112
arduino-0018-windows/hardware/tools/avr/avr/include/assert.h
Normal file
|
@ -0,0 +1,112 @@
|
|||
/* Copyright (c) 2005,2007 Joerg Wunsch
|
||||
All rights reserved.
|
||||
|
||||
Portions of documentation Copyright (c) 1991, 1993
|
||||
The Regents of the University of California.
|
||||
|
||||
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: assert.h,v 1.3 2007/01/23 15:32:48 joerg_wunsch Exp $
|
||||
*/
|
||||
|
||||
/** \file */
|
||||
/** \defgroup avr_assert <assert.h>: Diagnostics
|
||||
\code #include <assert.h> \endcode
|
||||
|
||||
This header file defines a debugging aid.
|
||||
|
||||
As there is no standard error output stream available for many
|
||||
applications using this library, the generation of a printable
|
||||
error message is not enabled by default. These messages will
|
||||
only be generated if the application defines the macro
|
||||
|
||||
\code __ASSERT_USE_STDERR \endcode
|
||||
|
||||
before including the \c <assert.h> header file. By default,
|
||||
only abort() will be called to halt the application.
|
||||
*/
|
||||
|
||||
/*@{*/
|
||||
|
||||
/*
|
||||
* The ability to include this file (with or without NDEBUG) is a
|
||||
* feature.
|
||||
*/
|
||||
|
||||
#undef assert
|
||||
|
||||
#if defined(__DOXYGEN__)
|
||||
/**
|
||||
* \def assert
|
||||
* \param expression Expression to test for.
|
||||
*
|
||||
* The assert() macro tests the given expression and if it is false,
|
||||
* the calling process is terminated. A diagnostic message is written
|
||||
* to stderr and the function abort() is called, effectively
|
||||
* terminating the program.
|
||||
*
|
||||
* If expression is true, the assert() macro does nothing.
|
||||
*
|
||||
* The assert() macro may be removed at compile time by defining
|
||||
* NDEBUG as a macro (e.g., by using the compiler option -DNDEBUG).
|
||||
*/
|
||||
# define assert(expression)
|
||||
|
||||
#else /* !DOXYGEN */
|
||||
|
||||
# if defined(NDEBUG)
|
||||
# define assert(e) ((void)0)
|
||||
# else /* !NDEBUG */
|
||||
# if defined(__ASSERT_USE_STDERR)
|
||||
# define assert(e) ((e) ? (void)0 : \
|
||||
__assert(__func__, __FILE__, __LINE__, #e))
|
||||
# else /* !__ASSERT_USE_STDERR */
|
||||
# define assert(e) ((e) ? (void)0 : abort())
|
||||
# endif /* __ASSERT_USE_STDERR */
|
||||
# endif /* NDEBUG */
|
||||
#endif /* DOXYGEN */
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#if !defined(__DOXYGEN__)
|
||||
|
||||
extern void __assert(const char *__func, const char *__file,
|
||||
int __lineno, const char *__sexp);
|
||||
|
||||
#endif /* not __DOXYGEN__ */
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
/*@}*/
|
||||
/* EOF */
|
677
arduino-0018-windows/hardware/tools/avr/avr/include/avr/boot.h
Normal file
677
arduino-0018-windows/hardware/tools/avr/avr/include/avr/boot.h
Normal file
|
@ -0,0 +1,677 @@
|
|||
/* Copyright (c) 2002, 2003, 2004, 2005, 2006, 2007 Eric B. Weddington
|
||||
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: boot.h,v 1.27.2.3 2008/09/30 13:58:48 arcanum Exp $ */
|
||||
|
||||
#ifndef _AVR_BOOT_H_
|
||||
#define _AVR_BOOT_H_ 1
|
||||
|
||||
/** \file */
|
||||
/** \defgroup avr_boot <avr/boot.h>: Bootloader Support Utilities
|
||||
\code
|
||||
#include <avr/io.h>
|
||||
#include <avr/boot.h>
|
||||
\endcode
|
||||
|
||||
The macros in this module provide a C language interface to the
|
||||
bootloader support functionality of certain AVR processors. These
|
||||
macros are designed to work with all sizes of flash memory.
|
||||
|
||||
Global interrupts are not automatically disabled for these macros. It
|
||||
is left up to the programmer to do this. See the code example below.
|
||||
Also see the processor datasheet for caveats on having global interrupts
|
||||
enabled during writing of the Flash.
|
||||
|
||||
\note Not all AVR processors provide bootloader support. See your
|
||||
processor datasheet to see if it provides bootloader support.
|
||||
|
||||
\todo From email with Marek: On smaller devices (all except ATmega64/128),
|
||||
__SPM_REG is in the I/O space, accessible with the shorter "in" and "out"
|
||||
instructions - since the boot loader has a limited size, this could be an
|
||||
important optimization.
|
||||
|
||||
\par API Usage Example
|
||||
The following code shows typical usage of the boot API.
|
||||
|
||||
\code
|
||||
#include <inttypes.h>
|
||||
#include <avr/interrupt.h>
|
||||
#include <avr/pgmspace.h>
|
||||
|
||||
void boot_program_page (uint32_t page, uint8_t *buf)
|
||||
{
|
||||
uint16_t i;
|
||||
uint8_t sreg;
|
||||
|
||||
// Disable interrupts.
|
||||
|
||||
sreg = SREG;
|
||||
cli();
|
||||
|
||||
eeprom_busy_wait ();
|
||||
|
||||
boot_page_erase (page);
|
||||
boot_spm_busy_wait (); // Wait until the memory is erased.
|
||||
|
||||
for (i=0; i<SPM_PAGESIZE; i+=2)
|
||||
{
|
||||
// Set up little-endian word.
|
||||
|
||||
uint16_t w = *buf++;
|
||||
w += (*buf++) << 8;
|
||||
|
||||
boot_page_fill (page + i, w);
|
||||
}
|
||||
|
||||
boot_page_write (page); // Store buffer in flash page.
|
||||
boot_spm_busy_wait(); // Wait until the memory is written.
|
||||
|
||||
// Reenable RWW-section again. We need this if we want to jump back
|
||||
// to the application after bootloading.
|
||||
|
||||
boot_rww_enable ();
|
||||
|
||||
// Re-enable interrupts (if they were ever enabled).
|
||||
|
||||
SREG = sreg;
|
||||
}\endcode */
|
||||
|
||||
#include <avr/eeprom.h>
|
||||
#include <avr/io.h>
|
||||
#include <inttypes.h>
|
||||
#include <limits.h>
|
||||
|
||||
/* Check for SPM Control Register in processor. */
|
||||
#if defined (SPMCSR)
|
||||
# define __SPM_REG SPMCSR
|
||||
#elif defined (SPMCR)
|
||||
# define __SPM_REG SPMCR
|
||||
#else
|
||||
# error AVR processor does not provide bootloader support!
|
||||
#endif
|
||||
|
||||
|
||||
/* Check for SPM Enable bit. */
|
||||
#if defined(SPMEN)
|
||||
# define __SPM_ENABLE SPMEN
|
||||
#elif defined(SELFPRGEN)
|
||||
# define __SPM_ENABLE SELFPRGEN
|
||||
#else
|
||||
# error Cannot find SPM Enable bit definition!
|
||||
#endif
|
||||
|
||||
/** \ingroup avr_boot
|
||||
\def BOOTLOADER_SECTION
|
||||
|
||||
Used to declare a function or variable to be placed into a
|
||||
new section called .bootloader. This section and its contents
|
||||
can then be relocated to any address (such as the bootloader
|
||||
NRWW area) at link-time. */
|
||||
|
||||
#define BOOTLOADER_SECTION __attribute__ ((section (".bootloader")))
|
||||
|
||||
/* Create common bit definitions. */
|
||||
#ifdef ASB
|
||||
#define __COMMON_ASB ASB
|
||||
#else
|
||||
#define __COMMON_ASB RWWSB
|
||||
#endif
|
||||
|
||||
#ifdef ASRE
|
||||
#define __COMMON_ASRE ASRE
|
||||
#else
|
||||
#define __COMMON_ASRE RWWSRE
|
||||
#endif
|
||||
|
||||
/* Define the bit positions of the Boot Lock Bits. */
|
||||
|
||||
#define BLB12 5
|
||||
#define BLB11 4
|
||||
#define BLB02 3
|
||||
#define BLB01 2
|
||||
|
||||
/** \ingroup avr_boot
|
||||
\def boot_spm_interrupt_enable()
|
||||
Enable the SPM interrupt. */
|
||||
|
||||
#define boot_spm_interrupt_enable() (__SPM_REG |= (uint8_t)_BV(SPMIE))
|
||||
|
||||
/** \ingroup avr_boot
|
||||
\def boot_spm_interrupt_disable()
|
||||
Disable the SPM interrupt. */
|
||||
|
||||
#define boot_spm_interrupt_disable() (__SPM_REG &= (uint8_t)~_BV(SPMIE))
|
||||
|
||||
/** \ingroup avr_boot
|
||||
\def boot_is_spm_interrupt()
|
||||
Check if the SPM interrupt is enabled. */
|
||||
|
||||
#define boot_is_spm_interrupt() (__SPM_REG & (uint8_t)_BV(SPMIE))
|
||||
|
||||
/** \ingroup avr_boot
|
||||
\def boot_rww_busy()
|
||||
Check if the RWW section is busy. */
|
||||
|
||||
#define boot_rww_busy() (__SPM_REG & (uint8_t)_BV(__COMMON_ASB))
|
||||
|
||||
/** \ingroup avr_boot
|
||||
\def boot_spm_busy()
|
||||
Check if the SPM instruction is busy. */
|
||||
|
||||
#define boot_spm_busy() (__SPM_REG & (uint8_t)_BV(__SPM_ENABLE))
|
||||
|
||||
/** \ingroup avr_boot
|
||||
\def boot_spm_busy_wait()
|
||||
Wait while the SPM instruction is busy. */
|
||||
|
||||
#define boot_spm_busy_wait() do{}while(boot_spm_busy())
|
||||
|
||||
#define __BOOT_PAGE_ERASE (_BV(__SPM_ENABLE) | _BV(PGERS))
|
||||
#define __BOOT_PAGE_WRITE (_BV(__SPM_ENABLE) | _BV(PGWRT))
|
||||
#define __BOOT_PAGE_FILL _BV(__SPM_ENABLE)
|
||||
#define __BOOT_RWW_ENABLE (_BV(__SPM_ENABLE) | _BV(__COMMON_ASRE))
|
||||
#define __BOOT_LOCK_BITS_SET (_BV(__SPM_ENABLE) | _BV(BLBSET))
|
||||
|
||||
#define __boot_page_fill_normal(address, data) \
|
||||
(__extension__({ \
|
||||
__asm__ __volatile__ \
|
||||
( \
|
||||
"movw r0, %3\n\t" \
|
||||
"sts %0, %1\n\t" \
|
||||
"spm\n\t" \
|
||||
"clr r1\n\t" \
|
||||
: \
|
||||
: "i" (_SFR_MEM_ADDR(__SPM_REG)), \
|
||||
"r" ((uint8_t)__BOOT_PAGE_FILL), \
|
||||
"z" ((uint16_t)address), \
|
||||
"r" ((uint16_t)data) \
|
||||
: "r0" \
|
||||
); \
|
||||
}))
|
||||
|
||||
#define __boot_page_fill_alternate(address, data)\
|
||||
(__extension__({ \
|
||||
__asm__ __volatile__ \
|
||||
( \
|
||||
"movw r0, %3\n\t" \
|
||||
"sts %0, %1\n\t" \
|
||||
"spm\n\t" \
|
||||
".word 0xffff\n\t" \
|
||||
"nop\n\t" \
|
||||
"clr r1\n\t" \
|
||||
: \
|
||||
: "i" (_SFR_MEM_ADDR(__SPM_REG)), \
|
||||
"r" ((uint8_t)__BOOT_PAGE_FILL), \
|
||||
"z" ((uint16_t)address), \
|
||||
"r" ((uint16_t)data) \
|
||||
: "r0" \
|
||||
); \
|
||||
}))
|
||||
|
||||
#define __boot_page_fill_extended(address, data) \
|
||||
(__extension__({ \
|
||||
__asm__ __volatile__ \
|
||||
( \
|
||||
"movw r0, %4\n\t" \
|
||||
"movw r30, %A3\n\t" \
|
||||
"sts %1, %C3\n\t" \
|
||||
"sts %0, %2\n\t" \
|
||||
"spm\n\t" \
|
||||
"clr r1\n\t" \
|
||||
: \
|
||||
: "i" (_SFR_MEM_ADDR(__SPM_REG)), \
|
||||
"i" (_SFR_MEM_ADDR(RAMPZ)), \
|
||||
"r" ((uint8_t)__BOOT_PAGE_FILL), \
|
||||
"r" ((uint32_t)address), \
|
||||
"r" ((uint16_t)data) \
|
||||
: "r0", "r30", "r31" \
|
||||
); \
|
||||
}))
|
||||
|
||||
#define __boot_page_erase_normal(address) \
|
||||
(__extension__({ \
|
||||
__asm__ __volatile__ \
|
||||
( \
|
||||
"sts %0, %1\n\t" \
|
||||
"spm\n\t" \
|
||||
: \
|
||||
: "i" (_SFR_MEM_ADDR(__SPM_REG)), \
|
||||
"r" ((uint8_t)__BOOT_PAGE_ERASE), \
|
||||
"z" ((uint16_t)address) \
|
||||
); \
|
||||
}))
|
||||
|
||||
#define __boot_page_erase_alternate(address) \
|
||||
(__extension__({ \
|
||||
__asm__ __volatile__ \
|
||||
( \
|
||||
"sts %0, %1\n\t" \
|
||||
"spm\n\t" \
|
||||
".word 0xffff\n\t" \
|
||||
"nop\n\t" \
|
||||
: \
|
||||
: "i" (_SFR_MEM_ADDR(__SPM_REG)), \
|
||||
"r" ((uint8_t)__BOOT_PAGE_ERASE), \
|
||||
"z" ((uint16_t)address) \
|
||||
); \
|
||||
}))
|
||||
|
||||
#define __boot_page_erase_extended(address) \
|
||||
(__extension__({ \
|
||||
__asm__ __volatile__ \
|
||||
( \
|
||||
"movw r30, %A3\n\t" \
|
||||
"sts %1, %C3\n\t" \
|
||||
"sts %0, %2\n\t" \
|
||||
"spm\n\t" \
|
||||
: \
|
||||
: "i" (_SFR_MEM_ADDR(__SPM_REG)), \
|
||||
"i" (_SFR_MEM_ADDR(RAMPZ)), \
|
||||
"r" ((uint8_t)__BOOT_PAGE_ERASE), \
|
||||
"r" ((uint32_t)address) \
|
||||
: "r30", "r31" \
|
||||
); \
|
||||
}))
|
||||
|
||||
#define __boot_page_write_normal(address) \
|
||||
(__extension__({ \
|
||||
__asm__ __volatile__ \
|
||||
( \
|
||||
"sts %0, %1\n\t" \
|
||||
"spm\n\t" \
|
||||
: \
|
||||
: "i" (_SFR_MEM_ADDR(__SPM_REG)), \
|
||||
"r" ((uint8_t)__BOOT_PAGE_WRITE), \
|
||||
"z" ((uint16_t)address) \
|
||||
); \
|
||||
}))
|
||||
|
||||
#define __boot_page_write_alternate(address) \
|
||||
(__extension__({ \
|
||||
__asm__ __volatile__ \
|
||||
( \
|
||||
"sts %0, %1\n\t" \
|
||||
"spm\n\t" \
|
||||
".word 0xffff\n\t" \
|
||||
"nop\n\t" \
|
||||
: \
|
||||
: "i" (_SFR_MEM_ADDR(__SPM_REG)), \
|
||||
"r" ((uint8_t)__BOOT_PAGE_WRITE), \
|
||||
"z" ((uint16_t)address) \
|
||||
); \
|
||||
}))
|
||||
|
||||
#define __boot_page_write_extended(address) \
|
||||
(__extension__({ \
|
||||
__asm__ __volatile__ \
|
||||
( \
|
||||
"movw r30, %A3\n\t" \
|
||||
"sts %1, %C3\n\t" \
|
||||
"sts %0, %2\n\t" \
|
||||
"spm\n\t" \
|
||||
: \
|
||||
: "i" (_SFR_MEM_ADDR(__SPM_REG)), \
|
||||
"i" (_SFR_MEM_ADDR(RAMPZ)), \
|
||||
"r" ((uint8_t)__BOOT_PAGE_WRITE), \
|
||||
"r" ((uint32_t)address) \
|
||||
: "r30", "r31" \
|
||||
); \
|
||||
}))
|
||||
|
||||
#define __boot_rww_enable() \
|
||||
(__extension__({ \
|
||||
__asm__ __volatile__ \
|
||||
( \
|
||||
"sts %0, %1\n\t" \
|
||||
"spm\n\t" \
|
||||
: \
|
||||
: "i" (_SFR_MEM_ADDR(__SPM_REG)), \
|
||||
"r" ((uint8_t)__BOOT_RWW_ENABLE) \
|
||||
); \
|
||||
}))
|
||||
|
||||
#define __boot_rww_enable_alternate() \
|
||||
(__extension__({ \
|
||||
__asm__ __volatile__ \
|
||||
( \
|
||||
"sts %0, %1\n\t" \
|
||||
"spm\n\t" \
|
||||
".word 0xffff\n\t" \
|
||||
"nop\n\t" \
|
||||
: \
|
||||
: "i" (_SFR_MEM_ADDR(__SPM_REG)), \
|
||||
"r" ((uint8_t)__BOOT_RWW_ENABLE) \
|
||||
); \
|
||||
}))
|
||||
|
||||
/* From the mega16/mega128 data sheets (maybe others):
|
||||
|
||||
Bits by SPM To set the Boot Loader Lock bits, write the desired data to
|
||||
R0, write "X0001001" to SPMCR and execute SPM within four clock cycles
|
||||
after writing SPMCR. The only accessible Lock bits are the Boot Lock bits
|
||||
that may prevent the Application and Boot Loader section from any
|
||||
software update by the MCU.
|
||||
|
||||
If bits 5..2 in R0 are cleared (zero), the corresponding Boot Lock bit
|
||||
will be programmed if an SPM instruction is executed within four cycles
|
||||
after BLBSET and SPMEN (or SELFPRGEN) are set in SPMCR. The Z-pointer is
|
||||
don't care during this operation, but for future compatibility it is
|
||||
recommended to load the Z-pointer with $0001 (same as used for reading the
|
||||
Lock bits). For future compatibility It is also recommended to set bits 7,
|
||||
6, 1, and 0 in R0 to 1 when writing the Lock bits. When programming the
|
||||
Lock bits the entire Flash can be read during the operation. */
|
||||
|
||||
#define __boot_lock_bits_set(lock_bits) \
|
||||
(__extension__({ \
|
||||
uint8_t value = (uint8_t)(~(lock_bits)); \
|
||||
__asm__ __volatile__ \
|
||||
( \
|
||||
"ldi r30, 1\n\t" \
|
||||
"ldi r31, 0\n\t" \
|
||||
"mov r0, %2\n\t" \
|
||||
"sts %0, %1\n\t" \
|
||||
"spm\n\t" \
|
||||
: \
|
||||
: "i" (_SFR_MEM_ADDR(__SPM_REG)), \
|
||||
"r" ((uint8_t)__BOOT_LOCK_BITS_SET), \
|
||||
"r" (value) \
|
||||
: "r0", "r30", "r31" \
|
||||
); \
|
||||
}))
|
||||
|
||||
#define __boot_lock_bits_set_alternate(lock_bits) \
|
||||
(__extension__({ \
|
||||
uint8_t value = (uint8_t)(~(lock_bits)); \
|
||||
__asm__ __volatile__ \
|
||||
( \
|
||||
"ldi r30, 1\n\t" \
|
||||
"ldi r31, 0\n\t" \
|
||||
"mov r0, %2\n\t" \
|
||||
"sts %0, %1\n\t" \
|
||||
"spm\n\t" \
|
||||
".word 0xffff\n\t" \
|
||||
"nop\n\t" \
|
||||
: \
|
||||
: "i" (_SFR_MEM_ADDR(__SPM_REG)), \
|
||||
"r" ((uint8_t)__BOOT_LOCK_BITS_SET), \
|
||||
"r" (value) \
|
||||
: "r0", "r30", "r31" \
|
||||
); \
|
||||
}))
|
||||
|
||||
/*
|
||||
Reading lock and fuse bits:
|
||||
|
||||
Similarly to writing the lock bits above, set BLBSET and SPMEN (or
|
||||
SELFPRGEN) bits in __SPMREG, and then (within four clock cycles) issue an
|
||||
LPM instruction.
|
||||
|
||||
Z address: contents:
|
||||
0x0000 low fuse bits
|
||||
0x0001 lock bits
|
||||
0x0002 extended fuse bits
|
||||
0x0003 high fuse bits
|
||||
|
||||
Sounds confusing, doesn't it?
|
||||
|
||||
Unlike the macros in pgmspace.h, no need to care for non-enhanced
|
||||
cores here as these old cores do not provide SPM support anyway.
|
||||
*/
|
||||
|
||||
/** \ingroup avr_boot
|
||||
\def GET_LOW_FUSE_BITS
|
||||
address to read the low fuse bits, using boot_lock_fuse_bits_get
|
||||
*/
|
||||
#define GET_LOW_FUSE_BITS (0x0000)
|
||||
/** \ingroup avr_boot
|
||||
\def GET_LOCK_BITS
|
||||
address to read the lock bits, using boot_lock_fuse_bits_get
|
||||
*/
|
||||
#define GET_LOCK_BITS (0x0001)
|
||||
/** \ingroup avr_boot
|
||||
\def GET_EXTENDED_FUSE_BITS
|
||||
address to read the extended fuse bits, using boot_lock_fuse_bits_get
|
||||
*/
|
||||
#define GET_EXTENDED_FUSE_BITS (0x0002)
|
||||
/** \ingroup avr_boot
|
||||
\def GET_HIGH_FUSE_BITS
|
||||
address to read the high fuse bits, using boot_lock_fuse_bits_get
|
||||
*/
|
||||
#define GET_HIGH_FUSE_BITS (0x0003)
|
||||
|
||||
/** \ingroup avr_boot
|
||||
\def boot_lock_fuse_bits_get(address)
|
||||
|
||||
Read the lock or fuse bits at \c address.
|
||||
|
||||
Parameter \c address can be any of GET_LOW_FUSE_BITS,
|
||||
GET_LOCK_BITS, GET_EXTENDED_FUSE_BITS, or GET_HIGH_FUSE_BITS.
|
||||
|
||||
\note The lock and fuse bits returned are the physical values,
|
||||
i.e. a bit returned as 0 means the corresponding fuse or lock bit
|
||||
is programmed.
|
||||
*/
|
||||
#define boot_lock_fuse_bits_get(address) \
|
||||
(__extension__({ \
|
||||
uint8_t __result; \
|
||||
__asm__ __volatile__ \
|
||||
( \
|
||||
"ldi r30, %3\n\t" \
|
||||
"ldi r31, 0\n\t" \
|
||||
"sts %1, %2\n\t" \
|
||||
"lpm %0, Z\n\t" \
|
||||
: "=r" (__result) \
|
||||
: "i" (_SFR_MEM_ADDR(__SPM_REG)), \
|
||||
"r" ((uint8_t)__BOOT_LOCK_BITS_SET), \
|
||||
"M" (address) \
|
||||
: "r0", "r30", "r31" \
|
||||
); \
|
||||
__result; \
|
||||
}))
|
||||
|
||||
/** \ingroup avr_boot
|
||||
\def boot_signature_byte_get(address)
|
||||
|
||||
Read the Signature Row byte at \c address. For some MCU types,
|
||||
this function can also retrieve the factory-stored oscillator
|
||||
calibration bytes.
|
||||
|
||||
Parameter \c address can be 0-0x1f as documented by the datasheet.
|
||||
\note The values are MCU type dependent.
|
||||
*/
|
||||
|
||||
#define __BOOT_SIGROW_READ (_BV(__SPM_ENABLE) | _BV(SIGRD))
|
||||
|
||||
#define boot_signature_byte_get(addr) \
|
||||
(__extension__({ \
|
||||
uint16_t __addr16 = (uint16_t)(addr); \
|
||||
uint8_t __result; \
|
||||
__asm__ __volatile__ \
|
||||
( \
|
||||
"sts %1, %2\n\t" \
|
||||
"lpm %0, Z" "\n\t" \
|
||||
: "=r" (__result) \
|
||||
: "i" (_SFR_MEM_ADDR(__SPM_REG)), \
|
||||
"r" ((uint8_t) __BOOT_SIGROW_READ), \
|
||||
"z" (__addr16) \
|
||||
); \
|
||||
__result; \
|
||||
}))
|
||||
|
||||
/** \ingroup avr_boot
|
||||
\def boot_page_fill(address, data)
|
||||
|
||||
Fill the bootloader temporary page buffer for flash
|
||||
address with data word.
|
||||
|
||||
\note The address is a byte address. The data is a word. The AVR
|
||||
writes data to the buffer a word at a time, but addresses the buffer
|
||||
per byte! So, increment your address by 2 between calls, and send 2
|
||||
data bytes in a word format! The LSB of the data is written to the lower
|
||||
address; the MSB of the data is written to the higher address.*/
|
||||
|
||||
/** \ingroup avr_boot
|
||||
\def boot_page_erase(address)
|
||||
|
||||
Erase the flash page that contains address.
|
||||
|
||||
\note address is a byte address in flash, not a word address. */
|
||||
|
||||
/** \ingroup avr_boot
|
||||
\def boot_page_write(address)
|
||||
|
||||
Write the bootloader temporary page buffer
|
||||
to flash page that contains address.
|
||||
|
||||
\note address is a byte address in flash, not a word address. */
|
||||
|
||||
/** \ingroup avr_boot
|
||||
\def boot_rww_enable()
|
||||
|
||||
Enable the Read-While-Write memory section. */
|
||||
|
||||
/** \ingroup avr_boot
|
||||
\def boot_lock_bits_set(lock_bits)
|
||||
|
||||
Set the bootloader lock bits.
|
||||
|
||||
\param lock_bits A mask of which Boot Loader Lock Bits to set.
|
||||
|
||||
\note In this context, a 'set bit' will be written to a zero value.
|
||||
Note also that only BLBxx bits can be programmed by this command.
|
||||
|
||||
For example, to disallow the SPM instruction from writing to the Boot
|
||||
Loader memory section of flash, you would use this macro as such:
|
||||
|
||||
\code
|
||||
boot_lock_bits_set (_BV (BLB11));
|
||||
\endcode
|
||||
|
||||
\note Like any lock bits, the Boot Loader Lock Bits, once set,
|
||||
cannot be cleared again except by a chip erase which will in turn
|
||||
also erase the boot loader itself. */
|
||||
|
||||
/* Normal versions of the macros use 16-bit addresses.
|
||||
Extended versions of the macros use 32-bit addresses.
|
||||
Alternate versions of the macros use 16-bit addresses and require special
|
||||
instruction sequences after LPM.
|
||||
|
||||
FLASHEND is defined in the ioXXXX.h file.
|
||||
USHRT_MAX is defined in <limits.h>. */
|
||||
|
||||
#if defined(__AVR_ATmega161__) || defined(__AVR_ATmega163__) \
|
||||
|| defined(__AVR_ATmega323__)
|
||||
|
||||
/* Alternate: ATmega161/163/323 and 16 bit address */
|
||||
#define boot_page_fill(address, data) __boot_page_fill_alternate(address, data)
|
||||
#define boot_page_erase(address) __boot_page_erase_alternate(address)
|
||||
#define boot_page_write(address) __boot_page_write_alternate(address)
|
||||
#define boot_rww_enable() __boot_rww_enable_alternate()
|
||||
#define boot_lock_bits_set(lock_bits) __boot_lock_bits_set_alternate(lock_bits)
|
||||
|
||||
#elif (FLASHEND > USHRT_MAX)
|
||||
|
||||
/* Extended: >16 bit address */
|
||||
#define boot_page_fill(address, data) __boot_page_fill_extended(address, data)
|
||||
#define boot_page_erase(address) __boot_page_erase_extended(address)
|
||||
#define boot_page_write(address) __boot_page_write_extended(address)
|
||||
#define boot_rww_enable() __boot_rww_enable()
|
||||
#define boot_lock_bits_set(lock_bits) __boot_lock_bits_set(lock_bits)
|
||||
|
||||
#else
|
||||
|
||||
/* Normal: 16 bit address */
|
||||
#define boot_page_fill(address, data) __boot_page_fill_normal(address, data)
|
||||
#define boot_page_erase(address) __boot_page_erase_normal(address)
|
||||
#define boot_page_write(address) __boot_page_write_normal(address)
|
||||
#define boot_rww_enable() __boot_rww_enable()
|
||||
#define boot_lock_bits_set(lock_bits) __boot_lock_bits_set(lock_bits)
|
||||
|
||||
#endif
|
||||
|
||||
/** \ingroup avr_boot
|
||||
|
||||
Same as boot_page_fill() except it waits for eeprom and spm operations to
|
||||
complete before filling the page. */
|
||||
|
||||
#define boot_page_fill_safe(address, data) \
|
||||
do { \
|
||||
boot_spm_busy_wait(); \
|
||||
eeprom_busy_wait(); \
|
||||
boot_page_fill(address, data); \
|
||||
} while (0)
|
||||
|
||||
/** \ingroup avr_boot
|
||||
|
||||
Same as boot_page_erase() except it waits for eeprom and spm operations to
|
||||
complete before erasing the page. */
|
||||
|
||||
#define boot_page_erase_safe(address) \
|
||||
do { \
|
||||
boot_spm_busy_wait(); \
|
||||
eeprom_busy_wait(); \
|
||||
boot_page_erase (address); \
|
||||
} while (0)
|
||||
|
||||
/** \ingroup avr_boot
|
||||
|
||||
Same as boot_page_write() except it waits for eeprom and spm operations to
|
||||
complete before writing the page. */
|
||||
|
||||
#define boot_page_write_safe(address) \
|
||||
do { \
|
||||
boot_spm_busy_wait(); \
|
||||
eeprom_busy_wait(); \
|
||||
boot_page_write (address); \
|
||||
} while (0)
|
||||
|
||||
/** \ingroup avr_boot
|
||||
|
||||
Same as boot_rww_enable() except waits for eeprom and spm operations to
|
||||
complete before enabling the RWW mameory. */
|
||||
|
||||
#define boot_rww_enable_safe() \
|
||||
do { \
|
||||
boot_spm_busy_wait(); \
|
||||
eeprom_busy_wait(); \
|
||||
boot_rww_enable(); \
|
||||
} while (0)
|
||||
|
||||
/** \ingroup avr_boot
|
||||
|
||||
Same as boot_lock_bits_set() except waits for eeprom and spm operations to
|
||||
complete before setting the lock bits. */
|
||||
|
||||
#define boot_lock_bits_set_safe(lock_bits) \
|
||||
do { \
|
||||
boot_spm_busy_wait(); \
|
||||
eeprom_busy_wait(); \
|
||||
boot_lock_bits_set (lock_bits); \
|
||||
} while (0)
|
||||
|
||||
#endif /* _AVR_BOOT_H_ */
|
|
@ -0,0 +1,101 @@
|
|||
/* Copyright (c) 2008 Anatoly Sokolv
|
||||
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:$ */
|
||||
|
||||
/*
|
||||
avr/builtins.h -
|
||||
*/
|
||||
|
||||
#ifndef _AVR_BUILTINS_H_
|
||||
#define _AVR_BUILTINS_H_
|
||||
|
||||
/** \file */
|
||||
/** \defgroup avr_builtins <avr/builtins.h>: GCC builtins
|
||||
\code #include <avr/builtins.h> \endcode
|
||||
|
||||
This header file declares avr builtins. */
|
||||
|
||||
/**
|
||||
\ingroup avr_builtins
|
||||
|
||||
Enables interrupts by setting the global interrupt mask. */
|
||||
extern void __builtin_avr_sei(void);
|
||||
|
||||
/**
|
||||
\ingroup avr_builtins
|
||||
|
||||
Disables all interrupts by clearing the global interrupt mask. */
|
||||
extern void __builtin_avr_cli(void);
|
||||
|
||||
/**
|
||||
\ingroup avr_builtins
|
||||
|
||||
TODO. */
|
||||
|
||||
extern void __builtin_avr_sleep(void);
|
||||
|
||||
/**
|
||||
\ingroup avr_builtins
|
||||
|
||||
TODO. */
|
||||
extern void __builtin_avr_wdr(void);
|
||||
|
||||
/**
|
||||
\ingroup avr_builtins
|
||||
|
||||
TODO. */
|
||||
extern unsigned char __builtin_avr_swap(unsigned char __b);
|
||||
|
||||
/**
|
||||
\ingroup avr_builtins
|
||||
|
||||
TODO. */
|
||||
extern unsigned int __builtin_avr_fmul(unsigned char __a, unsigned char __b);
|
||||
|
||||
/**
|
||||
\ingroup avr_builtins
|
||||
|
||||
TODO. */
|
||||
extern int __builtin_avr_fmuls(char __a, char __b);
|
||||
|
||||
/**
|
||||
\ingroup avr_builtins
|
||||
|
||||
TODO. */
|
||||
extern int __builtin_avr_fmulsu(char __a, unsigned char __b);
|
||||
|
||||
/**
|
||||
\ingroup avr_builtins
|
||||
|
||||
TODO. */
|
||||
extern void __builtin_avr_delay_cycles(unsigned long __n);
|
||||
|
||||
#endif /* _AVR_BUILTINS_H_ */
|
293
arduino-0018-windows/hardware/tools/avr/avr/include/avr/common.h
Normal file
293
arduino-0018-windows/hardware/tools/avr/avr/include/avr/common.h
Normal file
|
@ -0,0 +1,293 @@
|
|||
/* Copyright (c) 2007 Eric B. Weddington
|
||||
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: common.h,v 1.3.4.3 2008/03/24 17:11:06 arcanum Exp $ */
|
||||
|
||||
|
||||
#ifndef _AVR_COMMON_H
|
||||
#define _AVR_COMMON_H
|
||||
|
||||
#include <avr/sfr_defs.h>
|
||||
|
||||
/*
|
||||
This purpose of this header is to define registers that have not been
|
||||
previously defined in the individual device IO header files, and to define
|
||||
other symbols that are common across AVR device families.
|
||||
|
||||
This file is designed to be included in <avr/io.h> after the individual
|
||||
device IO header files, and after <avr/sfr_defs.h>
|
||||
|
||||
*/
|
||||
|
||||
/*------------ Registers Not Previously Defined ------------*/
|
||||
|
||||
/*
|
||||
These are registers that are not previously defined in the individual
|
||||
IO header files, OR they are defined here because they are used in parts of
|
||||
avr-libc even if a device is not selected but a general architecture has
|
||||
been selected.
|
||||
*/
|
||||
|
||||
|
||||
/*
|
||||
Stack pointer register.
|
||||
|
||||
AVR architecture 1 has no RAM, thus no stack pointer.
|
||||
|
||||
All other architectures do have a stack pointer. Some devices have only
|
||||
less than 256 bytes of possible RAM locations (128 Bytes of SRAM
|
||||
and no option for external RAM), thus SPH is officially "reserved"
|
||||
for them.
|
||||
*/
|
||||
#if __AVR_ARCH__ >= 100
|
||||
# ifndef SPL
|
||||
# define SPL _SFR_MEM8(0x3D)
|
||||
# endif
|
||||
# ifndef SPH
|
||||
# define SPH _SFR_MEM8(0x3E)
|
||||
# endif
|
||||
# ifndef SP
|
||||
# define SP _SFR_MEM16(0x3D)
|
||||
# endif
|
||||
#elif __AVR_ARCH__ != 1
|
||||
# ifndef SPL
|
||||
# define SPL _SFR_IO8(0x3D)
|
||||
# endif
|
||||
# if XRAMEND < 0x100 && !defined(__COMPILING_AVR_LIBC__)
|
||||
# ifndef SP
|
||||
# define SP _SFR_IO8(0x3D)
|
||||
# endif
|
||||
# else
|
||||
# ifndef SP
|
||||
# define SP _SFR_IO16(0x3D)
|
||||
# endif
|
||||
# ifndef SPH
|
||||
# define SPH _SFR_IO8(0x3E)
|
||||
# endif
|
||||
# endif /* XRAMEND < 0x100 && !defined(__COMPILING_AVR_LIBC__) */
|
||||
#endif /* __AVR_ARCH__ != 1 */
|
||||
|
||||
|
||||
/* Status Register */
|
||||
#ifndef SREG
|
||||
# if __AVR_ARCH__ >= 100
|
||||
# define SREG _SFR_MEM8(0x3F)
|
||||
# else
|
||||
# define SREG _SFR_IO8(0x3F)
|
||||
# endif
|
||||
#endif
|
||||
|
||||
|
||||
/* SREG bit definitions */
|
||||
#ifndef SREG_C
|
||||
# define SREG_C (0)
|
||||
#endif
|
||||
#ifndef SREG_Z
|
||||
# define SREG_Z (1)
|
||||
#endif
|
||||
#ifndef SREG_N
|
||||
# define SREG_N (2)
|
||||
#endif
|
||||
#ifndef SREG_V
|
||||
# define SREG_V (3)
|
||||
#endif
|
||||
#ifndef SREG_S
|
||||
# define SREG_S (4)
|
||||
#endif
|
||||
#ifndef SREG_H
|
||||
# define SREG_H (5)
|
||||
#endif
|
||||
#ifndef SREG_T
|
||||
# define SREG_T (6)
|
||||
#endif
|
||||
#ifndef SREG_I
|
||||
# define SREG_I (7)
|
||||
#endif
|
||||
|
||||
|
||||
#if defined(__COMPILING_AVR_LIBC__)
|
||||
|
||||
/* AVR 6 Architecture */
|
||||
# if __AVR_ARCH__ == 6
|
||||
# ifndef EIND
|
||||
# define EIND _SFR_IO8(0X3C)
|
||||
# endif
|
||||
/* XMEGA Architectures */
|
||||
# elif __AVR_ARCH__ >= 100
|
||||
# ifndef EIND
|
||||
# define EIND _SFR_MEM8(0x3C)
|
||||
# endif
|
||||
# endif
|
||||
|
||||
/*
|
||||
Only few devices come without EEPROM. In order to assemble the
|
||||
EEPROM library components without defining a specific device, we
|
||||
keep the EEPROM-related definitions here.
|
||||
*/
|
||||
|
||||
/* EEPROM Control Register */
|
||||
# ifndef EECR
|
||||
# define EECR _SFR_IO8(0x1C)
|
||||
# endif
|
||||
|
||||
/* EEPROM Data Register */
|
||||
# ifndef EEDR
|
||||
# define EEDR _SFR_IO8(0x1D)
|
||||
# endif
|
||||
|
||||
/* EEPROM Address Register */
|
||||
# ifndef EEAR
|
||||
# define EEAR _SFR_IO16(0x1E)
|
||||
# endif
|
||||
# ifndef EEARL
|
||||
# define EEARL _SFR_IO8(0x1E)
|
||||
# endif
|
||||
# ifndef EEARH
|
||||
# define EEARH _SFR_IO8(0x1F)
|
||||
# endif
|
||||
|
||||
/* EEPROM Control Register bits */
|
||||
# ifndef EERE
|
||||
# define EERE (0)
|
||||
# endif
|
||||
# ifndef EEWE
|
||||
# define EEWE (1)
|
||||
# endif
|
||||
# ifndef EEMWE
|
||||
# define EEMWE (2)
|
||||
# endif
|
||||
# ifndef EERIE
|
||||
# define EERIE (3)
|
||||
# endif
|
||||
|
||||
#endif /* __COMPILING_AVR_LIBC__ */
|
||||
|
||||
|
||||
|
||||
/*------------ Common Symbols ------------*/
|
||||
|
||||
/*
|
||||
Generic definitions for registers that are common across multiple AVR devices
|
||||
and families.
|
||||
*/
|
||||
|
||||
/* Pointer registers definitions */
|
||||
#if __AVR_ARCH__ != 1 /* avr1 does not have X and Y pointers */
|
||||
# define XL r26
|
||||
# define XH r27
|
||||
# define YL r28
|
||||
# define YH r29
|
||||
#endif /* #if __AVR_ARCH__ != 1 */
|
||||
#define ZL r30
|
||||
#define ZH r31
|
||||
|
||||
|
||||
/* Status Register */
|
||||
#if defined(SREG)
|
||||
# define AVR_STATUS_REG SREG
|
||||
# if __AVR_ARCH__ >= 100
|
||||
# define AVR_STATUS_ADDR _SFR_MEM_ADDR(SREG)
|
||||
# else
|
||||
# define AVR_STATUS_ADDR _SFR_IO_ADDR(SREG)
|
||||
# endif
|
||||
#endif
|
||||
|
||||
/* Stack Pointer (combined) Register */
|
||||
#if defined(SP)
|
||||
# define AVR_STACK_POINTER_REG SP
|
||||
# if __AVR_ARCH__ >= 100
|
||||
# define AVR_STACK_POINTER_ADDR _SFR_MEM_ADDR(SP)
|
||||
# else
|
||||
# define AVR_STACK_POINTER_ADDR _SFR_IO_ADDR(SP)
|
||||
# endif
|
||||
#endif
|
||||
|
||||
/* Stack Pointer High Register */
|
||||
#if defined(SPH)
|
||||
# define _HAVE_AVR_STACK_POINTER_HI 1
|
||||
# define AVR_STACK_POINTER_HI_REG SPH
|
||||
# if __AVR_ARCH__ >= 100
|
||||
# define AVR_STACK_POINTER_HI_ADDR _SFR_MEM_ADDR(SPH)
|
||||
# else
|
||||
# define AVR_STACK_POINTER_HI_ADDR _SFR_IO_ADDR(SPH)
|
||||
# endif
|
||||
#endif
|
||||
|
||||
/* Stack Pointer Low Register */
|
||||
#if defined(SPL)
|
||||
# define AVR_STACK_POINTER_LO_REG SPL
|
||||
# if __AVR_ARCH__ >= 100
|
||||
# define AVR_STACK_POINTER_LO_ADDR _SFR_MEM_ADDR(SPL)
|
||||
# else
|
||||
# define AVR_STACK_POINTER_LO_ADDR _SFR_IO_ADDR(SPL)
|
||||
# endif
|
||||
#endif
|
||||
|
||||
/* RAMPZ Register */
|
||||
#if defined(RAMPZ)
|
||||
# define AVR_RAMPZ_REG RAMPZ
|
||||
# if __AVR_ARCH__ >= 100
|
||||
# define AVR_RAMPZ_ADDR _SFR_MEM_ADDR(RAMPZ)
|
||||
# else
|
||||
# define AVR_RAMPZ_ADDR _SFR_IO_ADDR(RAMPZ)
|
||||
# endif
|
||||
#endif
|
||||
|
||||
/* Extended Indirect Register */
|
||||
#if defined(EIND)
|
||||
# define AVR_EXTENDED_INDIRECT_REG EIND
|
||||
# if __AVR_ARCH__ >= 100
|
||||
# define AVR_EXTENDED_INDIRECT_ADDR _SFR_MEM_ADDR(EIND)
|
||||
# else
|
||||
# define AVR_EXTENDED_INDIRECT_ADDR _SFR_IO_ADDR(EIND)
|
||||
# endif
|
||||
#endif
|
||||
|
||||
/*------------ Workaround to old compilers (4.1.2 and earlier) ------------*/
|
||||
|
||||
#ifndef __AVR_HAVE_MOVW__
|
||||
# if defined(__AVR_ENHANCED__) && __AVR_ENHANCED__
|
||||
# define __AVR_HAVE_MOVW__ 1
|
||||
# endif
|
||||
#endif
|
||||
|
||||
#ifndef __AVR_HAVE_LPMX__
|
||||
# if defined(__AVR_ENHANCED__) && __AVR_ENHANCED__
|
||||
# define __AVR_HAVE_LPMX__ 1
|
||||
# endif
|
||||
#endif
|
||||
|
||||
#ifndef __AVR_HAVE_MUL__
|
||||
# if defined(__AVR_ENHANCED__) && __AVR_ENHANCED__
|
||||
# define __AVR_HAVE_MUL__ 1
|
||||
# endif
|
||||
#endif
|
||||
|
||||
#endif /* _AVR_COMMON_H */
|
|
@ -0,0 +1,39 @@
|
|||
/* Copyright (c) 2005 Joerg Wunsch
|
||||
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: crc16.h,v 1.10 2005/11/05 22:23:15 joerg_wunsch Exp $ */
|
||||
|
||||
#ifndef _AVR_CRC16_H_
|
||||
#define _AVR_CRC16_H_
|
||||
|
||||
#warning "This file has been moved to <util/crc16.h>."
|
||||
#include <util/crc16.h>
|
||||
|
||||
#endif /* _AVR_CRC16_H_ */
|
|
@ -0,0 +1,39 @@
|
|||
/* Copyright (c) 2005 Joerg Wunsch
|
||||
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: delay.h,v 1.14 2005/11/05 22:23:15 joerg_wunsch Exp $ */
|
||||
|
||||
#ifndef _AVR_DELAY_H_
|
||||
#define _AVR_DELAY_H_
|
||||
|
||||
#warning "This file has been moved to <util/delay.h>."
|
||||
#include <util/delay.h>
|
||||
|
||||
#endif /* _AVR_DELAY_H_ */
|
423
arduino-0018-windows/hardware/tools/avr/avr/include/avr/eeprom.h
Normal file
423
arduino-0018-windows/hardware/tools/avr/avr/include/avr/eeprom.h
Normal file
|
@ -0,0 +1,423 @@
|
|||
/* Copyright (c) 2002, 2003, 2004, 2007 Marek Michalkiewicz
|
||||
Copyright (c) 2005, 2006 Bjoern Haase
|
||||
Copyright (c) 2008 Atmel Corporation
|
||||
Copyright (c) 2008 Wouter van Gulik
|
||||
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: eeprom.h,v 1.21.2.6 2008/08/19 22:10:39 arcanum Exp $ */
|
||||
|
||||
#ifndef _AVR_EEPROM_H_
|
||||
#define _AVR_EEPROM_H_ 1
|
||||
|
||||
#include <avr/io.h>
|
||||
#include <stddef.h> /* size_t */
|
||||
#include <stdint.h>
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#ifndef __ATTR_PURE__
|
||||
# ifdef __DOXYGEN__
|
||||
# define __ATTR_PURE__
|
||||
# else
|
||||
# define __ATTR_PURE__ __attribute__((__pure__))
|
||||
# endif
|
||||
#endif
|
||||
|
||||
#if (! (defined(__AVR_ATmega2560__) || defined(__AVR_ATmega2561__)) )
|
||||
uint16_t __eerd_word (const uint16_t *, uint8_t (*)(const uint8_t *))
|
||||
__ATTR_PURE__;
|
||||
uint32_t __eerd_dword (const uint32_t *, uint8_t (*)(const uint8_t *))
|
||||
__ATTR_PURE__;
|
||||
void __eerd_block (void *, const void *, size_t, uint8_t (*)(const uint8_t *));
|
||||
|
||||
void __eewr_word (uint16_t *, uint16_t, void (*)(uint8_t *, uint8_t));
|
||||
void __eewr_dword (uint32_t *, uint32_t, void (*)(uint8_t *, uint8_t));
|
||||
void __eewr_block (void *, const void *, size_t, void (*)(uint8_t *, uint8_t));
|
||||
#endif /* (! (defined(__AVR_ATmega2560__) || defined(__AVR_ATmega2561__)) ) */
|
||||
|
||||
#if !E2END && !defined(__DOXYGEN__)
|
||||
# ifndef __COMPILING_AVR_LIBC__
|
||||
# warning "Device does not have EEPROM available."
|
||||
# endif
|
||||
/* Omit below for chips without EEPROM. */
|
||||
|
||||
#else
|
||||
|
||||
/** \defgroup avr_eeprom <avr/eeprom.h>: EEPROM handling
|
||||
\code #include <avr/eeprom.h> \endcode
|
||||
|
||||
This header file declares the interface to some simple library
|
||||
routines suitable for handling the data EEPROM contained in the
|
||||
AVR microcontrollers. The implementation uses a simple polled
|
||||
mode interface. Applications that require interrupt-controlled
|
||||
EEPROM access to ensure that no time will be wasted in spinloops
|
||||
will have to deploy their own implementation.
|
||||
|
||||
\note All of the read/write functions first make sure the EEPROM
|
||||
is ready to be accessed. Since this may cause long delays if a
|
||||
write operation is still pending, time-critical applications
|
||||
should first poll the EEPROM e. g. using eeprom_is_ready() before
|
||||
attempting any actual I/O. But this functions are not wait until
|
||||
SELFPRGEN in SPMCSR becomes zero. Do this manually, if your
|
||||
softwate contains the Flash burning.
|
||||
|
||||
\note As these functions modify IO registers, they are known to be
|
||||
non-reentrant. If any of these functions are used from both,
|
||||
standard and interrupt context, the applications must ensure
|
||||
proper protection (e.g. by disabling interrupts before accessing
|
||||
them).
|
||||
|
||||
\note All write functions force erase_and_write programming mode.
|
||||
*/
|
||||
|
||||
/** \def EEMEM
|
||||
\ingroup avr_eeprom
|
||||
Attribute expression causing a variable to be allocated within the
|
||||
.eeprom section. */
|
||||
#define EEMEM __attribute__((section(".eeprom")))
|
||||
|
||||
|
||||
/* Register definitions */
|
||||
|
||||
/* Check for aliases. */
|
||||
#if !defined(EEWE) && defined(EEPE)
|
||||
# define EEWE EEPE
|
||||
#endif
|
||||
|
||||
#if !defined(EEMWE) && defined(EEMPE)
|
||||
# define EEMWE EEMPE
|
||||
#endif
|
||||
|
||||
#if !defined(EECR) && defined(DEECR)
|
||||
/* AT86RF401 */
|
||||
# define EECR DEECR
|
||||
# define EEAR DEEAR
|
||||
# define EEARL DEEAR
|
||||
# define EEDR DEEDR
|
||||
# define EERE EER
|
||||
# define EEWE EEL
|
||||
# define EEMWE EEU
|
||||
#endif
|
||||
|
||||
|
||||
#if !defined(EECR) || !defined(EEDR) || !defined(EEARL)
|
||||
|
||||
# if !defined(__EEPROM_REG_LOCATIONS__) \
|
||||
&& !defined(EEPROM_REG_LOCATIONS_OVERRIDE)
|
||||
/* 6-byte string 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.
|
||||
*/
|
||||
# error "Unknown EEPROM register(s) location."
|
||||
# endif
|
||||
|
||||
/* If needed, override the locations defined in the IO headers. */
|
||||
# ifdef EEPROM_REG_LOCATIONS_OVERRIDE
|
||||
# undef __EEPROM_REG_LOCATIONS__
|
||||
# define __EEPROM_REG_LOCATIONS__ EEPROM_REG_LOCATIONS_OVERRIDE
|
||||
# endif
|
||||
|
||||
# define CONCAT1(a, b) CONCAT2(a, b)
|
||||
# define CONCAT2(a, b) a ## b
|
||||
# define HEXNR CONCAT1(0x, __EEPROM_REG_LOCATIONS__)
|
||||
|
||||
# undef EECR
|
||||
# define EECR _SFR_IO8((HEXNR >> 16) & 0xFF)
|
||||
|
||||
# undef EEDR
|
||||
# define EEDR _SFR_IO8((HEXNR >> 8) & 0xFF)
|
||||
|
||||
# undef EEAR
|
||||
# define EEAR _SFR_IO8(HEXNR & 0xFF)
|
||||
|
||||
# undef EEARH
|
||||
|
||||
# undef EEARL
|
||||
# define EEARL EEAR
|
||||
|
||||
#endif
|
||||
|
||||
|
||||
/** \def eeprom_is_ready
|
||||
\ingroup avr_eeprom
|
||||
\returns 1 if EEPROM is ready for a new read/write operation, 0 if not.
|
||||
*/
|
||||
#if defined(__DOXYGEN__)
|
||||
# define eeprom_is_ready()
|
||||
#elif defined(DEECR)
|
||||
# define eeprom_is_ready() bit_is_clear(DEECR, BSY)
|
||||
#else
|
||||
# define eeprom_is_ready() bit_is_clear(EECR, EEWE)
|
||||
#endif
|
||||
|
||||
|
||||
/** \def eeprom_busy_wait
|
||||
\ingroup avr_eeprom
|
||||
Loops until the eeprom is no longer busy.
|
||||
\returns Nothing.
|
||||
*/
|
||||
#define eeprom_busy_wait() do {} while (!eeprom_is_ready())
|
||||
|
||||
|
||||
/** \ingroup avr_eeprom
|
||||
Read one byte from EEPROM address \a __p.
|
||||
*/
|
||||
__ATTR_PURE__ static __inline__ uint8_t eeprom_read_byte (const uint8_t *__p)
|
||||
{
|
||||
do {} while (!eeprom_is_ready ());
|
||||
#if E2END <= 0xFF
|
||||
EEARL = (uint8_t)__p;
|
||||
#else
|
||||
EEAR = (uint16_t)__p;
|
||||
#endif
|
||||
/* Use inline assembly below as some AVRs have problems with accessing
|
||||
EECR with STS instructions. For example, see errata for ATmega64.
|
||||
The code below also assumes that EECR and EEDR are in the I/O space.
|
||||
*/
|
||||
uint8_t __result;
|
||||
__asm__ __volatile__
|
||||
(
|
||||
"/* START EEPROM READ CRITICAL SECTION */ \n\t"
|
||||
"sbi %1, %2 \n\t"
|
||||
"in %0, %3 \n\t"
|
||||
"/* END EEPROM READ CRITICAL SECTION */ \n\t"
|
||||
: "=r" (__result)
|
||||
: "i" (_SFR_IO_ADDR(EECR)),
|
||||
"i" (EERE),
|
||||
"i" (_SFR_IO_ADDR(EEDR))
|
||||
);
|
||||
return __result;
|
||||
}
|
||||
|
||||
/** \ingroup avr_eeprom
|
||||
Read one 16-bit word (little endian) from EEPROM address \a __p.
|
||||
*/
|
||||
__ATTR_PURE__ static __inline__ uint16_t eeprom_read_word (const uint16_t *__p)
|
||||
{
|
||||
#if (! (defined(__AVR_ATmega2560__) || defined(__AVR_ATmega2561__)) )
|
||||
return __eerd_word (__p, eeprom_read_byte);
|
||||
#else
|
||||
/* If ATmega256x device, do not call function. */
|
||||
union
|
||||
{
|
||||
uint16_t word;
|
||||
struct
|
||||
{
|
||||
uint8_t lo;
|
||||
uint8_t hi;
|
||||
} byte;
|
||||
} x;
|
||||
|
||||
x.byte.lo = eeprom_read_byte ((const uint8_t *)__p);
|
||||
x.byte.hi = eeprom_read_byte ((const uint8_t *)__p + 1);
|
||||
return x.word;
|
||||
#endif
|
||||
}
|
||||
|
||||
/** \ingroup avr_eeprom
|
||||
Read one 32-bit double word (little endian) from EEPROM address \a __p.
|
||||
*/
|
||||
__ATTR_PURE__ static __inline__
|
||||
uint32_t eeprom_read_dword (const uint32_t *__p)
|
||||
{
|
||||
#if (! (defined(__AVR_ATmega2560__) || defined(__AVR_ATmega2561__)) )
|
||||
return __eerd_dword (__p, eeprom_read_byte);
|
||||
#else
|
||||
/* If ATmega256x device, do not call function. */
|
||||
union
|
||||
{
|
||||
uint32_t dword;
|
||||
struct
|
||||
{
|
||||
uint8_t byte0;
|
||||
uint8_t byte1;
|
||||
uint8_t byte2;
|
||||
uint8_t byte3;
|
||||
} byte;
|
||||
} x;
|
||||
|
||||
x.byte.byte0 = eeprom_read_byte ((const uint8_t *)__p);
|
||||
x.byte.byte1 = eeprom_read_byte ((const uint8_t *)__p + 1);
|
||||
x.byte.byte2 = eeprom_read_byte ((const uint8_t *)__p + 2);
|
||||
x.byte.byte3 = eeprom_read_byte ((const uint8_t *)__p + 3);
|
||||
return x.dword;
|
||||
#endif
|
||||
}
|
||||
|
||||
/** \ingroup avr_eeprom
|
||||
Read a block of \a __n bytes from EEPROM address \a __src to SRAM
|
||||
\a __dst.
|
||||
*/
|
||||
static __inline__ void
|
||||
eeprom_read_block (void *__dst, const void *__src, size_t __n)
|
||||
{
|
||||
#if (! (defined(__AVR_ATmega2560__) || defined(__AVR_ATmega2561__)) )
|
||||
__eerd_block (__dst, __src, __n, eeprom_read_byte);
|
||||
#else
|
||||
/* If ATmega256x device, do not call function. */
|
||||
while (__n--)
|
||||
{
|
||||
*(char *)__dst++ = eeprom_read_byte(__src++);
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
/** \ingroup avr_eeprom
|
||||
Write a byte \a __value to EEPROM address \a __p.
|
||||
*/
|
||||
static __inline__ void eeprom_write_byte (uint8_t *__p, uint8_t __value)
|
||||
{
|
||||
do {} while (!eeprom_is_ready ());
|
||||
|
||||
#if defined(EEPM0) && defined(EEPM1)
|
||||
EECR = 0; /* Set programming mode: erase and write. */
|
||||
#elif defined(EEPM0) || defined(EEPM1)
|
||||
# warning "Unknown EECR register, eeprom_write_byte() has become outdated."
|
||||
#endif
|
||||
|
||||
#if E2END <= 0xFF
|
||||
EEARL = (unsigned)__p;
|
||||
#else
|
||||
EEAR = (unsigned)__p;
|
||||
#endif
|
||||
EEDR = __value;
|
||||
|
||||
__asm__ __volatile__ (
|
||||
"/* START EEPROM WRITE CRITICAL SECTION */\n\t"
|
||||
"in r0, %[__sreg] \n\t"
|
||||
"cli \n\t"
|
||||
"sbi %[__eecr], %[__eemwe] \n\t"
|
||||
"sbi %[__eecr], %[__eewe] \n\t"
|
||||
"out %[__sreg], r0 \n\t"
|
||||
"/* END EEPROM WRITE CRITICAL SECTION */"
|
||||
:
|
||||
: [__eecr] "i" (_SFR_IO_ADDR(EECR)),
|
||||
[__sreg] "i" (_SFR_IO_ADDR(SREG)),
|
||||
[__eemwe] "i" (EEMWE),
|
||||
[__eewe] "i" (EEWE)
|
||||
: "r0"
|
||||
);
|
||||
}
|
||||
|
||||
/** \ingroup avr_eeprom
|
||||
Write a word \a __value to EEPROM address \a __p.
|
||||
*/
|
||||
static __inline__ void eeprom_write_word (uint16_t *__p, uint16_t __value)
|
||||
{
|
||||
#if (! (defined(__AVR_ATmega2560__) || defined(__AVR_ATmega2561__)) )
|
||||
__eewr_word (__p, __value, eeprom_write_byte);
|
||||
#else
|
||||
/* If ATmega256x device, do not call function. */
|
||||
union
|
||||
{
|
||||
uint16_t word;
|
||||
struct
|
||||
{
|
||||
uint8_t lo;
|
||||
uint8_t hi;
|
||||
} byte;
|
||||
} x;
|
||||
|
||||
x.word = __value;
|
||||
eeprom_write_byte ((uint8_t *)__p, x.byte.lo);
|
||||
eeprom_write_byte ((uint8_t *)__p + 1, x.byte.hi);
|
||||
#endif
|
||||
}
|
||||
|
||||
/** \ingroup avr_eeprom
|
||||
Write a 32-bit double word \a __value to EEPROM address \a __p.
|
||||
*/
|
||||
static __inline__ void eeprom_write_dword (uint32_t *__p, uint32_t __value)
|
||||
{
|
||||
#if (! (defined(__AVR_ATmega2560__) || defined(__AVR_ATmega2561__)) )
|
||||
__eewr_dword (__p, __value, eeprom_write_byte);
|
||||
#else
|
||||
/* If ATmega256x device, do not call function. */
|
||||
union
|
||||
{
|
||||
uint32_t dword;
|
||||
struct
|
||||
{
|
||||
uint8_t byte0;
|
||||
uint8_t byte1;
|
||||
uint8_t byte2;
|
||||
uint8_t byte3;
|
||||
} byte;
|
||||
} x;
|
||||
|
||||
x.dword = __value;
|
||||
eeprom_write_byte ((uint8_t *)__p, x.byte.byte0);
|
||||
eeprom_write_byte ((uint8_t *)__p + 1, x.byte.byte1);
|
||||
eeprom_write_byte ((uint8_t *)__p + 2, x.byte.byte2);
|
||||
eeprom_write_byte ((uint8_t *)__p + 3, x.byte.byte3);
|
||||
#endif
|
||||
}
|
||||
|
||||
/** \ingroup avr_eeprom
|
||||
Write a block of \a __n bytes to EEPROM address \a __dst from \a __src.
|
||||
\note The argument order is mismatch with common functions like strcpy().
|
||||
*/
|
||||
static __inline__ void
|
||||
eeprom_write_block (const void *__src, void *__dst, size_t __n)
|
||||
{
|
||||
#if (! (defined(__AVR_ATmega2560__) || defined(__AVR_ATmega2561__)) )
|
||||
__eewr_block (__dst, __src, __n, eeprom_write_byte);
|
||||
#else
|
||||
/* If ATmega256x device, do not call function. */
|
||||
while (__n--)
|
||||
eeprom_write_byte (__dst++, *(uint8_t *)__src++);
|
||||
#endif
|
||||
}
|
||||
|
||||
/** \name IAR C compatibility defines */
|
||||
/*@{*/
|
||||
|
||||
/** \def _EEPUT
|
||||
\ingroup avr_eeprom
|
||||
Write a byte to EEPROM. Compatibility define for IAR C. */
|
||||
#define _EEPUT(addr, val) eeprom_write_byte ((uint8_t *)(addr), (uint8_t)(val))
|
||||
|
||||
/** \def _EEGET
|
||||
\ingroup avr_eeprom
|
||||
Read a byte from EEPROM. Compatibility define for IAR C. */
|
||||
#define _EEGET(var, addr) (var) = eeprom_read_byte ((const uint8_t *)(addr))
|
||||
|
||||
/*@}*/
|
||||
|
||||
#endif /* E2END || defined(__DOXYGEN__) */
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif /* !_AVR_EEPROM_H */
|
264
arduino-0018-windows/hardware/tools/avr/avr/include/avr/fuse.h
Normal file
264
arduino-0018-windows/hardware/tools/avr/avr/include/avr/fuse.h
Normal file
|
@ -0,0 +1,264 @@
|
|||
/* Copyright (c) 2007, Atmel Corporation
|
||||
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: fuse.h,v 1.3.2.5 2008/07/18 20:32:14 arcanum Exp $ */
|
||||
|
||||
/* avr/fuse.h - Fuse API */
|
||||
|
||||
#ifndef _AVR_FUSE_H_
|
||||
#define _AVR_FUSE_H_ 1
|
||||
|
||||
|
||||
/** \file */
|
||||
/** \defgroup avr_fuse <avr/fuse.h>: Fuse Support
|
||||
|
||||
\par Introduction
|
||||
|
||||
The Fuse API allows a user to specify the fuse settings for the specific
|
||||
AVR device they are compiling for. These fuse settings will be placed
|
||||
in a special section in the ELF output file, after linking.
|
||||
|
||||
Programming tools can take advantage of the fuse information embedded in
|
||||
the ELF file, by extracting this information and determining if the fuses
|
||||
need to be programmed before programming the Flash and EEPROM memories.
|
||||
This also allows a single ELF file to contain all the
|
||||
information needed to program an AVR.
|
||||
|
||||
To use the Fuse API, include the <avr/io.h> header file, which in turn
|
||||
automatically includes the individual I/O header file and the <avr/fuse.h>
|
||||
file. These other two files provides everything necessary to set the AVR
|
||||
fuses.
|
||||
|
||||
\par Fuse API
|
||||
|
||||
Each I/O header file must define the FUSE_MEMORY_SIZE macro which is
|
||||
defined to the number of fuse bytes that exist in the AVR device.
|
||||
|
||||
A new type, __fuse_t, is defined as a structure. The number of fields in
|
||||
this structure are determined by the number of fuse bytes in the
|
||||
FUSE_MEMORY_SIZE macro.
|
||||
|
||||
If FUSE_MEMORY_SIZE == 1, there is only a single field: byte, of type
|
||||
unsigned char.
|
||||
|
||||
If FUSE_MEMORY_SIZE == 2, there are two fields: low, and high, of type
|
||||
unsigned char.
|
||||
|
||||
If FUSE_MEMORY_SIZE == 3, there are three fields: low, high, and extended,
|
||||
of type unsigned char.
|
||||
|
||||
If FUSE_MEMORY_SIZE > 3, there is a single field: byte, which is an array
|
||||
of unsigned char with the size of the array being FUSE_MEMORY_SIZE.
|
||||
|
||||
A convenience macro, FUSEMEM, is defined as a GCC attribute for a
|
||||
custom-named section of ".fuse".
|
||||
|
||||
A convenience macro, FUSES, is defined that declares a variable, __fuse, of
|
||||
type __fuse_t with the attribute defined by FUSEMEM. This variable
|
||||
allows the end user to easily set the fuse data.
|
||||
|
||||
\note If a device-specific I/O header file has previously defined FUSEMEM,
|
||||
then FUSEMEM is not redefined. If a device-specific I/O header file has
|
||||
previously defined FUSES, then FUSES is not redefined.
|
||||
|
||||
Each AVR device I/O header file has a set of defined macros which specify the
|
||||
actual fuse bits available on that device. The AVR fuses have inverted
|
||||
values, logical 1 for an unprogrammed (disabled) bit and logical 0 for a
|
||||
programmed (enabled) bit. The defined macros for each individual fuse
|
||||
bit represent this in their definition by a bit-wise inversion of a mask.
|
||||
For example, the FUSE_EESAVE fuse in the ATmega128 is defined as:
|
||||
\code
|
||||
#define FUSE_EESAVE ~_BV(3)
|
||||
\endcode
|
||||
\note The _BV macro creates a bit mask from a bit number. It is then
|
||||
inverted to represent logical values for a fuse memory byte.
|
||||
|
||||
To combine the fuse bits macros together to represent a whole fuse byte,
|
||||
use the bitwise AND operator, like so:
|
||||
\code
|
||||
(FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_EESAVE & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
\endcode
|
||||
|
||||
Each device I/O header file also defines macros that provide default values
|
||||
for each fuse byte that is available. LFUSE_DEFAULT is defined for a Low
|
||||
Fuse byte. HFUSE_DEFAULT is defined for a High Fuse byte. EFUSE_DEFAULT
|
||||
is defined for an Extended Fuse byte.
|
||||
|
||||
If FUSE_MEMORY_SIZE > 3, then the I/O header file defines macros that
|
||||
provide default values for each fuse byte like so:
|
||||
FUSE0_DEFAULT
|
||||
FUSE1_DEFAULT
|
||||
FUSE2_DEFAULT
|
||||
FUSE3_DEFAULT
|
||||
FUSE4_DEFAULT
|
||||
....
|
||||
|
||||
\par API Usage Example
|
||||
|
||||
Putting all of this together is easy. Using C99's designated initializers:
|
||||
|
||||
\code
|
||||
#include <avr/io.h>
|
||||
|
||||
FUSES =
|
||||
{
|
||||
.low = LFUSE_DEFAULT,
|
||||
.high = (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_EESAVE & FUSE_SPIEN & FUSE_JTAGEN),
|
||||
.extended = EFUSE_DEFAULT,
|
||||
};
|
||||
|
||||
int main(void)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
\endcode
|
||||
|
||||
Or, using the variable directly instead of the FUSES macro,
|
||||
|
||||
\code
|
||||
#include <avr/io.h>
|
||||
|
||||
__fuse_t __fuse __attribute__((section (".fuse"))) =
|
||||
{
|
||||
.low = LFUSE_DEFAULT,
|
||||
.high = (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_EESAVE & FUSE_SPIEN & FUSE_JTAGEN),
|
||||
.extended = EFUSE_DEFAULT,
|
||||
};
|
||||
|
||||
int main(void)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
\endcode
|
||||
|
||||
If you are compiling in C++, you cannot use the designated intializers so
|
||||
you must do:
|
||||
|
||||
\code
|
||||
#include <avr/io.h>
|
||||
|
||||
FUSES =
|
||||
{
|
||||
LFUSE_DEFAULT, // .low
|
||||
(FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_EESAVE & FUSE_SPIEN & FUSE_JTAGEN), // .high
|
||||
EFUSE_DEFAULT, // .extended
|
||||
};
|
||||
|
||||
int main(void)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
\endcode
|
||||
|
||||
|
||||
However there are a number of caveats that you need to be aware of to
|
||||
use this API properly.
|
||||
|
||||
Be sure to include <avr/io.h> to get all of the definitions for the API.
|
||||
The FUSES macro defines a global variable to store the fuse data. This
|
||||
variable is assigned to its own linker section. Assign the desired fuse
|
||||
values immediately in the variable initialization.
|
||||
|
||||
The .fuse section in the ELF file will get its values from the initial
|
||||
variable assignment ONLY. This means that you can NOT assign values to
|
||||
this variable in functions and the new values will not be put into the
|
||||
ELF .fuse section.
|
||||
|
||||
The global variable is declared in the FUSES macro has two leading
|
||||
underscores, which means that it is reserved for the "implementation",
|
||||
meaning the library, so it will not conflict with a user-named variable.
|
||||
|
||||
You must initialize ALL fields in the __fuse_t structure. This is because
|
||||
the fuse bits in all bytes default to a logical 1, meaning unprogrammed.
|
||||
Normal uninitialized data defaults to all locgial zeros. So it is vital that
|
||||
all fuse bytes are initialized, even with default data. If they are not,
|
||||
then the fuse bits may not programmed to the desired settings.
|
||||
|
||||
Be sure to have the -mmcu=<em>device</em> flag in your compile command line and
|
||||
your linker command line to have the correct device selected and to have
|
||||
the correct I/O header file included when you include <avr/io.h>.
|
||||
|
||||
You can print out the contents of the .fuse section in the ELF file by
|
||||
using this command line:
|
||||
\code
|
||||
avr-objdump -s -j .fuse <ELF file>
|
||||
\endcode
|
||||
The section contents shows the address on the left, then the data going from
|
||||
lower address to a higher address, left to right.
|
||||
|
||||
*/
|
||||
|
||||
#ifndef __ASSEMBLER__
|
||||
|
||||
#ifndef FUSEMEM
|
||||
#define FUSEMEM __attribute__((section (".fuse")))
|
||||
#endif
|
||||
|
||||
#if FUSE_MEMORY_SIZE > 3
|
||||
|
||||
typedef struct
|
||||
{
|
||||
unsigned char byte[FUSE_MEMORY_SIZE];
|
||||
} __fuse_t;
|
||||
|
||||
|
||||
#elif FUSE_MEMORY_SIZE == 3
|
||||
|
||||
typedef struct
|
||||
{
|
||||
unsigned char low;
|
||||
unsigned char high;
|
||||
unsigned char extended;
|
||||
} __fuse_t;
|
||||
|
||||
#elif FUSE_MEMORY_SIZE == 2
|
||||
|
||||
typedef struct
|
||||
{
|
||||
unsigned char low;
|
||||
unsigned char high;
|
||||
} __fuse_t;
|
||||
|
||||
#elif FUSE_MEMORY_SIZE == 1
|
||||
|
||||
typedef struct
|
||||
{
|
||||
unsigned char byte;
|
||||
} __fuse_t;
|
||||
|
||||
#endif
|
||||
|
||||
#ifndef FUSES
|
||||
#define FUSES __fuse_t __fuse FUSEMEM
|
||||
#endif
|
||||
|
||||
#endif /* !__ASSEMBLER__ */
|
||||
|
||||
#endif /* _AVR_FUSE_H_ */
|
|
@ -0,0 +1,344 @@
|
|||
/* Copyright (c) 2002,2005,2007 Marek Michalkiewicz
|
||||
Copyright (c) 2007, Dean Camera
|
||||
|
||||
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: interrupt.h,v 1.25.2.1 2008/01/05 06:33:11 dmix Exp $ */
|
||||
|
||||
#ifndef _AVR_INTERRUPT_H_
|
||||
#define _AVR_INTERRUPT_H_
|
||||
|
||||
#include <avr/io.h>
|
||||
|
||||
#if !defined(__DOXYGEN__) && !defined(__STRINGIFY)
|
||||
/* Auxiliary macro for ISR_ALIAS(). */
|
||||
#define __STRINGIFY(x) #x
|
||||
#endif /* !defined(__DOXYGEN__) */
|
||||
|
||||
/**
|
||||
\file
|
||||
\@{
|
||||
*/
|
||||
|
||||
|
||||
/** \name Global manipulation of the interrupt flag
|
||||
|
||||
The global interrupt flag is maintained in the I bit of the status
|
||||
register (SREG).
|
||||
*/
|
||||
|
||||
#if defined(__DOXYGEN__)
|
||||
/** \def sei()
|
||||
\ingroup avr_interrupts
|
||||
|
||||
\code #include <avr/interrupt.h> \endcode
|
||||
|
||||
Enables interrupts by setting the global interrupt mask. This function
|
||||
actually compiles into a single line of assembly, so there is no function
|
||||
call overhead. */
|
||||
#define sei()
|
||||
#else /* !DOXYGEN */
|
||||
# define sei() __asm__ __volatile__ ("sei" ::)
|
||||
#endif /* DOXYGEN */
|
||||
|
||||
#if defined(__DOXYGEN__)
|
||||
/** \def cli()
|
||||
\ingroup avr_interrupts
|
||||
|
||||
\code #include <avr/interrupt.h> \endcode
|
||||
|
||||
Disables all interrupts by clearing the global interrupt mask. This function
|
||||
actually compiles into a single line of assembly, so there is no function
|
||||
call overhead. */
|
||||
#define cli()
|
||||
#else /* !DOXYGEN */
|
||||
# define cli() __asm__ __volatile__ ("cli" ::)
|
||||
#endif /* DOXYGEN */
|
||||
|
||||
|
||||
/** \name Macros for writing interrupt handler functions */
|
||||
|
||||
|
||||
#if defined(__DOXYGEN__)
|
||||
/** \def ISR(vector [, attributes])
|
||||
\ingroup avr_interrupts
|
||||
|
||||
\code #include <avr/interrupt.h> \endcode
|
||||
|
||||
Introduces an interrupt handler function (interrupt service
|
||||
routine) that runs with global interrupts initially disabled
|
||||
by default with no attributes specified.
|
||||
|
||||
The attributes are optional and alter the behaviour and resultant
|
||||
generated code of the interrupt routine. Multiple attributes may
|
||||
be used for a single function, with a space seperating each
|
||||
attribute.
|
||||
|
||||
Valid attributes are ISR_BLOCK, ISR_NOBLOCK, ISR_NAKED and
|
||||
ISR_ALIASOF(vect).
|
||||
|
||||
\c vector must be one of the interrupt vector names that are
|
||||
valid for the particular MCU type.
|
||||
*/
|
||||
# define ISR(vector, [attributes])
|
||||
#else /* real code */
|
||||
|
||||
#if (__GNUC__ == 4 && __GNUC_MINOR__ >= 1) || (__GNUC__ > 4)
|
||||
# define __INTR_ATTRS used, externally_visible
|
||||
#else /* GCC < 4.1 */
|
||||
# define __INTR_ATTRS used
|
||||
#endif
|
||||
|
||||
#ifdef __cplusplus
|
||||
# define ISR(vector, ...) \
|
||||
extern "C" void vector (void) __attribute__ ((signal,__INTR_ATTRS)) __VA_ARGS__; \
|
||||
void vector (void)
|
||||
#else
|
||||
# define ISR(vector, ...) \
|
||||
void vector (void) __attribute__ ((signal,__INTR_ATTRS)) __VA_ARGS__; \
|
||||
void vector (void)
|
||||
#endif
|
||||
|
||||
#endif /* DOXYGEN */
|
||||
|
||||
#if defined(__DOXYGEN__)
|
||||
/** \def SIGNAL(vector)
|
||||
\ingroup avr_interrupts
|
||||
|
||||
\code #include <avr/interrupt.h> \endcode
|
||||
|
||||
Introduces an interrupt handler function that runs with global interrupts
|
||||
initially disabled.
|
||||
|
||||
This is the same as the ISR macro without optional attributes.
|
||||
\deprecated Do not use SIGNAL() in new code. Use ISR() instead.
|
||||
*/
|
||||
# define SIGNAL(vector)
|
||||
#else /* real code */
|
||||
|
||||
#ifdef __cplusplus
|
||||
# define SIGNAL(vector) \
|
||||
extern "C" void vector(void) __attribute__ ((signal, __INTR_ATTRS)); \
|
||||
void vector (void)
|
||||
#else
|
||||
# define SIGNAL(vector) \
|
||||
void vector (void) __attribute__ ((signal, __INTR_ATTRS)); \
|
||||
void vector (void)
|
||||
#endif
|
||||
|
||||
#endif /* DOXYGEN */
|
||||
|
||||
#if defined(__DOXYGEN__)
|
||||
/** \def EMPTY_INTERRUPT(vector)
|
||||
\ingroup avr_interrupts
|
||||
|
||||
\code #include <avr/interrupt.h> \endcode
|
||||
|
||||
Defines an empty interrupt handler function. This will not generate
|
||||
any prolog or epilog code and will only return from the ISR. Do not
|
||||
define a function body as this will define it for you.
|
||||
Example:
|
||||
\code EMPTY_INTERRUPT(ADC_vect);\endcode */
|
||||
# define EMPTY_INTERRUPT(vector)
|
||||
#else /* real code */
|
||||
|
||||
#ifdef __cplusplus
|
||||
# define EMPTY_INTERRUPT(vector) \
|
||||
extern "C" void vector(void) __attribute__ ((signal,naked,__INTR_ATTRS)); \
|
||||
void vector (void) { __asm__ __volatile__ ("reti" ::); }
|
||||
#else
|
||||
# define EMPTY_INTERRUPT(vector) \
|
||||
void vector (void) __attribute__ ((signal,naked,__INTR_ATTRS)); \
|
||||
void vector (void) { __asm__ __volatile__ ("reti" ::); }
|
||||
#endif
|
||||
|
||||
#endif /* DOXYGEN */
|
||||
|
||||
#if defined(__DOXYGEN__)
|
||||
/** \def ISR_ALIAS(vector, target_vector)
|
||||
\ingroup avr_interrupts
|
||||
|
||||
\code #include <avr/interrupt.h> \endcode
|
||||
|
||||
Aliases a given vector to another one in the same manner as the
|
||||
ISR_ALIASOF attribute for the ISR() macro. Unlike the ISR_ALIASOF
|
||||
attribute macro however, this is compatible for all versions of
|
||||
GCC rather than just GCC version 4.2 onwards.
|
||||
|
||||
\note This macro creates a trampoline function for the aliased
|
||||
macro. This will result in a two cycle penalty for the aliased
|
||||
vector compared to the ISR the vector is aliased to, due to the
|
||||
JMP/RJMP opcode used.
|
||||
|
||||
\deprecated
|
||||
For new code, the use of ISR(..., ISR_ALIASOF(...)) is
|
||||
recommended.
|
||||
|
||||
Example:
|
||||
\code
|
||||
ISR(INT0_vect)
|
||||
{
|
||||
PORTB = 42;
|
||||
}
|
||||
|
||||
ISR_ALIAS(INT1_vect, INT0_vect);
|
||||
\endcode
|
||||
*/
|
||||
# define ISR_ALIAS(vector, target_vector)
|
||||
#else /* real code */
|
||||
|
||||
#ifdef __cplusplus
|
||||
# if defined(__AVR_MEGA__) && __AVR_MEGA__
|
||||
# define ISR_ALIAS(vector, tgt) extern "C" void vector (void) \
|
||||
__attribute__((signal, naked, __INTR_ATTRS)); \
|
||||
void vector (void) { asm volatile ("jmp " __STRINGIFY(tgt) ::); }
|
||||
# else /* !__AVR_MEGA */
|
||||
# define ISR_ALIAS(vector, tgt) extern "C" void vector (void) \
|
||||
__attribute__((signal, naked, __INTR_ATTRS)); \
|
||||
void vector (void) { asm volatile ("rjmp " __STRINGIFY(tgt) ::); }
|
||||
# endif /* __AVR_MEGA__ */
|
||||
#else /* !__cplusplus */
|
||||
# if defined(__AVR_MEGA__) && __AVR_MEGA__
|
||||
# define ISR_ALIAS(vector, tgt) void vector (void) \
|
||||
__attribute__((signal, naked, __INTR_ATTRS)); \
|
||||
void vector (void) { asm volatile ("jmp " __STRINGIFY(tgt) ::); }
|
||||
# else /* !__AVR_MEGA */
|
||||
# define ISR_ALIAS(vector, tgt) void vector (void) \
|
||||
__attribute__((signal, naked, __INTR_ATTRS)); \
|
||||
void vector (void) { asm volatile ("rjmp " __STRINGIFY(tgt) ::); }
|
||||
# endif /* __AVR_MEGA__ */
|
||||
#endif /* __cplusplus */
|
||||
|
||||
#endif /* DOXYGEN */
|
||||
|
||||
#if defined(__DOXYGEN__)
|
||||
/** \def reti()
|
||||
\ingroup avr_interrupts
|
||||
|
||||
\code #include <avr/interrupt.h> \endcode
|
||||
|
||||
Returns from an interrupt routine, enabling global interrupts. This should
|
||||
be the last command executed before leaving an ISR defined with the ISR_NAKED
|
||||
attribute.
|
||||
|
||||
This macro actually compiles into a single line of assembly, so there is
|
||||
no function call overhead.
|
||||
*/
|
||||
# define reti()
|
||||
#else /* !DOXYGEN */
|
||||
# define reti() __asm__ __volatile__ ("reti" ::)
|
||||
#endif /* DOXYGEN */
|
||||
|
||||
#if defined(__DOXYGEN__)
|
||||
/** \def BADISR_vect
|
||||
\ingroup avr_interrupts
|
||||
|
||||
\code #include <avr/interrupt.h> \endcode
|
||||
|
||||
This is a vector which is aliased to __vector_default, the vector
|
||||
executed when an ISR fires with no accompanying ISR handler. This
|
||||
may be used along with the ISR() macro to create a catch-all for
|
||||
undefined but used ISRs for debugging purposes.
|
||||
*/
|
||||
# define BADISR_vect
|
||||
#else /* !DOXYGEN */
|
||||
# define BADISR_vect __vector_default
|
||||
#endif /* DOXYGEN */
|
||||
|
||||
/** \name ISR attributes */
|
||||
|
||||
#if defined(__DOXYGEN__)
|
||||
/** \def ISR_BLOCK
|
||||
\ingroup avr_interrupts
|
||||
|
||||
\code# include <avr/interrupt.h> \endcode
|
||||
|
||||
Identical to an ISR with no attributes specified. Global
|
||||
interrupts are initially disabled by the AVR hardware when
|
||||
entering the ISR, without the compiler modifying this state.
|
||||
|
||||
Use this attribute in the attributes parameter of the ISR macro.
|
||||
*/
|
||||
# define ISR_BLOCK
|
||||
|
||||
/** \def ISR_NOBLOCK
|
||||
\ingroup avr_interrupts
|
||||
|
||||
\code# include <avr/interrupt.h> \endcode
|
||||
|
||||
ISR runs with global interrupts initially enabled. The interrupt
|
||||
enable flag is activated by the compiler as early as possible
|
||||
within the ISR to ensure minimal processing delay for nested
|
||||
interrupts.
|
||||
|
||||
This may be used to create nested ISRs, however care should be
|
||||
taken to avoid stack overflows, or to avoid infinitely entering
|
||||
the ISR for those cases where the AVR hardware does not clear the
|
||||
respective interrupt flag before entering the ISR.
|
||||
|
||||
Use this attribute in the attributes parameter of the ISR macro.
|
||||
*/
|
||||
# define ISR_NOBLOCK
|
||||
|
||||
/** \def ISR_NAKED
|
||||
\ingroup avr_interrupts
|
||||
|
||||
\code# include <avr/interrupt.h> \endcode
|
||||
|
||||
ISR is created with no prologue or epilogue code. The user code is
|
||||
responsible for preservation of the machine state including the
|
||||
SREG register, as well as placing a reti() at the end of the
|
||||
interrupt routine.
|
||||
|
||||
Use this attribute in the attributes parameter of the ISR macro.
|
||||
*/
|
||||
# define ISR_NAKED
|
||||
|
||||
/** \def ISR_ALIASOF(target_vector)
|
||||
\ingroup avr_interrupts
|
||||
|
||||
\code#include <avr/interrupt.h>\endcode
|
||||
|
||||
The ISR is linked to another ISR, specified by the vect parameter.
|
||||
This is compatible with GCC 4.2 and greater only.
|
||||
|
||||
Use this attribute in the attributes parameter of the ISR macro.
|
||||
*/
|
||||
# define ISR_ALIASOF(target_vector)
|
||||
#else /* !DOXYGEN */
|
||||
# define ISR_BLOCK
|
||||
# define ISR_NOBLOCK __attribute__((interrupt))
|
||||
# define ISR_NAKED __attribute__((naked))
|
||||
# define ISR_ALIASOF(v) __attribute__((alias(__STRINGIFY(v))))
|
||||
#endif /* DOXYGEN */
|
||||
|
||||
/* \@} */
|
||||
|
||||
#endif
|
346
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io.h
Normal file
346
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io.h
Normal file
|
@ -0,0 +1,346 @@
|
|||
/* Copyright (c) 2002,2003,2005,2006,2007 Marek Michalkiewicz, Joerg Wunsch
|
||||
Copyright (c) 2007 Eric B. Weddington
|
||||
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: io.h,v 1.52.2.9 2008/11/03 04:13:14 arcanum Exp $ */
|
||||
|
||||
/** \file */
|
||||
/** \defgroup avr_io <avr/io.h>: AVR device-specific IO definitions
|
||||
\code #include <avr/io.h> \endcode
|
||||
|
||||
This header file includes the apropriate IO definitions for the
|
||||
device that has been specified by the <tt>-mmcu=</tt> compiler
|
||||
command-line switch. This is done by diverting to the appropriate
|
||||
file <tt><avr/io</tt><em>XXXX</em><tt>.h></tt> which should
|
||||
never be included directly. Some register names common to all
|
||||
AVR devices are defined directly within <tt><avr/common.h></tt>,
|
||||
which is included in <tt><avr/io.h></tt>,
|
||||
but most of the details come from the respective include file.
|
||||
|
||||
Note that this file always includes the following files:
|
||||
\code
|
||||
#include <avr/sfr_defs.h>
|
||||
#include <avr/portpins.h>
|
||||
#include <avr/common.h>
|
||||
#include <avr/version.h>
|
||||
\endcode
|
||||
See \ref avr_sfr for more details about that header file.
|
||||
|
||||
Included are definitions of the IO register set and their
|
||||
respective bit values as specified in the Atmel documentation.
|
||||
Note that inconsistencies in naming conventions,
|
||||
so even identical functions sometimes get different names on
|
||||
different devices.
|
||||
|
||||
Also included are the specific names useable for interrupt
|
||||
function definitions as documented
|
||||
\ref avr_signames "here".
|
||||
|
||||
Finally, the following macros are defined:
|
||||
|
||||
- \b RAMEND
|
||||
<br>
|
||||
The last on-chip RAM address.
|
||||
<br>
|
||||
- \b XRAMEND
|
||||
<br>
|
||||
The last possible RAM location that is addressable. This is equal to
|
||||
RAMEND for devices that do not allow for external RAM. For devices
|
||||
that allow external RAM, this will larger than RAMEND.
|
||||
<br>
|
||||
- \b E2END
|
||||
<br>
|
||||
The last EEPROM address.
|
||||
<br>
|
||||
- \b FLASHEND
|
||||
<br>
|
||||
The last byte address in the Flash program space.
|
||||
<br>
|
||||
- \b SPM_PAGESIZE
|
||||
<br>
|
||||
For devices with bootloader support, the flash pagesize
|
||||
(in bytes) to be used for the \c SPM instruction.
|
||||
- \b E2PAGESIZE
|
||||
<br>
|
||||
The size of the EEPROM page.
|
||||
|
||||
*/
|
||||
|
||||
#ifndef _AVR_IO_H_
|
||||
#define _AVR_IO_H_
|
||||
|
||||
#include <avr/sfr_defs.h>
|
||||
|
||||
#if defined (__AVR_AT94K__)
|
||||
# include <avr/ioat94k.h>
|
||||
#elif defined (__AVR_AT43USB320__)
|
||||
# include <avr/io43u32x.h>
|
||||
#elif defined (__AVR_AT43USB355__)
|
||||
# include <avr/io43u35x.h>
|
||||
#elif defined (__AVR_AT76C711__)
|
||||
# include <avr/io76c711.h>
|
||||
#elif defined (__AVR_AT86RF401__)
|
||||
# include <avr/io86r401.h>
|
||||
#elif defined (__AVR_AT90PWM1__)
|
||||
# include <avr/io90pwm1.h>
|
||||
#elif defined (__AVR_AT90PWM2__)
|
||||
# include <avr/io90pwmx.h>
|
||||
#elif defined (__AVR_AT90PWM2B__)
|
||||
# include <avr/io90pwm2b.h>
|
||||
#elif defined (__AVR_AT90PWM3__)
|
||||
# include <avr/io90pwmx.h>
|
||||
#elif defined (__AVR_AT90PWM3B__)
|
||||
# include <avr/io90pwm3b.h>
|
||||
#elif defined (__AVR_AT90PWM216__)
|
||||
# include <avr/io90pwm216.h>
|
||||
#elif defined (__AVR_AT90PWM316__)
|
||||
# include <avr/io90pwm316.h>
|
||||
#elif defined (__AVR_ATmega32C1__)
|
||||
# include <avr/iom32c1.h>
|
||||
#elif defined (__AVR_ATmega32M1__)
|
||||
# include <avr/iom32m1.h>
|
||||
#elif defined (__AVR_ATmega32U4__)
|
||||
# include <avr/iom32u4.h>
|
||||
#elif defined (__AVR_ATmega32U6__)
|
||||
# include <avr/iom32u6.h>
|
||||
#elif defined (__AVR_ATmega128__)
|
||||
# include <avr/iom128.h>
|
||||
#elif defined (__AVR_ATmega1280__)
|
||||
# include <avr/iom1280.h>
|
||||
#elif defined (__AVR_ATmega1281__)
|
||||
# include <avr/iom1281.h>
|
||||
#elif defined (__AVR_ATmega1284P__)
|
||||
# include <avr/iom1284p.h>
|
||||
#elif defined (__AVR_ATmega2560__)
|
||||
# include <avr/iom2560.h>
|
||||
#elif defined (__AVR_ATmega2561__)
|
||||
# include <avr/iom2561.h>
|
||||
#elif defined (__AVR_AT90CAN32__)
|
||||
# include <avr/iocan32.h>
|
||||
#elif defined (__AVR_AT90CAN64__)
|
||||
# include <avr/iocan64.h>
|
||||
#elif defined (__AVR_AT90CAN128__)
|
||||
# include <avr/iocan128.h>
|
||||
#elif defined (__AVR_AT90USB82__)
|
||||
# include <avr/iousb82.h>
|
||||
#elif defined (__AVR_AT90USB162__)
|
||||
# include <avr/iousb162.h>
|
||||
#elif defined (__AVR_AT90USB646__)
|
||||
# include <avr/iousb646.h>
|
||||
#elif defined (__AVR_AT90USB647__)
|
||||
# include <avr/iousb647.h>
|
||||
#elif defined (__AVR_AT90USB1286__)
|
||||
# include <avr/iousb1286.h>
|
||||
#elif defined (__AVR_AT90USB1287__)
|
||||
# include <avr/iousb1287.h>
|
||||
#elif defined (__AVR_ATmega64__)
|
||||
# include <avr/iom64.h>
|
||||
#elif defined (__AVR_ATmega640__)
|
||||
# include <avr/iom640.h>
|
||||
#elif defined (__AVR_ATmega644__)
|
||||
# include <avr/iom644.h>
|
||||
#elif defined (__AVR_ATmega644P__)
|
||||
# include <avr/iom644.h>
|
||||
#elif defined (__AVR_ATmega645__)
|
||||
# include <avr/iom645.h>
|
||||
#elif defined (__AVR_ATmega6450__)
|
||||
# include <avr/iom6450.h>
|
||||
#elif defined (__AVR_ATmega649__)
|
||||
# include <avr/iom649.h>
|
||||
#elif defined (__AVR_ATmega6490__)
|
||||
# include <avr/iom6490.h>
|
||||
#elif defined (__AVR_ATmega103__)
|
||||
# include <avr/iom103.h>
|
||||
#elif defined (__AVR_ATmega32__)
|
||||
# include <avr/iom32.h>
|
||||
#elif defined (__AVR_ATmega323__)
|
||||
# include <avr/iom323.h>
|
||||
#elif defined (__AVR_ATmega324P__)
|
||||
# include <avr/iom324.h>
|
||||
#elif defined (__AVR_ATmega325__)
|
||||
# include <avr/iom325.h>
|
||||
#elif defined (__AVR_ATmega325P__)
|
||||
# include <avr/iom325.h>
|
||||
#elif defined (__AVR_ATmega3250__)
|
||||
# include <avr/iom3250.h>
|
||||
#elif defined (__AVR_ATmega3250P__)
|
||||
# include <avr/iom3250.h>
|
||||
#elif defined (__AVR_ATmega328P__)
|
||||
# include <avr/iom328p.h>
|
||||
#elif defined (__AVR_ATmega329__)
|
||||
# include <avr/iom329.h>
|
||||
#elif defined (__AVR_ATmega329P__)
|
||||
# include <avr/iom329.h>
|
||||
#elif defined (__AVR_ATmega3290__)
|
||||
# include <avr/iom3290.h>
|
||||
#elif defined (__AVR_ATmega3290P__)
|
||||
# include <avr/iom3290.h>
|
||||
#elif defined (__AVR_ATmega32HVB__)
|
||||
# include <avr/iom32hvb.h>
|
||||
#elif defined (__AVR_ATmega406__)
|
||||
# include <avr/iom406.h>
|
||||
#elif defined (__AVR_ATmega16__)
|
||||
# include <avr/iom16.h>
|
||||
#elif defined (__AVR_ATmega161__)
|
||||
# include <avr/iom161.h>
|
||||
#elif defined (__AVR_ATmega162__)
|
||||
# include <avr/iom162.h>
|
||||
#elif defined (__AVR_ATmega163__)
|
||||
# include <avr/iom163.h>
|
||||
#elif defined (__AVR_ATmega164P__)
|
||||
# include <avr/iom164.h>
|
||||
#elif defined (__AVR_ATmega165__)
|
||||
# include <avr/iom165.h>
|
||||
#elif defined (__AVR_ATmega165P__)
|
||||
# include <avr/iom165p.h>
|
||||
#elif defined (__AVR_ATmega168__)
|
||||
# include <avr/iom168.h>
|
||||
#elif defined (__AVR_ATmega168P__)
|
||||
# include <avr/iom168p.h>
|
||||
#elif defined (__AVR_ATmega169__)
|
||||
# include <avr/iom169.h>
|
||||
#elif defined (__AVR_ATmega169P__)
|
||||
# include <avr/iom169p.h>
|
||||
#elif defined (__AVR_ATmega8HVA__)
|
||||
# include <avr/iom8hva.h>
|
||||
#elif defined (__AVR_ATmega16HVA__)
|
||||
# include <avr/iom16hva.h>
|
||||
#elif defined (__AVR_ATmega8__)
|
||||
# include <avr/iom8.h>
|
||||
#elif defined (__AVR_ATmega48__)
|
||||
# include <avr/iom48.h>
|
||||
#elif defined (__AVR_ATmega48P__)
|
||||
# include <avr/iom48p.h>
|
||||
#elif defined (__AVR_ATmega88__)
|
||||
# include <avr/iom88.h>
|
||||
#elif defined (__AVR_ATmega88P__)
|
||||
# include <avr/iom88p.h>
|
||||
#elif defined (__AVR_ATmega8515__)
|
||||
# include <avr/iom8515.h>
|
||||
#elif defined (__AVR_ATmega8535__)
|
||||
# include <avr/iom8535.h>
|
||||
#elif defined (__AVR_AT90S8535__)
|
||||
# include <avr/io8535.h>
|
||||
#elif defined (__AVR_AT90C8534__)
|
||||
# include <avr/io8534.h>
|
||||
#elif defined (__AVR_AT90S8515__)
|
||||
# include <avr/io8515.h>
|
||||
#elif defined (__AVR_AT90S4434__)
|
||||
# include <avr/io4434.h>
|
||||
#elif defined (__AVR_AT90S4433__)
|
||||
# include <avr/io4433.h>
|
||||
#elif defined (__AVR_AT90S4414__)
|
||||
# include <avr/io4414.h>
|
||||
#elif defined (__AVR_ATtiny22__)
|
||||
# include <avr/iotn22.h>
|
||||
#elif defined (__AVR_ATtiny26__)
|
||||
# include <avr/iotn26.h>
|
||||
#elif defined (__AVR_AT90S2343__)
|
||||
# include <avr/io2343.h>
|
||||
#elif defined (__AVR_AT90S2333__)
|
||||
# include <avr/io2333.h>
|
||||
#elif defined (__AVR_AT90S2323__)
|
||||
# include <avr/io2323.h>
|
||||
#elif defined (__AVR_AT90S2313__)
|
||||
# include <avr/io2313.h>
|
||||
#elif defined (__AVR_ATtiny2313__)
|
||||
# include <avr/iotn2313.h>
|
||||
#elif defined (__AVR_ATtiny13__)
|
||||
# include <avr/iotn13.h>
|
||||
#elif defined (__AVR_ATtiny13A__)
|
||||
# include <avr/iotn13a.h>
|
||||
#elif defined (__AVR_ATtiny25__)
|
||||
# include <avr/iotn25.h>
|
||||
#elif defined (__AVR_ATtiny45__)
|
||||
# include <avr/iotn45.h>
|
||||
#elif defined (__AVR_ATtiny85__)
|
||||
# include <avr/iotn85.h>
|
||||
#elif defined (__AVR_ATtiny24__)
|
||||
# include <avr/iotn24.h>
|
||||
#elif defined (__AVR_ATtiny44__)
|
||||
# include <avr/iotn44.h>
|
||||
#elif defined (__AVR_ATtiny84__)
|
||||
# include <avr/iotn84.h>
|
||||
#elif defined (__AVR_ATtiny261__)
|
||||
# include <avr/iotn261.h>
|
||||
#elif defined (__AVR_ATtiny461__)
|
||||
# include <avr/iotn461.h>
|
||||
#elif defined (__AVR_ATtiny861__)
|
||||
# include <avr/iotn861.h>
|
||||
#elif defined (__AVR_ATtiny43U__)
|
||||
# include <avr/iotn43u.h>
|
||||
#elif defined (__AVR_ATtiny48__)
|
||||
# include <avr/iotn48.h>
|
||||
#elif defined (__AVR_ATtiny88__)
|
||||
# include <avr/iotn88.h>
|
||||
#elif defined (__AVR_ATtiny167__)
|
||||
# include <avr/iotn167.h>
|
||||
/* avr1: the following only supported for assembler programs */
|
||||
#elif defined (__AVR_ATtiny28__)
|
||||
# include <avr/iotn28.h>
|
||||
#elif defined (__AVR_AT90S1200__)
|
||||
# include <avr/io1200.h>
|
||||
#elif defined (__AVR_ATtiny15__)
|
||||
# include <avr/iotn15.h>
|
||||
#elif defined (__AVR_ATtiny12__)
|
||||
# include <avr/iotn12.h>
|
||||
#elif defined (__AVR_ATtiny11__)
|
||||
# include <avr/iotn11.h>
|
||||
#elif defined (__AVR_ATxmega64A1__)
|
||||
# include <avr/iox64a1.h>
|
||||
#elif defined (__AVR_ATxmega64A3__)
|
||||
# include <avr/iox64a3.h>
|
||||
#elif defined (__AVR_ATxmega128A1__)
|
||||
# include <avr/iox128a1.h>
|
||||
#elif defined (__AVR_ATxmega128A3__)
|
||||
# include <avr/iox128a3.h>
|
||||
#elif defined (__AVR_ATxmega256A3__)
|
||||
# include <avr/iox256a3.h>
|
||||
#elif defined (__AVR_ATxmega256A3B__)
|
||||
# include <avr/iox256a3b.h>
|
||||
#else
|
||||
# if !defined(__COMPILING_AVR_LIBC__)
|
||||
# warning "device type not defined"
|
||||
# endif
|
||||
#endif
|
||||
|
||||
#include <avr/portpins.h>
|
||||
|
||||
#include <avr/common.h>
|
||||
|
||||
#include <avr/version.h>
|
||||
|
||||
/* Include fuse.h after individual IO header files. */
|
||||
#include <avr/fuse.h>
|
||||
|
||||
/* Include lock.h after individual IO header files. */
|
||||
#include <avr/lock.h>
|
||||
|
||||
#endif /* _AVR_IO_H_ */
|
270
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io1200.h
Normal file
270
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io1200.h
Normal file
|
@ -0,0 +1,270 @@
|
|||
/* Copyright (c) 2002, Marek Michalkiewicz
|
||||
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: io1200.h,v 1.8.4.3 2008/08/14 00:07:59 arcanum Exp $ */
|
||||
|
||||
/* avr/io1200.h - definitions for AT90S1200 */
|
||||
|
||||
#ifndef _AVR_IO1200_H_
|
||||
#define _AVR_IO1200_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_ "io1200.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
#ifndef __ASSEMBLER__
|
||||
# warning "MCU not supported by the C compiler"
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* 0x00..0x07 reserved */
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACSR _SFR_IO8(0x08)
|
||||
|
||||
/* 0x09..0x0F reserved */
|
||||
|
||||
#define PIND _SFR_IO8(0x10)
|
||||
#define DDRD _SFR_IO8(0x11)
|
||||
#define PORTD _SFR_IO8(0x12)
|
||||
|
||||
/* 0x13..0x15 reserved */
|
||||
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
|
||||
/* 0x19..0x1B reserved */
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EECR _SFR_IO8(0x1C)
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define EEDR _SFR_IO8(0x1D)
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#define EEAR _SFR_IO8(0x1E)
|
||||
#define EEARL _SFR_IO8(0x1E)
|
||||
|
||||
/* 0x1F..0x20 reserved */
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
|
||||
/* 0x22..0x31 reserved */
|
||||
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
/* 0x34 reserved */
|
||||
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
/* 0x36..0x37 reserved */
|
||||
|
||||
/* Timer/Counter Interrupt Flag Register */
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
|
||||
/* Timer/Counter Interrupt MaSK Register */
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
|
||||
/* 0x3A reserved */
|
||||
|
||||
#define GIMSK _SFR_IO8(0x3B)
|
||||
|
||||
/* 0x3C..0x3E reserved */
|
||||
|
||||
/* 0x3F SREG */
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
/* External Interrupt 0 */
|
||||
#define INT0_vect _VECTOR(1)
|
||||
#define SIG_INTERRUPT0 _VECTOR(1)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(2)
|
||||
#define SIG_OVERFLOW0 _VECTOR(2)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANA_COMP_vect _VECTOR(3)
|
||||
#define SIG_COMPARATOR _VECTOR(3)
|
||||
|
||||
#define _VECTORS_SIZE 8
|
||||
|
||||
/* Bit numbers */
|
||||
|
||||
/* GIMSK */
|
||||
#define INT0 6
|
||||
|
||||
/* TIMSK */
|
||||
#define TOIE0 1
|
||||
|
||||
/* TIFR */
|
||||
#define TOV0 1
|
||||
|
||||
/* MCUCR */
|
||||
#define SE 5
|
||||
#define SM 4
|
||||
#define ISC01 1
|
||||
#define ISC00 0
|
||||
|
||||
/* TCCR0 */
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/* WDTCR */
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/* EECR */
|
||||
#undef EEMWE
|
||||
|
||||
/*
|
||||
PB7 = SCK
|
||||
PB6 = MISO
|
||||
PB5 = MOSI
|
||||
PB1 = AIN1
|
||||
PB0 = AIN0
|
||||
*/
|
||||
|
||||
/* PORTB */
|
||||
#define PB7 7
|
||||
#define PB6 6
|
||||
#define PB5 5
|
||||
#define PB4 4
|
||||
#define PB3 3
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
/* DDRB */
|
||||
#define DDB7 7
|
||||
#define DDB6 6
|
||||
#define DDB5 5
|
||||
#define DDB4 4
|
||||
#define DDB3 3
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
/* PINB */
|
||||
#define PINB7 7
|
||||
#define PINB6 6
|
||||
#define PINB5 5
|
||||
#define PINB4 4
|
||||
#define PINB3 3
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
/* PORTD */
|
||||
#define PD6 6
|
||||
#define PD5 5
|
||||
#define PD4 4
|
||||
#define PD3 3
|
||||
#define PD2 2
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
/* DDRD */
|
||||
#define DDD6 6
|
||||
#define DDD5 5
|
||||
#define DDD4 4
|
||||
#define DDD3 3
|
||||
#define DDD2 2
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
/* PIND */
|
||||
#define PIND6 6
|
||||
#define PIND5 5
|
||||
#define PIND4 4
|
||||
#define PIND3 3
|
||||
#define PIND2 2
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
/* ACSR */
|
||||
#define ACD 7
|
||||
#define ACO 5
|
||||
#define ACI 4
|
||||
#define ACIE 3
|
||||
#define ACIS1 1
|
||||
#define ACIS0 0
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EERIE 3
|
||||
#define EEMWE 2
|
||||
#define EEWE 1
|
||||
#define EERE 0
|
||||
|
||||
#undef ZH
|
||||
|
||||
/* Last memory addresses */
|
||||
#define RAMEND 0x1F
|
||||
#define XRAMEND 0x0
|
||||
#define E2END 0x3F
|
||||
#define E2PAGESIZE 0
|
||||
#define FLASHEND 0x3FF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
#define FUSE_MEMORY_SIZE 1
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_RCEN (unsigned char)~_BV(0)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define LFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x90
|
||||
#define SIGNATURE_2 0x01
|
||||
|
||||
|
||||
#endif /* _AVR_IO1200_H_ */
|
371
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io2313.h
Normal file
371
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io2313.h
Normal file
|
@ -0,0 +1,371 @@
|
|||
/* Copyright (c) 2002, Marek Michalkiewicz
|
||||
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: io2313.h,v 1.10.2.3 2008/08/14 00:07:59 arcanum Exp $ */
|
||||
|
||||
/* avr/io2313.h - definitions for AT90S2313 */
|
||||
|
||||
#ifndef _AVR_IO2313_H_
|
||||
#define _AVR_IO2313_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_ "io2313.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACSR _SFR_IO8(0x08)
|
||||
|
||||
/* UART Baud Rate Register */
|
||||
#define UBRR _SFR_IO8(0x09)
|
||||
|
||||
/* UART Control Register */
|
||||
#define UCR _SFR_IO8(0x0A)
|
||||
|
||||
/* UART Status Register */
|
||||
#define USR _SFR_IO8(0x0B)
|
||||
|
||||
/* UART I/O Data Register */
|
||||
#define UDR _SFR_IO8(0x0C)
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND _SFR_IO8(0x10)
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDRD _SFR_IO8(0x11)
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PORTD _SFR_IO8(0x12)
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EECR _SFR_IO8(0x1C)
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define EEDR _SFR_IO8(0x1D)
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#define EEAR _SFR_IO8(0x1E)
|
||||
#define EEARL _SFR_IO8(0x1E)
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
|
||||
/* T/C 1 Input Capture Register */
|
||||
#define ICR1 _SFR_IO16(0x24)
|
||||
#define ICR1L _SFR_IO8(0x24)
|
||||
#define ICR1H _SFR_IO8(0x25)
|
||||
|
||||
/* Output Compare Register 1 */
|
||||
#define OCR1 _SFR_IO16(0x2A)
|
||||
#define OCR1L _SFR_IO8(0x2A)
|
||||
#define OCR1H _SFR_IO8(0x2B)
|
||||
#define OCR1A _SFR_IO16(0x2A)
|
||||
#define OCR1AL _SFR_IO8(0x2A)
|
||||
#define OCR1AH _SFR_IO8(0x2B)
|
||||
|
||||
/* Timer/Counter 1 */
|
||||
#define TCNT1 _SFR_IO16(0x2C)
|
||||
#define TCNT1L _SFR_IO8(0x2C)
|
||||
#define TCNT1H _SFR_IO8(0x2D)
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define TCCR1B _SFR_IO8(0x2E)
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define TCCR1A _SFR_IO8(0x2F)
|
||||
|
||||
/* Timer/Counter 0 */
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
/* Timer/Counter Interrupt Flag register */
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define GIFR _SFR_IO8(0x3A)
|
||||
|
||||
/* General Interrupt MaSK register */
|
||||
#define GIMSK _SFR_IO8(0x3B)
|
||||
|
||||
/* 0x3C..0x3D SP */
|
||||
|
||||
/* 0x3F SREG */
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
/* 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)
|
||||
|
||||
/* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_CAPT1_vect _VECTOR(3)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(3)
|
||||
|
||||
/* Timer/Counter1 Compare Match */
|
||||
#define TIMER1_COMP1_vect _VECTOR(4)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(4)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF1_vect _VECTOR(5)
|
||||
#define SIG_OVERFLOW1 _VECTOR(5)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF0_vect _VECTOR(6)
|
||||
#define SIG_OVERFLOW0 _VECTOR(6)
|
||||
|
||||
/* UART, Rx Complete */
|
||||
#define UART_RX_vect _VECTOR(7)
|
||||
#define SIG_UART_RECV _VECTOR(7)
|
||||
|
||||
/* UART Data Register Empty */
|
||||
#define UART_UDRE_vect _VECTOR(8)
|
||||
#define SIG_UART_DATA _VECTOR(8)
|
||||
|
||||
/* UART, Tx Complete */
|
||||
#define UART_TX_vect _VECTOR(9)
|
||||
#define SIG_UART_TRANS _VECTOR(9)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANA_COMP_vect _VECTOR(10)
|
||||
#define SIG_COMPARATOR _VECTOR(10)
|
||||
|
||||
#define _VECTORS_SIZE 22
|
||||
|
||||
/*
|
||||
* The Register Bit names are represented by their bit number (0-7).
|
||||
*/
|
||||
|
||||
/* General Interrupt MaSK register */
|
||||
#define INT1 7
|
||||
#define INT0 6
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define INTF1 7
|
||||
#define INTF0 6
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define TOIE1 7
|
||||
#define OCIE1A 6
|
||||
#define TICIE 3 /* old name */
|
||||
#define TICIE1 3
|
||||
#define TOIE0 1
|
||||
|
||||
/* Timer/Counter Interrupt Flag register */
|
||||
#define TOV1 7
|
||||
#define OCF1A 6
|
||||
#define ICF1 3
|
||||
#define TOV0 1
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define SE 5
|
||||
#define SM 4
|
||||
#define ISC11 3
|
||||
#define ISC10 2
|
||||
#define ISC01 1
|
||||
#define ISC00 0
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define COM1A1 7
|
||||
#define COM1A0 6
|
||||
#define PWM11 1
|
||||
#define PWM10 0
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define ICNC1 7
|
||||
#define ICES1 6
|
||||
#define CTC1 3
|
||||
#define CS12 2
|
||||
#define CS11 1
|
||||
#define CS10 0
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTOE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EEMWE 2
|
||||
#define EEWE 1
|
||||
#define EERE 0
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PB7 7
|
||||
#define PB6 6
|
||||
#define PB5 5
|
||||
#define PB4 4
|
||||
#define PB3 3
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDB7 7
|
||||
#define DDB6 6
|
||||
#define DDB5 5
|
||||
#define DDB4 4
|
||||
#define DDB3 3
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB7 7
|
||||
#define PINB6 6
|
||||
#define PINB5 5
|
||||
#define PINB4 4
|
||||
#define PINB3 3
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PD6 6
|
||||
#define PD5 5
|
||||
#define PD4 4
|
||||
#define PD3 3
|
||||
#define PD2 2
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDD6 6
|
||||
#define DDD5 5
|
||||
#define DDD4 4
|
||||
#define DDD3 3
|
||||
#define DDD2 2
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND6 6
|
||||
#define PIND5 5
|
||||
#define PIND4 4
|
||||
#define PIND3 3
|
||||
#define PIND2 2
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
/* UART Status Register */
|
||||
#define RXC 7
|
||||
#define TXC 6
|
||||
#define UDRE 5
|
||||
#define FE 4
|
||||
#define DOR 3
|
||||
|
||||
/* UART Control Register */
|
||||
#define RXCIE 7
|
||||
#define TXCIE 6
|
||||
#define UDRIE 5
|
||||
#define RXEN 4
|
||||
#define TXEN 3
|
||||
#define CHR9 2
|
||||
#define RXB8 1
|
||||
#define TXB8 0
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACD 7
|
||||
#define ACO 5
|
||||
#define ACI 4
|
||||
#define ACIE 3
|
||||
#define ACIC 2
|
||||
#define ACIS1 1
|
||||
#define ACIS0 0
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EERIE 3
|
||||
#define EEMWE 2
|
||||
#define EEWE 1
|
||||
#define EERE 0
|
||||
|
||||
/* Constants */
|
||||
#define RAMEND 0xDF
|
||||
#define XRAMEND 0xDF
|
||||
#define E2END 0x7F
|
||||
#define E2PAGESIZE 0
|
||||
#define FLASHEND 0x07FF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
#define FUSE_MEMORY_SIZE 1
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_FSTRT (unsigned char)~_BV(0)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define LFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x91
|
||||
#define SIGNATURE_2 0x01
|
||||
|
||||
|
||||
#endif /* _AVR_IO2313_H_ */
|
204
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io2323.h
Normal file
204
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io2323.h
Normal file
|
@ -0,0 +1,204 @@
|
|||
/* Copyright (c) 2002, Marek Michalkiewicz
|
||||
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: io2323.h,v 1.8.4.4 2008/10/17 23:27:45 arcanum Exp $ */
|
||||
|
||||
/* avr/io2323.h - definitions for AT90S2323 */
|
||||
|
||||
#ifndef _AVR_IO2323_H_
|
||||
#define _AVR_IO2323_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_ "io2323.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EECR _SFR_IO8(0x1C)
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define EEDR _SFR_IO8(0x1D)
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#define EEAR _SFR_IO8(0x1E)
|
||||
#define EEARL _SFR_IO8(0x1E)
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
|
||||
/* Timer/Counter 0 */
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
/* MCU Status Register */
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
/* Timer/Counter Interrupt Flag register */
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
|
||||
/* General Interrupt Flag register */
|
||||
#define GIFR _SFR_IO8(0x3A)
|
||||
|
||||
/* General Interrupt MaSK register */
|
||||
#define GIMSK _SFR_IO8(0x3B)
|
||||
|
||||
/* 0x3D..0x3E SP */
|
||||
|
||||
/* 0x3F SREG */
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
/* External Interrupt 0 */
|
||||
#define INT0_vect _VECTOR(1)
|
||||
#define SIG_INTERRUPT0 _VECTOR(1)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF0_vect _VECTOR(2)
|
||||
#define SIG_OVERFLOW0 _VECTOR(2)
|
||||
|
||||
#define _VECTORS_SIZE 6
|
||||
|
||||
/*
|
||||
The Register Bit names are represented by their bit number (0-7).
|
||||
*/
|
||||
|
||||
/* General Interrupt MaSK register */
|
||||
#define INT0 6
|
||||
#define INTF0 6
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define TOIE0 1
|
||||
#define TOV0 1
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define SE 5
|
||||
#define SM 4
|
||||
#define ISC01 1
|
||||
#define ISC00 0
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTOE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/*
|
||||
PB2 = SCK/T0
|
||||
PB1 = MISO/INT0
|
||||
PB0 = MOSI
|
||||
*/
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EERIE 3
|
||||
#define EEMWE 2
|
||||
#define EEWE 1
|
||||
#define EERE 0
|
||||
|
||||
/* Constants */
|
||||
#define RAMEND 0xDF
|
||||
#define XRAMEND 0xDF
|
||||
#define E2END 0x7F
|
||||
#define E2PAGESIZE 0
|
||||
#define FLASHEND 0x07FF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
#define FUSE_MEMORY_SIZE 1
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_FSTRT (unsigned char)~_BV(0)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define LFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x91
|
||||
#define SIGNATURE_2 0x02
|
||||
|
||||
|
||||
#endif /* _AVR_IO2323_H_ */
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x91
|
||||
#define SIGNATURE_2 0x02
|
||||
|
444
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io2333.h
Normal file
444
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io2333.h
Normal file
|
@ -0,0 +1,444 @@
|
|||
/* Copyright (c) 2002, Marek Michalkiewicz
|
||||
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: io2333.h,v 1.9 2005/10/30 22:11:23 joerg_wunsch Exp $ */
|
||||
|
||||
/* avr/io2333.h - definitions for AT90S2333 */
|
||||
|
||||
#ifndef _AVR_IO2333_H_
|
||||
#define _AVR_IO2333_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_ "io2333.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* UART Baud Rate Register high */
|
||||
#define UBRRH _SFR_IO8(0x03)
|
||||
|
||||
/* ADC Data register */
|
||||
#ifndef __ASSEMBLER__
|
||||
#define ADC _SFR_IO16(0x04)
|
||||
#endif
|
||||
#define ADCW _SFR_IO16(0x04)
|
||||
#define ADCL _SFR_IO8(0x04)
|
||||
#define ADCH _SFR_IO8(0x05)
|
||||
|
||||
/* ADC Control and Status Register */
|
||||
#define ADCSR _SFR_IO8(0x06)
|
||||
|
||||
/* ADC MUX */
|
||||
#define ADMUX _SFR_IO8(0x07)
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACSR _SFR_IO8(0x08)
|
||||
|
||||
/* UART Baud Rate Register */
|
||||
#define UBRR _SFR_IO8(0x09)
|
||||
|
||||
/* UART Control/Status Registers */
|
||||
#define UCSRB _SFR_IO8(0x0A)
|
||||
#define UCSRA _SFR_IO8(0x0B)
|
||||
|
||||
/* UART I/O Data Register */
|
||||
#define UDR _SFR_IO8(0x0C)
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPCR _SFR_IO8(0x0D)
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPSR _SFR_IO8(0x0E)
|
||||
|
||||
/* SPI I/O Data Register */
|
||||
#define SPDR _SFR_IO8(0x0F)
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND _SFR_IO8(0x10)
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDRD _SFR_IO8(0x11)
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PORTD _SFR_IO8(0x12)
|
||||
|
||||
/* Input Pins, Port C */
|
||||
#define PINC _SFR_IO8(0x13)
|
||||
|
||||
/* Data Direction Register, Port C */
|
||||
#define DDRC _SFR_IO8(0x14)
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PORTC _SFR_IO8(0x15)
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EECR _SFR_IO8(0x1C)
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define EEDR _SFR_IO8(0x1D)
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#define EEAR _SFR_IO8(0x1E)
|
||||
#define EEARL _SFR_IO8(0x1E)
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
|
||||
/* T/C 1 Input Capture Register */
|
||||
#define ICR1 _SFR_IO16(0x26)
|
||||
#define ICR1L _SFR_IO8(0x26)
|
||||
#define ICR1H _SFR_IO8(0x27)
|
||||
|
||||
/* Timer/Counter1 Output Compare Register A */
|
||||
#define OCR1 _SFR_IO16(0x2A)
|
||||
#define OCR1L _SFR_IO8(0x2A)
|
||||
#define OCR1H _SFR_IO8(0x2B)
|
||||
|
||||
/* Timer/Counter 1 */
|
||||
#define TCNT1 _SFR_IO16(0x2C)
|
||||
#define TCNT1L _SFR_IO8(0x2C)
|
||||
#define TCNT1H _SFR_IO8(0x2D)
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define TCCR1B _SFR_IO8(0x2E)
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define TCCR1A _SFR_IO8(0x2F)
|
||||
|
||||
/* Timer/Counter 0 */
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
/* MCU general Status Register */
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
/* Timer/Counter Interrupt Flag register */
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define GIFR _SFR_IO8(0x3A)
|
||||
|
||||
/* General Interrupt MaSK register */
|
||||
#define GIMSK _SFR_IO8(0x3B)
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
/* External Interrupt 0 */
|
||||
#define INT0_vect _VECTOR(1)
|
||||
#define SIG_INTERRUPT0 _VECTOR(1)
|
||||
|
||||
/* External Interrupt 1 */
|
||||
#define INT1_vect _VECTOR(2)
|
||||
#define SIG_INTERRUPT1 _VECTOR(2)
|
||||
|
||||
/* Timer/Counter Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(3)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(3)
|
||||
|
||||
/* Timer/Counter1 Compare Match */
|
||||
#define TIMER1_COMP_vect _VECTOR(4)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(4)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(5)
|
||||
#define SIG_OVERFLOW1 _VECTOR(5)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(6)
|
||||
#define SIG_OVERFLOW0 _VECTOR(6)
|
||||
|
||||
/* Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(7)
|
||||
#define SIG_SPI _VECTOR(7)
|
||||
|
||||
/* UART, Rx Complete */
|
||||
#define UART_RX_vect _VECTOR(8)
|
||||
#define SIG_UART_RECV _VECTOR(8)
|
||||
|
||||
/* UART Data Register Empty */
|
||||
#define UART_UDRE_vect _VECTOR(9)
|
||||
#define SIG_UART_DATA _VECTOR(9)
|
||||
|
||||
/* UART, Tx Complete */
|
||||
#define UART_TX_vect _VECTOR(10)
|
||||
#define SIG_UART_TRANS _VECTOR(10)
|
||||
|
||||
/* ADC Conversion Complete */
|
||||
#define ADC_vect _VECTOR(11)
|
||||
#define SIG_ADC _VECTOR(11)
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_RDY_vect _VECTOR(12)
|
||||
#define SIG_EEPROM_READY _VECTOR(12)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANA_COMP_vect _VECTOR(13)
|
||||
#define SIG_COMPARATOR _VECTOR(13)
|
||||
|
||||
#define _VECTORS_SIZE 28
|
||||
|
||||
/*
|
||||
The Register Bit names are represented by their bit number (0-7).
|
||||
*/
|
||||
|
||||
/* MCU general Status Register */
|
||||
#define WDRF 3
|
||||
#define BORF 2
|
||||
#define EXTRF 1
|
||||
#define PORF 0
|
||||
|
||||
/* General Interrupt MaSK register */
|
||||
#define INT1 7
|
||||
#define INT0 6
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define INTF1 7
|
||||
#define INTF0 6
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define TOIE1 7
|
||||
#define OCIE1 6
|
||||
#define TICIE1 3
|
||||
#define TOIE0 1
|
||||
|
||||
/* Timer/Counter Interrupt Flag register */
|
||||
#define TOV1 7
|
||||
#define OCF1 6
|
||||
#define ICF1 3
|
||||
#define TOV0 1
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define SE 5
|
||||
#define SM 4
|
||||
#define ISC11 3
|
||||
#define ISC10 2
|
||||
#define ISC01 1
|
||||
#define ISC00 0
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define COM11 7
|
||||
#define COM10 6
|
||||
#define PWM11 1
|
||||
#define PWM10 0
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define ICNC1 7
|
||||
#define ICES1 6
|
||||
#define CTC1 3
|
||||
#define CS12 2
|
||||
#define CS11 1
|
||||
#define CS10 0
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTOE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPIE 7
|
||||
#define SPE 6
|
||||
#define DORD 5
|
||||
#define MSTR 4
|
||||
#define CPOL 3
|
||||
#define CPHA 2
|
||||
#define SPR1 1
|
||||
#define SPR0 0
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPIF 7
|
||||
#define WCOL 6
|
||||
|
||||
/* UART Status Register */
|
||||
#define RXC 7
|
||||
#define TXC 6
|
||||
#define UDRE 5
|
||||
#define FE 4
|
||||
#define DOR 3
|
||||
#define MPCM 0
|
||||
|
||||
/* UART Control Register */
|
||||
#define RXCIE 7
|
||||
#define TXCIE 6
|
||||
#define UDRIE 5
|
||||
#define RXEN 4
|
||||
#define TXEN 3
|
||||
#define CHR9 2
|
||||
#define RXB8 1
|
||||
#define TXB8 0
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACD 7
|
||||
#define AINBG 6
|
||||
#define ACO 5
|
||||
#define ACI 4
|
||||
#define ACIE 3
|
||||
#define ACIC 2
|
||||
#define ACIS1 1
|
||||
#define ACIS0 0
|
||||
|
||||
/* ADC MUX */
|
||||
#define ACDBG 6
|
||||
#define MUX2 2
|
||||
#define MUX1 1
|
||||
#define MUX0 0
|
||||
|
||||
/* ADC Control and Status Register */
|
||||
#define ADEN 7
|
||||
#define ADSC 6
|
||||
#define ADFR 5
|
||||
#define ADIF 4
|
||||
#define ADIE 3
|
||||
#define ADPS2 2
|
||||
#define ADPS1 1
|
||||
#define ADPS0 0
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PB5 5
|
||||
#define PB4 4
|
||||
#define PB3 3
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDB5 5
|
||||
#define DDB4 4
|
||||
#define DDB3 3
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB5 5
|
||||
#define PINB4 4
|
||||
#define PINB3 3
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PC5 5
|
||||
#define PC4 4
|
||||
#define PC3 3
|
||||
#define PC2 2
|
||||
#define PC1 1
|
||||
#define PC0 0
|
||||
|
||||
/* Data Direction Register, Port C */
|
||||
#define DDC5 5
|
||||
#define DDC4 4
|
||||
#define DDC3 3
|
||||
#define DDC2 2
|
||||
#define DDC1 1
|
||||
#define DDC0 0
|
||||
|
||||
/* Input Pins, Port C */
|
||||
#define PINC5 5
|
||||
#define PINC4 4
|
||||
#define PINC3 3
|
||||
#define PINC2 2
|
||||
#define PINC1 1
|
||||
#define PINC0 0
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PD7 7
|
||||
#define PD6 6
|
||||
#define PD5 5
|
||||
#define PD4 4
|
||||
#define PD3 3
|
||||
#define PD2 2
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDD7 7
|
||||
#define DDD6 6
|
||||
#define DDD5 5
|
||||
#define DDD4 4
|
||||
#define DDD3 3
|
||||
#define DDD2 2
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND7 7
|
||||
#define PIND6 6
|
||||
#define PIND5 5
|
||||
#define PIND4 4
|
||||
#define PIND3 3
|
||||
#define PIND2 2
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EERIE 3
|
||||
#define EEMWE 2
|
||||
#define EEWE 1
|
||||
#define EERE 0
|
||||
|
||||
/* Constants */
|
||||
#define RAMEND 0xDF /*Last On-Chip SRAM location*/
|
||||
#define XRAMEND 0xDF
|
||||
#define E2END 0x7F
|
||||
#define FLASHEND 0x7FF
|
||||
|
||||
#endif /* _AVR_IO2333_H_ */
|
209
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io2343.h
Normal file
209
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io2343.h
Normal file
|
@ -0,0 +1,209 @@
|
|||
/* Copyright (c) 2002, Marek Michalkiewicz
|
||||
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: io2343.h,v 1.9.2.3 2008/08/14 00:07:59 arcanum Exp $ */
|
||||
|
||||
/* avr/io2343.h - definitions for AT90S2343 */
|
||||
|
||||
#ifndef _AVR_IO2343_H_
|
||||
#define _AVR_IO2343_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_ "io2343.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EECR _SFR_IO8(0x1C)
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define EEDR _SFR_IO8(0x1D)
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#define EEAR _SFR_IO8(0x1E)
|
||||
#define EEARL _SFR_IO8(0x1E)
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
|
||||
/* Timer/Counter 0 */
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
/* MCU Status Register */
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
/* Timer/Counter Interrupt Flag register */
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
|
||||
/* General Interrupt Flag register */
|
||||
#define GIFR _SFR_IO8(0x3A)
|
||||
|
||||
/* General Interrupt MaSK register */
|
||||
#define GIMSK _SFR_IO8(0x3B)
|
||||
|
||||
/* 0x3D..0x3E SP */
|
||||
|
||||
/* 0x3F SREG */
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
/* External Interrupt 0 */
|
||||
#define INT0_vect _VECTOR(1)
|
||||
#define SIG_INTERRUPT0 _VECTOR(1)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF0_vect _VECTOR(2)
|
||||
#define SIG_OVERFLOW0 _VECTOR(2)
|
||||
|
||||
#define _VECTORS_SIZE 6
|
||||
|
||||
/*
|
||||
The Register Bit names are represented by their bit number (0-7).
|
||||
*/
|
||||
|
||||
/* General Interrupt MaSK register */
|
||||
#define INT0 6
|
||||
#define INTF0 6
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define TOIE0 1
|
||||
#define TOV0 1
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define SE 5
|
||||
#define SM 4
|
||||
#define ISC01 1
|
||||
#define ISC00 0
|
||||
|
||||
/* MCU Status Register */
|
||||
#define PORF 0
|
||||
#define EXTRF 1
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTOE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/*
|
||||
PB3 = CLOCK
|
||||
PB2 = SCK/T0
|
||||
PB1 = MISO/INT0
|
||||
PB0 = MOSI
|
||||
*/
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PB4 4
|
||||
#define PB3 3
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDB4 4
|
||||
#define DDB3 3
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB4 4
|
||||
#define PINB3 3
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EERIE 3
|
||||
#define EEMWE 2
|
||||
#define EEWE 1
|
||||
#define EERE 0
|
||||
|
||||
/* Constants */
|
||||
#define RAMEND 0xDF
|
||||
#define XRAMEND 0xDF
|
||||
#define E2END 0x7F
|
||||
#define E2PAGESIZE 0
|
||||
#define FLASHEND 0x07FF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
#define FUSE_MEMORY_SIZE 1
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_RCEN (unsigned char)~_BV(0)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define LFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x91
|
||||
#define SIGNATURE_2 0x03
|
||||
|
||||
|
||||
#endif /* _AVR_IO2343_H_ */
|
|
@ -0,0 +1,436 @@
|
|||
/* Copyright (c) 2003,2005 Keith Gudger
|
||||
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: io43u32x.h,v 1.5 2005/11/10 22:19:07 joerg_wunsch Exp $ */
|
||||
|
||||
/* avr/io43u32x.h - definitions for AT43USB32x */
|
||||
|
||||
#ifndef _AVR_IO43U32X_H_
|
||||
#define _AVR_IO43U32X_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_ "io43u32x.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACSR _SFR_IO8(0x08)
|
||||
|
||||
/* UART Baud Rate Register */
|
||||
#define UBRR _SFR_IO8(0x09)
|
||||
|
||||
/* UART Control Register */
|
||||
#define UCR _SFR_IO8(0x0A)
|
||||
|
||||
/* UART Status Register */
|
||||
#define USR _SFR_IO8(0x0B)
|
||||
|
||||
/* UART I/O Data Register */
|
||||
#define UDR _SFR_IO8(0x0C)
|
||||
|
||||
/* Input Pins, Port E */ // new port for 43324/6
|
||||
#define PINE _SFR_IO8(0x01)
|
||||
|
||||
/* Data Direction Register, Port E */
|
||||
#define DDRE _SFR_IO8(0x02)
|
||||
|
||||
/* Data Register, Port E */
|
||||
#define PORTE _SFR_IO8(0x03)
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPCR _SFR_IO8(0x0D)
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPSR _SFR_IO8(0x0E)
|
||||
|
||||
/* SPI I/O Data Register */
|
||||
#define SPDR _SFR_IO8(0x0F)
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND _SFR_IO8(0x10)
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDRD _SFR_IO8(0x11)
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PORTD _SFR_IO8(0x12)
|
||||
|
||||
/* Input Pins, Port C */
|
||||
#define PINC _SFR_IO8(0x13)
|
||||
|
||||
/* Data Direction Register, Port C */
|
||||
#define DDRC _SFR_IO8(0x14)
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PORTC _SFR_IO8(0x15)
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
|
||||
/* Input Pins, Port A */
|
||||
#define PINA _SFR_IO8(0x19)
|
||||
|
||||
/* Data Direction Register, Port A */
|
||||
#define DDRA _SFR_IO8(0x1A)
|
||||
|
||||
/* Data Register, Port A */
|
||||
#define PORTA _SFR_IO8(0x1B)
|
||||
|
||||
/* 0x1C..0x1F reserved */
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
|
||||
/* T/C 1 Input Capture Register */
|
||||
#define ICR1 _SFR_IO16(0x24)
|
||||
#define ICR1L _SFR_IO8(0x24)
|
||||
#define ICR1H _SFR_IO8(0x25)
|
||||
|
||||
/* Timer/Counter1 Output Compare Register B */
|
||||
#define OCR1B _SFR_IO16(0x28)
|
||||
#define OCR1BL _SFR_IO8(0x28)
|
||||
#define OCR1BH _SFR_IO8(0x29)
|
||||
|
||||
/* Timer/Counter1 Output Compare Register A */
|
||||
#define OCR1A _SFR_IO16(0x2A)
|
||||
#define OCR1AL _SFR_IO8(0x2A)
|
||||
#define OCR1AH _SFR_IO8(0x2B)
|
||||
|
||||
/* Timer/Counter 1 */
|
||||
#define TCNT1 _SFR_IO16(0x2C)
|
||||
#define TCNT1L _SFR_IO8(0x2C)
|
||||
#define TCNT1H _SFR_IO8(0x2D)
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define TCCR1B _SFR_IO8(0x2E)
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define TCCR1A _SFR_IO8(0x2F)
|
||||
|
||||
/* Timer/Counter 0 */
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
/* Timer/Counter Interrupt Flag Register */
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
|
||||
/* General Interrupt Control Register */
|
||||
#define GIFR _SFR_IO8(0x3A)
|
||||
|
||||
/* General Interrupt Mask register */
|
||||
#define GIMSK _SFR_IO8(0x3B)
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
#define SIG_INTERRUPT0 _VECTOR(1)
|
||||
#define SIG_INTERRUPT1 _VECTOR(2)
|
||||
#define SIG_TIMER1_CAPT1 _VECTOR(3)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(3)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(4)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(5)
|
||||
#define SIG_OVERFLOW1 _VECTOR(6)
|
||||
#define SIG_OVERFLOW0 _VECTOR(7)
|
||||
#define SIG_SPI _VECTOR(8)
|
||||
#define SIG_UART_RECV _VECTOR(9)
|
||||
#define SIG_UART_DATA _VECTOR(10)
|
||||
#define SIG_UART_TRANS _VECTOR(11)
|
||||
#define SIG_USB_INT _VECTOR(12)
|
||||
|
||||
#define _VECTORS_SIZE 52
|
||||
|
||||
/*
|
||||
The Register Bit names are represented by their bit number (0-7).
|
||||
*/
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define TICIE1 3
|
||||
#define OCIE1A 6
|
||||
#define OCIE1B 5
|
||||
#define TOIE1 7
|
||||
#define TOIE0 1
|
||||
|
||||
/* Timer/Counter Interrupt Flag Register */
|
||||
#define ICF1 3
|
||||
#define OCF1A 6
|
||||
#define OCF1B 5
|
||||
#define TOV1 7
|
||||
#define TOV0 1
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define SE 5
|
||||
#define SM 4
|
||||
#define ISC11 3
|
||||
#define ISC10 2
|
||||
#define ISC01 1
|
||||
#define ISC00 0
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define COM1A1 7
|
||||
#define COM1A0 6
|
||||
#define COM1B1 5
|
||||
#define COM1B0 4
|
||||
#define PWM11 1
|
||||
#define PWM10 0
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define ICNC1 7
|
||||
#define ICES1 6
|
||||
#define CTC1 3
|
||||
#define CS12 2
|
||||
#define CS11 1
|
||||
#define CS10 0
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTOE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/* Data Register, Port A */
|
||||
#define PA7 7
|
||||
#define PA6 6
|
||||
#define PA5 5
|
||||
#define PA4 4
|
||||
#define PA3 3
|
||||
#define PA2 2
|
||||
#define PA1 1
|
||||
#define PA0 0
|
||||
|
||||
/* Data Direction Register, Port A */
|
||||
#define DDA7 7
|
||||
#define DDA6 6
|
||||
#define DDA5 5
|
||||
#define DDA4 4
|
||||
#define DDA3 3
|
||||
#define DDA2 2
|
||||
#define DDA1 1
|
||||
#define DDA0 0
|
||||
|
||||
/* Input Pins, Port A */
|
||||
#define PINA7 7
|
||||
#define PINA6 6
|
||||
#define PINA5 5
|
||||
#define PINA4 4
|
||||
#define PINA3 3
|
||||
#define PINA2 2
|
||||
#define PINA1 1
|
||||
#define PINA0 0
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PB7 7
|
||||
#define PB6 6
|
||||
#define PB5 5
|
||||
#define PB4 4
|
||||
#define PB3 3
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDB7 7
|
||||
#define DDB6 6
|
||||
#define DDB5 5
|
||||
#define DDB4 4
|
||||
#define DDB3 3
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB7 7
|
||||
#define PINB6 6
|
||||
#define PINB5 5
|
||||
#define PINB4 4
|
||||
#define PINB3 3
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
/* Data Direction Register, Port C */
|
||||
#define DDC7 7
|
||||
#define DDC6 6
|
||||
#define DDC5 5
|
||||
#define DDC4 4
|
||||
#define DDC3 3
|
||||
#define DDC2 2
|
||||
#define DDC1 1
|
||||
#define DDC0 0
|
||||
|
||||
/* Input Pins, Port C */
|
||||
#define PINC7 7
|
||||
#define PINC6 6
|
||||
#define PINC5 5
|
||||
#define PINC4 4
|
||||
#define PINC3 3
|
||||
#define PINC2 2
|
||||
#define PINC1 1
|
||||
#define PINC0 0
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PC7 7
|
||||
#define PC6 6
|
||||
#define PC5 5
|
||||
#define PC4 4
|
||||
#define PC3 3
|
||||
#define PC2 2
|
||||
#define PC1 1
|
||||
#define PC0 0
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PD7 7
|
||||
#define PD6 6
|
||||
#define PD5 5
|
||||
#define PD4 4
|
||||
#define PD3 3
|
||||
#define PD2 2
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDD7 7
|
||||
#define DDD6 6
|
||||
#define DDD5 5
|
||||
#define DDD4 4
|
||||
#define DDD3 3
|
||||
#define DDD2 2
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND7 7
|
||||
#define PIND6 6
|
||||
#define PIND5 5
|
||||
#define PIND4 4
|
||||
#define PIND3 3
|
||||
#define PIND2 2
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
/* Data Register, Port E */
|
||||
#define PE7 7
|
||||
#define PE6 6
|
||||
#define PE5 5
|
||||
#define PE4 4
|
||||
#define PE3 3
|
||||
#define PE2 2
|
||||
#define PE1 1
|
||||
#define PE0 0
|
||||
|
||||
/* Data Direction Register, Port E */
|
||||
#define DDE7 7
|
||||
#define DDE6 6
|
||||
#define DDE5 5
|
||||
#define DDE4 4
|
||||
#define DDE3 3
|
||||
#define DDE2 2
|
||||
#define DDE1 1
|
||||
#define DDE0 0
|
||||
|
||||
/* Input Pins, Port E */
|
||||
#define PINE7 7
|
||||
#define PINE6 6
|
||||
#define PINE5 5
|
||||
#define PINE4 4
|
||||
#define PINE3 3
|
||||
#define PINE2 2
|
||||
#define PINE1 1
|
||||
#define PINE0 0
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPIF 7
|
||||
#define WCOL 6
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPIE 7
|
||||
#define SPE 6
|
||||
#define DORD 5
|
||||
#define MSTR 4
|
||||
#define CPOL 3
|
||||
#define CPHA 2
|
||||
#define SPR1 1
|
||||
#define SPR0 0
|
||||
|
||||
/* UART Status Register */
|
||||
#define RXC 7
|
||||
#define TXC 6
|
||||
#define UDRE 5
|
||||
#define FE 4
|
||||
#define DOR 3
|
||||
|
||||
/* UART Control Register */
|
||||
#define RXCIE 7
|
||||
#define TXCIE 6
|
||||
#define UDRIE 5
|
||||
#define RXEN 4
|
||||
#define TXEN 3
|
||||
#define CHR9 2
|
||||
#define RXB8 1
|
||||
#define TXB8 0
|
||||
|
||||
/* Constants */
|
||||
#define RAMEND 0x025F /*Last On-Chip SRAM Location*/
|
||||
#define XRAMEND 0x025F
|
||||
#define E2END 0x0000
|
||||
|
||||
/* FIXME: should be 0x1FFFF for max 128K (64K*16) external program memory,
|
||||
but no RAMPZ causes gcrt1.S build to fail, so assume 64K for now... */
|
||||
#define FLASHEND 0x0FFFF
|
||||
|
||||
#endif /* _AVR_43USB32X_H_ */
|
|
@ -0,0 +1,428 @@
|
|||
/* Copyright (c) 2003,2005 Keith Gudger
|
||||
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: io43u35x.h,v 1.7 2005/11/10 22:19:07 joerg_wunsch Exp $ */
|
||||
|
||||
/* avr/io43u35x.h - definitions for AT43USB35x */
|
||||
|
||||
#ifndef _AVR_IO43U35X_H_
|
||||
#define _AVR_IO43U35X_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_ "io43u35x.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* ADC Data Register */
|
||||
#ifndef __ASSEMBLER__
|
||||
#define ADC _SFR_IO16(0x02)
|
||||
#endif
|
||||
#define ADCW _SFR_IO16(0x02)
|
||||
#define ADCL _SFR_IO8(0x02)
|
||||
#define ADCH _SFR_IO8(0x03)
|
||||
|
||||
/* ADC Control and status register */
|
||||
#define ADCSR _SFR_IO8(0x07)
|
||||
|
||||
/* ADC Multiplexer select */
|
||||
#define ADMUX _SFR_IO8(0x08)
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACSR _SFR_IO8(0x08)
|
||||
|
||||
/* Input Pins, Port F */
|
||||
#define PINF _SFR_IO8(0x04)
|
||||
|
||||
/* Data Direction Register, Port F */
|
||||
#define DDRF _SFR_IO8(0x05)
|
||||
|
||||
/* Data Register, Port F */
|
||||
#define PORTF _SFR_IO8(0x06)
|
||||
|
||||
/* Input Pins, Port E */
|
||||
#define PINE _SFR_IO8(0x01)
|
||||
|
||||
/* Data Direction Register, Port E */
|
||||
#define DDRE _SFR_IO8(0x02)
|
||||
|
||||
/* Data Register, Port E */
|
||||
#define PORTE _SFR_IO8(0x03)
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPCR _SFR_IO8(0x0D)
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPSR _SFR_IO8(0x0E)
|
||||
|
||||
/* SPI I/O Data Register */
|
||||
#define SPDR _SFR_IO8(0x0F)
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND _SFR_IO8(0x10)
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDRD _SFR_IO8(0x11)
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PORTD _SFR_IO8(0x12)
|
||||
|
||||
/* Input Pins, Port C */
|
||||
#define PINC _SFR_IO8(0x13)
|
||||
|
||||
/* Data Direction Register, Port C */
|
||||
#define DDRC _SFR_IO8(0x14)
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PORTC _SFR_IO8(0x15)
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
|
||||
/* Input Pins, Port A */
|
||||
#define PINA _SFR_IO8(0x19)
|
||||
|
||||
/* Data Direction Register, Port A */
|
||||
#define DDRA _SFR_IO8(0x1A)
|
||||
|
||||
/* Data Register, Port A */
|
||||
#define PORTA _SFR_IO8(0x1B)
|
||||
|
||||
/* 0x1C..0x1F reserved */
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
|
||||
/* T/C 1 Input Capture Register */
|
||||
#define ICR1 _SFR_IO16(0x24)
|
||||
#define ICR1L _SFR_IO8(0x24)
|
||||
#define ICR1H _SFR_IO8(0x25)
|
||||
|
||||
/* Timer/Counter1 Output Compare Register B */
|
||||
#define OCR1B _SFR_IO16(0x28)
|
||||
#define OCR1BL _SFR_IO8(0x28)
|
||||
#define OCR1BH _SFR_IO8(0x29)
|
||||
|
||||
/* Timer/Counter1 Output Compare Register A */
|
||||
#define OCR1A _SFR_IO16(0x2A)
|
||||
#define OCR1AL _SFR_IO8(0x2A)
|
||||
#define OCR1AH _SFR_IO8(0x2B)
|
||||
|
||||
/* Timer/Counter 1 */
|
||||
#define TCNT1 _SFR_IO16(0x2C)
|
||||
#define TCNT1L _SFR_IO8(0x2C)
|
||||
#define TCNT1H _SFR_IO8(0x2D)
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define TCCR1B _SFR_IO8(0x2E)
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define TCCR1A _SFR_IO8(0x2F)
|
||||
|
||||
/* Timer/Counter 0 */
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
/* Timer/Counter Interrupt Flag Register */
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
|
||||
/* General Interrupt Control Register */
|
||||
#define GIFR _SFR_IO8(0x3A)
|
||||
|
||||
/* General Interrupt Mask register */
|
||||
#define GIMSK _SFR_IO8(0x3B)
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
#define SIG_INTERRUPT0 _VECTOR(1) /* suspend/resume */
|
||||
#define SIG_INTERRUPT1 _VECTOR(2)
|
||||
#define SIG_TIMER1_CAPT1 _VECTOR(3)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(3)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(4)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(5)
|
||||
#define SIG_OVERFLOW1 _VECTOR(6)
|
||||
#define SIG_OVERFLOW0 _VECTOR(7)
|
||||
#define SIG_SPI _VECTOR(8)
|
||||
/* 9, 10: reserved */
|
||||
#define SIG_ADC _VECTOR(11)
|
||||
#define SIG_USB_INT _VECTOR(12)
|
||||
|
||||
#define _VECTORS_SIZE 52
|
||||
|
||||
/*
|
||||
The Register Bit names are represented by their bit number (0-7).
|
||||
*/
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define TICIE1 3
|
||||
#define OCIE1A 6
|
||||
#define OCIE1B 5
|
||||
#define TOIE1 7
|
||||
#define TOIE0 1
|
||||
|
||||
/* Timer/Counter Interrupt Flag Register */
|
||||
#define ICF1 3
|
||||
#define OCF1A 6
|
||||
#define OCF1B 5
|
||||
#define TOV1 7
|
||||
#define TOV0 1
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define SE 5
|
||||
#define SM 4
|
||||
#define ISC11 3
|
||||
#define ISC10 2
|
||||
#define ISC01 1
|
||||
#define ISC00 0
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define COM1A1 7
|
||||
#define COM1A0 6
|
||||
#define COM1B1 5
|
||||
#define COM1B0 4
|
||||
#define PWM11 1
|
||||
#define PWM10 0
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define ICNC1 7
|
||||
#define ICES1 6
|
||||
#define CTC1 3
|
||||
#define CS12 2
|
||||
#define CS11 1
|
||||
#define CS10 0
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTOE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/* Data Register, Port A */
|
||||
#define PA7 7
|
||||
#define PA6 6
|
||||
#define PA5 5
|
||||
#define PA4 4
|
||||
#define PA3 3
|
||||
#define PA2 2
|
||||
#define PA1 1
|
||||
#define PA0 0
|
||||
|
||||
/* Data Direction Register, Port A */
|
||||
#define DDA7 7
|
||||
#define DDA6 6
|
||||
#define DDA5 5
|
||||
#define DDA4 4
|
||||
#define DDA3 3
|
||||
#define DDA2 2
|
||||
#define DDA1 1
|
||||
#define DDA0 0
|
||||
|
||||
/* Input Pins, Port A */
|
||||
#define PINA7 7
|
||||
#define PINA6 6
|
||||
#define PINA5 5
|
||||
#define PINA4 4
|
||||
#define PINA3 3
|
||||
#define PINA2 2
|
||||
#define PINA1 1
|
||||
#define PINA0 0
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PB7 7
|
||||
#define PB6 6
|
||||
#define PB5 5
|
||||
#define PB4 4
|
||||
#define PB3 3
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDB7 7
|
||||
#define DDB6 6
|
||||
#define DDB5 5
|
||||
#define DDB4 4
|
||||
#define DDB3 3
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB7 7
|
||||
#define PINB6 6
|
||||
#define PINB5 5
|
||||
#define PINB4 4
|
||||
#define PINB3 3
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
/* Data Direction Register, Port C */
|
||||
#define DDC7 7
|
||||
#define DDC6 6
|
||||
#define DDC5 5
|
||||
#define DDC4 4
|
||||
#define DDC3 3
|
||||
#define DDC2 2
|
||||
#define DDC1 1
|
||||
#define DDC0 0
|
||||
|
||||
/* Input Pins, Port C */
|
||||
#define PINC7 7
|
||||
#define PINC6 6
|
||||
#define PINC5 5
|
||||
#define PINC4 4
|
||||
#define PINC3 3
|
||||
#define PINC2 2
|
||||
#define PINC1 1
|
||||
#define PINC0 0
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PC7 7
|
||||
#define PC6 6
|
||||
#define PC5 5
|
||||
#define PC4 4
|
||||
#define PC3 3
|
||||
#define PC2 2
|
||||
#define PC1 1
|
||||
#define PC0 0
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PD7 7
|
||||
#define PD6 6
|
||||
#define PD5 5
|
||||
#define PD4 4
|
||||
#define PD3 3
|
||||
#define PD2 2
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDD7 7
|
||||
#define DDD6 6
|
||||
#define DDD5 5
|
||||
#define DDD4 4
|
||||
#define DDD3 3
|
||||
#define DDD2 2
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND7 7
|
||||
#define PIND6 6
|
||||
#define PIND5 5
|
||||
#define PIND4 4
|
||||
#define PIND3 3
|
||||
#define PIND2 2
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
/* Data Register, Port F */
|
||||
#define PF3 3
|
||||
#define PF2 2
|
||||
#define PF1 1
|
||||
#define PF0 0
|
||||
|
||||
/* Data Direction Register, Port F */
|
||||
#define DDF3 3
|
||||
#define DDF2 2
|
||||
#define DDF1 1
|
||||
|
||||
/* Input Pins, Port F */
|
||||
#define PINF3 3
|
||||
#define PINF2 2
|
||||
#define PINF1 1
|
||||
#define PINF0 0
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPIF 7
|
||||
#define WCOL 6
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPIE 7
|
||||
#define SPE 6
|
||||
#define DORD 5
|
||||
#define MSTR 4
|
||||
#define CPOL 3
|
||||
#define CPHA 2
|
||||
#define SPR1 1
|
||||
#define SPR0 0
|
||||
|
||||
/* ADC Multiplexer select */
|
||||
#define MUX2 2
|
||||
#define MUX1 1
|
||||
#define MUX0 0
|
||||
|
||||
/* ADC Control and Status Register */
|
||||
#define ADEN 7
|
||||
#define ADSC 6
|
||||
#define ADFR 5
|
||||
#define ADIF 4
|
||||
#define ADIE 3
|
||||
#define ADPS2 2
|
||||
#define ADPS1 1
|
||||
#define ADPS0 0
|
||||
|
||||
/* Constants */
|
||||
#define RAMEND 0x045F /*Last On-Chip SRAM Location*/
|
||||
#define XRAMEND 0x045F
|
||||
#define E2END 0x0000
|
||||
#define FLASHEND 0x5FFF
|
||||
|
||||
#endif /* _AVR_43USB355_H_ */
|
485
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io4414.h
Normal file
485
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io4414.h
Normal file
|
@ -0,0 +1,485 @@
|
|||
/* Copyright (c) 2002, Marek Michalkiewicz
|
||||
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: io4414.h,v 1.8.4.3 2008/08/14 00:07:59 arcanum Exp $ */
|
||||
|
||||
/* avr/io4414.h - definitions for AT90S4414 */
|
||||
|
||||
#ifndef _AVR_IO4414_H_
|
||||
#define _AVR_IO4414_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_ "io4414.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACSR _SFR_IO8(0x08)
|
||||
|
||||
/* UART Baud Rate Register */
|
||||
#define UBRR _SFR_IO8(0x09)
|
||||
|
||||
/* UART Control Register */
|
||||
#define UCR _SFR_IO8(0x0A)
|
||||
|
||||
/* UART Status Register */
|
||||
#define USR _SFR_IO8(0x0B)
|
||||
|
||||
/* UART I/O Data Register */
|
||||
#define UDR _SFR_IO8(0x0C)
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPCR _SFR_IO8(0x0D)
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPSR _SFR_IO8(0x0E)
|
||||
|
||||
/* SPI I/O Data Register */
|
||||
#define SPDR _SFR_IO8(0x0F)
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND _SFR_IO8(0x10)
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDRD _SFR_IO8(0x11)
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PORTD _SFR_IO8(0x12)
|
||||
|
||||
/* Input Pins, Port C */
|
||||
#define PINC _SFR_IO8(0x13)
|
||||
|
||||
/* Data Direction Register, Port C */
|
||||
#define DDRC _SFR_IO8(0x14)
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PORTC _SFR_IO8(0x15)
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
|
||||
/* Input Pins, Port A */
|
||||
#define PINA _SFR_IO8(0x19)
|
||||
|
||||
/* Data Direction Register, Port A */
|
||||
#define DDRA _SFR_IO8(0x1A)
|
||||
|
||||
/* Data Register, Port A */
|
||||
#define PORTA _SFR_IO8(0x1B)
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EECR _SFR_IO8(0x1C)
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define EEDR _SFR_IO8(0x1D)
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#define EEAR _SFR_IO8(0x1E)
|
||||
#define EEARL _SFR_IO8(0x1E)
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
|
||||
/* T/C 1 Input Capture Register */
|
||||
#define ICR1 _SFR_IO16(0x24)
|
||||
#define ICR1L _SFR_IO8(0x24)
|
||||
#define ICR1H _SFR_IO8(0x25)
|
||||
|
||||
/* Timer/Counter1 Output Compare Register B */
|
||||
#define OCR1B _SFR_IO16(0x28)
|
||||
#define OCR1BL _SFR_IO8(0x28)
|
||||
#define OCR1BH _SFR_IO8(0x29)
|
||||
|
||||
/* Timer/Counter1 Output Compare Register A */
|
||||
#define OCR1A _SFR_IO16(0x2A)
|
||||
#define OCR1AL _SFR_IO8(0x2A)
|
||||
#define OCR1AH _SFR_IO8(0x2B)
|
||||
|
||||
/* Timer/Counter 1 */
|
||||
#define TCNT1 _SFR_IO16(0x2C)
|
||||
#define TCNT1L _SFR_IO8(0x2C)
|
||||
#define TCNT1H _SFR_IO8(0x2D)
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define TCCR1B _SFR_IO8(0x2E)
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define TCCR1A _SFR_IO8(0x2F)
|
||||
|
||||
/* Timer/Counter 0 */
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
/* Timer/Counter Interrupt Flag register */
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define GIFR _SFR_IO8(0x3A)
|
||||
|
||||
/* General Interrupt MaSK register */
|
||||
#define GIMSK _SFR_IO8(0x3B)
|
||||
|
||||
/* 0x3C..0x3D SP */
|
||||
|
||||
/* 0x3F SREG */
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
/* 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)
|
||||
|
||||
/* Timer/Counter Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(3)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(3)
|
||||
|
||||
/* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPA_vect _VECTOR(4)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(4)
|
||||
|
||||
/* Timer/Counter1 Compare MatchB */
|
||||
#define TIMER1_COMPB_vect _VECTOR(5)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(5)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(6)
|
||||
#define SIG_OVERFLOW1 _VECTOR(6)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(7)
|
||||
#define SIG_OVERFLOW0 _VECTOR(7)
|
||||
|
||||
/* Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(8)
|
||||
#define SIG_SPI _VECTOR(8)
|
||||
|
||||
/* UART, Rx Complete */
|
||||
#define UART_RX_vect _VECTOR(9)
|
||||
#define SIG_UART_RECV _VECTOR(9)
|
||||
|
||||
/* UART Data Register Empty */
|
||||
#define UART_UDRE_vect _VECTOR(10)
|
||||
#define SIG_UART_DATA _VECTOR(10)
|
||||
|
||||
/* UART, Tx Complete */
|
||||
#define UART_TX_vect _VECTOR(11)
|
||||
#define SIG_UART_TRANS _VECTOR(11)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANA_COMP_vect _VECTOR(12)
|
||||
#define SIG_COMPARATOR _VECTOR(12)
|
||||
|
||||
#define _VECTORS_SIZE 26
|
||||
|
||||
/*
|
||||
The Register Bit names are represented by their bit number (0-7).
|
||||
*/
|
||||
|
||||
/* General Interrupt MaSK register */
|
||||
#define INT1 7
|
||||
#define INT0 6
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define INTF1 7
|
||||
#define INTF0 6
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define TOIE1 7
|
||||
#define OCIE1A 6
|
||||
#define OCIE1B 5
|
||||
#define TICIE1 3
|
||||
#define TOIE0 1
|
||||
|
||||
/* Timer/Counter Interrupt Flag register */
|
||||
#define TOV1 7
|
||||
#define OCF1A 6
|
||||
#define OCF1B 5
|
||||
#define ICF1 3
|
||||
#define TOV0 1
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define SRE 7
|
||||
#define SRW 6
|
||||
#define SE 5
|
||||
#define SM 4
|
||||
#define ISC11 3
|
||||
#define ISC10 2
|
||||
#define ISC01 1
|
||||
#define ISC00 0
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define COM1A1 7
|
||||
#define COM1A0 6
|
||||
#define COM1B1 5
|
||||
#define COM1B0 4
|
||||
#define PWM11 1
|
||||
#define PWM10 0
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define ICNC1 7
|
||||
#define ICES1 6
|
||||
#define CTC1 3
|
||||
#define CS12 2
|
||||
#define CS11 1
|
||||
#define CS10 0
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTOE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/* Data Register, Port A */
|
||||
#define PA7 7
|
||||
#define PA6 6
|
||||
#define PA5 5
|
||||
#define PA4 4
|
||||
#define PA3 3
|
||||
#define PA2 2
|
||||
#define PA1 1
|
||||
#define PA0 0
|
||||
|
||||
/* Data Direction Register, Port A */
|
||||
#define DDA7 7
|
||||
#define DDA6 6
|
||||
#define DDA5 5
|
||||
#define DDA4 4
|
||||
#define DDA3 3
|
||||
#define DDA2 2
|
||||
#define DDA1 1
|
||||
#define DDA0 0
|
||||
|
||||
/* Input Pins, Port A */
|
||||
#define PINA7 7
|
||||
#define PINA6 6
|
||||
#define PINA5 5
|
||||
#define PINA4 4
|
||||
#define PINA3 3
|
||||
#define PINA2 2
|
||||
#define PINA1 1
|
||||
#define PINA0 0
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PB7 7
|
||||
#define PB6 6
|
||||
#define PB5 5
|
||||
#define PB4 4
|
||||
#define PB3 3
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDB7 7
|
||||
#define DDB6 6
|
||||
#define DDB5 5
|
||||
#define DDB4 4
|
||||
#define DDB3 3
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB7 7
|
||||
#define PINB6 6
|
||||
#define PINB5 5
|
||||
#define PINB4 4
|
||||
#define PINB3 3
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PC7 7
|
||||
#define PC6 6
|
||||
#define PC5 5
|
||||
#define PC4 4
|
||||
#define PC3 3
|
||||
#define PC2 2
|
||||
#define PC1 1
|
||||
#define PC0 0
|
||||
|
||||
/* Data Direction Register, Port C */
|
||||
#define DDC7 7
|
||||
#define DDC6 6
|
||||
#define DDC5 5
|
||||
#define DDC4 4
|
||||
#define DDC3 3
|
||||
#define DDC2 2
|
||||
#define DDC1 1
|
||||
#define DDC0 0
|
||||
|
||||
/* Input Pins, Port C */
|
||||
#define PINC7 7
|
||||
#define PINC6 6
|
||||
#define PINC5 5
|
||||
#define PINC4 4
|
||||
#define PINC3 3
|
||||
#define PINC2 2
|
||||
#define PINC1 1
|
||||
#define PINC0 0
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PD7 7
|
||||
#define PD6 6
|
||||
#define PD5 5
|
||||
#define PD4 4
|
||||
#define PD3 3
|
||||
#define PD2 2
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDD7 7
|
||||
#define DDD6 6
|
||||
#define DDD5 5
|
||||
#define DDD4 4
|
||||
#define DDD3 3
|
||||
#define DDD2 2
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND7 7
|
||||
#define PIND6 6
|
||||
#define PIND5 5
|
||||
#define PIND4 4
|
||||
#define PIND3 3
|
||||
#define PIND2 2
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPIF 7
|
||||
#define WCOL 6
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPIE 7
|
||||
#define SPE 6
|
||||
#define DORD 5
|
||||
#define MSTR 4
|
||||
#define CPOL 3
|
||||
#define CPHA 2
|
||||
#define SPR1 1
|
||||
#define SPR0 0
|
||||
|
||||
/* UART Status Register */
|
||||
#define RXC 7
|
||||
#define TXC 6
|
||||
#define UDRE 5
|
||||
#define FE 4
|
||||
#define DOR 3
|
||||
|
||||
/* UART Control Register */
|
||||
#define RXCIE 7
|
||||
#define TXCIE 6
|
||||
#define UDRIE 5
|
||||
#define RXEN 4
|
||||
#define TXEN 3
|
||||
#define CHR9 2
|
||||
#define RXB8 1
|
||||
#define TXB8 0
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACD 7
|
||||
#define ACO 5
|
||||
#define ACI 4
|
||||
#define ACIE 3
|
||||
#define ACIC 2
|
||||
#define ACIS1 1
|
||||
#define ACIS0 0
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EERIE 3
|
||||
#define EEMWE 2
|
||||
#define EEWE 1
|
||||
#define EERE 0
|
||||
|
||||
/* Constants */
|
||||
#define RAMEND 0x15F /* Last On-Chip SRAM Location */
|
||||
#define XRAMEND 0xFFFF
|
||||
#define E2END 0xFF
|
||||
#define E2PAGESIZE 0
|
||||
#define FLASHEND 0xFFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
#define FUSE_MEMORY_SIZE 1
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(1) /* Serial Program Downloading Enabled */
|
||||
#define FUSE_FSTRT (unsigned char)~_BV(2) /* Short Start-up time selected */
|
||||
#define LFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x92
|
||||
#define SIGNATURE_2 0x01
|
||||
|
||||
|
||||
#endif /* _AVR_IO4414_H_ */
|
473
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io4433.h
Normal file
473
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io4433.h
Normal file
|
@ -0,0 +1,473 @@
|
|||
/* Copyright (c) 2002, Marek Michalkiewicz
|
||||
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: io4433.h,v 1.9.4.3 2008/08/14 00:07:59 arcanum Exp $ */
|
||||
|
||||
/* avr/io4433.h - definitions for AT90S4433 */
|
||||
|
||||
#ifndef _AVR_IO4433_H_
|
||||
#define _AVR_IO4433_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_ "io4433.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* UART Baud Rate Register high */
|
||||
#define UBRRH _SFR_IO8(0x03)
|
||||
|
||||
/* ADC Data register */
|
||||
#ifndef __ASSEMBLER__
|
||||
#define ADC _SFR_IO16(0x04)
|
||||
#endif
|
||||
#define ADCW _SFR_IO16(0x04)
|
||||
#define ADCL _SFR_IO8(0x04)
|
||||
#define ADCH _SFR_IO8(0x05)
|
||||
|
||||
/* ADC Control and Status Register */
|
||||
#define ADCSR _SFR_IO8(0x06)
|
||||
|
||||
/* ADC MUX */
|
||||
#define ADMUX _SFR_IO8(0x07)
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACSR _SFR_IO8(0x08)
|
||||
|
||||
/* UART Baud Rate Register */
|
||||
#define UBRR _SFR_IO8(0x09)
|
||||
|
||||
/* UART Control/Status Registers */
|
||||
#define UCSRB _SFR_IO8(0x0A)
|
||||
#define UCSRA _SFR_IO8(0x0B)
|
||||
|
||||
/* UART I/O Data Register */
|
||||
#define UDR _SFR_IO8(0x0C)
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPCR _SFR_IO8(0x0D)
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPSR _SFR_IO8(0x0E)
|
||||
|
||||
/* SPI I/O Data Register */
|
||||
#define SPDR _SFR_IO8(0x0F)
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND _SFR_IO8(0x10)
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDRD _SFR_IO8(0x11)
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PORTD _SFR_IO8(0x12)
|
||||
|
||||
/* Input Pins, Port C */
|
||||
#define PINC _SFR_IO8(0x13)
|
||||
|
||||
/* Data Direction Register, Port C */
|
||||
#define DDRC _SFR_IO8(0x14)
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PORTC _SFR_IO8(0x15)
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EECR _SFR_IO8(0x1C)
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define EEDR _SFR_IO8(0x1D)
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#define EEAR _SFR_IO8(0x1E)
|
||||
#define EEARL _SFR_IO8(0x1E)
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
|
||||
/* T/C 1 Input Capture Register */
|
||||
#define ICR1 _SFR_IO16(0x26)
|
||||
#define ICR1L _SFR_IO8(0x26)
|
||||
#define ICR1H _SFR_IO8(0x27)
|
||||
|
||||
/* Timer/Counter1 Output Compare Register A */
|
||||
#define OCR1 _SFR_IO16(0x2A)
|
||||
#define OCR1L _SFR_IO8(0x2A)
|
||||
#define OCR1H _SFR_IO8(0x2B)
|
||||
|
||||
/* Timer/Counter 1 */
|
||||
#define TCNT1 _SFR_IO16(0x2C)
|
||||
#define TCNT1L _SFR_IO8(0x2C)
|
||||
#define TCNT1H _SFR_IO8(0x2D)
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define TCCR1B _SFR_IO8(0x2E)
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define TCCR1A _SFR_IO8(0x2F)
|
||||
|
||||
/* Timer/Counter 0 */
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
/* MCU general Status Register */
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
/* Timer/Counter Interrupt Flag register */
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define GIFR _SFR_IO8(0x3A)
|
||||
|
||||
/* General Interrupt MaSK register */
|
||||
#define GIMSK _SFR_IO8(0x3B)
|
||||
|
||||
/* 0x3D..0x3E SP */
|
||||
|
||||
/* 0x3F SREG */
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
/* External Interrupt 0 */
|
||||
#define INT0_vect _VECTOR(1)
|
||||
#define SIG_INTERRUPT0 _VECTOR(1)
|
||||
|
||||
/* External Interrupt 1 */
|
||||
#define INT1_vect _VECTOR(2)
|
||||
#define SIG_INTERRUPT1 _VECTOR(2)
|
||||
|
||||
/* Timer/Counter Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(3)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(3)
|
||||
|
||||
/* Timer/Counter1 Compare Match */
|
||||
#define TIMER1_COMP_vect _VECTOR(4)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(4)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(5)
|
||||
#define SIG_OVERFLOW1 _VECTOR(5)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(6)
|
||||
#define SIG_OVERFLOW0 _VECTOR(6)
|
||||
|
||||
/* Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(7)
|
||||
#define SIG_SPI _VECTOR(7)
|
||||
|
||||
/* UART, Rx Complete */
|
||||
#define UART_RX_vect _VECTOR(8)
|
||||
#define SIG_UART_RECV _VECTOR(8)
|
||||
|
||||
/* UART Data Register Empty */
|
||||
#define UART_UDRE_vect _VECTOR(9)
|
||||
#define SIG_UART_DATA _VECTOR(9)
|
||||
|
||||
/* UART, Tx Complete */
|
||||
#define UART_TX_vect _VECTOR(10)
|
||||
#define SIG_UART_TRANS _VECTOR(10)
|
||||
|
||||
/* ADC Conversion Complete */
|
||||
#define ADC_vect _VECTOR(11)
|
||||
#define SIG_ADC _VECTOR(11)
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_RDY_vect _VECTOR(12)
|
||||
#define SIG_EEPROM_READY _VECTOR(12)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANA_COMP_vect _VECTOR(13)
|
||||
#define SIG_COMPARATOR _VECTOR(13)
|
||||
|
||||
#define _VECTORS_SIZE 28
|
||||
|
||||
/*
|
||||
The Register Bit names are represented by their bit number (0-7).
|
||||
*/
|
||||
|
||||
/* MCU general Status Register */
|
||||
#define WDRF 3
|
||||
#define BORF 2
|
||||
#define EXTRF 1
|
||||
#define PORF 0
|
||||
|
||||
/* General Interrupt MaSK register */
|
||||
#define INT1 7
|
||||
#define INT0 6
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define INTF1 7
|
||||
#define INTF0 6
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define TOIE1 7
|
||||
#define OCIE1 6
|
||||
#define TICIE1 3
|
||||
#define TOIE0 1
|
||||
|
||||
/* Timer/Counter Interrupt Flag register */
|
||||
#define TOV1 7
|
||||
#define OCF1 6
|
||||
#define ICF1 3
|
||||
#define TOV0 1
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define SE 5
|
||||
#define SM 4
|
||||
#define ISC11 3
|
||||
#define ISC10 2
|
||||
#define ISC01 1
|
||||
#define ISC00 0
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define COM11 7
|
||||
#define COM10 6
|
||||
#define PWM11 1
|
||||
#define PWM10 0
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define ICNC1 7
|
||||
#define ICES1 6
|
||||
#define CTC1 3
|
||||
#define CS12 2
|
||||
#define CS11 1
|
||||
#define CS10 0
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTOE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPIE 7
|
||||
#define SPE 6
|
||||
#define DORD 5
|
||||
#define MSTR 4
|
||||
#define CPOL 3
|
||||
#define CPHA 2
|
||||
#define SPR1 1
|
||||
#define SPR0 0
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPIF 7
|
||||
#define WCOL 6
|
||||
|
||||
/* UART Status Register */
|
||||
#define RXC 7
|
||||
#define TXC 6
|
||||
#define UDRE 5
|
||||
#define FE 4
|
||||
#define DOR 3
|
||||
#define MPCM 0
|
||||
|
||||
/* UART Control Register */
|
||||
#define RXCIE 7
|
||||
#define TXCIE 6
|
||||
#define UDRIE 5
|
||||
#define RXEN 4
|
||||
#define TXEN 3
|
||||
#define CHR9 2
|
||||
#define RXB8 1
|
||||
#define TXB8 0
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACD 7
|
||||
#define AINBG 6
|
||||
#define ACO 5
|
||||
#define ACI 4
|
||||
#define ACIE 3
|
||||
#define ACIC 2
|
||||
#define ACIS1 1
|
||||
#define ACIS0 0
|
||||
|
||||
/* ADC MUX */
|
||||
#define ACDBG 6
|
||||
#define MUX2 2
|
||||
#define MUX1 1
|
||||
#define MUX0 0
|
||||
|
||||
/* ADC Control and Status Register */
|
||||
#define ADEN 7
|
||||
#define ADSC 6
|
||||
#define ADFR 5
|
||||
#define ADIF 4
|
||||
#define ADIE 3
|
||||
#define ADPS2 2
|
||||
#define ADPS1 1
|
||||
#define ADPS0 0
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PB5 5
|
||||
#define PB4 4
|
||||
#define PB3 3
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDB5 5
|
||||
#define DDB4 4
|
||||
#define DDB3 3
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB5 5
|
||||
#define PINB4 4
|
||||
#define PINB3 3
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PC5 5
|
||||
#define PC4 4
|
||||
#define PC3 3
|
||||
#define PC2 2
|
||||
#define PC1 1
|
||||
#define PC0 0
|
||||
|
||||
/* Data Direction Register, Port C */
|
||||
#define DDC5 5
|
||||
#define DDC4 4
|
||||
#define DDC3 3
|
||||
#define DDC2 2
|
||||
#define DDC1 1
|
||||
#define DDC0 0
|
||||
|
||||
/* Input Pins, Port C */
|
||||
#define PINC5 5
|
||||
#define PINC4 4
|
||||
#define PINC3 3
|
||||
#define PINC2 2
|
||||
#define PINC1 1
|
||||
#define PINC0 0
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PD7 7
|
||||
#define PD6 6
|
||||
#define PD5 5
|
||||
#define PD4 4
|
||||
#define PD3 3
|
||||
#define PD2 2
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDD7 7
|
||||
#define DDD6 6
|
||||
#define DDD5 5
|
||||
#define DDD4 4
|
||||
#define DDD3 3
|
||||
#define DDD2 2
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND7 7
|
||||
#define PIND6 6
|
||||
#define PIND5 5
|
||||
#define PIND4 4
|
||||
#define PIND3 3
|
||||
#define PIND2 2
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EERIE 3
|
||||
#define EEMWE 2
|
||||
#define EEWE 1
|
||||
#define EERE 0
|
||||
|
||||
/* Constants */
|
||||
#define RAMEND 0xDF /*Last On-Chip SRAM location*/
|
||||
#define XRAMEND 0xDF
|
||||
#define E2END 0xFF
|
||||
#define E2PAGESIZE 0
|
||||
#define FLASHEND 0xFFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
#define FUSE_MEMORY_SIZE 1
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_BODEN (unsigned char)~_BV(3)
|
||||
#define FUSE_BODLEVEL (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define LFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x92
|
||||
#define SIGNATURE_2 0x03
|
||||
|
||||
|
||||
#endif /* _AVR_IO4433_H_ */
|
567
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io4434.h
Normal file
567
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io4434.h
Normal file
|
@ -0,0 +1,567 @@
|
|||
/* Copyright (c) 2002, Marek Michalkiewicz
|
||||
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: io4434.h,v 1.9.4.2 2008/08/14 00:07:59 arcanum Exp $ */
|
||||
|
||||
/* avr/io4434.h - definitions for AT90S4434 */
|
||||
|
||||
#ifndef _AVR_IO4434_H_
|
||||
#define _AVR_IO4434_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_ "io4434.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* ADC Data register */
|
||||
#ifndef __ASSEMBLER__
|
||||
#define ADC _SFR_IO16(0x04)
|
||||
#endif
|
||||
#define ADCW _SFR_IO16(0x04)
|
||||
#define ADCL _SFR_IO8(0x04)
|
||||
#define ADCH _SFR_IO8(0x05)
|
||||
|
||||
/* ADC Control and Status Register */
|
||||
#define ADCSR _SFR_IO8(0x06)
|
||||
|
||||
/* ADC MUX */
|
||||
#define ADMUX _SFR_IO8(0x07)
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACSR _SFR_IO8(0x08)
|
||||
|
||||
/* UART Baud Rate Register */
|
||||
#define UBRR _SFR_IO8(0x09)
|
||||
|
||||
/* UART Control Register */
|
||||
#define UCR _SFR_IO8(0x0A)
|
||||
|
||||
/* UART Status Register */
|
||||
#define USR _SFR_IO8(0x0B)
|
||||
|
||||
/* UART I/O Data Register */
|
||||
#define UDR _SFR_IO8(0x0C)
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPCR _SFR_IO8(0x0D)
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPSR _SFR_IO8(0x0E)
|
||||
|
||||
/* SPI I/O Data Register */
|
||||
#define SPDR _SFR_IO8(0x0F)
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND _SFR_IO8(0x10)
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDRD _SFR_IO8(0x11)
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PORTD _SFR_IO8(0x12)
|
||||
|
||||
/* Input Pins, Port C */
|
||||
#define PINC _SFR_IO8(0x13)
|
||||
|
||||
/* Data Direction Register, Port C */
|
||||
#define DDRC _SFR_IO8(0x14)
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PORTC _SFR_IO8(0x15)
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
|
||||
/* Input Pins, Port A */
|
||||
#define PINA _SFR_IO8(0x19)
|
||||
|
||||
/* Data Direction Register, Port A */
|
||||
#define DDRA _SFR_IO8(0x1A)
|
||||
|
||||
/* Data Register, Port A */
|
||||
#define PORTA _SFR_IO8(0x1B)
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EECR _SFR_IO8(0x1C)
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define EEDR _SFR_IO8(0x1D)
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#define EEAR _SFR_IO8(0x1E)
|
||||
#define EEARL _SFR_IO8(0x1E)
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
|
||||
/* Asynchronous mode Status Register */
|
||||
#define ASSR _SFR_IO8(0x22)
|
||||
|
||||
/* Timer/Counter2 Output Compare Register */
|
||||
#define OCR2 _SFR_IO8(0x23)
|
||||
|
||||
/* Timer/Counter 2 */
|
||||
#define TCNT2 _SFR_IO8(0x24)
|
||||
|
||||
/* Timer/Counter 2 Control Register */
|
||||
#define TCCR2 _SFR_IO8(0x25)
|
||||
|
||||
/* T/C 1 Input Capture Register */
|
||||
#define ICR1 _SFR_IO16(0x26)
|
||||
#define ICR1L _SFR_IO8(0x26)
|
||||
#define ICR1H _SFR_IO8(0x27)
|
||||
|
||||
/* Timer/Counter1 Output Compare Register B */
|
||||
#define OCR1B _SFR_IO16(0x28)
|
||||
#define OCR1BL _SFR_IO8(0x28)
|
||||
#define OCR1BH _SFR_IO8(0x29)
|
||||
|
||||
/* Timer/Counter1 Output Compare Register A */
|
||||
#define OCR1A _SFR_IO16(0x2A)
|
||||
#define OCR1AL _SFR_IO8(0x2A)
|
||||
#define OCR1AH _SFR_IO8(0x2B)
|
||||
|
||||
/* Timer/Counter 1 */
|
||||
#define TCNT1 _SFR_IO16(0x2C)
|
||||
#define TCNT1L _SFR_IO8(0x2C)
|
||||
#define TCNT1H _SFR_IO8(0x2D)
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define TCCR1B _SFR_IO8(0x2E)
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define TCCR1A _SFR_IO8(0x2F)
|
||||
|
||||
/* Timer/Counter 0 */
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
/* MCU general Status Register */
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
/* Timer/Counter Interrupt Flag register */
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define GIFR _SFR_IO8(0x3A)
|
||||
|
||||
/* General Interrupt MaSK register */
|
||||
#define GIMSK _SFR_IO8(0x3B)
|
||||
|
||||
/* 0x3D..0x3E SP */
|
||||
|
||||
/* 0x3F SREG */
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
/* External Interrupt 0 */
|
||||
#define INT0_vect _VECTOR(1)
|
||||
#define SIG_INTERRUPT0 _VECTOR(1)
|
||||
|
||||
/* External Interrupt 1 */
|
||||
#define INT1_vect _VECTOR(2)
|
||||
#define SIG_INTERRUPT1 _VECTOR(2)
|
||||
|
||||
/* Timer/Counter2 Compare Match */
|
||||
#define TIMER2_COMP_vect _VECTOR(3)
|
||||
#define SIG_OUTPUT_COMPARE2 _VECTOR(3)
|
||||
|
||||
/* Timer/Counter2 Overflow */
|
||||
#define TIMER2_OVF_vect _VECTOR(4)
|
||||
#define SIG_OVERFLOW2 _VECTOR(4)
|
||||
|
||||
/* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(5)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(5)
|
||||
|
||||
/* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPA_vect _VECTOR(6)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(6)
|
||||
|
||||
/* Timer/Counter1 Compare Match B */
|
||||
#define TIMER1_COMPB_vect _VECTOR(7)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(7)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(8)
|
||||
#define SIG_OVERFLOW1 _VECTOR(8)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(9)
|
||||
#define SIG_OVERFLOW0 _VECTOR(9)
|
||||
|
||||
/* SPI Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(10)
|
||||
#define SIG_SPI _VECTOR(10)
|
||||
|
||||
/* UART, RX Complete */
|
||||
#define UART_RX_vect _VECTOR(11)
|
||||
#define SIG_UART_RECV _VECTOR(11)
|
||||
|
||||
/* UART Data Register Empty */
|
||||
#define UART_UDRE_vect _VECTOR(12)
|
||||
#define SIG_UART_DATA _VECTOR(12)
|
||||
|
||||
/* UART, TX Complete */
|
||||
#define UART_TX_vect _VECTOR(13)
|
||||
#define SIG_UART_TRANS _VECTOR(13)
|
||||
|
||||
/* ADC Conversion Complete */
|
||||
#define ADC_vect _VECTOR(14)
|
||||
#define SIG_ADC _VECTOR(14)
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_RDY_vect _VECTOR(15)
|
||||
#define SIG_EEPROM_READY _VECTOR(15)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANA_COMP_vect _VECTOR(16)
|
||||
#define SIG_COMPARATOR _VECTOR(16)
|
||||
|
||||
#define _VECTORS_SIZE 34
|
||||
|
||||
/*
|
||||
The Register Bit names are represented by their bit number (0-7).
|
||||
*/
|
||||
|
||||
/* MCU general Status Register */
|
||||
#define EXTRF 1
|
||||
#define PORF 0
|
||||
|
||||
/* General Interrupt MaSK register */
|
||||
#define INT1 7
|
||||
#define INT0 6
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define INTF1 7
|
||||
#define INTF0 6
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define OCIE2 7
|
||||
#define TOIE2 6
|
||||
#define TICIE1 5
|
||||
#define OCIE1A 4
|
||||
#define OCIE1B 3
|
||||
#define TOIE1 2
|
||||
#define TOIE0 0
|
||||
|
||||
/* Timer/Counter Interrupt Flag register */
|
||||
#define OCF2 7
|
||||
#define TOV2 6
|
||||
#define ICF1 5
|
||||
#define OCF1A 4
|
||||
#define OCF1B 3
|
||||
#define TOV1 2
|
||||
#define TOV0 0
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define SE 6
|
||||
#define SM1 5
|
||||
#define SM0 4
|
||||
#define ISC11 3
|
||||
#define ISC10 2
|
||||
#define ISC01 1
|
||||
#define ISC00 0
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define COM1A1 7
|
||||
#define COM1A0 6
|
||||
#define COM1B1 5
|
||||
#define COM1B0 4
|
||||
#define PWM11 1
|
||||
#define PWM10 0
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define ICNC1 7
|
||||
#define ICES1 6
|
||||
#define CTC1 3
|
||||
#define CS12 2
|
||||
#define CS11 1
|
||||
#define CS10 0
|
||||
|
||||
/* Timer/Counter 2 Control Register */
|
||||
#define PWM2 6
|
||||
#define COM21 5
|
||||
#define COM20 4
|
||||
#define CTC2 3
|
||||
#define CS22 2
|
||||
#define CS21 1
|
||||
#define CS20 0
|
||||
|
||||
/* Asynchronous mode Status Register */
|
||||
#define AS2 3
|
||||
#define TCN2UB 2
|
||||
#define OCR2UB 1
|
||||
#define TCR2UB 0
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTOE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/* Data Register, Port A */
|
||||
#define PA7 7
|
||||
#define PA6 6
|
||||
#define PA5 5
|
||||
#define PA4 4
|
||||
#define PA3 3
|
||||
#define PA2 2
|
||||
#define PA1 1
|
||||
#define PA0 0
|
||||
|
||||
/* Data Direction Register, Port A */
|
||||
#define DDA7 7
|
||||
#define DDA6 6
|
||||
#define DDA5 5
|
||||
#define DDA4 4
|
||||
#define DDA3 3
|
||||
#define DDA2 2
|
||||
#define DDA1 1
|
||||
#define DDA0 0
|
||||
|
||||
/* Input Pins, Port A */
|
||||
#define PINA7 7
|
||||
#define PINA6 6
|
||||
#define PINA5 5
|
||||
#define PINA4 4
|
||||
#define PINA3 3
|
||||
#define PINA2 2
|
||||
#define PINA1 1
|
||||
#define PINA0 0
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PB7 7
|
||||
#define PB6 6
|
||||
#define PB5 5
|
||||
#define PB4 4
|
||||
#define PB3 3
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDB7 7
|
||||
#define DDB6 6
|
||||
#define DDB5 5
|
||||
#define DDB4 4
|
||||
#define DDB3 3
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB7 7
|
||||
#define PINB6 6
|
||||
#define PINB5 5
|
||||
#define PINB4 4
|
||||
#define PINB3 3
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PC7 7
|
||||
#define PC6 6
|
||||
#define PC5 5
|
||||
#define PC4 4
|
||||
#define PC3 3
|
||||
#define PC2 2
|
||||
#define PC1 1
|
||||
#define PC0 0
|
||||
|
||||
/* Data Direction Register, Port C */
|
||||
#define DDC7 7
|
||||
#define DDC6 6
|
||||
#define DDC5 5
|
||||
#define DDC4 4
|
||||
#define DDC3 3
|
||||
#define DDC2 2
|
||||
#define DDC1 1
|
||||
#define DDC0 0
|
||||
|
||||
/* Input Pins, Port C */
|
||||
#define PINC7 7
|
||||
#define PINC6 6
|
||||
#define PINC5 5
|
||||
#define PINC4 4
|
||||
#define PINC3 3
|
||||
#define PINC2 2
|
||||
#define PINC1 1
|
||||
#define PINC0 0
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PD7 7
|
||||
#define PD6 6
|
||||
#define PD5 5
|
||||
#define PD4 4
|
||||
#define PD3 3
|
||||
#define PD2 2
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDD7 7
|
||||
#define DDD6 6
|
||||
#define DDD5 5
|
||||
#define DDD4 4
|
||||
#define DDD3 3
|
||||
#define DDD2 2
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND7 7
|
||||
#define PIND6 6
|
||||
#define PIND5 5
|
||||
#define PIND4 4
|
||||
#define PIND3 3
|
||||
#define PIND2 2
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPIE 7
|
||||
#define SPE 6
|
||||
#define DORD 5
|
||||
#define MSTR 4
|
||||
#define CPOL 3
|
||||
#define CPHA 2
|
||||
#define SPR1 1
|
||||
#define SPR0 0
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPIF 7
|
||||
#define WCOL 6
|
||||
|
||||
/* UART Status Register */
|
||||
#define RXC 7
|
||||
#define TXC 6
|
||||
#define UDRE 5
|
||||
#define FE 4
|
||||
#define DOR 3
|
||||
|
||||
/* UART Control Register */
|
||||
#define RXCIE 7
|
||||
#define TXCIE 6
|
||||
#define UDRIE 5
|
||||
#define RXEN 4
|
||||
#define TXEN 3
|
||||
#define CHR9 2
|
||||
#define RXB8 1
|
||||
#define TXB8 0
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACD 7
|
||||
#define ACO 5
|
||||
#define ACI 4
|
||||
#define ACIE 3
|
||||
#define ACIC 2
|
||||
#define ACIS1 1
|
||||
#define ACIS0 0
|
||||
|
||||
/* ADC MUX */
|
||||
#define MUX2 2
|
||||
#define MUX1 1
|
||||
#define MUX0 0
|
||||
|
||||
/* ADC Control and Status Register */
|
||||
#define ADEN 7
|
||||
#define ADSC 6
|
||||
#define ADFR 5
|
||||
#define ADIF 4
|
||||
#define ADIE 3
|
||||
#define ADPS2 2
|
||||
#define ADPS1 1
|
||||
#define ADPS0 0
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EERIE 3
|
||||
#define EEMWE 2
|
||||
#define EEWE 1
|
||||
#define EERE 0
|
||||
|
||||
/* Constants */
|
||||
#define RAMEND 0x15F /*Last On-Chip SRAM location*/
|
||||
#define XRAMEND 0x15F
|
||||
#define E2END 0xFF
|
||||
#define E2PAGESIZE 0
|
||||
#define FLASHEND 0xFFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
#define FUSE_MEMORY_SIZE 1
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_SPIEN ~_BV(1) /* Serial Program Downloading Enabled */
|
||||
#define FUSE_FSTRT ~_BV(2) /* Short Start-up time selected */
|
||||
#define LFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x93
|
||||
#define SIGNATURE_2 0x03
|
||||
|
||||
|
||||
#endif /* _AVR_IO4434_H_ */
|
1558
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io58u54a.h
Normal file
1558
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io58u54a.h
Normal file
File diff suppressed because it is too large
Load diff
|
@ -0,0 +1,493 @@
|
|||
/* Copyright (c) 2002, Marek Michalkiewicz
|
||||
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: io76c711.h,v 1.5 2004/11/01 21:19:54 arcanum Exp $ */
|
||||
|
||||
/* avr/io76c711.h - definitions for AT76C711 */
|
||||
|
||||
#ifndef _AVR_IO76C711_H_
|
||||
#define _AVR_IO76C711_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_ "io76c711.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* 0x00-0x0C reserved */
|
||||
|
||||
/* SPI */
|
||||
#define SPCR _SFR_IO8(0x0D)
|
||||
#define SPSR _SFR_IO8(0x0E)
|
||||
#define SPDR _SFR_IO8(0x0F)
|
||||
|
||||
/* Port D */
|
||||
#define PIND _SFR_IO8(0x10)
|
||||
#define DDRD _SFR_IO8(0x11)
|
||||
#define PORTD _SFR_IO8(0x12)
|
||||
|
||||
/* Peripheral Enable Register */
|
||||
#define PERIPHEN _SFR_IO8(0x13)
|
||||
|
||||
/* Clock Control Register */
|
||||
#define CLK_CNTR _SFR_IO8(0x14)
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PORTC _SFR_IO8(0x15)
|
||||
|
||||
/* Port B */
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
|
||||
/* Port A */
|
||||
#define PINA _SFR_IO8(0x19)
|
||||
#define DDRA _SFR_IO8(0x1A)
|
||||
#define PORTA _SFR_IO8(0x1B)
|
||||
|
||||
/* 0x1C-0x1F reserved */
|
||||
|
||||
#define IRDAMOD _SFR_IO8(0x20)
|
||||
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
|
||||
/* 0x22-0x25 reserved */
|
||||
/* Timer 1 */
|
||||
#define ICR1 _SFR_IO16(0x26)
|
||||
#define ICR1L _SFR_IO8(0x26)
|
||||
#define ICR1H _SFR_IO8(0x27)
|
||||
#define OCR1B _SFR_IO16(0x28)
|
||||
#define OCR1BL _SFR_IO8(0x28)
|
||||
#define OCR1BH _SFR_IO8(0x29)
|
||||
#define OCR1A _SFR_IO16(0x2A)
|
||||
#define OCR1AL _SFR_IO8(0x2A)
|
||||
#define OCR1AH _SFR_IO8(0x2B)
|
||||
#define TCNT1 _SFR_IO16(0x2C)
|
||||
#define TCNT1L _SFR_IO8(0x2C)
|
||||
#define TCNT1H _SFR_IO8(0x2D)
|
||||
#define TCCR1B _SFR_IO8(0x2E)
|
||||
#define TCCR1A _SFR_IO8(0x2F)
|
||||
|
||||
/* 0x30 reserved */
|
||||
|
||||
/* Timer 0 */
|
||||
#define PRELD _SFR_IO8(0x31)
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
#define TIFR _SFR_IO8(0x36)
|
||||
#define TIMSK _SFR_IO8(0x37)
|
||||
|
||||
/* 0x38 reserved */
|
||||
|
||||
#define EIMSK _SFR_IO8(0x39)
|
||||
|
||||
/* 0x3A-0x3C reserved */
|
||||
|
||||
/* 0x3D..0x3E SP */
|
||||
|
||||
/* 0x3F SREG */
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
#define SIG_SUSPEND_RESUME _VECTOR(1)
|
||||
#define SIG_INTERRUPT0 _VECTOR(2)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(3)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(4)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(5)
|
||||
#define SIG_OVERFLOW1 _VECTOR(6)
|
||||
#define SIG_OVERFLOW0 _VECTOR(7)
|
||||
#define SIG_SPI _VECTOR(8)
|
||||
#define SIG_TDMAC _VECTOR(9)
|
||||
#define SIG_UART0 _VECTOR(10)
|
||||
#define SIG_RDMAC _VECTOR(11)
|
||||
#define SIG_USB_HW _VECTOR(12)
|
||||
#define SIG_UART1 _VECTOR(13)
|
||||
#define SIG_INTERRUPT1 _VECTOR(14)
|
||||
|
||||
#define _VECTORS_SIZE 60
|
||||
|
||||
/* Bit numbers */
|
||||
|
||||
/* EIMSK */
|
||||
/* bits 7-4 reserved */
|
||||
#define POL1 3
|
||||
#define POL0 2
|
||||
#define INT1 1
|
||||
#define INT0 0
|
||||
|
||||
/* TIMSK */
|
||||
#define TOIE1 7
|
||||
#define OCIE1A 6
|
||||
#define OCIE1B 5
|
||||
/* bit 4 reserved */
|
||||
#define TICIE1 3
|
||||
/* bit 2 reserved */
|
||||
#define TOIE0 1
|
||||
/* bit 0 reserved */
|
||||
|
||||
/* TIFR */
|
||||
#define TOV1 7
|
||||
#define OCF1A 6
|
||||
#define OCF1B 5
|
||||
/* bit 4 reserved */
|
||||
#define ICF1 3
|
||||
/* bit 2 reserved */
|
||||
#define TOV0 1
|
||||
/* bit 0 reserved */
|
||||
|
||||
/* MCUCR */
|
||||
/* bits 7-6 reserved */
|
||||
#define SE 5
|
||||
#define SM1 4
|
||||
#define SM0 3
|
||||
/* bits 2-0 reserved */
|
||||
|
||||
/* MCUSR */
|
||||
/* bits 7-2 reserved */
|
||||
#define EXTRF 1
|
||||
#define PORF 0
|
||||
|
||||
/* TCCR0 */
|
||||
/* bits 7-6 reserved */
|
||||
#define COM01 5
|
||||
#define COM00 4
|
||||
#define CTC0 3
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/* TCCR1A */
|
||||
#define COM1A1 7
|
||||
#define COM1A0 6
|
||||
#define COM1B1 5
|
||||
#define COM1B0 4
|
||||
/* bits 3-0 reserved */
|
||||
|
||||
/* TCCR1B */
|
||||
#define ICNC1 7
|
||||
#define ICES1 6
|
||||
/* bits 5-4 reserved */
|
||||
#define CTC1 3
|
||||
#define CS12 2
|
||||
#define CS11 1
|
||||
#define CS10 0
|
||||
|
||||
/* WDTCR */
|
||||
/* bits 7-5 reserved */
|
||||
#define WDTOE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/* IRDAMOD */
|
||||
/* bits 7-3 reserved */
|
||||
#define POL 2
|
||||
#define MODE 1
|
||||
#define EN 0
|
||||
|
||||
/* PORTA */
|
||||
#define PA7 7
|
||||
#define PA6 6
|
||||
#define PA5 5
|
||||
#define PA4 4
|
||||
#define PA3 3
|
||||
#define PA2 2
|
||||
#define PA1 1
|
||||
#define PA0 0
|
||||
|
||||
/* DDRA */
|
||||
#define DDA7 7
|
||||
#define DDA6 6
|
||||
#define DDA5 5
|
||||
#define DDA4 4
|
||||
#define DDA3 3
|
||||
#define DDA2 2
|
||||
#define DDA1 1
|
||||
#define DDA0 0
|
||||
|
||||
/* PINA */
|
||||
#define PINA7 7
|
||||
#define PINA6 6
|
||||
#define PINA5 5
|
||||
#define PINA4 4
|
||||
#define PINA3 3
|
||||
#define PINA2 2
|
||||
#define PINA1 1
|
||||
#define PINA0 0
|
||||
|
||||
/*
|
||||
PB7 = SCK
|
||||
PB6 = MISO
|
||||
PB5 = MOSI
|
||||
PB4 = SS#
|
||||
PB2 = ICP
|
||||
PB1 = T1
|
||||
PB0 = T0
|
||||
*/
|
||||
|
||||
/* PORTB */
|
||||
#define PB7 7
|
||||
#define PB6 6
|
||||
#define PB5 5
|
||||
#define PB4 4
|
||||
#define PB3 3
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
/* DDRB */
|
||||
#define DDB7 7
|
||||
#define DDB6 6
|
||||
#define DDB5 5
|
||||
#define DDB4 4
|
||||
#define DDB3 3
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
/* PINB */
|
||||
#define PINB7 7
|
||||
#define PINB6 6
|
||||
#define PINB5 5
|
||||
#define PINB4 4
|
||||
#define PINB3 3
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
/* PORTC */
|
||||
/* bits 7-4 reserved */
|
||||
#define PC3 3
|
||||
#define PC2 2
|
||||
#define PC1 1
|
||||
#define PC0 0
|
||||
|
||||
/*
|
||||
PD7 = INT1 / OC1B
|
||||
PD6 = INT0 / OC1A
|
||||
PD1 = TXD
|
||||
PD0 = RXD
|
||||
*/
|
||||
|
||||
/* PORTD */
|
||||
#define PD7 7
|
||||
#define PD6 6
|
||||
#define PD5 5
|
||||
#define PD4 4
|
||||
#define PD3 3
|
||||
#define PD2 2
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
/* DDRD */
|
||||
#define DDD7 7
|
||||
#define DDD6 6
|
||||
#define DDD5 5
|
||||
#define DDD4 4
|
||||
#define DDD3 3
|
||||
#define DDD2 2
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
/* PIND */
|
||||
#define PIND7 7
|
||||
#define PIND6 6
|
||||
#define PIND5 5
|
||||
#define PIND4 4
|
||||
#define PIND3 3
|
||||
#define PIND2 2
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
/* CLK_CNTR */
|
||||
/* bits 7-5 reserved */
|
||||
#define UOSC 4
|
||||
#define UCK 3
|
||||
#define IRCK 2
|
||||
/* bits 1-0 reserved */
|
||||
|
||||
/* PERIPHEN */
|
||||
/* bits 7-3 reserved */
|
||||
#define IRDA 2
|
||||
#define UART 1
|
||||
#define USB 0
|
||||
|
||||
/* SPSR */
|
||||
#define SPIF 7
|
||||
#define WCOL 6
|
||||
/* bits 5-0 reserved */
|
||||
|
||||
/* SPCR */
|
||||
#define SPIE 7
|
||||
#define SPE 6
|
||||
#define DORD 5
|
||||
#define MSTR 4
|
||||
#define CPOL 3
|
||||
#define CPHA 2
|
||||
#define SPR1 1
|
||||
#define SPR0 0
|
||||
|
||||
/* Memory mapped registers (XXX - not yet changed to use _SFR_MEM8() macros) */
|
||||
|
||||
/* UART */
|
||||
#define UART0_BASE 0x2020
|
||||
#define UART1_BASE 0x2030
|
||||
/* offsets from the base address */
|
||||
#define US_RHR 0x00
|
||||
#define US_THR 0x00
|
||||
#define US_IER 0x01
|
||||
#define US_FCR 0x02
|
||||
#define US_PMR 0x03
|
||||
#define US_MR 0x04
|
||||
#define US_CSR 0x05
|
||||
#define US_CR 0x06
|
||||
#define US_BL 0x07
|
||||
#define US_BM 0x08
|
||||
#define US_RTO 0x09
|
||||
#define US_TTG 0x0A
|
||||
|
||||
/* DMA */
|
||||
#define DMA_BASE 0x2000
|
||||
/* offsets from the base address */
|
||||
#define TXTADL 0x01
|
||||
#define TXPLL 0x03
|
||||
#define TXPLM 0x04
|
||||
#define TXTPLL 0x05
|
||||
#define TXTPLM 0x06
|
||||
#define RXTADL 0x07
|
||||
#define RXTADMEN 0x08
|
||||
#define RSPLL 0x09
|
||||
#define RXPLM 0x0A
|
||||
#define RXTPLL 0x0B
|
||||
#define RXTPLM 0x0C
|
||||
#define INTCST 0x0D
|
||||
/* XXX DPORG register mentioned on page 20, but undocumented */
|
||||
|
||||
/* XXX Program Memory Control Bit mentioned on page 20, but undocumented */
|
||||
#define PROGRAM_MEMORY_CONTROL_BIT 0x2040
|
||||
|
||||
/* USB */
|
||||
#define USB_BASE 0x1000
|
||||
/* offsets from the base address */
|
||||
#define FRM_NUM_H 0x0FD
|
||||
#define FRM_NUM_L 0x0FC
|
||||
#define GLB_STATE 0x0FB
|
||||
#define SPRSR 0x0FA
|
||||
#define SPRSIE 0x0F9
|
||||
#define UISR 0x0F7
|
||||
#define UIAR 0x0F5
|
||||
#define FADDR 0x0F2
|
||||
#define ENDPPGPG 0x0F1
|
||||
#define ECR0 0x0EF
|
||||
#define ECR1 0x0EE
|
||||
#define ECR2 0x0ED
|
||||
#define ECR3 0x0EC
|
||||
#define ECR4 0x0EB
|
||||
#define ECR5 0x0EA
|
||||
#define ECR6 0x0E9
|
||||
#define ECR7 0x0E8
|
||||
#define CSR0 0x0DF
|
||||
#define CSR1 0x0DE
|
||||
#define CSR2 0x0DD
|
||||
#define CSR3 0x0DC
|
||||
#define CSR4 0x0DB
|
||||
#define CSR5 0x0DA
|
||||
#define CSR6 0x0D9
|
||||
#define CSR7 0x0D8
|
||||
#define FDR0 0x0CF
|
||||
#define FDR1 0x0CE
|
||||
#define FDR2 0x0CD
|
||||
#define FDR3 0x0CC
|
||||
#define FDR4 0x0CB
|
||||
#define FDR5 0x0CA
|
||||
#define FDR6 0x0C9
|
||||
#define FDR7 0x0C8
|
||||
#define FBYTE_CNT0_L 0x0BF
|
||||
#define FBYTE_CNT1_L 0x0BE
|
||||
#define FBYTE_CNT2_L 0x0BD
|
||||
#define FBYTE_CNT3_L 0x0BC
|
||||
#define FBYTE_CNT4_L 0x0BB
|
||||
#define FBYTE_CNT5_L 0x0BA
|
||||
#define FBYTE_CNT6_L 0x0B9
|
||||
#define FBYTE_CNT7_L 0x0B8
|
||||
#define FBYTE_CNT0_H 0x0AF
|
||||
#define FBYTE_CNT1_H 0x0AE
|
||||
#define FBYTE_CNT2_H 0x0AD
|
||||
#define FBYTE_CNT3_H 0x0AC
|
||||
#define FBYTE_CNT4_H 0x0AB
|
||||
#define FBYTE_CNT5_H 0x0AA
|
||||
#define FBYTE_CNT6_H 0x0A9
|
||||
#define FBYTE_CNT7_H 0x0A8
|
||||
#define SLP_MD_EN 0x100
|
||||
#define IRQ_EN 0x101
|
||||
#define IRQ_STAT 0x102
|
||||
#define SUSP_WUP 0x103
|
||||
#define PA_EN 0x104
|
||||
#define USB_DMA_ADL 0x105
|
||||
#define USB_DMA_ADH 0x106
|
||||
#define USB_DMA_PLR 0x107
|
||||
#define USB_DMA_EAD 0x108
|
||||
#define USB_DMA_PLT 0x109
|
||||
#define USB_DMA_EN 0x10A
|
||||
|
||||
/* Last memory addresses */
|
||||
#define RAMEND 0x07FF
|
||||
#define XRAMEND 0x07FF
|
||||
#define E2END 0
|
||||
#define FLASHEND 0x3FFF
|
||||
|
||||
/*
|
||||
AT76C711 data space memory map (ranges not listed are reserved):
|
||||
0x0000 - 0x001F - AVR registers
|
||||
0x0020 - 0x005F - AVR I/O space
|
||||
0x0060 - 0x07FF - AVR data SRAM
|
||||
0x1000 - 0x1FFF - USB (not all locations used)
|
||||
0x2000 - 0x201F - DMA controller
|
||||
0x2020 - 0x202F - UART0
|
||||
0x2030 - 0x203F - UART1 (IRDA)
|
||||
0x2040 - the mysterious Program Memory Control bit (???)
|
||||
0x3000 - 0x37FF - DPRAM
|
||||
0x8000 - 0xBFFF - program SRAM (read/write), would be nice if other
|
||||
AVR devices did that as well (no need to use LPM!)
|
||||
*/
|
||||
#endif /* _AVR_IO76C711_H_ */
|
486
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io8515.h
Normal file
486
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io8515.h
Normal file
|
@ -0,0 +1,486 @@
|
|||
/* Copyright (c) 2002, Marek Michalkiewicz
|
||||
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: io8515.h,v 1.8.4.2 2008/08/14 00:07:59 arcanum Exp $ */
|
||||
|
||||
/* avr/io8515.h - definitions for AT90S8515 */
|
||||
|
||||
#ifndef _AVR_IO8515_H_
|
||||
#define _AVR_IO8515_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_ "io8515.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACSR _SFR_IO8(0x08)
|
||||
|
||||
/* UART Baud Rate Register */
|
||||
#define UBRR _SFR_IO8(0x09)
|
||||
|
||||
/* UART Control Register */
|
||||
#define UCR _SFR_IO8(0x0A)
|
||||
|
||||
/* UART Status Register */
|
||||
#define USR _SFR_IO8(0x0B)
|
||||
|
||||
/* UART I/O Data Register */
|
||||
#define UDR _SFR_IO8(0x0C)
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPCR _SFR_IO8(0x0D)
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPSR _SFR_IO8(0x0E)
|
||||
|
||||
/* SPI I/O Data Register */
|
||||
#define SPDR _SFR_IO8(0x0F)
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND _SFR_IO8(0x10)
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDRD _SFR_IO8(0x11)
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PORTD _SFR_IO8(0x12)
|
||||
|
||||
/* Input Pins, Port C */
|
||||
#define PINC _SFR_IO8(0x13)
|
||||
|
||||
/* Data Direction Register, Port C */
|
||||
#define DDRC _SFR_IO8(0x14)
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PORTC _SFR_IO8(0x15)
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
|
||||
/* Input Pins, Port A */
|
||||
#define PINA _SFR_IO8(0x19)
|
||||
|
||||
/* Data Direction Register, Port A */
|
||||
#define DDRA _SFR_IO8(0x1A)
|
||||
|
||||
/* Data Register, Port A */
|
||||
#define PORTA _SFR_IO8(0x1B)
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EECR _SFR_IO8(0x1C)
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define EEDR _SFR_IO8(0x1D)
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#define EEAR _SFR_IO16(0x1E)
|
||||
#define EEARL _SFR_IO8(0x1E)
|
||||
#define EEARH _SFR_IO8(0x1F)
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
|
||||
/* T/C 1 Input Capture Register */
|
||||
#define ICR1 _SFR_IO16(0x24)
|
||||
#define ICR1L _SFR_IO8(0x24)
|
||||
#define ICR1H _SFR_IO8(0x25)
|
||||
|
||||
/* Timer/Counter1 Output Compare Register B */
|
||||
#define OCR1B _SFR_IO16(0x28)
|
||||
#define OCR1BL _SFR_IO8(0x28)
|
||||
#define OCR1BH _SFR_IO8(0x29)
|
||||
|
||||
/* Timer/Counter1 Output Compare Register A */
|
||||
#define OCR1A _SFR_IO16(0x2A)
|
||||
#define OCR1AL _SFR_IO8(0x2A)
|
||||
#define OCR1AH _SFR_IO8(0x2B)
|
||||
|
||||
/* Timer/Counter 1 */
|
||||
#define TCNT1 _SFR_IO16(0x2C)
|
||||
#define TCNT1L _SFR_IO8(0x2C)
|
||||
#define TCNT1H _SFR_IO8(0x2D)
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define TCCR1B _SFR_IO8(0x2E)
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define TCCR1A _SFR_IO8(0x2F)
|
||||
|
||||
/* Timer/Counter 0 */
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
/* Timer/Counter Interrupt Flag register */
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define GIFR _SFR_IO8(0x3A)
|
||||
|
||||
/* General Interrupt MaSK register */
|
||||
#define GIMSK _SFR_IO8(0x3B)
|
||||
|
||||
/* 0x3D..0x3E SP */
|
||||
|
||||
/* 0x3F SREG */
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
/* 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)
|
||||
|
||||
/* Timer/Counter Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(3)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(3)
|
||||
|
||||
/* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPA_vect _VECTOR(4)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(4)
|
||||
|
||||
/* Timer/Counter1 Compare MatchB */
|
||||
#define TIMER1_COMPB_vect _VECTOR(5)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(5)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(6)
|
||||
#define SIG_OVERFLOW1 _VECTOR(6)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(7)
|
||||
#define SIG_OVERFLOW0 _VECTOR(7)
|
||||
|
||||
/* Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(8)
|
||||
#define SIG_SPI _VECTOR(8)
|
||||
|
||||
/* UART, Rx Complete */
|
||||
#define UART_RX_vect _VECTOR(9)
|
||||
#define SIG_UART_RECV _VECTOR(9)
|
||||
|
||||
/* UART Data Register Empty */
|
||||
#define UART_UDRE_vect _VECTOR(10)
|
||||
#define SIG_UART_DATA _VECTOR(10)
|
||||
|
||||
/* UART, Tx Complete */
|
||||
#define UART_TX_vect _VECTOR(11)
|
||||
#define SIG_UART_TRANS _VECTOR(11)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANA_COMP_vect _VECTOR(12)
|
||||
#define SIG_COMPARATOR _VECTOR(12)
|
||||
|
||||
#define _VECTORS_SIZE 26
|
||||
|
||||
/*
|
||||
The Register Bit names are represented by their bit number (0-7).
|
||||
*/
|
||||
|
||||
/* General Interrupt MaSK register */
|
||||
#define INT1 7
|
||||
#define INT0 6
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define INTF1 7
|
||||
#define INTF0 6
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define TOIE1 7
|
||||
#define OCIE1A 6
|
||||
#define OCIE1B 5
|
||||
#define TICIE1 3
|
||||
#define TOIE0 1
|
||||
|
||||
/* Timer/Counter Interrupt Flag register */
|
||||
#define TOV1 7
|
||||
#define OCF1A 6
|
||||
#define OCF1B 5
|
||||
#define ICF1 3
|
||||
#define TOV0 1
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define SRE 7
|
||||
#define SRW 6
|
||||
#define SE 5
|
||||
#define SM 4
|
||||
#define ISC11 3
|
||||
#define ISC10 2
|
||||
#define ISC01 1
|
||||
#define ISC00 0
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define COM1A1 7
|
||||
#define COM1A0 6
|
||||
#define COM1B1 5
|
||||
#define COM1B0 4
|
||||
#define PWM11 1
|
||||
#define PWM10 0
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define ICNC1 7
|
||||
#define ICES1 6
|
||||
#define CTC1 3
|
||||
#define CS12 2
|
||||
#define CS11 1
|
||||
#define CS10 0
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTOE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/* Data Register, Port A */
|
||||
#define PA7 7
|
||||
#define PA6 6
|
||||
#define PA5 5
|
||||
#define PA4 4
|
||||
#define PA3 3
|
||||
#define PA2 2
|
||||
#define PA1 1
|
||||
#define PA0 0
|
||||
|
||||
/* Data Direction Register, Port A */
|
||||
#define DDA7 7
|
||||
#define DDA6 6
|
||||
#define DDA5 5
|
||||
#define DDA4 4
|
||||
#define DDA3 3
|
||||
#define DDA2 2
|
||||
#define DDA1 1
|
||||
#define DDA0 0
|
||||
|
||||
/* Input Pins, Port A */
|
||||
#define PINA7 7
|
||||
#define PINA6 6
|
||||
#define PINA5 5
|
||||
#define PINA4 4
|
||||
#define PINA3 3
|
||||
#define PINA2 2
|
||||
#define PINA1 1
|
||||
#define PINA0 0
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PB7 7
|
||||
#define PB6 6
|
||||
#define PB5 5
|
||||
#define PB4 4
|
||||
#define PB3 3
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDB7 7
|
||||
#define DDB6 6
|
||||
#define DDB5 5
|
||||
#define DDB4 4
|
||||
#define DDB3 3
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB7 7
|
||||
#define PINB6 6
|
||||
#define PINB5 5
|
||||
#define PINB4 4
|
||||
#define PINB3 3
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PC7 7
|
||||
#define PC6 6
|
||||
#define PC5 5
|
||||
#define PC4 4
|
||||
#define PC3 3
|
||||
#define PC2 2
|
||||
#define PC1 1
|
||||
#define PC0 0
|
||||
|
||||
/* Data Direction Register, Port C */
|
||||
#define DDC7 7
|
||||
#define DDC6 6
|
||||
#define DDC5 5
|
||||
#define DDC4 4
|
||||
#define DDC3 3
|
||||
#define DDC2 2
|
||||
#define DDC1 1
|
||||
#define DDC0 0
|
||||
|
||||
/* Input Pins, Port C */
|
||||
#define PINC7 7
|
||||
#define PINC6 6
|
||||
#define PINC5 5
|
||||
#define PINC4 4
|
||||
#define PINC3 3
|
||||
#define PINC2 2
|
||||
#define PINC1 1
|
||||
#define PINC0 0
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PD7 7
|
||||
#define PD6 6
|
||||
#define PD5 5
|
||||
#define PD4 4
|
||||
#define PD3 3
|
||||
#define PD2 2
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDD7 7
|
||||
#define DDD6 6
|
||||
#define DDD5 5
|
||||
#define DDD4 4
|
||||
#define DDD3 3
|
||||
#define DDD2 2
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND7 7
|
||||
#define PIND6 6
|
||||
#define PIND5 5
|
||||
#define PIND4 4
|
||||
#define PIND3 3
|
||||
#define PIND2 2
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPIF 7
|
||||
#define WCOL 6
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPIE 7
|
||||
#define SPE 6
|
||||
#define DORD 5
|
||||
#define MSTR 4
|
||||
#define CPOL 3
|
||||
#define CPHA 2
|
||||
#define SPR1 1
|
||||
#define SPR0 0
|
||||
|
||||
/* UART Status Register */
|
||||
#define RXC 7
|
||||
#define TXC 6
|
||||
#define UDRE 5
|
||||
#define FE 4
|
||||
#define DOR 3
|
||||
|
||||
/* UART Control Register */
|
||||
#define RXCIE 7
|
||||
#define TXCIE 6
|
||||
#define UDRIE 5
|
||||
#define RXEN 4
|
||||
#define TXEN 3
|
||||
#define CHR9 2
|
||||
#define RXB8 1
|
||||
#define TXB8 0
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACD 7
|
||||
#define ACO 5
|
||||
#define ACI 4
|
||||
#define ACIE 3
|
||||
#define ACIC 2
|
||||
#define ACIS1 1
|
||||
#define ACIS0 0
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EERIE 3
|
||||
#define EEMWE 2
|
||||
#define EEWE 1
|
||||
#define EERE 0
|
||||
|
||||
/* Constants */
|
||||
#define RAMEND 0x25F /* Last On-Chip SRAM Location */
|
||||
#define XRAMEND 0xFFFF
|
||||
#define E2END 0x1FF
|
||||
#define E2PAGESIZE 0
|
||||
#define FLASHEND 0x1FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
#define FUSE_MEMORY_SIZE 1
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_SPIEN ~_BV(1) /* Serial Program Downloading Enabled */
|
||||
#define FUSE_FSTRT ~_BV(2) /* Short Start-up time selected */
|
||||
#define LFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x93
|
||||
#define SIGNATURE_2 0x01
|
||||
|
||||
|
||||
#endif /* _AVR_IO8515_H_ */
|
216
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io8534.h
Normal file
216
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io8534.h
Normal file
|
@ -0,0 +1,216 @@
|
|||
/* Copyright (c) 2002, Marek Michalkiewicz
|
||||
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: io8534.h,v 1.7 2005/07/09 14:01:11 aesok Exp $ */
|
||||
|
||||
/* avr/io8534.h - definitions for AT90C8534 */
|
||||
|
||||
#ifndef _AVR_IO8534_
|
||||
#define _AVR_IO8534_ 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_ "io8534.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* 0x00..0x03 reserved */
|
||||
|
||||
/* ADC Data Register */
|
||||
#ifndef __ASSEMBLER__
|
||||
#define ADC _SFR_IO16(0x04)
|
||||
#endif
|
||||
#define ADCW _SFR_IO16(0x04)
|
||||
#define ADCL _SFR_IO8(0x04)
|
||||
#define ADCH _SFR_IO8(0x05)
|
||||
|
||||
/* ADC Control and Status Register */
|
||||
#define ADCSR _SFR_IO8(0x06)
|
||||
|
||||
/* ADC Multiplexer Select Register */
|
||||
#define ADMUX _SFR_IO8(0x07)
|
||||
|
||||
/* 0x08..0x0F reserved */
|
||||
|
||||
/* General Interrupt Pin Register */
|
||||
#define GIPR _SFR_IO8(0x10)
|
||||
|
||||
/* 0x11..0x19 reserved */
|
||||
|
||||
/* Data Direction Register, Port A */
|
||||
#define DDRA _SFR_IO8(0x1A)
|
||||
|
||||
/* Data Register, Port A */
|
||||
#define PORTA _SFR_IO8(0x1B)
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EECR _SFR_IO8(0x1C)
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define EEDR _SFR_IO8(0x1D)
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#define EEAR _SFR_IO16(0x1E)
|
||||
#define EEARL _SFR_IO8(0x1E)
|
||||
#define EEARH _SFR_IO8(0x1F)
|
||||
|
||||
/* 0x20..0x2B reserved */
|
||||
|
||||
/* Timer/Counter1 */
|
||||
#define TCNT1 _SFR_IO16(0x2C)
|
||||
#define TCNT1L _SFR_IO8(0x2C)
|
||||
#define TCNT1H _SFR_IO8(0x2D)
|
||||
|
||||
/* Timer/Counter1 Control Register */
|
||||
#define TCCR1 _SFR_IO8(0x2E)
|
||||
|
||||
/* 0x2F..0x31 reserved */
|
||||
|
||||
/* Timer/Counter0 (8-bit) */
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
|
||||
/* Timer/Counter0 Control Register */
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
/* 0x34 reserved */
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
/* 0x36..0x37 reserved */
|
||||
|
||||
/* Timer/Counter Interrupt Flag Register */
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
|
||||
/* Timer/Counter Interrupt MaSK Register */
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define GIFR _SFR_IO8(0x3A)
|
||||
|
||||
/* General Interrupt MaSK register */
|
||||
#define GIMSK _SFR_IO8(0x3B)
|
||||
|
||||
/* 0x3C reserved */
|
||||
|
||||
/* 0x3D..0x3E SP */
|
||||
|
||||
/* 0x3F SREG */
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
#define SIG_INTERRUPT0 _VECTOR(1)
|
||||
#define SIG_INTERRUPT1 _VECTOR(2)
|
||||
#define SIG_OVERFLOW1 _VECTOR(3)
|
||||
#define SIG_OVERFLOW0 _VECTOR(4)
|
||||
#define SIG_ADC _VECTOR(5)
|
||||
#define SIG_EEPROM_READY _VECTOR(6)
|
||||
|
||||
#define _VECTORS_SIZE 14
|
||||
|
||||
/* Bit numbers */
|
||||
|
||||
/* GIMSK */
|
||||
#define INT1 7
|
||||
#define INT0 6
|
||||
|
||||
/* GIFR */
|
||||
#define INTF1 7
|
||||
#define INTF0 6
|
||||
|
||||
/* GIPR */
|
||||
#define IPIN1 3
|
||||
#define IPIN0 2
|
||||
|
||||
/* TIMSK */
|
||||
#define TOIE1 2
|
||||
#define TOIE0 0
|
||||
|
||||
/* TIFR */
|
||||
#define TOV1 2
|
||||
#define TOV0 0
|
||||
|
||||
/* MCUCR */
|
||||
#define SE 6
|
||||
#define SM 5
|
||||
#define ISC1 2
|
||||
#define ISC0 0
|
||||
|
||||
/* TCCR0 */
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/* TCCR1 */
|
||||
#define CS12 2
|
||||
#define CS11 1
|
||||
#define CS10 0
|
||||
|
||||
/* PORTA */
|
||||
#define PA7 7
|
||||
#define PA6 6
|
||||
#define PA5 5
|
||||
#define PA4 4
|
||||
#define PA3 3
|
||||
#define PA2 2
|
||||
#define PA1 1
|
||||
#define PA0 0
|
||||
|
||||
/* DDRA */
|
||||
#define DDA7 7
|
||||
#define DDA6 6
|
||||
#define DDA5 5
|
||||
#define DDA4 4
|
||||
#define DDA3 3
|
||||
#define DDA2 2
|
||||
#define DDA1 1
|
||||
#define DDA0 0
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EERIE 3
|
||||
#define EEMWE 2
|
||||
#define EEWE 1
|
||||
#define EERE 0
|
||||
|
||||
/* Last memory addresses */
|
||||
#define RAMEND 0x15F
|
||||
#define XRAMEND 0x15F
|
||||
#define E2END 0x1FF
|
||||
#define FLASHEND 0x1FFF
|
||||
|
||||
#endif /* _AVR_IO8534_H_ */
|
568
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io8535.h
Normal file
568
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io8535.h
Normal file
|
@ -0,0 +1,568 @@
|
|||
/* Copyright (c) 2002, Marek Michalkiewicz
|
||||
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: io8535.h,v 1.9.4.3 2008/08/14 00:07:59 arcanum Exp $ */
|
||||
|
||||
/* avr/io8535.h - definitions for AT90S8535 */
|
||||
|
||||
#ifndef _AVR_IO8535_H_
|
||||
#define _AVR_IO8535_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_ "io8535.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* ADC Data register */
|
||||
#ifndef __ASSEMBLER__
|
||||
#define ADC _SFR_IO16(0x04)
|
||||
#endif
|
||||
#define ADCW _SFR_IO16(0x04)
|
||||
#define ADCL _SFR_IO8(0x04)
|
||||
#define ADCH _SFR_IO8(0x05)
|
||||
|
||||
/* ADC Control and Status Register */
|
||||
#define ADCSR _SFR_IO8(0x06)
|
||||
|
||||
/* ADC MUX */
|
||||
#define ADMUX _SFR_IO8(0x07)
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACSR _SFR_IO8(0x08)
|
||||
|
||||
/* UART Baud Rate Register */
|
||||
#define UBRR _SFR_IO8(0x09)
|
||||
|
||||
/* UART Control Register */
|
||||
#define UCR _SFR_IO8(0x0A)
|
||||
|
||||
/* UART Status Register */
|
||||
#define USR _SFR_IO8(0x0B)
|
||||
|
||||
/* UART I/O Data Register */
|
||||
#define UDR _SFR_IO8(0x0C)
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPCR _SFR_IO8(0x0D)
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPSR _SFR_IO8(0x0E)
|
||||
|
||||
/* SPI I/O Data Register */
|
||||
#define SPDR _SFR_IO8(0x0F)
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND _SFR_IO8(0x10)
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDRD _SFR_IO8(0x11)
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PORTD _SFR_IO8(0x12)
|
||||
|
||||
/* Input Pins, Port C */
|
||||
#define PINC _SFR_IO8(0x13)
|
||||
|
||||
/* Data Direction Register, Port C */
|
||||
#define DDRC _SFR_IO8(0x14)
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PORTC _SFR_IO8(0x15)
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
|
||||
/* Input Pins, Port A */
|
||||
#define PINA _SFR_IO8(0x19)
|
||||
|
||||
/* Data Direction Register, Port A */
|
||||
#define DDRA _SFR_IO8(0x1A)
|
||||
|
||||
/* Data Register, Port A */
|
||||
#define PORTA _SFR_IO8(0x1B)
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EECR _SFR_IO8(0x1C)
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define EEDR _SFR_IO8(0x1D)
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#define EEAR _SFR_IO16(0x1E)
|
||||
#define EEARL _SFR_IO8(0x1E)
|
||||
#define EEARH _SFR_IO8(0x1F)
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
|
||||
/* Asynchronous mode Status Register */
|
||||
#define ASSR _SFR_IO8(0x22)
|
||||
|
||||
/* Timer/Counter2 Output Compare Register */
|
||||
#define OCR2 _SFR_IO8(0x23)
|
||||
|
||||
/* Timer/Counter 2 */
|
||||
#define TCNT2 _SFR_IO8(0x24)
|
||||
|
||||
/* Timer/Counter 2 Control Register */
|
||||
#define TCCR2 _SFR_IO8(0x25)
|
||||
|
||||
/* T/C 1 Input Capture Register */
|
||||
#define ICR1 _SFR_IO16(0x26)
|
||||
#define ICR1L _SFR_IO8(0x26)
|
||||
#define ICR1H _SFR_IO8(0x27)
|
||||
|
||||
/* Timer/Counter1 Output Compare Register B */
|
||||
#define OCR1B _SFR_IO16(0x28)
|
||||
#define OCR1BL _SFR_IO8(0x28)
|
||||
#define OCR1BH _SFR_IO8(0x29)
|
||||
|
||||
/* Timer/Counter1 Output Compare Register A */
|
||||
#define OCR1A _SFR_IO16(0x2A)
|
||||
#define OCR1AL _SFR_IO8(0x2A)
|
||||
#define OCR1AH _SFR_IO8(0x2B)
|
||||
|
||||
/* Timer/Counter 1 */
|
||||
#define TCNT1 _SFR_IO16(0x2C)
|
||||
#define TCNT1L _SFR_IO8(0x2C)
|
||||
#define TCNT1H _SFR_IO8(0x2D)
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define TCCR1B _SFR_IO8(0x2E)
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define TCCR1A _SFR_IO8(0x2F)
|
||||
|
||||
/* Timer/Counter 0 */
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
/* MCU general Status Register */
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
/* Timer/Counter Interrupt Flag register */
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define GIFR _SFR_IO8(0x3A)
|
||||
|
||||
/* General Interrupt MaSK register */
|
||||
#define GIMSK _SFR_IO8(0x3B)
|
||||
|
||||
/* 0x3D..0x3E SP */
|
||||
|
||||
/* 0x3F SREG */
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
/* External Interrupt 0 */
|
||||
#define INT0_vect _VECTOR(1)
|
||||
#define SIG_INTERRUPT0 _VECTOR(1)
|
||||
|
||||
/* External Interrupt 1 */
|
||||
#define INT1_vect _VECTOR(2)
|
||||
#define SIG_INTERRUPT1 _VECTOR(2)
|
||||
|
||||
/* Timer/Counter2 Compare Match */
|
||||
#define TIMER2_COMP_vect _VECTOR(3)
|
||||
#define SIG_OUTPUT_COMPARE2 _VECTOR(3)
|
||||
|
||||
/* Timer/Counter2 Overflow */
|
||||
#define TIMER2_OVF_vect _VECTOR(4)
|
||||
#define SIG_OVERFLOW2 _VECTOR(4)
|
||||
|
||||
/* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(5)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(5)
|
||||
|
||||
/* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPA_vect _VECTOR(6)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(6)
|
||||
|
||||
/* Timer/Counter1 Compare Match B */
|
||||
#define TIMER1_COMPB_vect _VECTOR(7)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(7)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(8)
|
||||
#define SIG_OVERFLOW1 _VECTOR(8)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(9)
|
||||
#define SIG_OVERFLOW0 _VECTOR(9)
|
||||
|
||||
/* SPI Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(10)
|
||||
#define SIG_SPI _VECTOR(10)
|
||||
|
||||
/* UART, RX Complete */
|
||||
#define UART_RX_vect _VECTOR(11)
|
||||
#define SIG_UART_RECV _VECTOR(11)
|
||||
|
||||
/* UART Data Register Empty */
|
||||
#define UART_UDRE_vect _VECTOR(12)
|
||||
#define SIG_UART_DATA _VECTOR(12)
|
||||
|
||||
/* UART, TX Complete */
|
||||
#define UART_TX_vect _VECTOR(13)
|
||||
#define SIG_UART_TRANS _VECTOR(13)
|
||||
|
||||
/* ADC Conversion Complete */
|
||||
#define ADC_vect _VECTOR(14)
|
||||
#define SIG_ADC _VECTOR(14)
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_RDY_vect _VECTOR(15)
|
||||
#define SIG_EEPROM_READY _VECTOR(15)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANA_COMP_vect _VECTOR(16)
|
||||
#define SIG_COMPARATOR _VECTOR(16)
|
||||
|
||||
#define _VECTORS_SIZE 34
|
||||
|
||||
/*
|
||||
The Register Bit names are represented by their bit number (0-7).
|
||||
*/
|
||||
|
||||
/* MCU general Status Register */
|
||||
#define EXTRF 1
|
||||
#define PORF 0
|
||||
|
||||
/* General Interrupt MaSK register */
|
||||
#define INT1 7
|
||||
#define INT0 6
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define INTF1 7
|
||||
#define INTF0 6
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define OCIE2 7
|
||||
#define TOIE2 6
|
||||
#define TICIE1 5
|
||||
#define OCIE1A 4
|
||||
#define OCIE1B 3
|
||||
#define TOIE1 2
|
||||
#define TOIE0 0
|
||||
|
||||
/* Timer/Counter Interrupt Flag register */
|
||||
#define OCF2 7
|
||||
#define TOV2 6
|
||||
#define ICF1 5
|
||||
#define OCF1A 4
|
||||
#define OCF1B 3
|
||||
#define TOV1 2
|
||||
#define TOV0 0
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define SE 6
|
||||
#define SM1 5
|
||||
#define SM0 4
|
||||
#define ISC11 3
|
||||
#define ISC10 2
|
||||
#define ISC01 1
|
||||
#define ISC00 0
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define COM1A1 7
|
||||
#define COM1A0 6
|
||||
#define COM1B1 5
|
||||
#define COM1B0 4
|
||||
#define PWM11 1
|
||||
#define PWM10 0
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define ICNC1 7
|
||||
#define ICES1 6
|
||||
#define CTC1 3
|
||||
#define CS12 2
|
||||
#define CS11 1
|
||||
#define CS10 0
|
||||
|
||||
/* Timer/Counter 2 Control Register */
|
||||
#define PWM2 6
|
||||
#define COM21 5
|
||||
#define COM20 4
|
||||
#define CTC2 3
|
||||
#define CS22 2
|
||||
#define CS21 1
|
||||
#define CS20 0
|
||||
|
||||
/* Asynchronous mode Status Register */
|
||||
#define AS2 3
|
||||
#define TCN2UB 2
|
||||
#define OCR2UB 1
|
||||
#define TCR2UB 0
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTOE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/* Data Register, Port A */
|
||||
#define PA7 7
|
||||
#define PA6 6
|
||||
#define PA5 5
|
||||
#define PA4 4
|
||||
#define PA3 3
|
||||
#define PA2 2
|
||||
#define PA1 1
|
||||
#define PA0 0
|
||||
|
||||
/* Data Direction Register, Port A */
|
||||
#define DDA7 7
|
||||
#define DDA6 6
|
||||
#define DDA5 5
|
||||
#define DDA4 4
|
||||
#define DDA3 3
|
||||
#define DDA2 2
|
||||
#define DDA1 1
|
||||
#define DDA0 0
|
||||
|
||||
/* Input Pins, Port A */
|
||||
#define PINA7 7
|
||||
#define PINA6 6
|
||||
#define PINA5 5
|
||||
#define PINA4 4
|
||||
#define PINA3 3
|
||||
#define PINA2 2
|
||||
#define PINA1 1
|
||||
#define PINA0 0
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PB7 7
|
||||
#define PB6 6
|
||||
#define PB5 5
|
||||
#define PB4 4
|
||||
#define PB3 3
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDB7 7
|
||||
#define DDB6 6
|
||||
#define DDB5 5
|
||||
#define DDB4 4
|
||||
#define DDB3 3
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB7 7
|
||||
#define PINB6 6
|
||||
#define PINB5 5
|
||||
#define PINB4 4
|
||||
#define PINB3 3
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PC7 7
|
||||
#define PC6 6
|
||||
#define PC5 5
|
||||
#define PC4 4
|
||||
#define PC3 3
|
||||
#define PC2 2
|
||||
#define PC1 1
|
||||
#define PC0 0
|
||||
|
||||
/* Data Direction Register, Port C */
|
||||
#define DDC7 7
|
||||
#define DDC6 6
|
||||
#define DDC5 5
|
||||
#define DDC4 4
|
||||
#define DDC3 3
|
||||
#define DDC2 2
|
||||
#define DDC1 1
|
||||
#define DDC0 0
|
||||
|
||||
/* Input Pins, Port C */
|
||||
#define PINC7 7
|
||||
#define PINC6 6
|
||||
#define PINC5 5
|
||||
#define PINC4 4
|
||||
#define PINC3 3
|
||||
#define PINC2 2
|
||||
#define PINC1 1
|
||||
#define PINC0 0
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PD7 7
|
||||
#define PD6 6
|
||||
#define PD5 5
|
||||
#define PD4 4
|
||||
#define PD3 3
|
||||
#define PD2 2
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDD7 7
|
||||
#define DDD6 6
|
||||
#define DDD5 5
|
||||
#define DDD4 4
|
||||
#define DDD3 3
|
||||
#define DDD2 2
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND7 7
|
||||
#define PIND6 6
|
||||
#define PIND5 5
|
||||
#define PIND4 4
|
||||
#define PIND3 3
|
||||
#define PIND2 2
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPIE 7
|
||||
#define SPE 6
|
||||
#define DORD 5
|
||||
#define MSTR 4
|
||||
#define CPOL 3
|
||||
#define CPHA 2
|
||||
#define SPR1 1
|
||||
#define SPR0 0
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPIF 7
|
||||
#define WCOL 6
|
||||
|
||||
/* UART Status Register */
|
||||
#define RXC 7
|
||||
#define TXC 6
|
||||
#define UDRE 5
|
||||
#define FE 4
|
||||
#define DOR 3
|
||||
|
||||
/* UART Control Register */
|
||||
#define RXCIE 7
|
||||
#define TXCIE 6
|
||||
#define UDRIE 5
|
||||
#define RXEN 4
|
||||
#define TXEN 3
|
||||
#define CHR9 2
|
||||
#define RXB8 1
|
||||
#define TXB8 0
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACD 7
|
||||
#define ACO 5
|
||||
#define ACI 4
|
||||
#define ACIE 3
|
||||
#define ACIC 2
|
||||
#define ACIS1 1
|
||||
#define ACIS0 0
|
||||
|
||||
/* ADC MUX */
|
||||
#define MUX2 2
|
||||
#define MUX1 1
|
||||
#define MUX0 0
|
||||
|
||||
/* ADC Control and Status Register */
|
||||
#define ADEN 7
|
||||
#define ADSC 6
|
||||
#define ADFR 5
|
||||
#define ADIF 4
|
||||
#define ADIE 3
|
||||
#define ADPS2 2
|
||||
#define ADPS1 1
|
||||
#define ADPS0 0
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EERIE 3
|
||||
#define EEMWE 2
|
||||
#define EEWE 1
|
||||
#define EERE 0
|
||||
|
||||
/* Constants */
|
||||
#define RAMEND 0x25F /*Last On-Chip SRAM location*/
|
||||
#define XRAMEND 0x25F
|
||||
#define E2END 0x1FF
|
||||
#define E2PAGESIZE 0
|
||||
#define FLASHEND 0x1FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
#define FUSE_MEMORY_SIZE 1
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(1) /* Serial Program Downloading Enabled */
|
||||
#define FUSE_FSTRT (unsigned char)~_BV(2) /* Short Start-up time selected */
|
||||
#define LFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x93
|
||||
#define SIGNATURE_2 0x03
|
||||
|
||||
|
||||
#endif /* _AVR_IO8535_H_ */
|
|
@ -0,0 +1,308 @@
|
|||
/* Copyright (c) 2002, Colin O'Flynn
|
||||
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. */
|
||||
|
||||
/* avr/io86r401.h - definitions for AT86RF401 */
|
||||
|
||||
#ifndef _AVR_IO86RF401_H_
|
||||
#define _AVR_IO86RF401_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_ "io86r401.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
#include <avr/sfr_defs.h>
|
||||
|
||||
/* Status REGister */
|
||||
#define SREG _SFR_IO8(0x3F)
|
||||
|
||||
/* Stack Pointer */
|
||||
#define SP _SFR_IO16(0x3D)
|
||||
#define SPH _SFR_IO8(0x3E)
|
||||
#define SPL _SFR_IO8(0x3D)
|
||||
|
||||
/*Battery low configeration register */
|
||||
#define BL_CONFIG _SFR_IO8(0x35)
|
||||
|
||||
/*Button detect register*/
|
||||
#define B_DET _SFR_IO8(0x34)
|
||||
|
||||
/*AVR Configeration register*/
|
||||
#define AVR_CONFIG _SFR_IO8(0x33)
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/*Data in register */
|
||||
#define IO_DATIN _SFR_IO8(0x32)
|
||||
|
||||
/*Data out register */
|
||||
#define IO_DATOUT _SFR_IO8(0x31)
|
||||
|
||||
/*IO Enable register */
|
||||
#define IO_ENAB _SFR_IO8(0x30)
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTCR _SFR_IO8(0x22)
|
||||
|
||||
/* Bit Timer Control Register */
|
||||
#define BTCR _SFR_IO8(0x21)
|
||||
|
||||
#define BTCNT _SFR_IO8(0x20)
|
||||
|
||||
/*
|
||||
NOTE: EEPROM name's changed to have D in front on them, per datasheet, but
|
||||
you may want to remove the leading D.
|
||||
*/
|
||||
/* EEPROM Control Register */
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#define DEEAR _SFR_IO8(0x1E)
|
||||
#define DEEARL _SFR_IO8(0x1E)
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define DEEDR _SFR_IO8(0x1D)
|
||||
/* EEPROM Control Register */
|
||||
#define DEECR _SFR_IO8(0x1C)
|
||||
|
||||
/* Lock Detector Configuration Register 2 */
|
||||
#define LOCKDET2 _SFR_IO8(0x17)
|
||||
|
||||
/* VCO Tuning Register*/
|
||||
#define VCOTUNE _SFR_IO8(0x16)
|
||||
|
||||
/* Power Attenuation Control Register */
|
||||
#define PWR_ATTEN _SFR_IO8(0x14)
|
||||
|
||||
/* Transmitter Control Register */
|
||||
#define TX_CNTL _SFR_IO8(0x12)
|
||||
|
||||
/* Lock Detector Configuration Register 1 */
|
||||
#define LOCKDET1 _SFR_IO8(0x10)
|
||||
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
/* Transmission Done, Bit Timer Flag 2 Interrupt */
|
||||
#define TXDONE_vect _VECTOR(1)
|
||||
#define SIG_TXDONE _VECTOR(1)
|
||||
|
||||
/* Transmit Buffer Empty, Bit Itmer Flag 0 Interrupt */
|
||||
#define TXEMPTY_vect _VECTOR(2)
|
||||
#define SIG_TXBE _VECTOR(2)
|
||||
|
||||
#define _VECTORS_SIZE 12
|
||||
|
||||
/*
|
||||
* The Register Bit names are represented by their bit number (0-7).
|
||||
*/
|
||||
|
||||
/* Lock Detector Configuration Register 1 - LOCKDET1 */
|
||||
#define UPOK 4
|
||||
#define ENKO 3
|
||||
#define BOD 2
|
||||
#define CS1 1
|
||||
#define CS0 0
|
||||
|
||||
/* Transmit Control Register - TX_CNTL */
|
||||
#define TXE 5
|
||||
#define TXK 4
|
||||
#define LOC 2
|
||||
|
||||
/* Power Attenuation Control Register - PWR_ATTEN */
|
||||
#define PCC2 5
|
||||
#define PCC1 4
|
||||
#define PCC0 3
|
||||
#define PCF2 2
|
||||
#define PCF1 1
|
||||
#define PCF0 0
|
||||
|
||||
/* VCO Tuning Register 6 - VCOTUNE --NOTE: [] removed from names*/
|
||||
#define VCOVDET1 7
|
||||
#define VCOVDET0 6
|
||||
#define VCOTUNE4 4
|
||||
#define VCOTUNE3 3
|
||||
#define VCOTUNE2 2
|
||||
#define VCOTUNE1 1
|
||||
#define VCOTUNE0 0
|
||||
|
||||
/* Lock Detector Configuration Register 2 - LOCKDET2 --NOTE: [] removed from names*/
|
||||
#define EUD 7
|
||||
#define LAT 6
|
||||
#define ULC2 5
|
||||
#define ULC1 4
|
||||
#define ULC0 3
|
||||
#define LC2 2
|
||||
#define LC1 1
|
||||
#define LC0 0
|
||||
|
||||
/* Data EEPROM Control Register - DEECR */
|
||||
#define BSY 3
|
||||
#define EEU 2
|
||||
#define EEL 1
|
||||
#define EER 0
|
||||
|
||||
/* Data EEPROM Data Register - DEEDR */
|
||||
#define ED7 7
|
||||
#define ED6 6
|
||||
#define ED5 5
|
||||
#define ED4 4
|
||||
#define ED3 3
|
||||
#define ED2 2
|
||||
#define ED1 1
|
||||
#define ED0 0
|
||||
|
||||
/* Data EEPROM Address Register - DEEAR */
|
||||
#define PA6 6
|
||||
#define PA5 5
|
||||
#define PA4 4
|
||||
#define PA3 3
|
||||
#define BA2 2 /* B is not a typo! */
|
||||
#define BA1 1
|
||||
#define BA0 0
|
||||
|
||||
/* Bit Timer Count Register - BTCNT */
|
||||
#define C7 7
|
||||
#define C6 6
|
||||
#define C5 5
|
||||
#define C4 4
|
||||
#define C3 3
|
||||
#define C2 2
|
||||
#define C1 1
|
||||
#define C0 0
|
||||
|
||||
/* Bit Timer Control Register - BTCR */
|
||||
#define C9 7
|
||||
#define C8 6
|
||||
#define M1 5
|
||||
#define M0 4
|
||||
#define IE 3
|
||||
#define F2 2
|
||||
#define DATA 1
|
||||
#define F0 0
|
||||
|
||||
/* Watchdog Timer Control Register - WDTCR */
|
||||
#define WDTOE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/* I/O Enable Register - IO_ENAB */
|
||||
#define BOHYST 6
|
||||
#define IOE5 5
|
||||
#define IOE4 4
|
||||
#define IOE3 3
|
||||
#define IOE2 2
|
||||
#define IOE1 1
|
||||
#define IOE0 0
|
||||
|
||||
/* Note: No PORTB or whatever, this is the equivalent. */
|
||||
/* I/O Data Out Register - IO_DATOUT */
|
||||
#define IOO5 5
|
||||
#define IOO4 4
|
||||
#define IOO3 3
|
||||
#define IOO2 2
|
||||
#define IOO1 1
|
||||
#define IOO0 0
|
||||
|
||||
/* Note: No PINB or whatever, this is the equivalent. */
|
||||
/* I/O Data In Register - IO_DATIN */
|
||||
#define IOI5 5
|
||||
#define IOI4 4
|
||||
#define IOI3 3
|
||||
#define IOI2 2
|
||||
#define IOI1 1
|
||||
#define IOI0 0
|
||||
|
||||
/* AVR Configuration Register - AVR_CONFIG */
|
||||
#define ACS1 6
|
||||
#define ACS0 5
|
||||
#define TM 4
|
||||
#define BD 3
|
||||
#define BLI 2
|
||||
#define SLEEP 1
|
||||
#define BBM 0
|
||||
|
||||
/* Button Detect Register - B_DET */
|
||||
#define BD5 5
|
||||
#define BD4 4
|
||||
#define BD3 3
|
||||
#define BD2 2
|
||||
#define BD1 1
|
||||
#define BD0 0
|
||||
|
||||
/* Battery Low Configuration Register - BL_CONFIG */
|
||||
#define BL 7
|
||||
#define BLV 6
|
||||
#define BL5 5
|
||||
#define BL4 4
|
||||
#define BL3 3
|
||||
#define BL2 2
|
||||
#define BL1 1
|
||||
#define BL0 0
|
||||
|
||||
/* Pointer definition */
|
||||
#define XL r26
|
||||
#define XH r27
|
||||
#define YL r28
|
||||
#define YH r29
|
||||
#define ZL r30
|
||||
#define ZH r31
|
||||
|
||||
/* Constants */
|
||||
#define RAMEND 0xDF
|
||||
#define XRAMEND 0xDF
|
||||
#define E2END 0x7F
|
||||
#define E2PAGESIZE 0
|
||||
#define FLASHEND 0x07FF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
#define FUSE_MEMORY_SIZE 0
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x91
|
||||
#define SIGNATURE_2 0x81
|
||||
|
||||
|
||||
#endif /* _AVR_IO86RF401_H_ */
|
1121
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io90pwm1.h
Normal file
1121
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io90pwm1.h
Normal file
File diff suppressed because it is too large
Load diff
1181
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io90pwm216.h
Normal file
1181
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io90pwm216.h
Normal file
File diff suppressed because it is too large
Load diff
1383
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io90pwm2b.h
Normal file
1383
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io90pwm2b.h
Normal file
File diff suppressed because it is too large
Load diff
1224
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io90pwm316.h
Normal file
1224
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io90pwm316.h
Normal file
File diff suppressed because it is too large
Load diff
1383
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io90pwm3b.h
Normal file
1383
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io90pwm3b.h
Normal file
File diff suppressed because it is too large
Load diff
1371
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io90pwmx.h
Normal file
1371
arduino-0018-windows/hardware/tools/avr/avr/include/avr/io90pwmx.h
Normal file
File diff suppressed because it is too large
Load diff
|
@ -0,0 +1,557 @@
|
|||
/* Copyright (c) 2002, Marek Michalkiewicz
|
||||
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: ioat94k.h,v 1.9 2004/11/01 22:23:56 arcanum Exp $ */
|
||||
|
||||
/* avr/ioat94k.h - definitions for AT94K series FPSLIC(tm) */
|
||||
|
||||
#ifndef _AVR_IOAT94K_H_
|
||||
#define _AVR_IOAT94K_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_ "ioat94k.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* UART1 Baud Rate Register */
|
||||
#define UBRR1 _SFR_IO8(0x00)
|
||||
|
||||
/* UART1 Control and Status Registers */
|
||||
#define UCSR1B _SFR_IO8(0x01)
|
||||
#define UCSR1A _SFR_IO8(0x02)
|
||||
|
||||
/* UART1 I/O Data Register */
|
||||
#define UDR1 _SFR_IO8(0x03)
|
||||
|
||||
/* 0x04 reserved */
|
||||
|
||||
/* Input Pins, Port E */
|
||||
#define PINE _SFR_IO8(0x05)
|
||||
|
||||
/* Data Direction Register, Port E */
|
||||
#define DDRE _SFR_IO8(0x06)
|
||||
|
||||
/* Data Register, Port E */
|
||||
#define PORTE _SFR_IO8(0x07)
|
||||
|
||||
/* On Chip Debug Register (reserved) */
|
||||
#define OCDR _SFR_IO8(0x08)
|
||||
|
||||
/* UART0 Baud Rate Register */
|
||||
#define UBRR0 _SFR_IO8(0x09)
|
||||
|
||||
/* UART0 Control and Status Registers */
|
||||
#define UCSR0B _SFR_IO8(0x0A)
|
||||
#define UCSR0A _SFR_IO8(0x0B)
|
||||
|
||||
/* UART0 I/O Data Register */
|
||||
#define UDR0 _SFR_IO8(0x0C)
|
||||
|
||||
/* 0x0D..0x0F reserved */
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND _SFR_IO8(0x10)
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDRD _SFR_IO8(0x11)
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PORTD _SFR_IO8(0x12)
|
||||
|
||||
/* FPGA I/O Select Control Register */
|
||||
#define FISCR _SFR_IO8(0x13)
|
||||
|
||||
/* FPGA I/O Select Registers A, B, C, D */
|
||||
#define FISUA _SFR_IO8(0x14)
|
||||
#define FISUB _SFR_IO8(0x15)
|
||||
#define FISUC _SFR_IO8(0x16)
|
||||
#define FISUD _SFR_IO8(0x17)
|
||||
|
||||
/* FPGA Cache Logic(R) registers (top secret, under NDA) */
|
||||
#define FPGAX _SFR_IO8(0x18)
|
||||
#define FPGAY _SFR_IO8(0x19)
|
||||
#define FPGAZ _SFR_IO8(0x1A)
|
||||
#define FPGAD _SFR_IO8(0x1B)
|
||||
|
||||
/* TWI stands for "Two Wire Interface" or "TWI Was I2C(tm)" */
|
||||
|
||||
/* 2-wire Serial Bit Rate Register */
|
||||
#define TWBR _SFR_IO8(0x1C)
|
||||
|
||||
/* 2-wire Serial Status Register */
|
||||
#define TWSR _SFR_IO8(0x1D)
|
||||
|
||||
/* 2-wire Serial (Slave) Address Register */
|
||||
#define TWAR _SFR_IO8(0x1E)
|
||||
|
||||
/* 2-wire Serial Data Register */
|
||||
#define TWDR _SFR_IO8(0x1F)
|
||||
|
||||
/* UART Baud Register High */
|
||||
#define UBRRH _SFR_IO8(0x20)
|
||||
#define UBRRHI UBRRH /* New name in datasheet (1138F-FPSLI-06/02) */
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
|
||||
/* Timer/Counter2 Output Compare Register */
|
||||
#define OCR2 _SFR_IO8(0x22)
|
||||
|
||||
/* Timer/Counter2 (8-bit) */
|
||||
#define TCNT2 _SFR_IO8(0x23)
|
||||
|
||||
/* Timer/Counter1 Input Capture Register */
|
||||
#define ICR1 _SFR_IO16(0x24)
|
||||
#define ICR1L _SFR_IO8(0x24)
|
||||
#define ICR1H _SFR_IO8(0x25)
|
||||
|
||||
/* Asynchronous mode StatuS Register */
|
||||
#define ASSR _SFR_IO8(0x26)
|
||||
|
||||
/* Timer/Counter2 Control Register */
|
||||
#define TCCR2 _SFR_IO8(0x27)
|
||||
|
||||
/* Timer/Counter1 Output Compare RegisterB */
|
||||
#define OCR1B _SFR_IO16(0x28)
|
||||
#define OCR1BL _SFR_IO8(0x28)
|
||||
#define OCR1BH _SFR_IO8(0x29)
|
||||
|
||||
/* Timer/Counter1 Output Compare RegisterA */
|
||||
#define OCR1A _SFR_IO16(0x2A)
|
||||
#define OCR1AL _SFR_IO8(0x2A)
|
||||
#define OCR1AH _SFR_IO8(0x2B)
|
||||
|
||||
/* Timer/Counter1 */
|
||||
#define TCNT1 _SFR_IO16(0x2C)
|
||||
#define TCNT1L _SFR_IO8(0x2C)
|
||||
#define TCNT1H _SFR_IO8(0x2D)
|
||||
|
||||
/* Timer/Counter1 Control Register B */
|
||||
#define TCCR1B _SFR_IO8(0x2E)
|
||||
|
||||
/* Timer/Counter1 Control Register A */
|
||||
#define TCCR1A _SFR_IO8(0x2F)
|
||||
|
||||
/* Special Function IO Register */
|
||||
#define SFIOR _SFR_IO8(0x30)
|
||||
|
||||
/* Timer/Counter0 Output Compare Register */
|
||||
#define OCR0 _SFR_IO8(0x31)
|
||||
|
||||
/* Timer/Counter0 (8-bit) */
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
|
||||
/* Timer/Counter0 Control Register */
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
/* 0x34 reserved */
|
||||
|
||||
/* MCU Control/Status Register */
|
||||
#define MCUR _SFR_IO8(0x35)
|
||||
|
||||
/* 2-wire Serial Control Register */
|
||||
#define TWCR _SFR_IO8(0x36)
|
||||
|
||||
/* 0x37 reserved */
|
||||
|
||||
/* Timer/Counter Interrupt Flag Register */
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
|
||||
/* Timer/Counter Interrupt MaSK Register */
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
|
||||
/* Software Control Register */
|
||||
#define SFTCR _SFR_IO8(0x3A)
|
||||
|
||||
/* External Interrupt Mask/Flag Register */
|
||||
#define EIMF _SFR_IO8(0x3B)
|
||||
|
||||
/* 0x3C reserved */
|
||||
|
||||
/* 0x3D..0x3E SP */
|
||||
|
||||
/* 0x3F SREG */
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
#define SIG_FPGA_INTERRUPT0 _VECTOR(1) /* FPGA_INT0 */
|
||||
#define SIG_INTERRUPT0 _VECTOR(2) /* EXT_INT0 */
|
||||
#define SIG_FPGA_INTERRUPT1 _VECTOR(3) /* FPGA_INT1 */
|
||||
#define SIG_INTERRUPT1 _VECTOR(4) /* EXT_INT1 */
|
||||
#define SIG_FPGA_INTERRUPT2 _VECTOR(5) /* FPGA_INT2 */
|
||||
#define SIG_INTERRUPT2 _VECTOR(6) /* EXT_INT2 */
|
||||
#define SIG_FPGA_INTERRUPT3 _VECTOR(7) /* FPGA_INT3 */
|
||||
#define SIG_INTERRUPT3 _VECTOR(8) /* EXT_INT3 */
|
||||
#define SIG_OUTPUT_COMPARE2 _VECTOR(9) /* TIM2_COMP */
|
||||
#define SIG_OVERFLOW2 _VECTOR(10) /* TIM2_OVF */
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(11) /* TIM1_CAPT */
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(12) /* TIM1_COMPA */
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(13) /* TIM1_COMPB */
|
||||
#define SIG_OVERFLOW1 _VECTOR(14) /* TIM1_OVF */
|
||||
#define SIG_OUTPUT_COMPARE0 _VECTOR(15) /* TIM0_COMP */
|
||||
#define SIG_OVERFLOW0 _VECTOR(16) /* TIM0_OVF */
|
||||
#define SIG_FPGA_INTERRUPT4 _VECTOR(17) /* FPGA_INT4 */
|
||||
#define SIG_FPGA_INTERRUPT5 _VECTOR(18) /* FPGA_INT5 */
|
||||
#define SIG_FPGA_INTERRUPT6 _VECTOR(19) /* FPGA_INT6 */
|
||||
#define SIG_FPGA_INTERRUPT7 _VECTOR(20) /* FPGA_INT7 */
|
||||
#define SIG_UART0_RECV _VECTOR(21) /* UART0_RXC */
|
||||
#define SIG_UART0_DATA _VECTOR(22) /* UART0_DRE */
|
||||
#define SIG_UART0_TRANS _VECTOR(23) /* UART0_TXC */
|
||||
#define SIG_FPGA_INTERRUPT8 _VECTOR(24) /* FPGA_INT8 */
|
||||
#define SIG_FPGA_INTERRUPT9 _VECTOR(25) /* FPGA_INT9 */
|
||||
#define SIG_FPGA_INTERRUPT10 _VECTOR(26) /* FPGA_INT10 */
|
||||
#define SIG_FPGA_INTERRUPT11 _VECTOR(27) /* FPGA_INT11 */
|
||||
#define SIG_UART1_RECV _VECTOR(28) /* UART1_RXC */
|
||||
#define SIG_UART1_DATA _VECTOR(29) /* UART1_DRE */
|
||||
#define SIG_UART1_TRANS _VECTOR(30) /* UART1_TXC */
|
||||
#define SIG_FPGA_INTERRUPT12 _VECTOR(31) /* FPGA_INT12 */
|
||||
#define SIG_FPGA_INTERRUPT13 _VECTOR(32) /* FPGA_INT13 */
|
||||
#define SIG_FPGA_INTERRUPT14 _VECTOR(33) /* FPGA_INT14 */
|
||||
#define SIG_FPGA_INTERRUPT15 _VECTOR(34) /* FPGA_INT15 */
|
||||
#define SIG_2WIRE_SERIAL _VECTOR(35) /* TWS_INT */
|
||||
|
||||
#define _VECTORS_SIZE 144
|
||||
|
||||
/* Bit numbers (SFRs alphabetically sorted) */
|
||||
|
||||
/* ASSR */
|
||||
#define AS2 3
|
||||
#define TCN2UB 2
|
||||
#define OCR2UB 1
|
||||
#define TCR2UB 0
|
||||
|
||||
/* DDRD */
|
||||
#define DDD7 7
|
||||
#define DDD6 6
|
||||
#define DDD5 5
|
||||
#define DDD4 4
|
||||
#define DDD3 3
|
||||
#define DDD2 2
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
/* DDRE */
|
||||
#define DDE7 7
|
||||
#define DDE6 6
|
||||
#define DDE5 5
|
||||
#define DDE4 4
|
||||
#define DDE3 3
|
||||
#define DDE2 2
|
||||
#define DDE1 1
|
||||
#define DDE0 0
|
||||
|
||||
/* EIMF */
|
||||
#define INTF3 7
|
||||
#define INTF2 6
|
||||
#define INTF1 5
|
||||
#define INTF0 4
|
||||
#define INT3 3
|
||||
#define INT2 2
|
||||
#define INT1 1
|
||||
#define INT0 0
|
||||
|
||||
/* FISCR */
|
||||
#define FIADR 7
|
||||
#define XFIS1 1
|
||||
#define XFIS0 0
|
||||
|
||||
/* FISUA */
|
||||
#define FIF3 7
|
||||
#define FIF2 6
|
||||
#define FIF1 5
|
||||
#define FIF0 4
|
||||
#define FINT3 3
|
||||
#define FINT2 2
|
||||
#define FINT1 1
|
||||
#define FINT0 0
|
||||
|
||||
/* FISUB */
|
||||
#define FIF7 7
|
||||
#define FIF6 6
|
||||
#define FIF5 5
|
||||
#define FIF4 4
|
||||
#define FINT7 3
|
||||
#define FINT6 2
|
||||
#define FINT5 1
|
||||
#define FINT4 0
|
||||
|
||||
/* FISUC */
|
||||
#define FIF11 7
|
||||
#define FIF10 6
|
||||
#define FIF9 5
|
||||
#define FIF8 4
|
||||
#define FINT11 3
|
||||
#define FINT10 2
|
||||
#define FINT9 1
|
||||
#define FINT8 0
|
||||
|
||||
/* FISUD */
|
||||
#define FIF15 7
|
||||
#define FIF14 6
|
||||
#define FIF13 5
|
||||
#define FIF12 4
|
||||
#define FINT15 3
|
||||
#define FINT14 2
|
||||
#define FINT13 1
|
||||
#define FINT12 0
|
||||
|
||||
/* MCUR */
|
||||
#define JTRF 7
|
||||
#define JTD 6
|
||||
#define SE 5
|
||||
#define SM1 4
|
||||
#define SM0 3
|
||||
#define PORF 2
|
||||
#define WDRF 1
|
||||
#define EXTRF 0
|
||||
|
||||
/* OCDR (reserved) */
|
||||
#define IDRD 7
|
||||
|
||||
/* PIND */
|
||||
#define PIND7 7
|
||||
#define PIND6 6
|
||||
#define PIND5 5
|
||||
#define PIND4 4
|
||||
#define PIND3 3
|
||||
#define PIND2 2
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
/* PINE */
|
||||
#define PINE7 7
|
||||
#define PINE6 6
|
||||
#define PINE5 5
|
||||
#define PINE4 4
|
||||
#define PINE3 3
|
||||
#define PINE2 2
|
||||
#define PINE1 1
|
||||
#define PINE0 0
|
||||
|
||||
/* PORTD */
|
||||
#define PD7 7
|
||||
#define PD6 6
|
||||
#define PD5 5
|
||||
#define PD4 4
|
||||
#define PD3 3
|
||||
#define PD2 2
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
/* PORTE */
|
||||
/*
|
||||
PE7 = IC1 / INT3 (alternate)
|
||||
PE6 = OC1A / INT2 (alternate)
|
||||
PE5 = OC1B / INT1 (alternate)
|
||||
PE4 = ET11 / INT0 (alternate)
|
||||
PE3 = OC2 / RX1 (alternate)
|
||||
PE2 = / TX1 (alternate)
|
||||
PE1 = OC0 / RX0 (alternate)
|
||||
PE0 = ET0 / TX0 (alternate)
|
||||
*/
|
||||
#define PE7 7
|
||||
#define PE6 6
|
||||
#define PE5 5
|
||||
#define PE4 4
|
||||
#define PE3 3
|
||||
#define PE2 2
|
||||
#define PE1 1
|
||||
#define PE0 0
|
||||
|
||||
/* SFIOR */
|
||||
#define PSR2 1
|
||||
#define PSR10 0
|
||||
|
||||
/* SFTCR */
|
||||
#define FMXOR 3
|
||||
#define WDTS 2
|
||||
#define DBG 1
|
||||
#define SRST 0
|
||||
|
||||
/* TCCR0 */
|
||||
#define FOC0 7
|
||||
#define PWM0 6
|
||||
#define COM01 5
|
||||
#define COM00 4
|
||||
#define CTC0 3
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/* TCCR1A */
|
||||
#define COM1A1 7
|
||||
#define COM1A0 6
|
||||
#define COM1B1 5
|
||||
#define COM1B0 4
|
||||
#define FOC1A 3
|
||||
#define FOC1B 2
|
||||
#define PWM11 1
|
||||
#define PWM10 0
|
||||
|
||||
/* TCCR1B */
|
||||
#define ICNC1 7
|
||||
#define ICES1 6
|
||||
#define ICPE 5
|
||||
#define CTC1 3
|
||||
#define CS12 2
|
||||
#define CS11 1
|
||||
#define CS10 0
|
||||
|
||||
/* TCCR2 */
|
||||
#define FOC2 7
|
||||
#define PWM2 6
|
||||
#define COM21 5
|
||||
#define COM20 4
|
||||
#define CTC2 3
|
||||
#define CS22 2
|
||||
#define CS21 1
|
||||
#define CS20 0
|
||||
|
||||
/* TIFR */
|
||||
#define TOV1 7
|
||||
#define OCF1A 6
|
||||
#define OCF1B 5
|
||||
#define TOV2 4
|
||||
#define ICF1 3
|
||||
#define OCF2 2
|
||||
#define TOV0 1
|
||||
#define OCF0 0
|
||||
|
||||
/* TIMSK */
|
||||
#define TOIE1 7
|
||||
#define OCIE1A 6
|
||||
#define OCIE1B 5
|
||||
#define TOIE2 4
|
||||
#define TICIE1 3
|
||||
#define OCIE2 2
|
||||
#define TOIE0 1
|
||||
#define OCIE0 0
|
||||
|
||||
/* TWAR */
|
||||
/* #define TWA 1 */ /* TWA is bits 7:1 */
|
||||
#define TWGCE 0
|
||||
|
||||
/* TWCR */
|
||||
#define TWINT 7
|
||||
#define TWEA 6
|
||||
#define TWSTA 5
|
||||
#define TWSTO 4
|
||||
#define TWWC 3
|
||||
#define TWEN 2
|
||||
#define TWIE 0
|
||||
|
||||
/* TWSR */
|
||||
#define TWS7 7
|
||||
#define TWS6 6
|
||||
#define TWS5 5
|
||||
#define TWS4 4
|
||||
#define TWS3 3
|
||||
|
||||
/* UBRRHI
|
||||
Bits 11..8 of UART1 are bits 7..4 of UBRRHI.
|
||||
Bits 11..8 of UART0 are bits 3..0 of UBRRHI. */
|
||||
/* #define UBRRHI1 4 */
|
||||
/* #define UBRRHI0 0 */
|
||||
|
||||
/* UCSR0A */
|
||||
#define RXC0 7
|
||||
#define TXC0 6
|
||||
#define UDRE0 5
|
||||
#define FE0 4
|
||||
#define OR0 3
|
||||
#define U2X0 1
|
||||
#define MPCM0 0
|
||||
|
||||
/* UCSR0B */
|
||||
#define RXCIE0 7
|
||||
#define TXCIE0 6
|
||||
#define UDRIE0 5
|
||||
#define RXEN0 4
|
||||
#define TXEN0 3
|
||||
#define CHR90 2
|
||||
#define RXB80 1
|
||||
#define TXB80 0
|
||||
|
||||
/* UCSR1A */
|
||||
#define RXC1 7
|
||||
#define TXC1 6
|
||||
#define UDRE1 5
|
||||
#define FE1 4
|
||||
#define OR1 3
|
||||
#define U2X1 1
|
||||
#define MPCM1 0
|
||||
|
||||
/* UCSR1B */
|
||||
#define RXCIE1 7
|
||||
#define TXCIE1 6
|
||||
#define UDRIE1 5
|
||||
#define RXEN1 4
|
||||
#define TXEN1 3
|
||||
#define CHR91 2
|
||||
#define RXB81 1
|
||||
#define TXB81 0
|
||||
|
||||
/* WDTCR */
|
||||
#define WDTOE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/*
|
||||
Last memory addresses - depending on configuration, it is possible
|
||||
to have 20K-32K of program memory and 4K-16K of data memory
|
||||
(all in the same 36K total of SRAM, loaded from external EEPROM).
|
||||
*/
|
||||
|
||||
#ifndef RAMEND
|
||||
#define RAMEND 0x0FFF
|
||||
#endif
|
||||
|
||||
#ifndef XRAMEND
|
||||
#define XRAMEND RAMEND
|
||||
#endif
|
||||
|
||||
#define E2END 0
|
||||
|
||||
#ifndef FLASHEND
|
||||
#define FLASHEND 0x7FFF
|
||||
#endif
|
||||
|
||||
#endif /* _AVR_IOAT94K_H_ */
|
|
@ -0,0 +1,94 @@
|
|||
/* Copyright (c) 2004,2005, Colin O'Flynn <coflynn@newae.com>
|
||||
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: iocan128.h,v 1.17.2.5 2008/10/17 23:27:46 arcanum Exp $ */
|
||||
|
||||
/* iocan128.h - definitions for CAN128 */
|
||||
|
||||
#ifndef _AVR_IOCAN128_H_
|
||||
#define _AVR_IOCAN128_H_ 1
|
||||
|
||||
#include <avr/iocanxx.h>
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 256
|
||||
#define RAMEND 0x10FF /* Last On-Chip SRAM Location */
|
||||
#define XRAMEND 0xFFFF
|
||||
#define E2END 0x0FFF
|
||||
#define E2PAGESIZE 8
|
||||
#define FLASHEND 0x1FFFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6)
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(2)
|
||||
#define FUSE_BODLEVEL2 (unsigned char)~_BV(3)
|
||||
#define EFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x97
|
||||
#define SIGNATURE_2 0x81
|
||||
|
||||
|
||||
#endif /* _AVR_IOCAN128_H_ */
|
|
@ -0,0 +1,94 @@
|
|||
/* Copyright (c) 2004,2005, Anatoly Sokolov <aesok@pautinka.net>
|
||||
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: iocan32.h,v 1.2.2.5 2008/10/17 23:27:46 arcanum Exp $ */
|
||||
|
||||
/* iocan32.h - definitions for CAN32 */
|
||||
|
||||
#ifndef _AVR_IOCAN32_H_
|
||||
#define _AVR_IOCAN32_H_ 1
|
||||
|
||||
#include <avr/iocanxx.h>
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 256
|
||||
#define RAMEND 0x08FF /* Last On-Chip SRAM Location */
|
||||
#define XRAMEND 0xFFFF
|
||||
#define E2END 0x03FF
|
||||
#define E2PAGESIZE 8
|
||||
#define FLASHEND 0x7FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6)
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(2)
|
||||
#define FUSE_BODLEVEL2 (unsigned char)~_BV(3)
|
||||
#define EFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x95
|
||||
#define SIGNATURE_2 0x81
|
||||
|
||||
|
||||
#endif /* _AVR_IOCAN32_H_ */
|
|
@ -0,0 +1,94 @@
|
|||
/* Copyright (c) 2004,2005, Anatoly Sokolov <aesok@pautinka.net>
|
||||
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: iocan64.h,v 1.2.2.5 2008/10/17 23:27:46 arcanum Exp $ */
|
||||
|
||||
/* iocan64.h - definitions for CAN64 */
|
||||
|
||||
#ifndef _AVR_IOCAN64_H_
|
||||
#define _AVR_IOCAN64_H_ 1
|
||||
|
||||
#include <avr/iocanxx.h>
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 256
|
||||
#define RAMEND 0x10FF /* Last On-Chip SRAM Location */
|
||||
#define XRAMEND 0xFFFF
|
||||
#define E2END 0x07FF
|
||||
#define E2PAGESIZE 8
|
||||
#define FLASHEND 0xFFFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6)
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(2)
|
||||
#define FUSE_BODLEVEL2 (unsigned char)~_BV(3)
|
||||
#define EFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x96
|
||||
#define SIGNATURE_2 0x81
|
||||
|
||||
|
||||
#endif /* _AVR_IOCAN64_H_ */
|
1978
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iocanxx.h
Normal file
1978
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iocanxx.h
Normal file
File diff suppressed because it is too large
Load diff
675
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom103.h
Normal file
675
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom103.h
Normal file
|
@ -0,0 +1,675 @@
|
|||
/* Copyright (c) 2002, Marek Michalkiewicz
|
||||
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: iom103.h,v 1.9.4.3 2008/08/14 00:08:00 arcanum Exp $ */
|
||||
|
||||
/* avr/iom103.h - definitions for ATmega103 */
|
||||
|
||||
#ifndef _AVR_IOM103_H_
|
||||
#define _AVR_IOM103_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_ "iom103.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* Input Pins, Port F */
|
||||
#define PINF _SFR_IO8(0x00)
|
||||
|
||||
/* Input Pins, Port E */
|
||||
#define PINE _SFR_IO8(0x01)
|
||||
|
||||
/* Data Direction Register, Port E */
|
||||
#define DDRE _SFR_IO8(0x02)
|
||||
|
||||
/* Data Register, Port E */
|
||||
#define PORTE _SFR_IO8(0x03)
|
||||
|
||||
/* ADC Data Register */
|
||||
#ifndef __ASSEMBLER__
|
||||
#define ADC _SFR_IO16(0x04)
|
||||
#endif
|
||||
#define ADCW _SFR_IO16(0x04)
|
||||
#define ADCL _SFR_IO8(0x04)
|
||||
#define ADCH _SFR_IO8(0x05)
|
||||
|
||||
/* ADC Control and status register */
|
||||
#define ADCSR _SFR_IO8(0x06)
|
||||
|
||||
/* ADC Multiplexer select */
|
||||
#define ADMUX _SFR_IO8(0x07)
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACSR _SFR_IO8(0x08)
|
||||
|
||||
/* UART Baud Rate Register */
|
||||
#define UBRR _SFR_IO8(0x09)
|
||||
|
||||
/* UART Control Register */
|
||||
#define UCR _SFR_IO8(0x0A)
|
||||
|
||||
/* UART Status Register */
|
||||
#define USR _SFR_IO8(0x0B)
|
||||
|
||||
/* UART I/O Data Register */
|
||||
#define UDR _SFR_IO8(0x0C)
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPCR _SFR_IO8(0x0D)
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPSR _SFR_IO8(0x0E)
|
||||
|
||||
/* SPI I/O Data Register */
|
||||
#define SPDR _SFR_IO8(0x0F)
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND _SFR_IO8(0x10)
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDRD _SFR_IO8(0x11)
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PORTD _SFR_IO8(0x12)
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PORTC _SFR_IO8(0x15)
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
|
||||
/* Input Pins, Port A */
|
||||
#define PINA _SFR_IO8(0x19)
|
||||
|
||||
/* Data Direction Register, Port A */
|
||||
#define DDRA _SFR_IO8(0x1A)
|
||||
|
||||
/* Data Register, Port A */
|
||||
#define PORTA _SFR_IO8(0x1B)
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EECR _SFR_IO8(0x1C)
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define EEDR _SFR_IO8(0x1D)
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#define EEAR _SFR_IO16(0x1E)
|
||||
#define EEARL _SFR_IO8(0x1E)
|
||||
#define EEARH _SFR_IO8(0x1F)
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
|
||||
/* Timer2 Output Compare Register */
|
||||
#define OCR2 _SFR_IO8(0x23)
|
||||
|
||||
/* Timer/Counter 2 */
|
||||
#define TCNT2 _SFR_IO8(0x24)
|
||||
|
||||
/* Timer/Counter 2 Control register */
|
||||
#define TCCR2 _SFR_IO8(0x25)
|
||||
|
||||
/* T/C 1 Input Capture Register */
|
||||
#define ICR1 _SFR_IO16(0x26)
|
||||
#define ICR1L _SFR_IO8(0x26)
|
||||
#define ICR1H _SFR_IO8(0x27)
|
||||
|
||||
/* Timer/Counter1 Output Compare Register B */
|
||||
#define OCR1B _SFR_IO16(0x28)
|
||||
#define OCR1BL _SFR_IO8(0x28)
|
||||
#define OCR1BH _SFR_IO8(0x29)
|
||||
|
||||
/* Timer/Counter1 Output Compare Register A */
|
||||
#define OCR1A _SFR_IO16(0x2A)
|
||||
#define OCR1AL _SFR_IO8(0x2A)
|
||||
#define OCR1AH _SFR_IO8(0x2B)
|
||||
|
||||
/* Timer/Counter 1 */
|
||||
#define TCNT1 _SFR_IO16(0x2C)
|
||||
#define TCNT1L _SFR_IO8(0x2C)
|
||||
#define TCNT1H _SFR_IO8(0x2D)
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define TCCR1B _SFR_IO8(0x2E)
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define TCCR1A _SFR_IO8(0x2F)
|
||||
|
||||
/* Timer/Counter 0 Asynchronous Control & Status Register */
|
||||
#define ASSR _SFR_IO8(0x30)
|
||||
|
||||
/* Output Compare Register 0 */
|
||||
#define OCR0 _SFR_IO8(0x31)
|
||||
|
||||
/* Timer/Counter 0 */
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
/* MCU Status Register */
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
/* Timer/Counter Interrupt Flag Register */
|
||||
#define TIFR _SFR_IO8(0x36)
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define TIMSK _SFR_IO8(0x37)
|
||||
|
||||
/* Èxternal Interrupt Flag Register */
|
||||
#define EIFR _SFR_IO8(0x38)
|
||||
|
||||
/* External Interrupt MaSK register */
|
||||
#define EIMSK _SFR_IO8(0x39)
|
||||
|
||||
/* External Interrupt Control Register */
|
||||
#define EICR _SFR_IO8(0x3A)
|
||||
|
||||
/* RAM Page Z select register */
|
||||
#define RAMPZ _SFR_IO8(0x3B)
|
||||
|
||||
/* XDIV Divide control register */
|
||||
#define XDIV _SFR_IO8(0x3C)
|
||||
|
||||
/* 0x3D..0x3E SP */
|
||||
|
||||
/* 0x3F SREG */
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
/* External Interrupt 0 */
|
||||
#define INT0_vect _VECTOR(1)
|
||||
#define SIG_INTERRUPT0 _VECTOR(1)
|
||||
|
||||
/* External Interrupt 1 */
|
||||
#define INT1_vect _VECTOR(2)
|
||||
#define SIG_INTERRUPT1 _VECTOR(2)
|
||||
|
||||
/* External Interrupt 2 */
|
||||
#define INT2_vect _VECTOR(3)
|
||||
#define SIG_INTERRUPT2 _VECTOR(3)
|
||||
|
||||
/* External Interrupt 3 */
|
||||
#define INT3_vect _VECTOR(4)
|
||||
#define SIG_INTERRUPT3 _VECTOR(4)
|
||||
|
||||
/* External Interrupt 4 */
|
||||
#define INT4_vect _VECTOR(5)
|
||||
#define SIG_INTERRUPT4 _VECTOR(5)
|
||||
|
||||
/* External Interrupt 5 */
|
||||
#define INT5_vect _VECTOR(6)
|
||||
#define SIG_INTERRUPT5 _VECTOR(6)
|
||||
|
||||
/* External Interrupt 6 */
|
||||
#define INT6_vect _VECTOR(7)
|
||||
#define SIG_INTERRUPT6 _VECTOR(7)
|
||||
|
||||
/* External Interrupt 7 */
|
||||
#define INT7_vect _VECTOR(8)
|
||||
#define SIG_INTERRUPT7 _VECTOR(8)
|
||||
|
||||
/* Timer/Counter2 Compare Match */
|
||||
#define TIMER2_COMP_vect _VECTOR(9)
|
||||
#define SIG_OUTPUT_COMPARE2 _VECTOR(9)
|
||||
|
||||
/* Timer/Counter2 Overflow */
|
||||
#define TIMER2_OVF_vect _VECTOR(10)
|
||||
#define SIG_OVERFLOW2 _VECTOR(10)
|
||||
|
||||
/* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(11)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(11)
|
||||
|
||||
/* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPA_vect _VECTOR(12)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(12)
|
||||
|
||||
/* Timer/Counter1 Compare Match B */
|
||||
#define TIMER1_COMPB_vect _VECTOR(13)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(13)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(14)
|
||||
#define SIG_OVERFLOW1 _VECTOR(14)
|
||||
|
||||
/* Timer/Counter0 Compare Match */
|
||||
#define TIMER0_COMP_vect _VECTOR(15)
|
||||
#define SIG_OUTPUT_COMPARE0 _VECTOR(15)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(16)
|
||||
#define SIG_OVERFLOW0 _VECTOR(16)
|
||||
|
||||
/* SPI Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(17)
|
||||
#define SIG_SPI _VECTOR(17)
|
||||
|
||||
/* UART, Rx Complete */
|
||||
#define UART_RX_vect _VECTOR(18)
|
||||
#define SIG_UART_RECV _VECTOR(18)
|
||||
|
||||
/* UART Data Register Empty */
|
||||
#define UART_UDRE_vect _VECTOR(19)
|
||||
#define SIG_UART_DATA _VECTOR(19)
|
||||
|
||||
/* UART, Tx Complete */
|
||||
#define UART_TX_vect _VECTOR(20)
|
||||
#define SIG_UART_TRANS _VECTOR(20)
|
||||
|
||||
/* ADC Conversion Complete */
|
||||
#define ADC_vect _VECTOR(21)
|
||||
#define SIG_ADC _VECTOR(21)
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_READY_vect _VECTOR(22)
|
||||
#define SIG_EEPROM_READY _VECTOR(22)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANALOG_COMP_vect _VECTOR(23)
|
||||
#define SIG_COMPARATOR _VECTOR(23)
|
||||
|
||||
#define _VECTORS_SIZE 96
|
||||
|
||||
/*
|
||||
The Register Bit names are represented by their bit number (0-7).
|
||||
*/
|
||||
|
||||
/* XDIV Divide control register*/
|
||||
#define XDIVEN 7
|
||||
#define XDIV6 6
|
||||
#define XDIV5 5
|
||||
#define XDIV4 4
|
||||
#define XDIV3 3
|
||||
#define XDIV2 2
|
||||
#define XDIV1 1
|
||||
#define XDIV0 0
|
||||
|
||||
/* RAM Page Z select register */
|
||||
#define RAMPZ0 0
|
||||
|
||||
/* External Interrupt Control Register */
|
||||
#define ISC71 7
|
||||
#define ISC70 6
|
||||
#define ISC61 5
|
||||
#define ISC60 4
|
||||
#define ISC51 3
|
||||
#define ISC50 2
|
||||
#define ISC41 1
|
||||
#define ISC40 0
|
||||
|
||||
/* External Interrupt MaSK register */
|
||||
#define INT7 7
|
||||
#define INT6 6
|
||||
#define INT5 5
|
||||
#define INT4 4
|
||||
#define INT3 3
|
||||
#define INT2 2
|
||||
#define INT1 1
|
||||
#define INT0 0
|
||||
|
||||
/* Èxternal Interrupt Flag Register */
|
||||
#define INTF7 7
|
||||
#define INTF6 6
|
||||
#define INTF5 5
|
||||
#define INTF4 4
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define OCIE2 7
|
||||
#define TOIE2 6
|
||||
#define TICIE1 5
|
||||
#define OCIE1A 4
|
||||
#define OCIE1B 3
|
||||
#define TOIE1 2
|
||||
#define OCIE0 1
|
||||
#define TOIE0 0
|
||||
|
||||
/* Timer/Counter Interrupt Flag Register */
|
||||
#define OCF2 7
|
||||
#define TOV2 6
|
||||
#define ICF1 5
|
||||
#define OCF1A 4
|
||||
#define OCF1B 3
|
||||
#define TOV1 2
|
||||
#define OCF0 1
|
||||
#define TOV0 0
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define SRE 7
|
||||
#define SRW 6
|
||||
#define SE 5
|
||||
#define SM1 4
|
||||
#define SM0 3
|
||||
|
||||
/* MCU Status Register */
|
||||
#define EXTRF 1
|
||||
#define PORF 0
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define PWM0 6
|
||||
#define COM01 5
|
||||
#define COM00 4
|
||||
#define CTC0 3
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/* Timer/Counter 0 Asynchronous Control & Status Register */
|
||||
#define AS0 3
|
||||
#define TCN0UB 2
|
||||
#define OCR0UB 1
|
||||
#define TCR0UB 0
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define COM1A1 7
|
||||
#define COM1A0 6
|
||||
#define COM1B1 5
|
||||
#define COM1B0 4
|
||||
#define PWM11 1
|
||||
#define PWM10 0
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define ICNC1 7
|
||||
#define ICES1 6
|
||||
#define CTC1 3
|
||||
#define CS12 2
|
||||
#define CS11 1
|
||||
#define CS10 0
|
||||
|
||||
/* Timer/Counter 2 Control register */
|
||||
#define PWM2 6
|
||||
#define COM21 5
|
||||
#define COM20 4
|
||||
#define CTC2 3
|
||||
#define CS22 2
|
||||
#define CS21 1
|
||||
#define CS20 0
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTOE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/* Data Register, Port A */
|
||||
#define PA7 7
|
||||
#define PA6 6
|
||||
#define PA5 5
|
||||
#define PA4 4
|
||||
#define PA3 3
|
||||
#define PA2 2
|
||||
#define PA1 1
|
||||
#define PA0 0
|
||||
|
||||
/* Data Direction Register, Port A */
|
||||
#define DDA7 7
|
||||
#define DDA6 6
|
||||
#define DDA5 5
|
||||
#define DDA4 4
|
||||
#define DDA3 3
|
||||
#define DDA2 2
|
||||
#define DDA1 1
|
||||
#define DDA0 0
|
||||
|
||||
/* Input Pins, Port A */
|
||||
#define PINA7 7
|
||||
#define PINA6 6
|
||||
#define PINA5 5
|
||||
#define PINA4 4
|
||||
#define PINA3 3
|
||||
#define PINA2 2
|
||||
#define PINA1 1
|
||||
#define PINA0 0
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PB7 7
|
||||
#define PB6 6
|
||||
#define PB5 5
|
||||
#define PB4 4
|
||||
#define PB3 3
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDB7 7
|
||||
#define DDB6 6
|
||||
#define DDB5 5
|
||||
#define DDB4 4
|
||||
#define DDB3 3
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB7 7
|
||||
#define PINB6 6
|
||||
#define PINB5 5
|
||||
#define PINB4 4
|
||||
#define PINB3 3
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PC7 7
|
||||
#define PC6 6
|
||||
#define PC5 5
|
||||
#define PC4 4
|
||||
#define PC3 3
|
||||
#define PC2 2
|
||||
#define PC1 1
|
||||
#define PC0 0
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PD7 7
|
||||
#define PD6 6
|
||||
#define PD5 5
|
||||
#define PD4 4
|
||||
#define PD3 3
|
||||
#define PD2 2
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDD7 7
|
||||
#define DDD6 6
|
||||
#define DDD5 5
|
||||
#define DDD4 4
|
||||
#define DDD3 3
|
||||
#define DDD2 2
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND7 7
|
||||
#define PIND6 6
|
||||
#define PIND5 5
|
||||
#define PIND4 4
|
||||
#define PIND3 3
|
||||
#define PIND2 2
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
/* Data Register, Port E */
|
||||
#define PE7 7
|
||||
#define PE6 6
|
||||
#define PE5 5
|
||||
#define PE4 4
|
||||
#define PE3 3
|
||||
#define PE2 2
|
||||
#define PE1 1
|
||||
#define PE0 0
|
||||
|
||||
/* Data Direction Register, Port E */
|
||||
#define DDE7 7
|
||||
#define DDE6 6
|
||||
#define DDE5 5
|
||||
#define DDE4 4
|
||||
#define DDE3 3
|
||||
#define DDE2 2
|
||||
#define DDE1 1
|
||||
#define DDE0 0
|
||||
|
||||
/* Input Pins, Port E */
|
||||
#define PINE7 7
|
||||
#define PINE6 6
|
||||
#define PINE5 5
|
||||
#define PINE4 4
|
||||
#define PINE3 3
|
||||
#define PINE2 2
|
||||
#define PINE1 1
|
||||
#define PINE0 0
|
||||
|
||||
/* Input Pins, Port F */
|
||||
#define PINF7 7
|
||||
#define PINF6 6
|
||||
#define PINF5 5
|
||||
#define PINF4 4
|
||||
#define PINF3 3
|
||||
#define PINF2 2
|
||||
#define PINF1 1
|
||||
#define PINF0 0
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPIF 7
|
||||
#define WCOL 6
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPIE 7
|
||||
#define SPE 6
|
||||
#define DORD 5
|
||||
#define MSTR 4
|
||||
#define CPOL 3
|
||||
#define CPHA 2
|
||||
#define SPR1 1
|
||||
#define SPR0 0
|
||||
|
||||
/* UART Status Register */
|
||||
#define RXC 7
|
||||
#define TXC 6
|
||||
#define UDRE 5
|
||||
#define FE 4
|
||||
#define DOR 3
|
||||
|
||||
/* UART Control Register */
|
||||
#define RXCIE 7
|
||||
#define TXCIE 6
|
||||
#define UDRIE 5
|
||||
#define RXEN 4
|
||||
#define TXEN 3
|
||||
#define CHR9 2
|
||||
#define RXB8 1
|
||||
#define TXB8 0
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACD 7
|
||||
#define ACO 5
|
||||
#define ACI 4
|
||||
#define ACIE 3
|
||||
#define ACIC 2
|
||||
#define ACIS1 1
|
||||
#define ACIS0 0
|
||||
|
||||
/* ADC Control and status register */
|
||||
#define ADEN 7
|
||||
#define ADSC 6
|
||||
#define ADFR 5
|
||||
#define ADIF 4
|
||||
#define ADIE 3
|
||||
#define ADPS2 2
|
||||
#define ADPS1 1
|
||||
#define ADPS0 0
|
||||
|
||||
/* ADC Multiplexer select */
|
||||
#define MUX2 2
|
||||
#define MUX1 1
|
||||
#define MUX0 0
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EERIE 3
|
||||
#define EEMWE 2
|
||||
#define EEWE 1
|
||||
#define EERE 0
|
||||
|
||||
/* Constants */
|
||||
#define RAMEND 0x0FFF /*Last On-Chip SRAM Location*/
|
||||
#define XRAMEND 0xFFFF
|
||||
#define E2END 0x0FFF
|
||||
#define E2PAGESIZE 0
|
||||
#define FLASHEND 0x1FFFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
#define FUSE_MEMORY_SIZE 1
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0) /* Select Clock Source */
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1) /* Select Clock Source */
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2) /* Select Clock Source */
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3) /* Select Clock Source */
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4) /* Select start-up time */
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5) /* Select start-up time */
|
||||
#define FUSE_BODEN (unsigned char)~_BV(6) /* Brown out detector enable */
|
||||
#define FUSE_BODLEVEL (unsigned char)~_BV(7) /* Brown out detector trigger level */
|
||||
#define LFUSE_DEFAULT (FUSE_SUT1 & FUSE_SUT0 & FUSE_CKSEL3 & FUSE_CKSEL2 & FUSE_CKSEL1)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x97
|
||||
#define SIGNATURE_2 0x01
|
||||
|
||||
|
||||
#endif /* _AVR_IOM103_H_ */
|
1203
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom128.h
Normal file
1203
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom128.h
Normal file
File diff suppressed because it is too large
Load diff
|
@ -0,0 +1,94 @@
|
|||
/* 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: iom1280.h,v 1.2.2.5 2008/10/17 23:27:46 arcanum Exp $ */
|
||||
|
||||
/* avr/iom1280.h - definitions for ATmega1280 */
|
||||
|
||||
#ifndef _AVR_IOM1280_H_
|
||||
#define _AVR_IOM1280_H_ 1
|
||||
|
||||
#include <avr/iomxx0_1.h>
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 256
|
||||
#define RAMEND 0x21FF
|
||||
#define XRAMEND 0xFFFF
|
||||
#define E2END 0xFFF
|
||||
#define E2PAGESIZE 8
|
||||
#define FLASHEND 0x1FFFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6)
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_BODLEVEL2 (unsigned char)~_BV(2)
|
||||
#define EFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x97
|
||||
#define SIGNATURE_2 0x03
|
||||
|
||||
|
||||
#endif /* _AVR_IOM1280_H_ */
|
|
@ -0,0 +1,94 @@
|
|||
/* 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: iom1281.h,v 1.2.2.5 2008/10/17 23:27:47 arcanum Exp $ */
|
||||
|
||||
/* avr/iom1281.h - definitions for ATmega1281 */
|
||||
|
||||
#ifndef _AVR_IOM1281_H_
|
||||
#define _AVR_IOM1281_H_ 1
|
||||
|
||||
#include <avr/iomxx0_1.h>
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 256
|
||||
#define RAMEND 0x21FF
|
||||
#define XRAMEND 0xFFFF
|
||||
#define E2END 0xFFF
|
||||
#define E2PAGESIZE 8
|
||||
#define FLASHEND 0x1FFFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6)
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_BODLEVEL2 (unsigned char)~_BV(2)
|
||||
#define EFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x97
|
||||
#define SIGNATURE_2 0x04
|
||||
|
||||
|
||||
#endif /* _AVR_IOM1281_H_ */
|
1132
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom1284p.h
Normal file
1132
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom1284p.h
Normal file
File diff suppressed because it is too large
Load diff
614
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom16.h
Normal file
614
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom16.h
Normal file
|
@ -0,0 +1,614 @@
|
|||
/* Copyright (c) 2004 Eric B. Weddington
|
||||
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: iom16.h,v 1.14.2.5 2008/10/17 23:27:47 arcanum Exp $ */
|
||||
|
||||
/* avr/iom16.h - definitions for ATmega16 */
|
||||
|
||||
#ifndef _AVR_IOM16_H_
|
||||
#define _AVR_IOM16_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_ "iom16.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* Registers and associated bit numbers */
|
||||
|
||||
#define TWBR _SFR_IO8(0x00)
|
||||
|
||||
#define TWSR _SFR_IO8(0x01)
|
||||
#define TWPS0 0
|
||||
#define TWPS1 1
|
||||
#define TWS3 3
|
||||
#define TWS4 4
|
||||
#define TWS5 5
|
||||
#define TWS6 6
|
||||
#define TWS7 7
|
||||
|
||||
#define TWAR _SFR_IO8(0x02)
|
||||
#define TWGCE 0
|
||||
#define TWA0 1
|
||||
#define TWA1 2
|
||||
#define TWA2 3
|
||||
#define TWA3 4
|
||||
#define TWA4 5
|
||||
#define TWA5 6
|
||||
#define TWA6 7
|
||||
|
||||
#define TWDR _SFR_IO8(0x03)
|
||||
|
||||
/* Combine ADCL and ADCH */
|
||||
#ifndef __ASSEMBLER__
|
||||
#define ADC _SFR_IO16(0x04)
|
||||
#endif
|
||||
#define ADCW _SFR_IO16(0x04)
|
||||
#define ADCL _SFR_IO8(0x04)
|
||||
#define ADCH _SFR_IO8(0x05)
|
||||
|
||||
#define ADCSRA _SFR_IO8(0x06)
|
||||
#define ADPS0 0
|
||||
#define ADPS1 1
|
||||
#define ADPS2 2
|
||||
#define ADIE 3
|
||||
#define ADIF 4
|
||||
#define ADATE 5
|
||||
#define ADSC 6
|
||||
#define ADEN 7
|
||||
|
||||
#define ADMUX _SFR_IO8(0x07)
|
||||
#define MUX0 0
|
||||
#define MUX1 1
|
||||
#define MUX2 2
|
||||
#define MUX3 3
|
||||
#define MUX4 4
|
||||
#define ADLAR 5
|
||||
#define REFS0 6
|
||||
#define REFS1 7
|
||||
|
||||
#define ACSR _SFR_IO8(0x08)
|
||||
#define ACIS0 0
|
||||
#define ACIS1 1
|
||||
#define ACIC 2
|
||||
#define ACIE 3
|
||||
#define ACI 4
|
||||
#define ACO 5
|
||||
#define ACBG 6
|
||||
#define ACD 7
|
||||
|
||||
#define UBRRL _SFR_IO8(0x09)
|
||||
|
||||
#define UCSRB _SFR_IO8(0x0A)
|
||||
#define TXB8 0
|
||||
#define RXB8 1
|
||||
#define UCSZ2 2
|
||||
#define TXEN 3
|
||||
#define RXEN 4
|
||||
#define UDRIE 5
|
||||
#define TXCIE 6
|
||||
#define RXCIE 7
|
||||
|
||||
#define UCSRA _SFR_IO8(0x0B)
|
||||
#define MPCM 0
|
||||
#define U2X 1
|
||||
#define PE 2
|
||||
#define DOR 3
|
||||
#define FE 4
|
||||
#define UDRE 5
|
||||
#define TXC 6
|
||||
#define RXC 7
|
||||
|
||||
#define UDR _SFR_IO8(0x0C)
|
||||
|
||||
#define SPCR _SFR_IO8(0x0D)
|
||||
#define SPR0 0
|
||||
#define SPR1 1
|
||||
#define CPHA 2
|
||||
#define CPOL 3
|
||||
#define MSTR 4
|
||||
#define DORD 5
|
||||
#define SPE 6
|
||||
#define SPIE 7
|
||||
|
||||
#define SPSR _SFR_IO8(0x0E)
|
||||
#define SPI2X 0
|
||||
#define WCOL 6
|
||||
#define SPIF 7
|
||||
|
||||
#define SPDR _SFR_IO8(0x0F)
|
||||
|
||||
#define PIND _SFR_IO8(0x10)
|
||||
#define PIND0 0
|
||||
#define PIND1 1
|
||||
#define PIND2 2
|
||||
#define PIND3 3
|
||||
#define PIND4 4
|
||||
#define PIND5 5
|
||||
#define PIND6 6
|
||||
#define PIND7 7
|
||||
|
||||
#define DDRD _SFR_IO8(0x11)
|
||||
#define DDD0 0
|
||||
#define DDD1 1
|
||||
#define DDD2 2
|
||||
#define DDD3 3
|
||||
#define DDD4 4
|
||||
#define DDD5 5
|
||||
#define DDD6 6
|
||||
#define DDD7 7
|
||||
|
||||
#define PORTD _SFR_IO8(0x12)
|
||||
#define PD0 0
|
||||
#define PD1 1
|
||||
#define PD2 2
|
||||
#define PD3 3
|
||||
#define PD4 4
|
||||
#define PD5 5
|
||||
#define PD6 6
|
||||
#define PD7 7
|
||||
|
||||
#define PINC _SFR_IO8(0x13)
|
||||
#define PINC0 0
|
||||
#define PINC1 1
|
||||
#define PINC2 2
|
||||
#define PINC3 3
|
||||
#define PINC4 4
|
||||
#define PINC5 5
|
||||
#define PINC6 6
|
||||
#define PINC7 7
|
||||
|
||||
#define DDRC _SFR_IO8(0x14)
|
||||
#define DDC0 0
|
||||
#define DDC1 1
|
||||
#define DDC2 2
|
||||
#define DDC3 3
|
||||
#define DDC4 4
|
||||
#define DDC5 5
|
||||
#define DDC6 6
|
||||
#define DDC7 7
|
||||
|
||||
#define PORTC _SFR_IO8(0x15)
|
||||
#define PC0 0
|
||||
#define PC1 1
|
||||
#define PC2 2
|
||||
#define PC3 3
|
||||
#define PC4 4
|
||||
#define PC5 5
|
||||
#define PC6 6
|
||||
#define PC7 7
|
||||
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
#define PINB0 0
|
||||
#define PINB1 1
|
||||
#define PINB2 2
|
||||
#define PINB3 3
|
||||
#define PINB4 4
|
||||
#define PINB5 5
|
||||
#define PINB6 6
|
||||
#define PINB7 7
|
||||
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
#define DDB0 0
|
||||
#define DDB1 1
|
||||
#define DDB2 2
|
||||
#define DDB3 3
|
||||
#define DDB4 4
|
||||
#define DDB5 5
|
||||
#define DDB6 6
|
||||
#define DDB7 7
|
||||
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
#define PB0 0
|
||||
#define PB1 1
|
||||
#define PB2 2
|
||||
#define PB3 3
|
||||
#define PB4 4
|
||||
#define PB5 5
|
||||
#define PB6 6
|
||||
#define PB7 7
|
||||
|
||||
#define PINA _SFR_IO8(0x19)
|
||||
#define PINA0 0
|
||||
#define PINA1 1
|
||||
#define PINA2 2
|
||||
#define PINA3 3
|
||||
#define PINA4 4
|
||||
#define PINA5 5
|
||||
#define PINA6 6
|
||||
#define PINA7 7
|
||||
|
||||
#define DDRA _SFR_IO8(0x1A)
|
||||
#define DDA0 0
|
||||
#define DDA1 1
|
||||
#define DDA2 2
|
||||
#define DDA3 3
|
||||
#define DDA4 4
|
||||
#define DDA5 5
|
||||
#define DDA6 6
|
||||
#define DDA7 7
|
||||
|
||||
#define PORTA _SFR_IO8(0x1B)
|
||||
#define PA0 0
|
||||
#define PA1 1
|
||||
#define PA2 2
|
||||
#define PA3 3
|
||||
#define PA4 4
|
||||
#define PA5 5
|
||||
#define PA6 6
|
||||
#define PA7 7
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EECR _SFR_IO8(0x1C)
|
||||
#define EERE 0
|
||||
#define EEWE 1
|
||||
#define EEMWE 2
|
||||
#define EERIE 3
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define EEDR _SFR_IO8(0x1D)
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#define EEAR _SFR_IO16(0x1E)
|
||||
#define EEARL _SFR_IO8(0x1E)
|
||||
#define EEARH _SFR_IO8(0x1F)
|
||||
|
||||
#define UCSRC _SFR_IO8(0x20)
|
||||
#define UCPOL 0
|
||||
#define UCSZ0 1
|
||||
#define UCSZ1 2
|
||||
#define USBS 3
|
||||
#define UPM0 4
|
||||
#define UPM1 5
|
||||
#define UMSEL 6
|
||||
#define URSEL 7
|
||||
|
||||
#define UBRRH _SFR_IO8(0x20)
|
||||
#define URSEL 7
|
||||
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
#define WDP0 0
|
||||
#define WDP1 1
|
||||
#define WDP2 2
|
||||
#define WDE 3
|
||||
#define WDTOE 4
|
||||
|
||||
#define ASSR _SFR_IO8(0x22)
|
||||
#define TCR2UB 0
|
||||
#define OCR2UB 1
|
||||
#define TCN2UB 2
|
||||
#define AS2 3
|
||||
|
||||
#define OCR2 _SFR_IO8(0x23)
|
||||
|
||||
#define TCNT2 _SFR_IO8(0x24)
|
||||
|
||||
#define TCCR2 _SFR_IO8(0x25)
|
||||
#define CS20 0
|
||||
#define CS21 1
|
||||
#define CS22 2
|
||||
#define WGM21 3
|
||||
#define COM20 4
|
||||
#define COM21 5
|
||||
#define WGM20 6
|
||||
#define FOC2 7
|
||||
|
||||
/* Combine ICR1L and ICR1H */
|
||||
#define ICR1 _SFR_IO16(0x26)
|
||||
|
||||
#define ICR1L _SFR_IO8(0x26)
|
||||
#define ICR1H _SFR_IO8(0x27)
|
||||
|
||||
/* Combine OCR1BL and OCR1BH */
|
||||
#define OCR1B _SFR_IO16(0x28)
|
||||
|
||||
#define OCR1BL _SFR_IO8(0x28)
|
||||
#define OCR1BH _SFR_IO8(0x29)
|
||||
|
||||
/* Combine OCR1AL and OCR1AH */
|
||||
#define OCR1A _SFR_IO16(0x2A)
|
||||
|
||||
#define OCR1AL _SFR_IO8(0x2A)
|
||||
#define OCR1AH _SFR_IO8(0x2B)
|
||||
|
||||
/* Combine TCNT1L and TCNT1H */
|
||||
#define TCNT1 _SFR_IO16(0x2C)
|
||||
|
||||
#define TCNT1L _SFR_IO8(0x2C)
|
||||
#define TCNT1H _SFR_IO8(0x2D)
|
||||
|
||||
#define TCCR1B _SFR_IO8(0x2E)
|
||||
#define CS10 0
|
||||
#define CS11 1
|
||||
#define CS12 2
|
||||
#define WGM12 3
|
||||
#define WGM13 4
|
||||
#define ICES1 6
|
||||
#define ICNC1 7
|
||||
|
||||
#define TCCR1A _SFR_IO8(0x2F)
|
||||
#define WGM10 0
|
||||
#define WGM11 1
|
||||
#define FOC1B 2
|
||||
#define FOC1A 3
|
||||
#define COM1B0 4
|
||||
#define COM1B1 5
|
||||
#define COM1A0 6
|
||||
#define COM1A1 7
|
||||
|
||||
/*
|
||||
The ADHSM bit has been removed from all documentation,
|
||||
as being not needed at all since the comparator has proven
|
||||
to be fast enough even without feeding it more power.
|
||||
*/
|
||||
|
||||
#define SFIOR _SFR_IO8(0x30)
|
||||
#define PSR10 0
|
||||
#define PSR2 1
|
||||
#define PUD 2
|
||||
#define ACME 3
|
||||
#define ADTS0 5
|
||||
#define ADTS1 6
|
||||
#define ADTS2 7
|
||||
|
||||
#define OSCCAL _SFR_IO8(0x31)
|
||||
|
||||
#define OCDR _SFR_IO8(0x31)
|
||||
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
#define CS00 0
|
||||
#define CS01 1
|
||||
#define CS02 2
|
||||
#define WGM01 3
|
||||
#define COM00 4
|
||||
#define COM01 5
|
||||
#define WGM00 6
|
||||
#define FOC0 7
|
||||
|
||||
#define MCUCSR _SFR_IO8(0x34)
|
||||
#define PORF 0
|
||||
#define EXTRF 1
|
||||
#define BORF 2
|
||||
#define WDRF 3
|
||||
#define JTRF 4
|
||||
#define ISC2 6
|
||||
#define JTD 7
|
||||
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
#define ISC00 0
|
||||
#define ISC01 1
|
||||
#define ISC10 2
|
||||
#define ISC11 3
|
||||
#define SM0 4
|
||||
#define SM1 5
|
||||
#define SE 6
|
||||
#define SM2 7
|
||||
|
||||
#define TWCR _SFR_IO8(0x36)
|
||||
#define TWIE 0
|
||||
#define TWEN 2
|
||||
#define TWWC 3
|
||||
#define TWSTO 4
|
||||
#define TWSTA 5
|
||||
#define TWEA 6
|
||||
#define TWINT 7
|
||||
|
||||
#define SPMCR _SFR_IO8(0x37)
|
||||
#define SPMEN 0
|
||||
#define PGERS 1
|
||||
#define PGWRT 2
|
||||
#define BLBSET 3
|
||||
#define RWWSRE 4
|
||||
#define RWWSB 6
|
||||
#define SPMIE 7
|
||||
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
#define TOV0 0
|
||||
#define OCF0 1
|
||||
#define TOV1 2
|
||||
#define OCF1B 3
|
||||
#define OCF1A 4
|
||||
#define ICF1 5
|
||||
#define TOV2 6
|
||||
#define OCF2 7
|
||||
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
#define TOIE0 0
|
||||
#define OCIE0 1
|
||||
#define TOIE1 2
|
||||
#define OCIE1B 3
|
||||
#define OCIE1A 4
|
||||
#define TICIE1 5
|
||||
#define TOIE2 6
|
||||
#define OCIE2 7
|
||||
|
||||
#define GIFR _SFR_IO8(0x3A)
|
||||
#define INTF2 5
|
||||
#define INTF0 6
|
||||
#define INTF1 7
|
||||
|
||||
#define GICR _SFR_IO8(0x3B)
|
||||
#define IVCE 0
|
||||
#define IVSEL 1
|
||||
#define INT2 5
|
||||
#define INT0 6
|
||||
#define INT1 7
|
||||
|
||||
#define OCR0 _SFR_IO8(0x3C)
|
||||
|
||||
/* SP [0x3D..0x3E] */
|
||||
/* SREG [0x3F] */
|
||||
|
||||
|
||||
/* 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)
|
||||
|
||||
/* Timer/Counter2 Compare Match */
|
||||
#define TIMER2_COMP_vect _VECTOR(3)
|
||||
#define SIG_OUTPUT_COMPARE2 _VECTOR(3)
|
||||
|
||||
/* Timer/Counter2 Overflow */
|
||||
#define TIMER2_OVF_vect _VECTOR(4)
|
||||
#define SIG_OVERFLOW2 _VECTOR(4)
|
||||
|
||||
/* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(5)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(5)
|
||||
|
||||
/* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPA_vect _VECTOR(6)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(6)
|
||||
|
||||
/* Timer/Counter1 Compare Match B */
|
||||
#define TIMER1_COMPB_vect _VECTOR(7)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(7)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(8)
|
||||
#define SIG_OVERFLOW1 _VECTOR(8)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(9)
|
||||
#define SIG_OVERFLOW0 _VECTOR(9)
|
||||
|
||||
/* Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(10)
|
||||
#define SIG_SPI _VECTOR(10)
|
||||
|
||||
/* USART, Rx Complete */
|
||||
#define USART_RXC_vect _VECTOR(11)
|
||||
#define SIG_USART_RECV _VECTOR(11)
|
||||
#define SIG_UART_RECV _VECTOR(11)
|
||||
|
||||
/* USART Data Register Empty */
|
||||
#define USART_UDRE_vect _VECTOR(12)
|
||||
#define SIG_USART_DATA _VECTOR(12)
|
||||
#define SIG_UART_DATA _VECTOR(12)
|
||||
|
||||
/* USART, Tx Complete */
|
||||
#define USART_TXC_vect _VECTOR(13)
|
||||
#define SIG_USART_TRANS _VECTOR(13)
|
||||
#define SIG_UART_TRANS _VECTOR(13)
|
||||
|
||||
/* ADC Conversion Complete */
|
||||
#define ADC_vect _VECTOR(14)
|
||||
#define SIG_ADC _VECTOR(14)
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_RDY_vect _VECTOR(15)
|
||||
#define SIG_EEPROM_READY _VECTOR(15)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANA_COMP_vect _VECTOR(16)
|
||||
#define SIG_COMPARATOR _VECTOR(16)
|
||||
|
||||
/* 2-wire Serial Interface */
|
||||
#define TWI_vect _VECTOR(17)
|
||||
#define SIG_2WIRE_SERIAL _VECTOR(17)
|
||||
|
||||
/* External Interrupt Request 2 */
|
||||
#define INT2_vect _VECTOR(18)
|
||||
#define SIG_INTERRUPT2 _VECTOR(18)
|
||||
|
||||
/* Timer/Counter0 Compare Match */
|
||||
#define TIMER0_COMP_vect _VECTOR(19)
|
||||
#define SIG_OUTPUT_COMPARE0 _VECTOR(19)
|
||||
|
||||
/* Store Program Memory Ready */
|
||||
#define SPM_RDY_vect _VECTOR(20)
|
||||
#define SIG_SPM_READY _VECTOR(20)
|
||||
|
||||
#define _VECTORS_SIZE 84
|
||||
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 128
|
||||
#define RAMEND 0x45F
|
||||
#define XRAMEND 0x45F
|
||||
#define E2END 0x1FF
|
||||
#define E2PAGESIZE 4
|
||||
#define FLASHEND 0x3FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 2
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_BODEN (unsigned char)~_BV(6)
|
||||
#define FUSE_BODLEVEL (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL1 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_CKOPT (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x94
|
||||
#define SIGNATURE_2 0x03
|
||||
|
||||
|
||||
#endif /* _AVR_IOM16_H_ */
|
673
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom161.h
Normal file
673
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom161.h
Normal file
|
@ -0,0 +1,673 @@
|
|||
/* Copyright (c) 2002, Marek Michalkiewicz
|
||||
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: iom161.h,v 1.10.2.5 2008/10/17 23:27:47 arcanum Exp $ */
|
||||
|
||||
/* avr/iom161.h - definitions for ATmega161 */
|
||||
|
||||
#ifndef _AVR_IOM161_H_
|
||||
#define _AVR_IOM161_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_ "iom161.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* UART1 Baud Rate Register */
|
||||
#define UBRR1 _SFR_IO8(0x00)
|
||||
|
||||
/* UART1 Control and Status Registers */
|
||||
#define UCSR1B _SFR_IO8(0x01)
|
||||
#define UCSR1A _SFR_IO8(0x02)
|
||||
|
||||
/* UART1 I/O Data Register */
|
||||
#define UDR1 _SFR_IO8(0x03)
|
||||
|
||||
/* 0x04 reserved */
|
||||
|
||||
/* Input Pins, Port E */
|
||||
#define PINE _SFR_IO8(0x05)
|
||||
|
||||
/* Data Direction Register, Port E */
|
||||
#define DDRE _SFR_IO8(0x06)
|
||||
|
||||
/* Data Register, Port E */
|
||||
#define PORTE _SFR_IO8(0x07)
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACSR _SFR_IO8(0x08)
|
||||
|
||||
/* UART0 Baud Rate Register */
|
||||
#define UBRR0 _SFR_IO8(0x09)
|
||||
|
||||
/* UART0 Control and Status Registers */
|
||||
#define UCSR0B _SFR_IO8(0x0A)
|
||||
#define UCSR0A _SFR_IO8(0x0B)
|
||||
|
||||
/* UART0 I/O Data Register */
|
||||
#define UDR0 _SFR_IO8(0x0C)
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPCR _SFR_IO8(0x0D)
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPSR _SFR_IO8(0x0E)
|
||||
|
||||
/* SPI I/O Data Register */
|
||||
#define SPDR _SFR_IO8(0x0F)
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND _SFR_IO8(0x10)
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDRD _SFR_IO8(0x11)
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PORTD _SFR_IO8(0x12)
|
||||
|
||||
/* Input Pins, Port C */
|
||||
#define PINC _SFR_IO8(0x13)
|
||||
|
||||
/* Data Direction Register, Port C */
|
||||
#define DDRC _SFR_IO8(0x14)
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PORTC _SFR_IO8(0x15)
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
|
||||
/* Input Pins, Port A */
|
||||
#define PINA _SFR_IO8(0x19)
|
||||
|
||||
/* Data Direction Register, Port A */
|
||||
#define DDRA _SFR_IO8(0x1A)
|
||||
|
||||
/* Data Register, Port A */
|
||||
#define PORTA _SFR_IO8(0x1B)
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EECR _SFR_IO8(0x1C)
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define EEDR _SFR_IO8(0x1D)
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#define EEAR _SFR_IO16(0x1E)
|
||||
#define EEARL _SFR_IO8(0x1E)
|
||||
#define EEARH _SFR_IO8(0x1F)
|
||||
|
||||
/* UART Baud Register HIgh */
|
||||
#define UBRRH _SFR_IO8(0x20)
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
|
||||
/* Timer/Counter2 Output Compare Register */
|
||||
#define OCR2 _SFR_IO8(0x22)
|
||||
|
||||
/* Timer/Counter2 (8-bit) */
|
||||
#define TCNT2 _SFR_IO8(0x23)
|
||||
|
||||
/* Timer/Counter1 Input Capture Register */
|
||||
#define ICR1 _SFR_IO16(0x24)
|
||||
#define ICR1L _SFR_IO8(0x24)
|
||||
#define ICR1H _SFR_IO8(0x25)
|
||||
|
||||
/* ASynchronous mode Status Register */
|
||||
#define ASSR _SFR_IO8(0x26)
|
||||
|
||||
/* Timer/Counter2 Control Register */
|
||||
#define TCCR2 _SFR_IO8(0x27)
|
||||
|
||||
/* Timer/Counter1 Output Compare RegisterB */
|
||||
#define OCR1B _SFR_IO16(0x28)
|
||||
#define OCR1BL _SFR_IO8(0x28)
|
||||
#define OCR1BH _SFR_IO8(0x29)
|
||||
|
||||
/* Timer/Counter1 Output Compare RegisterA */
|
||||
#define OCR1A _SFR_IO16(0x2A)
|
||||
#define OCR1AL _SFR_IO8(0x2A)
|
||||
#define OCR1AH _SFR_IO8(0x2B)
|
||||
|
||||
/* Timer/Counter1 */
|
||||
#define TCNT1 _SFR_IO16(0x2C)
|
||||
#define TCNT1L _SFR_IO8(0x2C)
|
||||
#define TCNT1H _SFR_IO8(0x2D)
|
||||
|
||||
/* Timer/Counter1 Control Register B */
|
||||
#define TCCR1B _SFR_IO8(0x2E)
|
||||
|
||||
/* Timer/Counter1 Control Register A */
|
||||
#define TCCR1A _SFR_IO8(0x2F)
|
||||
|
||||
/* Special Function IO Register */
|
||||
#define SFIOR _SFR_IO8(0x30)
|
||||
|
||||
/* Timer/Counter0 Output Compare Register */
|
||||
#define OCR0 _SFR_IO8(0x31)
|
||||
|
||||
/* Timer/Counter0 (8-bit) */
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
|
||||
/* Timer/Counter0 Control Register */
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
/* MCU general Status Register */
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
/* Extended MCU general Control Register */
|
||||
#define EMCUCR _SFR_IO8(0x36)
|
||||
|
||||
/* Store Program Memory Control Register */
|
||||
#define SPMCR _SFR_IO8(0x37)
|
||||
|
||||
/* Timer/Counter Interrupt Flag Register */
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
|
||||
/* Timer/Counter Interrupt MaSK Register */
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define GIFR _SFR_IO8(0x3A)
|
||||
|
||||
/* General Interrupt MaSK register */
|
||||
#define GIMSK _SFR_IO8(0x3B)
|
||||
|
||||
/* 0x3C reserved */
|
||||
|
||||
/* 0x3D..0x3E SP */
|
||||
|
||||
/* 0x3F SREG */
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
/* External Interrupt 0 */
|
||||
#define INT0_vect _VECTOR(1)
|
||||
#define SIG_INTERRUPT0 _VECTOR(1)
|
||||
|
||||
/* External Interrupt 1 */
|
||||
#define INT1_vect _VECTOR(2)
|
||||
#define SIG_INTERRUPT1 _VECTOR(2)
|
||||
|
||||
/* External Interrupt 2 */
|
||||
#define INT2_vect _VECTOR(3)
|
||||
#define SIG_INTERRUPT2 _VECTOR(3)
|
||||
|
||||
/* Timer/Counter2 Compare Match */
|
||||
#define TIMER2_COMP_vect _VECTOR(4)
|
||||
#define SIG_OUTPUT_COMPARE2 _VECTOR(4)
|
||||
|
||||
/* Timer/Counter2 Overflow */
|
||||
#define TIMER2_OVF_vect _VECTOR(5)
|
||||
#define SIG_OVERFLOW2 _VECTOR(5)
|
||||
|
||||
/* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(6)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(6)
|
||||
|
||||
/* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPA_vect _VECTOR(7)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(7)
|
||||
|
||||
/* Timer/Counter1 Compare Match B */
|
||||
#define TIMER1_COMPB_vect _VECTOR(8)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(8)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(9)
|
||||
#define SIG_OVERFLOW1 _VECTOR(9)
|
||||
|
||||
/* Timer/Counter0 Compare Match */
|
||||
#define TIMER0_COMP_vect _VECTOR(10)
|
||||
#define SIG_OUTPUT_COMPARE0 _VECTOR(10)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(11)
|
||||
#define SIG_OVERFLOW0 _VECTOR(11)
|
||||
|
||||
/* Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(12)
|
||||
#define SIG_SPI _VECTOR(12)
|
||||
|
||||
/* UART0, Rx Complete */
|
||||
#define UART0_RX_vect _VECTOR(13)
|
||||
#define SIG_UART0_RECV _VECTOR(13)
|
||||
|
||||
/* UART1, Rx Complete */
|
||||
#define UART1_RX_vect _VECTOR(14)
|
||||
#define SIG_UART1_RECV _VECTOR(14)
|
||||
|
||||
/* UART0 Data Register Empty */
|
||||
#define UART0_UDRE_vect _VECTOR(15)
|
||||
#define SIG_UART0_DATA _VECTOR(15)
|
||||
|
||||
/* UART1 Data Register Empty */
|
||||
#define UART1_UDRE_vect _VECTOR(16)
|
||||
#define SIG_UART1_DATA _VECTOR(16)
|
||||
|
||||
/* UART0, Tx Complete */
|
||||
#define UART0_TX_vect _VECTOR(17)
|
||||
#define SIG_UART0_TRANS _VECTOR(17)
|
||||
|
||||
/* UART1, Tx Complete */
|
||||
#define UART1_TX_vect _VECTOR(18)
|
||||
#define SIG_UART1_TRANS _VECTOR(18)
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_RDY_vect _VECTOR(19)
|
||||
#define SIG_EEPROM_READY _VECTOR(19)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANA_COMP_vect _VECTOR(20)
|
||||
#define SIG_COMPARATOR _VECTOR(20)
|
||||
|
||||
#define _VECTORS_SIZE 84
|
||||
|
||||
/* Bit numbers */
|
||||
|
||||
/* GIMSK */
|
||||
#define INT1 7
|
||||
#define INT0 6
|
||||
#define INT2 5
|
||||
|
||||
/* GIFR */
|
||||
#define INTF1 7
|
||||
#define INTF0 6
|
||||
#define INTF2 5
|
||||
|
||||
/* TIMSK */
|
||||
#define TOIE1 7
|
||||
#define OCIE1A 6
|
||||
#define OCIE1B 5
|
||||
#define TOIE2 4
|
||||
#define TICIE1 3
|
||||
#define OCIE2 2
|
||||
#define TOIE0 1
|
||||
#define OCIE0 0
|
||||
|
||||
/* TIFR */
|
||||
#define TOV1 7
|
||||
#define OCF1A 6
|
||||
#define OCF1B 5
|
||||
#define TOV2 4
|
||||
#define ICF1 3
|
||||
#define OCF2 2
|
||||
#define TOV0 1
|
||||
#define OCF0 0
|
||||
|
||||
/* MCUCR */
|
||||
#define SRE 7
|
||||
#define SRW10 6
|
||||
#define SE 5
|
||||
#define SM1 4
|
||||
#define ISC11 3
|
||||
#define ISC10 2
|
||||
#define ISC01 1
|
||||
#define ISC00 0
|
||||
|
||||
/* EMCUCR */
|
||||
#define SM0 7
|
||||
#define SRL2 6
|
||||
#define SRL1 5
|
||||
#define SRL0 4
|
||||
#define SRW01 3
|
||||
#define SRW00 2
|
||||
#define SRW11 1
|
||||
#define ISC2 0
|
||||
|
||||
/* SPMCR */
|
||||
#define BLBSET 3
|
||||
#define PGWRT 2
|
||||
#define PGERS 1
|
||||
#define SPMEN 0
|
||||
|
||||
/* SFIOR */
|
||||
#define PSR2 1
|
||||
#define PSR10 0
|
||||
|
||||
/* TCCR0 */
|
||||
#define FOC0 7
|
||||
#define PWM0 6
|
||||
#define COM01 5
|
||||
#define COM00 4
|
||||
#define CTC0 3
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/* TCCR2 */
|
||||
#define FOC2 7
|
||||
#define PWM2 6
|
||||
#define COM21 5
|
||||
#define COM20 4
|
||||
#define CTC2 3
|
||||
#define CS22 2
|
||||
#define CS21 1
|
||||
#define CS20 0
|
||||
|
||||
/* ASSR */
|
||||
#define AS2 3
|
||||
#define TCN2UB 2
|
||||
#define OCR2UB 1
|
||||
#define TCR2UB 0
|
||||
|
||||
/* TCCR1A */
|
||||
#define COM1A1 7
|
||||
#define COM1A0 6
|
||||
#define COM1B1 5
|
||||
#define COM1B0 4
|
||||
#define FOC1A 3
|
||||
#define FOC1B 2
|
||||
#define PWM11 1
|
||||
#define PWM10 0
|
||||
|
||||
/* TCCR1B */
|
||||
#define ICNC1 7
|
||||
#define ICES1 6
|
||||
#define CTC1 3
|
||||
#define CS12 2
|
||||
#define CS11 1
|
||||
#define CS10 0
|
||||
|
||||
/* WDTCR */
|
||||
#define WDTOE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/* PORTA */
|
||||
#define PA7 7
|
||||
#define PA6 6
|
||||
#define PA5 5
|
||||
#define PA4 4
|
||||
#define PA3 3
|
||||
#define PA2 2
|
||||
#define PA1 1
|
||||
#define PA0 0
|
||||
|
||||
/* DDRA */
|
||||
#define DDA7 7
|
||||
#define DDA6 6
|
||||
#define DDA5 5
|
||||
#define DDA4 4
|
||||
#define DDA3 3
|
||||
#define DDA2 2
|
||||
#define DDA1 1
|
||||
#define DDA0 0
|
||||
|
||||
/* PINA */
|
||||
#define PINA7 7
|
||||
#define PINA6 6
|
||||
#define PINA5 5
|
||||
#define PINA4 4
|
||||
#define PINA3 3
|
||||
#define PINA2 2
|
||||
#define PINA1 1
|
||||
#define PINA0 0
|
||||
|
||||
/*
|
||||
PB7 = SCK
|
||||
PB6 = MISO
|
||||
PB5 = MOSI
|
||||
PB4 = SS#
|
||||
PB3 = TXD1 / AIN1
|
||||
PB2 = RXD1 / AIN0
|
||||
PB1 = OC2 / T1
|
||||
PB0 = OC0 / T0
|
||||
*/
|
||||
|
||||
/* PORTB */
|
||||
#define PB7 7
|
||||
#define PB6 6
|
||||
#define PB5 5
|
||||
#define PB4 4
|
||||
#define PB3 3
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
/* DDRB */
|
||||
#define DDB7 7
|
||||
#define DDB6 6
|
||||
#define DDB5 5
|
||||
#define DDB4 4
|
||||
#define DDB3 3
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
/* PINB */
|
||||
#define PINB7 7
|
||||
#define PINB6 6
|
||||
#define PINB5 5
|
||||
#define PINB4 4
|
||||
#define PINB3 3
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
/* PORTC */
|
||||
#define PC7 7
|
||||
#define PC6 6
|
||||
#define PC5 5
|
||||
#define PC4 4
|
||||
#define PC3 3
|
||||
#define PC2 2
|
||||
#define PC1 1
|
||||
#define PC0 0
|
||||
|
||||
/* DDRC */
|
||||
#define DDC7 7
|
||||
#define DDC6 6
|
||||
#define DDC5 5
|
||||
#define DDC4 4
|
||||
#define DDC3 3
|
||||
#define DDC2 2
|
||||
#define DDC1 1
|
||||
#define DDC0 0
|
||||
|
||||
/* PINC */
|
||||
#define PINC7 7
|
||||
#define PINC6 6
|
||||
#define PINC5 5
|
||||
#define PINC4 4
|
||||
#define PINC3 3
|
||||
#define PINC2 2
|
||||
#define PINC1 1
|
||||
#define PINC0 0
|
||||
|
||||
/*
|
||||
PD7 = RD#
|
||||
PD6 = WR#
|
||||
PD5 = TOSC2 / OC1A
|
||||
PD4 = TOSC1
|
||||
PD3 = INT1
|
||||
PD2 = INT0
|
||||
PD1 = TXD0
|
||||
PD0 = RXD0
|
||||
*/
|
||||
|
||||
/* PORTD */
|
||||
#define PD7 7
|
||||
#define PD6 6
|
||||
#define PD5 5
|
||||
#define PD4 4
|
||||
#define PD3 3
|
||||
#define PD2 2
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
/* DDRD */
|
||||
#define DDD7 7
|
||||
#define DDD6 6
|
||||
#define DDD5 5
|
||||
#define DDD4 4
|
||||
#define DDD3 3
|
||||
#define DDD2 2
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
/* PIND */
|
||||
#define PIND7 7
|
||||
#define PIND6 6
|
||||
#define PIND5 5
|
||||
#define PIND4 4
|
||||
#define PIND3 3
|
||||
#define PIND2 2
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
/*
|
||||
PE2 = ALE
|
||||
PE1 = OC1B
|
||||
PE0 = ICP / INT2
|
||||
*/
|
||||
|
||||
/* PORTE */
|
||||
#define PE2 2
|
||||
#define PE1 1
|
||||
#define PE0 0
|
||||
|
||||
/* DDRE */
|
||||
#define DDE2 2
|
||||
#define DDE1 1
|
||||
#define DDE0 0
|
||||
|
||||
/* PINE */
|
||||
#define PINE2 2
|
||||
#define PINE1 1
|
||||
#define PINE0 0
|
||||
|
||||
/* SPSR */
|
||||
#define SPIF 7
|
||||
#define WCOL 6
|
||||
#define SPI2X 0
|
||||
|
||||
/* SPCR */
|
||||
#define SPIE 7
|
||||
#define SPE 6
|
||||
#define DORD 5
|
||||
#define MSTR 4
|
||||
#define CPOL 3
|
||||
#define CPHA 2
|
||||
#define SPR1 1
|
||||
#define SPR0 0
|
||||
|
||||
/* UCSR0A, UCSR1A */
|
||||
#define RXC 7
|
||||
#define TXC 6
|
||||
#define UDRE 5
|
||||
#define FE 4
|
||||
#define DOR 3
|
||||
#define U2X 1
|
||||
#define MPCM 0
|
||||
|
||||
/* UCSR0B, UCSR1B */
|
||||
#define RXCIE 7
|
||||
#define TXCIE 6
|
||||
#define UDRIE 5
|
||||
#define RXEN 4
|
||||
#define TXEN 3
|
||||
#define CHR9 2
|
||||
#define RXB8 1
|
||||
#define TXB8 0
|
||||
|
||||
/* ACSR */
|
||||
#define ACD 7
|
||||
#define AINBG 6
|
||||
#define ACO 5
|
||||
#define ACI 4
|
||||
#define ACIE 3
|
||||
#define ACIC 2
|
||||
#define ACIS1 1
|
||||
#define ACIS0 0
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EERIE 3
|
||||
#define EEMWE 2
|
||||
#define EEWE 1
|
||||
#define EERE 0
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 128
|
||||
#define RAMEND 0x45F
|
||||
#define XRAMEND 0xFFFF
|
||||
#define E2END 0x1FF
|
||||
#define E2PAGESIZE 0
|
||||
#define FLASHEND 0x3FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 1
|
||||
|
||||
/* Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_SUT (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(6)
|
||||
#define FUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_SPIEN)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x94
|
||||
#define SIGNATURE_2 0x01
|
||||
|
||||
|
||||
#endif /* _AVR_IOM161_H_ */
|
951
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom162.h
Normal file
951
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom162.h
Normal file
|
@ -0,0 +1,951 @@
|
|||
/* Copyright (c) 2002, Nils Kristian Strom <nilsst@omegav.ntnu.no>
|
||||
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: iom162.h,v 1.13.2.5 2008/10/17 23:27:47 arcanum Exp $ */
|
||||
|
||||
/* iom162.h - definitions for ATmega162 */
|
||||
|
||||
#ifndef _AVR_IOM162_H_
|
||||
#define _AVR_IOM162_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_ "iom162.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* Memory mapped I/O registers */
|
||||
|
||||
/* Timer/Counter3 Control Register A */
|
||||
#define TCCR3A _SFR_MEM8(0x8B)
|
||||
|
||||
/* Timer/Counter3 Control Register B */
|
||||
#define TCCR3B _SFR_MEM8(0x8A)
|
||||
|
||||
/* Timer/Counter3 - Counter Register */
|
||||
#define TCNT3H _SFR_MEM8(0x89)
|
||||
#define TCNT3L _SFR_MEM8(0x88)
|
||||
#define TCNT3 _SFR_MEM16(0x88)
|
||||
|
||||
/* Timer/Counter3 - Output Compare Register A */
|
||||
#define OCR3AH _SFR_MEM8(0x87)
|
||||
#define OCR3AL _SFR_MEM8(0x86)
|
||||
#define OCR3A _SFR_MEM16(0x86)
|
||||
|
||||
/* Timer/Counter3 - Output Compare Register B */
|
||||
#define OCR3BH _SFR_MEM8(0x85)
|
||||
#define OCR3BL _SFR_MEM8(0x84)
|
||||
#define OCR3B _SFR_MEM16(0x84)
|
||||
|
||||
/* Timer/Counter3 - Input Capture Register */
|
||||
#define ICR3H _SFR_MEM8(0x81)
|
||||
#define ICR3L _SFR_MEM8(0x80)
|
||||
#define ICR3 _SFR_MEM16(0x80)
|
||||
|
||||
/* Extended Timer/Counter Interrupt Mask */
|
||||
#define ETIMSK _SFR_MEM8(0x7D)
|
||||
|
||||
/* Extended Timer/Counter Interrupt Flag Register */
|
||||
#define ETIFR _SFR_MEM8(0x7C)
|
||||
|
||||
/* Pin Change Mask Register 1 */
|
||||
#define PCMSK1 _SFR_MEM8(0x6C)
|
||||
|
||||
/* Pin Change Mask Register 0 */
|
||||
#define PCMSK0 _SFR_MEM8(0x6B)
|
||||
|
||||
/* Clock PRescale */
|
||||
#define CLKPR _SFR_MEM8(0x61)
|
||||
|
||||
|
||||
/* Standard I/O registers */
|
||||
|
||||
/* 0x3F SREG */
|
||||
/* 0x3D..0x3E SP */
|
||||
#define UBRR1H _SFR_IO8(0x3C) /* USART 1 Baud Rate Register High Byte, Shared with UCSR1C */
|
||||
#define UCSR1C _SFR_IO8(0x3C) /* USART 1 Control and Status Register, Shared with UBRR1H */
|
||||
#define GICR _SFR_IO8(0x3B) /* General Interrupt Control Register */
|
||||
#define GIFR _SFR_IO8(0x3A) /* General Interrupt Flag Register */
|
||||
#define TIMSK _SFR_IO8(0x39) /* Timer Interrupt Mask */
|
||||
#define TIFR _SFR_IO8(0x38) /* Timer Interrupt Flag Register */
|
||||
#define SPMCR _SFR_IO8(0x37) /* Store Program Memory Control Register */
|
||||
#define EMCUCR _SFR_IO8(0x36) /* Extended MCU Control Register */
|
||||
#define MCUCR _SFR_IO8(0x35) /* MCU Control Register */
|
||||
#define MCUCSR _SFR_IO8(0x34) /* MCU Control and Status Register */
|
||||
#define TCCR0 _SFR_IO8(0x33) /* Timer/Counter 0 Control Register */
|
||||
#define TCNT0 _SFR_IO8(0x32) /* TImer/Counter 0 */
|
||||
#define OCR0 _SFR_IO8(0x31) /* Output Compare Register 0 */
|
||||
#define SFIOR _SFR_IO8(0x30) /* Special Function I/O Register */
|
||||
#define TCCR1A _SFR_IO8(0x2F) /* Timer/Counter 1 Control Register A */
|
||||
#define TCCR1B _SFR_IO8(0x2E) /* Timer/Counter 1 Control Register A */
|
||||
#define TCNT1H _SFR_IO8(0x2D) /* Timer/Counter 1 High Byte */
|
||||
#define TCNT1L _SFR_IO8(0x2C) /* Timer/Counter 1 Low Byte */
|
||||
#define TCNT1 _SFR_IO16(0x2C) /* Timer/Counter 1 */
|
||||
#define OCR1AH _SFR_IO8(0x2B) /* Timer/Counter 1 Output Compare Register A High Byte */
|
||||
#define OCR1AL _SFR_IO8(0x2A) /* Timer/Counter 1 Output Compare Register A Low Byte */
|
||||
#define OCR1A _SFR_IO16(0x2A) /* Timer/Counter 1 Output Compare Register A */
|
||||
#define OCR1BH _SFR_IO8(0x29) /* Timer/Counter 1 Output Compare Register B High Byte */
|
||||
#define OCR1BL _SFR_IO8(0x28) /* Timer/Counter 1 Output Compare Register B Low Byte */
|
||||
#define OCR1B _SFR_IO16(0x28) /* Timer/Counter 1 Output Compare Register B */
|
||||
#define TCCR2 _SFR_IO8(0x27) /* Timer/Counter 2 Control Register */
|
||||
#define ASSR _SFR_IO8(0x26) /* Asynchronous Status Register */
|
||||
#define ICR1H _SFR_IO8(0x25) /* Input Capture Register 1 High Byte */
|
||||
#define ICR1L _SFR_IO8(0x24) /* Input Capture Register 1 Low Byte */
|
||||
#define ICR1 _SFR_IO16(0x24) /* Input Capture Register 1 */
|
||||
#define TCNT2 _SFR_IO8(0x23) /* Timer/Counter 2 */
|
||||
#define OCR2 _SFR_IO8(0x22) /* Timer/Counter 2 Output Compare Register */
|
||||
#define WDTCR _SFR_IO8(0x21) /* Watchdow Timer Control Register */
|
||||
#define UBRR0H _SFR_IO8(0x20) /* USART 0 Baud-Rate Register High Byte, Shared with UCSR0C */
|
||||
#define UCSR0C _SFR_IO8(0x20) /* USART 0 Control and Status Register C, Shared with UBRR0H */
|
||||
#define EEARH _SFR_IO8(0x1F) /* EEPROM Address Register High Byte */
|
||||
#define EEARL _SFR_IO8(0x1E) /* EEPROM Address Register Low Byte */
|
||||
#define EEAR _SFR_IO16(0x1E) /* EEPROM Address Register */
|
||||
#define EEDR _SFR_IO8(0x1D) /* EEPROM Data Register */
|
||||
#define EECR _SFR_IO8(0x1C) /* EEPROM Control Register */
|
||||
#define PORTA _SFR_IO8(0x1B) /* Port A */
|
||||
#define DDRA _SFR_IO8(0x1A) /* Port A Data Direction Register */
|
||||
#define PINA _SFR_IO8(0x19) /* Port A Pin Register */
|
||||
#define PORTB _SFR_IO8(0x18) /* Port B */
|
||||
#define DDRB _SFR_IO8(0x17) /* Port B Data Direction Register */
|
||||
#define PINB _SFR_IO8(0x16) /* Port B Pin Register */
|
||||
#define PORTC _SFR_IO8(0x15) /* Port C */
|
||||
#define DDRC _SFR_IO8(0x14) /* Port C Data Direction Register */
|
||||
#define PINC _SFR_IO8(0x13) /* Port C Pin Register */
|
||||
#define PORTD _SFR_IO8(0x12) /* Port D */
|
||||
#define DDRD _SFR_IO8(0x11) /* Port D Data Direction Register */
|
||||
#define PIND _SFR_IO8(0x10) /* Port D Pin Register */
|
||||
#define SPDR _SFR_IO8(0x0F) /* SPI Data Register */
|
||||
#define SPSR _SFR_IO8(0x0E) /* SPI Status Register */
|
||||
#define SPCR _SFR_IO8(0x0D) /* SPI Control Register */
|
||||
#define UDR0 _SFR_IO8(0x0C) /* USART 0 Data Register */
|
||||
#define UCSR0A _SFR_IO8(0x0B) /* USART 0 Control and Status Register A */
|
||||
#define UCSR0B _SFR_IO8(0x0A) /* USART 0 Control and Status Register B */
|
||||
#define UBRR0L _SFR_IO8(0x09) /* USART 0 Baud-Rate Register Low Byte */
|
||||
#define ACSR _SFR_IO8(0x08) /* Analog Comparator Status Register */
|
||||
#define PORTE _SFR_IO8(0x07) /* Port E */
|
||||
#define DDRE _SFR_IO8(0x06) /* Port E Data Direction Register */
|
||||
#define PINE _SFR_IO8(0x05) /* Port E Pin Register */
|
||||
#define OSCCAL _SFR_IO8(0x04) /* Oscillator Calibration, Shared with OCDR */
|
||||
#define OCDR _SFR_IO8(0x04) /* On-Chip Debug Register, Shared with OSCCAL */
|
||||
#define UDR1 _SFR_IO8(0x03) /* USART 1 Data Register */
|
||||
#define UCSR1A _SFR_IO8(0x02) /* USART 1 Control and Status Register A */
|
||||
#define UCSR1B _SFR_IO8(0x01) /* USART 1 Control and Status Register B */
|
||||
#define UBRR1L _SFR_IO8(0x00) /* USART 0 Baud Rate Register High Byte */
|
||||
|
||||
|
||||
/* Interrupt vectors (byte addresses) */
|
||||
|
||||
/* 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)
|
||||
|
||||
/* Pin Change Interrupt Request 0 */
|
||||
#define PCINT0_vect _VECTOR(4)
|
||||
#define SIG_PIN_CHANGE0 _VECTOR(4)
|
||||
|
||||
/* Pin Change Interrupt Request 1 */
|
||||
#define PCINT1_vect _VECTOR(5)
|
||||
#define SIG_PIN_CHANGE1 _VECTOR(5)
|
||||
|
||||
/* Timer/Counter3 Capture Event */
|
||||
#define TIMER3_CAPT_vect _VECTOR(6)
|
||||
#define SIG_INPUT_CAPTURE3 _VECTOR(6)
|
||||
|
||||
/* Timer/Counter3 Compare Match A */
|
||||
#define TIMER3_COMPA_vect _VECTOR(7)
|
||||
#define SIG_OUTPUT_COMPARE3A _VECTOR(7)
|
||||
|
||||
/* Timer/Counter3 Compare Match B */
|
||||
#define TIMER3_COMPB_vect _VECTOR(8)
|
||||
#define SIG_OUTPUT_COMPARE3B _VECTOR(8)
|
||||
|
||||
/* Timer/Counter3 Overflow */
|
||||
#define TIMER3_OVF_vect _VECTOR(9)
|
||||
#define SIG_OVERFLOW3 _VECTOR(9)
|
||||
|
||||
/* Timer/Counter2 Compare Match */
|
||||
#define TIMER2_COMP_vect _VECTOR(10)
|
||||
#define SIG_OUTPUT_COMPARE2 _VECTOR(10)
|
||||
|
||||
/* Timer/Counter2 Overflow */
|
||||
#define TIMER2_OVF_vect _VECTOR(11)
|
||||
#define SIG_OVERFLOW2 _VECTOR(11)
|
||||
|
||||
/* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(12)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(12)
|
||||
|
||||
/* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPA_vect _VECTOR(13)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(13)
|
||||
|
||||
/* Timer/Counter Compare Match B */
|
||||
#define TIMER1_COMPB_vect _VECTOR(14)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(14)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(15)
|
||||
#define SIG_OVERFLOW1 _VECTOR(15)
|
||||
|
||||
/* Timer/Counter0 Compare Match */
|
||||
#define TIMER0_COMP_vect _VECTOR(16)
|
||||
#define SIG_OUTPUT_COMPARE0 _VECTOR(16)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(17)
|
||||
#define SIG_OVERFLOW0 _VECTOR(17)
|
||||
|
||||
/* SPI Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(18)
|
||||
#define SIG_SPI _VECTOR(18)
|
||||
|
||||
/* USART0, Rx Complete */
|
||||
#define USART0_RXC_vect _VECTOR(19)
|
||||
#define SIG_USART0_RECV _VECTOR(19)
|
||||
|
||||
/* USART1, Rx Complete */
|
||||
#define USART1_RXC_vect _VECTOR(20)
|
||||
#define SIG_USART1_RECV _VECTOR(20)
|
||||
|
||||
/* USART0 Data register Empty */
|
||||
#define USART0_UDRE_vect _VECTOR(21)
|
||||
#define SIG_USART0_DATA _VECTOR(21)
|
||||
|
||||
/* USART1, Data register Empty */
|
||||
#define USART1_UDRE_vect _VECTOR(22)
|
||||
#define SIG_USART1_DATA _VECTOR(22)
|
||||
|
||||
/* USART0, Tx Complete */
|
||||
#define USART0_TXC_vect _VECTOR(23)
|
||||
#define SIG_USART0_TRANS _VECTOR(23)
|
||||
|
||||
/* USART1, Tx Complete */
|
||||
#define USART1_TXC_vect _VECTOR(24)
|
||||
#define SIG_USART1_TRANS _VECTOR(24)
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_RDY_vect _VECTOR(25)
|
||||
#define SIG_EEPROM_READY _VECTOR(25)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANA_COMP_vect _VECTOR(26)
|
||||
#define SIG_COMPARATOR _VECTOR(26)
|
||||
|
||||
/* Store Program Memory Read */
|
||||
#define SPM_RDY_vect _VECTOR(27)
|
||||
#define SIG_SPM_READY _VECTOR(27)
|
||||
|
||||
#define _VECTORS_SIZE 112 /* = (num vec+1) * 4 */
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
/* TCCR3B bit definitions, memory mapped I/O */
|
||||
|
||||
#define ICNC3 7
|
||||
#define ICES3 6
|
||||
#define WGM33 4
|
||||
#define WGM32 3
|
||||
#define CS32 2
|
||||
#define CS31 1
|
||||
#define CS30 0
|
||||
|
||||
|
||||
|
||||
/* TCCR3A bit definitions, memory mapped I/O */
|
||||
|
||||
#define COM3A1 7
|
||||
#define COM3A0 6
|
||||
#define COM3B1 5
|
||||
#define COM3B0 4
|
||||
#define FOC3A 3
|
||||
#define FOC3B 2
|
||||
#define WGM31 1
|
||||
#define WGM30 0
|
||||
|
||||
|
||||
|
||||
/* ETIMSK bit definitions, memory mapped I/O */
|
||||
|
||||
#define TICIE3 5
|
||||
#define OCIE3A 4
|
||||
#define OCIE3B 3
|
||||
#define TOIE3 2
|
||||
|
||||
|
||||
|
||||
/* ETIFR bit definitions, memory mapped I/O */
|
||||
|
||||
#define ICF3 5
|
||||
#define OCF3A 4
|
||||
#define OCF3B 3
|
||||
#define TOV3 2
|
||||
|
||||
|
||||
|
||||
/* PCMSK1 bit definitions, memory mapped I/O */
|
||||
#define PCINT15 7
|
||||
#define PCINT14 6
|
||||
#define PCINT13 5
|
||||
#define PCINT12 4
|
||||
#define PCINT11 3
|
||||
#define PCINT10 2
|
||||
#define PCINT9 1
|
||||
#define PCINT8 0
|
||||
|
||||
|
||||
|
||||
/* PCMSK0 bit definitions, memory mapped I/O */
|
||||
|
||||
#define PCINT7 7
|
||||
#define PCINT6 6
|
||||
#define PCINT5 5
|
||||
#define PCINT4 4
|
||||
#define PCINT3 3
|
||||
#define PCINT2 2
|
||||
#define PCINT1 1
|
||||
#define PCINT0 0
|
||||
|
||||
|
||||
|
||||
/* CLKPR bit definitions, memory mapped I/O */
|
||||
|
||||
#define CLKPCE 7
|
||||
#define CLKPS3 3
|
||||
#define CLKPS2 2
|
||||
#define CLKPS1 1
|
||||
#define CLKPS0 0
|
||||
|
||||
|
||||
|
||||
/* SPH bit definitions */
|
||||
|
||||
#define SP15 15
|
||||
#define SP14 14
|
||||
#define SP13 13
|
||||
#define SP12 12
|
||||
#define SP11 11
|
||||
#define SP10 10
|
||||
#define SP9 9
|
||||
#define SP8 8
|
||||
|
||||
|
||||
|
||||
/* SPL bit definitions */
|
||||
|
||||
#define SP7 7
|
||||
#define SP6 6
|
||||
#define SP5 5
|
||||
#define SP4 4
|
||||
#define SP3 3
|
||||
#define SP2 2
|
||||
#define SP1 1
|
||||
#define SP0 0
|
||||
|
||||
|
||||
|
||||
/* UBRR1H bit definitions */
|
||||
|
||||
#define URSEL1 7
|
||||
#define UBRR111 3
|
||||
#define UBRR110 2
|
||||
#define UBRR19 1
|
||||
#define UBRR18 0
|
||||
|
||||
|
||||
|
||||
/* UCSR1C bit definitions */
|
||||
|
||||
#define URSEL1 7
|
||||
#define UMSEL1 6
|
||||
#define UPM11 5
|
||||
#define UPM10 4
|
||||
#define USBS1 3
|
||||
#define UCSZ11 2
|
||||
#define UCSZ10 1
|
||||
#define UCPOL1 0
|
||||
|
||||
|
||||
|
||||
/* GICR bit definitions */
|
||||
|
||||
#define INT1 7
|
||||
#define INT0 6
|
||||
#define INT2 5
|
||||
#define PCIE1 4
|
||||
#define PCIE0 3
|
||||
#define IVSEL 1
|
||||
#define IVCE 0
|
||||
|
||||
|
||||
|
||||
/* GIFR bit definitions */
|
||||
|
||||
#define INTF1 7
|
||||
#define INTF0 6
|
||||
#define INTF2 5
|
||||
#define PCIF1 4
|
||||
#define PCIF0 3
|
||||
|
||||
|
||||
|
||||
/* TIMSK bit definitions */
|
||||
|
||||
#define TOIE1 7
|
||||
#define OCIE1A 6
|
||||
#define OCIE1B 5
|
||||
#define OCIE2 4
|
||||
#define TICIE1 3
|
||||
#define TOIE2 2
|
||||
#define TOIE0 1
|
||||
#define OCIE0 0
|
||||
|
||||
|
||||
|
||||
/* TIFR bit definitions */
|
||||
|
||||
#define TOV1 7
|
||||
#define OCF1A 6
|
||||
#define OCF1B 5
|
||||
#define OCF2 4
|
||||
#define ICF1 3
|
||||
#define TOV2 2
|
||||
#define TOV0 1
|
||||
#define OCF0 0
|
||||
|
||||
|
||||
|
||||
/* SPMCR bit definitions */
|
||||
|
||||
#define SPMIE 7
|
||||
#define RWWSB 6
|
||||
#define RWWSRE 4
|
||||
#define BLBSET 3
|
||||
#define PGWRT 2
|
||||
#define PGERS 1
|
||||
#define SPMEN 0
|
||||
|
||||
|
||||
|
||||
/* EMCUCR bit definitions */
|
||||
|
||||
#define SM0 7
|
||||
#define SRL2 6
|
||||
#define SRL1 5
|
||||
#define SRL0 4
|
||||
#define SRW01 3
|
||||
#define SRW00 2
|
||||
#define SRW11 1
|
||||
#define ISC2 0
|
||||
|
||||
|
||||
|
||||
/* MCUCR bit definitions */
|
||||
|
||||
#define SRE 7
|
||||
#define SRW10 6
|
||||
#define SE 5
|
||||
#define SM1 4
|
||||
#define ISC11 3
|
||||
#define ISC10 2
|
||||
#define ISC01 1
|
||||
#define ISC00 0
|
||||
|
||||
|
||||
|
||||
/* MCUCSR bit definitions */
|
||||
|
||||
#define JTD 7
|
||||
#define SM2 5
|
||||
#define JTRF 4
|
||||
#define WDRF 3
|
||||
#define BORF 2
|
||||
#define EXTRF 1
|
||||
#define PORF 0
|
||||
|
||||
|
||||
|
||||
/* TCCR0 bit definitions */
|
||||
|
||||
#define FOC0 7
|
||||
#define WGM00 6
|
||||
#define COM01 5
|
||||
#define COM00 4
|
||||
#define WGM01 3
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
|
||||
|
||||
/* SFIOR bit definitions */
|
||||
|
||||
#define TSM 7
|
||||
#define XMBK 6
|
||||
#define XMM2 5
|
||||
#define XMM1 4
|
||||
#define XMM0 3
|
||||
#define PUD 2
|
||||
#define PSR2 1
|
||||
#define PSR310 0
|
||||
|
||||
|
||||
|
||||
/* TCCR1A bit definitions */
|
||||
|
||||
#define COM1A1 7
|
||||
#define COM1A0 6
|
||||
#define COM1B1 5
|
||||
#define COM1B0 4
|
||||
#define FOC1A 3
|
||||
#define FOC1B 2
|
||||
#define WGM11 1
|
||||
#define WGM10 0
|
||||
|
||||
|
||||
|
||||
|
||||
/* TCCR1B bit definitions */
|
||||
|
||||
#define ICNC1 7 /* Input Capture Noise Canceler */
|
||||
#define ICES1 6 /* Input Capture Edge Select */
|
||||
#define WGM13 4 /* Waveform Generation Mode 3 */
|
||||
#define WGM12 3 /* Waveform Generation Mode 2 */
|
||||
#define CS12 2 /* Clock Select 2 */
|
||||
#define CS11 1 /* Clock Select 1 */
|
||||
#define CS10 0 /* Clock Select 0 */
|
||||
|
||||
|
||||
|
||||
/* TCCR2 bit definitions */
|
||||
|
||||
#define FOC2 7
|
||||
#define WGM20 6
|
||||
#define COM21 5
|
||||
#define COM20 4
|
||||
#define WGM21 3
|
||||
#define CS22 2
|
||||
#define CS21 1
|
||||
#define CS20 0
|
||||
|
||||
|
||||
|
||||
/* ASSR bit definitions */
|
||||
|
||||
#define AS2 3
|
||||
#define TCON2UB 2
|
||||
#define OCR2UB 1
|
||||
#define TCR2UB 0
|
||||
|
||||
|
||||
|
||||
/* WDTCR bit definitions */
|
||||
|
||||
#define WDCE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
|
||||
|
||||
/* UBRR0H bif definitions */
|
||||
|
||||
#define URSEL0 7
|
||||
#define UBRR011 3
|
||||
#define UBRR010 2
|
||||
#define UBRR09 1
|
||||
#define UBRR08 0
|
||||
|
||||
|
||||
|
||||
/* UCSR0C bit definitions */
|
||||
|
||||
#define URSEL0 7
|
||||
#define UMSEL0 6
|
||||
#define UPM01 5
|
||||
#define UPM00 4
|
||||
#define USBS0 3
|
||||
#define UCSZ01 2
|
||||
#define UCSZ00 1
|
||||
#define UCPOL0 0
|
||||
|
||||
|
||||
|
||||
/* EEARH bit definitions */
|
||||
|
||||
#define EEAR8 0
|
||||
|
||||
|
||||
|
||||
/* EECR bit definitions */
|
||||
|
||||
#define EERIE 3
|
||||
#define EEMWE 2
|
||||
#define EEWE 1
|
||||
#define EERE 0
|
||||
|
||||
|
||||
|
||||
/* PORTA bit definitions */
|
||||
|
||||
#define PA7 7
|
||||
#define PA6 6
|
||||
#define PA5 5
|
||||
#define PA4 4
|
||||
#define PA3 3
|
||||
#define PA2 2
|
||||
#define PA1 1
|
||||
#define PA0 0
|
||||
|
||||
|
||||
|
||||
/* DDRA bit definitions */
|
||||
|
||||
#define DDA7 7
|
||||
#define DDA6 6
|
||||
#define DDA5 5
|
||||
#define DDA4 4
|
||||
#define DDA3 3
|
||||
#define DDA2 2
|
||||
#define DDA1 1
|
||||
#define DDA0 0
|
||||
|
||||
|
||||
|
||||
/* PINA bit definitions */
|
||||
|
||||
#define PINA7 7
|
||||
#define PINA6 6
|
||||
#define PINA5 5
|
||||
#define PINA4 4
|
||||
#define PINA3 3
|
||||
#define PINA2 2
|
||||
#define PINA1 1
|
||||
#define PINA0 0
|
||||
|
||||
|
||||
/* PORTB bit definitions */
|
||||
|
||||
#define PB7 7
|
||||
#define PB6 6
|
||||
#define PB5 5
|
||||
#define PB4 4
|
||||
#define PB3 3
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
|
||||
|
||||
/* DDRB bit definitions */
|
||||
|
||||
#define DDB7 7
|
||||
#define DDB6 6
|
||||
#define DDB5 5
|
||||
#define DDB4 4
|
||||
#define DDB3 3
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
|
||||
|
||||
/* PINB bit definitions */
|
||||
|
||||
#define PINB7 7
|
||||
#define PINB6 6
|
||||
#define PINB5 5
|
||||
#define PINB4 4
|
||||
#define PINB3 3
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
|
||||
|
||||
/* PORTC bit definitions */
|
||||
|
||||
#define PC7 7
|
||||
#define PC6 6
|
||||
#define PC5 5
|
||||
#define PC4 4
|
||||
#define PC3 3
|
||||
#define PC2 2
|
||||
#define PC1 1
|
||||
#define PC0 0
|
||||
|
||||
|
||||
|
||||
/* DDRC bit definitions */
|
||||
|
||||
#define DDC7 7
|
||||
#define DDC6 6
|
||||
#define DDC5 5
|
||||
#define DDC4 4
|
||||
#define DDC3 3
|
||||
#define DDC2 2
|
||||
#define DDC1 1
|
||||
#define DDC0 0
|
||||
|
||||
|
||||
|
||||
/* PINC bit definitions */
|
||||
|
||||
#define PINC7 7
|
||||
#define PINC6 6
|
||||
#define PINC5 5
|
||||
#define PINC4 4
|
||||
#define PINC3 3
|
||||
#define PINC2 2
|
||||
#define PINC1 1
|
||||
#define PINC0 0
|
||||
|
||||
|
||||
|
||||
/* PORTD bit definitions */
|
||||
|
||||
#define PD7 7
|
||||
#define PD6 6
|
||||
#define PD5 5
|
||||
#define PD4 4
|
||||
#define PD3 3
|
||||
#define PD2 2
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
|
||||
|
||||
/* DDRD bit definitions */
|
||||
|
||||
#define DDD7 7
|
||||
#define DDD6 6
|
||||
#define DDD5 5
|
||||
#define DDD4 4
|
||||
#define DDD3 3
|
||||
#define DDD2 2
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
|
||||
|
||||
/* PIND bit definitions */
|
||||
|
||||
#define PIND7 7
|
||||
#define PIND6 6
|
||||
#define PIND5 5
|
||||
#define PIND4 4
|
||||
#define PIND3 3
|
||||
#define PIND2 2
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
|
||||
|
||||
/* SPSR bit definitions */
|
||||
|
||||
#define SPIF 7
|
||||
#define WCOL 6
|
||||
#define SPI2X 0
|
||||
|
||||
|
||||
|
||||
/* SPCR bit definitions */
|
||||
|
||||
#define SPIE 7
|
||||
#define SPE 6
|
||||
#define DORD 5
|
||||
#define MSTR 4
|
||||
#define CPOL 3
|
||||
#define CPHA 2
|
||||
#define SPR1 1
|
||||
#define SPR0 0
|
||||
|
||||
|
||||
|
||||
/* UCSR0A bit definitions */
|
||||
|
||||
#define RXC0 7
|
||||
#define TXC0 6
|
||||
#define UDRE0 5
|
||||
#define FE0 4
|
||||
#define DOR0 3
|
||||
#define UPE0 2
|
||||
#define U2X0 1
|
||||
#define MPCM0 0
|
||||
|
||||
|
||||
|
||||
/* UCSR0B bit definitions */
|
||||
|
||||
#define RXCIE0 7
|
||||
#define TXCIE0 6
|
||||
#define UDRIE0 5
|
||||
#define RXEN0 4
|
||||
#define TXEN0 3
|
||||
#define UCSZ02 2
|
||||
#define RXB80 1
|
||||
#define TXB80 0
|
||||
|
||||
|
||||
|
||||
/* ACSR bit definitions */
|
||||
|
||||
#define ACD 7
|
||||
#define ACBG 6
|
||||
#define ACO 5
|
||||
#define ACI 4
|
||||
#define ACIE 3
|
||||
#define ACIC 2
|
||||
#define ACIS1 1
|
||||
#define ACIS0 0
|
||||
|
||||
|
||||
|
||||
/* PORTE bit definitions */
|
||||
|
||||
#define PE2 2
|
||||
#define PE1 1
|
||||
#define PE0 0
|
||||
|
||||
|
||||
|
||||
/* DDRE bit definitions */
|
||||
|
||||
#define DDE2 2
|
||||
#define DDE1 1
|
||||
#define DDE0 0
|
||||
|
||||
|
||||
|
||||
/* PINE bit definitions */
|
||||
|
||||
#define PINE2 2
|
||||
#define PINE1 1
|
||||
#define PINE0 0
|
||||
|
||||
|
||||
|
||||
/* UCSR1A bit definitions */
|
||||
|
||||
#define RXC1 7
|
||||
#define TXC1 6
|
||||
#define UDRE1 5
|
||||
#define FE1 4
|
||||
#define DOR1 3
|
||||
#define UPE1 2
|
||||
#define U2X1 1
|
||||
#define MPCM1 0
|
||||
|
||||
|
||||
|
||||
/* UCSR1B bit definitions */
|
||||
|
||||
#define RXCIE1 7
|
||||
#define TXCIE1 6
|
||||
#define UDRIE1 5
|
||||
#define RXEN1 4
|
||||
#define TXEN1 3
|
||||
#define UCSZ12 2
|
||||
#define RXB81 1
|
||||
#define TXB81 0
|
||||
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 128
|
||||
#define RAMEND 0x4FF
|
||||
#define XRAMEND 0xFFFF
|
||||
#define E2END 0x1FF
|
||||
#define E2PAGESIZE 4
|
||||
#define FLASHEND 0x3FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6)
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(2)
|
||||
#define FUSE_BODLEVEL2 (unsigned char)~_BV(3)
|
||||
#define FUSE_M161C (unsigned char)~_BV(4)
|
||||
#define EFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x94
|
||||
#define SIGNATURE_2 0x04
|
||||
|
||||
|
||||
#endif /* _AVR_IOM162_H_ */
|
639
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom163.h
Normal file
639
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom163.h
Normal file
|
@ -0,0 +1,639 @@
|
|||
/* Copyright (c) 2002, Marek Michalkiewicz
|
||||
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: iom163.h,v 1.14.2.5 2008/10/17 23:27:47 arcanum Exp $ */
|
||||
|
||||
/* avr/iom163.h - definitions for ATmega163 */
|
||||
|
||||
#ifndef _AVR_IOM163_H_
|
||||
#define _AVR_IOM163_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_ "iom163.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
#define TWBR _SFR_IO8(0x00)
|
||||
#define TWSR _SFR_IO8(0x01)
|
||||
#define TWAR _SFR_IO8(0x02)
|
||||
#define TWDR _SFR_IO8(0x03)
|
||||
|
||||
/* ADC */
|
||||
#ifndef __ASSEMBLER__
|
||||
#define ADC _SFR_IO16(0x04)
|
||||
#endif
|
||||
#define ADCW _SFR_IO16(0x04)
|
||||
#define ADCL _SFR_IO8(0x04)
|
||||
#define ADCH _SFR_IO8(0x05)
|
||||
#define ADCSR _SFR_IO8(0x06)
|
||||
#define ADMUX _SFR_IO8(0x07)
|
||||
|
||||
/* analog comparator */
|
||||
#define ACSR _SFR_IO8(0x08)
|
||||
|
||||
/* UART */
|
||||
#define UBRR _SFR_IO8(0x09)
|
||||
#define UCSRB _SFR_IO8(0x0A)
|
||||
#define UCSRA _SFR_IO8(0x0B)
|
||||
#define UDR _SFR_IO8(0x0C)
|
||||
|
||||
/* SPI */
|
||||
#define SPCR _SFR_IO8(0x0D)
|
||||
#define SPSR _SFR_IO8(0x0E)
|
||||
#define SPDR _SFR_IO8(0x0F)
|
||||
|
||||
/* Port D */
|
||||
#define PIND _SFR_IO8(0x10)
|
||||
#define DDRD _SFR_IO8(0x11)
|
||||
#define PORTD _SFR_IO8(0x12)
|
||||
|
||||
/* Port C */
|
||||
#define PINC _SFR_IO8(0x13)
|
||||
#define DDRC _SFR_IO8(0x14)
|
||||
#define PORTC _SFR_IO8(0x15)
|
||||
|
||||
/* Port B */
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
|
||||
/* Port A */
|
||||
#define PINA _SFR_IO8(0x19)
|
||||
#define DDRA _SFR_IO8(0x1A)
|
||||
#define PORTA _SFR_IO8(0x1B)
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EECR _SFR_IO8(0x1C)
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define EEDR _SFR_IO8(0x1D)
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#define EEAR _SFR_IO16(0x1E)
|
||||
#define EEARL _SFR_IO8(0x1E)
|
||||
#define EEARH _SFR_IO8(0x1F)
|
||||
|
||||
#define UBRRHI _SFR_IO8(0x20)
|
||||
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
|
||||
#define ASSR _SFR_IO8(0x22)
|
||||
|
||||
/* Timer 2 */
|
||||
#define OCR2 _SFR_IO8(0x23)
|
||||
#define TCNT2 _SFR_IO8(0x24)
|
||||
#define TCCR2 _SFR_IO8(0x25)
|
||||
|
||||
/* Timer 1 */
|
||||
#define ICR1 _SFR_IO16(0x26)
|
||||
#define ICR1L _SFR_IO8(0x26)
|
||||
#define ICR1H _SFR_IO8(0x27)
|
||||
#define OCR1B _SFR_IO16(0x28)
|
||||
#define OCR1BL _SFR_IO8(0x28)
|
||||
#define OCR1BH _SFR_IO8(0x29)
|
||||
#define OCR1A _SFR_IO16(0x2A)
|
||||
#define OCR1AL _SFR_IO8(0x2A)
|
||||
#define OCR1AH _SFR_IO8(0x2B)
|
||||
#define TCNT1 _SFR_IO16(0x2C)
|
||||
#define TCNT1L _SFR_IO8(0x2C)
|
||||
#define TCNT1H _SFR_IO8(0x2D)
|
||||
#define TCCR1B _SFR_IO8(0x2E)
|
||||
#define TCCR1A _SFR_IO8(0x2F)
|
||||
|
||||
#define SFIOR _SFR_IO8(0x30)
|
||||
|
||||
#define OSCCAL _SFR_IO8(0x31)
|
||||
|
||||
/* Timer 0 */
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
#define TWCR _SFR_IO8(0x36)
|
||||
|
||||
#define SPMCR _SFR_IO8(0x37)
|
||||
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
|
||||
#define GIFR _SFR_IO8(0x3A)
|
||||
#define GIMSK _SFR_IO8(0x3B)
|
||||
|
||||
/* 0x3C reserved */
|
||||
|
||||
/* 0x3D..0x3E SP */
|
||||
|
||||
/* 0x3F SREG */
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
/* External Interrupt 0 */
|
||||
#define INT0_vect _VECTOR(1)
|
||||
#define SIG_INTERRUPT0 _VECTOR(1)
|
||||
|
||||
/* External Interrupt 1 */
|
||||
#define INT1_vect _VECTOR(2)
|
||||
#define SIG_INTERRUPT1 _VECTOR(2)
|
||||
|
||||
/* Timer/Counter2 Compare Match */
|
||||
#define TIMER2_COMP_vect _VECTOR(3)
|
||||
#define SIG_OUTPUT_COMPARE2 _VECTOR(3)
|
||||
|
||||
/* Timer/Counter2 Overflow */
|
||||
#define TIMER2_OVF_vect _VECTOR(4)
|
||||
#define SIG_OVERFLOW2 _VECTOR(4)
|
||||
|
||||
/* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(5)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(5)
|
||||
|
||||
/* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPA_vect _VECTOR(6)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(6)
|
||||
|
||||
/* Timer/Counter1 Compare Match B */
|
||||
#define TIMER1_COMPB_vect _VECTOR(7)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(7)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(8)
|
||||
#define SIG_OVERFLOW1 _VECTOR(8)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(9)
|
||||
#define SIG_OVERFLOW0 _VECTOR(9)
|
||||
|
||||
/* SPI Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(10)
|
||||
#define SIG_SPI _VECTOR(10)
|
||||
|
||||
/* UART, RX Complete */
|
||||
#define UART_RX_vect _VECTOR(11)
|
||||
#define SIG_UART_RECV _VECTOR(11)
|
||||
|
||||
/* UART Data Register Empty */
|
||||
#define UART_UDRE_vect _VECTOR(12)
|
||||
#define SIG_UART_DATA _VECTOR(12)
|
||||
|
||||
/* UART, TX Complete */
|
||||
#define UART_TX_vect _VECTOR(13)
|
||||
#define SIG_UART_TRANS _VECTOR(13)
|
||||
|
||||
/* ADC Conversion Complete */
|
||||
#define ADC_vect _VECTOR(14)
|
||||
#define SIG_ADC _VECTOR(14)
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_RDY_vect _VECTOR(15)
|
||||
#define SIG_EEPROM_READY _VECTOR(15)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANA_COMP_vect _VECTOR(16)
|
||||
#define SIG_COMPARATOR _VECTOR(16)
|
||||
|
||||
/* 2-Wire Serial Interface */
|
||||
#define TWI_vect _VECTOR(17)
|
||||
#define SIG_2WIRE_SERIAL _VECTOR(17)
|
||||
|
||||
#define _VECTORS_SIZE 72
|
||||
|
||||
/* Bit numbers */
|
||||
|
||||
/* GIMSK */
|
||||
#define INT1 7
|
||||
#define INT0 6
|
||||
/* bit 5 reserved, undefined */
|
||||
/* bits 4-0 reserved */
|
||||
|
||||
/* GIFR */
|
||||
#define INTF1 7
|
||||
#define INTF0 6
|
||||
/* bits 5-0 reserved */
|
||||
|
||||
/* TIMSK */
|
||||
#define OCIE2 7
|
||||
#define TOIE2 6
|
||||
#define TICIE1 5
|
||||
#define OCIE1A 4
|
||||
#define OCIE1B 3
|
||||
#define TOIE1 2
|
||||
/* bit 1 reserved */
|
||||
#define TOIE0 0
|
||||
|
||||
/* TIFR */
|
||||
#define OCF2 7
|
||||
#define TOV2 6
|
||||
#define ICF1 5
|
||||
#define OCF1A 4
|
||||
#define OCF1B 3
|
||||
#define TOV1 2
|
||||
/* bit 1 reserved, undefined */
|
||||
#define TOV0 0
|
||||
|
||||
/* SPMCR */
|
||||
/* bit 7 reserved */
|
||||
#define ASB 6
|
||||
/* bit 5 reserved */
|
||||
#define ASRE 4
|
||||
#define BLBSET 3
|
||||
#define PGWRT 2
|
||||
#define PGERS 1
|
||||
#define SPMEN 0
|
||||
|
||||
/* TWCR */
|
||||
#define TWINT 7
|
||||
#define TWEA 6
|
||||
#define TWSTA 5
|
||||
#define TWSTO 4
|
||||
#define TWWC 3
|
||||
#define TWEN 2
|
||||
/* bit 1 reserved */
|
||||
#define TWIE 0
|
||||
|
||||
/* TWAR */
|
||||
#define TWGCE 0
|
||||
|
||||
/* TWSR */
|
||||
#define TWS7 7
|
||||
#define TWS6 6
|
||||
#define TWS5 5
|
||||
#define TWS4 4
|
||||
#define TWS3 3
|
||||
/* bits 2-0 reserved */
|
||||
|
||||
/* MCUCR */
|
||||
/* bit 7 reserved */
|
||||
#define SE 6
|
||||
#define SM1 5
|
||||
#define SM0 4
|
||||
#define ISC11 3
|
||||
#define ISC10 2
|
||||
#define ISC01 1
|
||||
#define ISC00 0
|
||||
|
||||
/* MCUSR */
|
||||
/* bits 7-4 reserved */
|
||||
#define WDRF 3
|
||||
#define BORF 2
|
||||
#define EXTRF 1
|
||||
#define PORF 0
|
||||
|
||||
/* SFIOR */
|
||||
/* bits 7-4 reserved */
|
||||
#define ACME 3
|
||||
#define PUD 2
|
||||
#define PSR2 1
|
||||
#define PSR10 0
|
||||
|
||||
/* TCCR0 */
|
||||
/* bits 7-3 reserved */
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/* TCCR2 */
|
||||
#define FOC2 7
|
||||
#define PWM2 6
|
||||
#define COM21 5
|
||||
#define COM20 4
|
||||
#define CTC2 3
|
||||
#define CS22 2
|
||||
#define CS21 1
|
||||
#define CS20 0
|
||||
|
||||
/* ASSR */
|
||||
/* bits 7-4 reserved */
|
||||
#define AS2 3
|
||||
#define TCN2UB 2
|
||||
#define OCR2UB 1
|
||||
#define TCR2UB 0
|
||||
|
||||
/* TCCR1A */
|
||||
#define COM1A1 7
|
||||
#define COM1A0 6
|
||||
#define COM1B1 5
|
||||
#define COM1B0 4
|
||||
#define FOC1A 3
|
||||
#define FOC1B 2
|
||||
#define PWM11 1
|
||||
#define PWM10 0
|
||||
|
||||
/* TCCR1B */
|
||||
#define ICNC1 7
|
||||
#define ICES1 6
|
||||
/* bits 5-4 reserved */
|
||||
#define CTC1 3
|
||||
#define CS12 2
|
||||
#define CS11 1
|
||||
#define CS10 0
|
||||
|
||||
/* WDTCR */
|
||||
/* bits 7-5 reserved */
|
||||
#define WDTOE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/* PA7-PA0 = ADC7-ADC0 */
|
||||
/* PORTA */
|
||||
#define PA7 7
|
||||
#define PA6 6
|
||||
#define PA5 5
|
||||
#define PA4 4
|
||||
#define PA3 3
|
||||
#define PA2 2
|
||||
#define PA1 1
|
||||
#define PA0 0
|
||||
|
||||
/* DDRA */
|
||||
#define DDA7 7
|
||||
#define DDA6 6
|
||||
#define DDA5 5
|
||||
#define DDA4 4
|
||||
#define DDA3 3
|
||||
#define DDA2 2
|
||||
#define DDA1 1
|
||||
#define DDA0 0
|
||||
|
||||
/* PINA */
|
||||
#define PINA7 7
|
||||
#define PINA6 6
|
||||
#define PINA5 5
|
||||
#define PINA4 4
|
||||
#define PINA3 3
|
||||
#define PINA2 2
|
||||
#define PINA1 1
|
||||
#define PINA0 0
|
||||
|
||||
/*
|
||||
PB7 = SCK
|
||||
PB6 = MISO
|
||||
PB5 = MOSI
|
||||
PB4 = SS#
|
||||
PB3 = AIN1
|
||||
PB2 = AIN0
|
||||
PB1 = T1
|
||||
PB0 = T0
|
||||
*/
|
||||
|
||||
/* PORTB */
|
||||
#define PB7 7
|
||||
#define PB6 6
|
||||
#define PB5 5
|
||||
#define PB4 4
|
||||
#define PB3 3
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
/* DDRB */
|
||||
#define DDB7 7
|
||||
#define DDB6 6
|
||||
#define DDB5 5
|
||||
#define DDB4 4
|
||||
#define DDB3 3
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
/* PINB */
|
||||
#define PINB7 7
|
||||
#define PINB6 6
|
||||
#define PINB5 5
|
||||
#define PINB4 4
|
||||
#define PINB3 3
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
/*
|
||||
PC7 = TOSC2
|
||||
PC6 = TOSC1
|
||||
PC1 = SDA
|
||||
PC0 = SCL
|
||||
*/
|
||||
/* PORTC */
|
||||
#define PC7 7
|
||||
#define PC6 6
|
||||
#define PC5 5
|
||||
#define PC4 4
|
||||
#define PC3 3
|
||||
#define PC2 2
|
||||
#define PC1 1
|
||||
#define PC0 0
|
||||
|
||||
/* DDRC */
|
||||
#define DDC7 7
|
||||
#define DDC6 6
|
||||
#define DDC5 5
|
||||
#define DDC4 4
|
||||
#define DDC3 3
|
||||
#define DDC2 2
|
||||
#define DDC1 1
|
||||
#define DDC0 0
|
||||
|
||||
/* PINC */
|
||||
#define PINC7 7
|
||||
#define PINC6 6
|
||||
#define PINC5 5
|
||||
#define PINC4 4
|
||||
#define PINC3 3
|
||||
#define PINC2 2
|
||||
#define PINC1 1
|
||||
#define PINC0 0
|
||||
|
||||
/*
|
||||
PD7 = OC2
|
||||
PD6 = ICP
|
||||
PD5 = OC1A
|
||||
PD4 = OC1B
|
||||
PD3 = INT1
|
||||
PD2 = INT0
|
||||
PD1 = TXD
|
||||
PD0 = RXD
|
||||
*/
|
||||
|
||||
/* PORTD */
|
||||
#define PD7 7
|
||||
#define PD6 6
|
||||
#define PD5 5
|
||||
#define PD4 4
|
||||
#define PD3 3
|
||||
#define PD2 2
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
/* DDRD */
|
||||
#define DDD7 7
|
||||
#define DDD6 6
|
||||
#define DDD5 5
|
||||
#define DDD4 4
|
||||
#define DDD3 3
|
||||
#define DDD2 2
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
/* PIND */
|
||||
#define PIND7 7
|
||||
#define PIND6 6
|
||||
#define PIND5 5
|
||||
#define PIND4 4
|
||||
#define PIND3 3
|
||||
#define PIND2 2
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
/* SPSR */
|
||||
#define SPIF 7
|
||||
#define WCOL 6
|
||||
/* bits 5-1 reserved */
|
||||
#define SPI2X 0
|
||||
|
||||
/* SPCR */
|
||||
#define SPIE 7
|
||||
#define SPE 6
|
||||
#define DORD 5
|
||||
#define MSTR 4
|
||||
#define CPOL 3
|
||||
#define CPHA 2
|
||||
#define SPR1 1
|
||||
#define SPR0 0
|
||||
|
||||
/* UCSRA */
|
||||
#define RXC 7
|
||||
#define TXC 6
|
||||
#define UDRE 5
|
||||
#define FE 4
|
||||
#define DOR 3
|
||||
/* bit 2 reserved */
|
||||
#define U2X 1
|
||||
#define MPCM 0
|
||||
|
||||
/* UCSRB */
|
||||
#define RXCIE 7
|
||||
#define TXCIE 6
|
||||
#define UDRIE 5
|
||||
#define RXEN 4
|
||||
#define TXEN 3
|
||||
#define CHR9 2
|
||||
#define RXB8 1
|
||||
#define TXB8 0
|
||||
|
||||
/* ACSR */
|
||||
#define ACD 7
|
||||
#define AINBG 6
|
||||
#define ACO 5
|
||||
#define ACI 4
|
||||
#define ACIE 3
|
||||
#define ACIC 2
|
||||
#define ACIS1 1
|
||||
#define ACIS0 0
|
||||
|
||||
/* ADCSR */
|
||||
#define ADEN 7
|
||||
#define ADSC 6
|
||||
#define ADFR 5
|
||||
#define ADIF 4
|
||||
#define ADIE 3
|
||||
#define ADPS2 2
|
||||
#define ADPS1 1
|
||||
#define ADPS0 0
|
||||
|
||||
/* ADMUX */
|
||||
#define REFS1 7
|
||||
#define REFS0 6
|
||||
#define ADLAR 5
|
||||
#define MUX4 4
|
||||
#define MUX3 3
|
||||
#define MUX2 2
|
||||
#define MUX1 1
|
||||
#define MUX0 0
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EERIE 3
|
||||
#define EEMWE 2
|
||||
#define EEWE 1
|
||||
#define EERE 0
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 128
|
||||
#define RAMEND 0x45F
|
||||
#define XRAMEND 0x45F
|
||||
#define E2END 0x1FF
|
||||
#define E2PAGESIZE 0
|
||||
#define FLASHEND 0x3FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 2
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_BODEN (unsigned char)~_BV(6)
|
||||
#define FUSE_BODLEVEL (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SPIEN)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define HFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x94
|
||||
#define SIGNATURE_2 0x02
|
||||
|
||||
|
||||
#endif /* _AVR_IOM163_H_ */
|
|
@ -0,0 +1,88 @@
|
|||
/* Copyright (c) 2005, 2006 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. */
|
||||
|
||||
/* avr/iom164.h - definitions for ATmega164 */
|
||||
|
||||
/* $Id: iom164.h,v 1.3.2.4 2008/08/14 00:08:01 arcanum Exp $ */
|
||||
|
||||
#ifndef _AVR_IOM164_H_
|
||||
#define _AVR_IOM164_H_ 1
|
||||
|
||||
#include <avr/iomxx4.h>
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 128
|
||||
#define RAMEND 0x04FF
|
||||
#define XRAMEND 0x04FF
|
||||
#define E2END 0x1FF
|
||||
#define E2PAGESIZE 4
|
||||
#define FLASHEND 0x3FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6)
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_SUT1 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_BODLEVEL2 (unsigned char)~_BV(2)
|
||||
#define EFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
#endif /* _AVR_IOM164_H_ */
|
820
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom165.h
Normal file
820
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom165.h
Normal file
|
@ -0,0 +1,820 @@
|
|||
/* Copyright (c) 2004,2005,2006 Eric B. Weddington
|
||||
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: iom165.h,v 1.10.2.6 2008/10/17 23:27:47 arcanum Exp $ */
|
||||
|
||||
/* avr/iom165.h - definitions for ATmega165 */
|
||||
|
||||
#ifndef _AVR_IOM165_H_
|
||||
#define _AVR_IOM165_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_ "iom165.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#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 PING4 4
|
||||
#define PING3 3
|
||||
#define PING2 2
|
||||
#define PING1 1
|
||||
#define PING0 0
|
||||
|
||||
#define DDRG _SFR_IO8(0x13)
|
||||
#define DDG4 4
|
||||
#define DDG3 3
|
||||
#define DDG2 2
|
||||
#define DDG1 1
|
||||
#define DDG0 0
|
||||
|
||||
#define PORTG _SFR_IO8(0x14)
|
||||
#define PG4 4
|
||||
#define PG3 3
|
||||
#define PG2 2
|
||||
#define PG1 1
|
||||
#define PG0 0
|
||||
|
||||
#define TIFR0 _SFR_IO8(0x15)
|
||||
#define TOV0 0
|
||||
#define OCF0A 1
|
||||
|
||||
#define TIFR1 _SFR_IO8(0x16)
|
||||
#define TOV1 0
|
||||
#define OCF1A 1
|
||||
#define OCF1B 2
|
||||
#define ICF1 5
|
||||
|
||||
#define TIFR2 _SFR_IO8(0x17)
|
||||
#define TOV2 0
|
||||
#define OCF2A 1
|
||||
|
||||
/* Reserved [0x18..0x1B] */
|
||||
|
||||
#define EIFR _SFR_IO8(0x1C)
|
||||
#define INTF0 0
|
||||
#define PCIF0 6
|
||||
#define PCIF1 7
|
||||
|
||||
#define EIMSK _SFR_IO8(0x1D)
|
||||
#define INT0 0
|
||||
#define PCIE0 6
|
||||
#define PCIE1 7
|
||||
|
||||
#define GPIOR0 _SFR_IO8(0x1E)
|
||||
|
||||
#define EECR _SFR_IO8(0x1F)
|
||||
#define EERE 0
|
||||
#define EEWE 1
|
||||
#define EEMWE 2
|
||||
#define EERIE 3
|
||||
|
||||
#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 PSR10 0
|
||||
#define PSR2 1
|
||||
#define TSM 7
|
||||
|
||||
#define TCCR0A _SFR_IO8(0x24)
|
||||
#define CS00 0
|
||||
#define CS01 1
|
||||
#define CS02 2
|
||||
#define WGM01 3
|
||||
#define COM0A0 4
|
||||
#define COM0A1 5
|
||||
#define WGM00 6
|
||||
#define FOC0A 7
|
||||
|
||||
/* Reserved [0x25] */
|
||||
|
||||
#define TCNT0 _SFR_IO8(0X26)
|
||||
|
||||
#define OCR0A _SFR_IO8(0X27)
|
||||
|
||||
/* Reserved [0x28..0x29] */
|
||||
|
||||
#define GPIOR1 _SFR_IO8(0x2A)
|
||||
|
||||
#define GPIOR2 _SFR_IO8(0x2B)
|
||||
|
||||
#define SPCR _SFR_IO8(0x2C)
|
||||
#define SPR0 0
|
||||
#define SPR1 1
|
||||
#define CPHA 2
|
||||
#define CPOL 3
|
||||
#define MSTR 4
|
||||
#define DORD 5
|
||||
#define SPE 6
|
||||
#define SPIE 7
|
||||
|
||||
#define SPSR _SFR_IO8(0x2D)
|
||||
#define SPI2X 0
|
||||
#define WCOL 6
|
||||
#define SPIF 7
|
||||
|
||||
#define SPDR _SFR_IO8(0X2E)
|
||||
|
||||
/* Reserved [0x2F] */
|
||||
|
||||
#define ACSR _SFR_IO8(0x30)
|
||||
#define ACIS0 0
|
||||
#define ACIS1 1
|
||||
#define ACIC 2
|
||||
#define ACIE 3
|
||||
#define ACI 4
|
||||
#define ACO 5
|
||||
#define ACBG 6
|
||||
#define ACD 7
|
||||
|
||||
#define OCDR _SFR_IO8(0x31)
|
||||
#define OCDR0 0
|
||||
#define OCDR1 1
|
||||
#define OCDR2 2
|
||||
#define OCDR3 3
|
||||
#define OCDR4 4
|
||||
#define OCDR5 5
|
||||
#define OCDR6 6
|
||||
#define OCD 7 // The datasheet defines this but IMO it should be OCDR7.
|
||||
#define OCDR7 7
|
||||
#define IDRD 7
|
||||
|
||||
/* Reserved [0x32] */
|
||||
|
||||
#define SMCR _SFR_IO8(0x33)
|
||||
#define SE 0
|
||||
#define SM0 1
|
||||
#define SM1 2
|
||||
#define SM2 3
|
||||
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
#define PORF 0
|
||||
#define EXTRF 1
|
||||
#define BORF 2
|
||||
#define WDRF 3
|
||||
#define JTRF 4
|
||||
|
||||
#define MCUCR _SFR_IO8(0X35)
|
||||
#define IVCE 0
|
||||
#define IVSEL 1
|
||||
#define PUD 4
|
||||
#define JTD 7
|
||||
|
||||
/* Reserved [0x36] */
|
||||
|
||||
#define SPMCSR _SFR_IO8(0x37)
|
||||
#define SPMEN 0
|
||||
#define PGERS 1
|
||||
#define PGWRT 2
|
||||
#define BLBSET 3
|
||||
#define RWWSRE 4
|
||||
#define RWWSB 6
|
||||
#define SPMIE 7
|
||||
|
||||
/* Reserved [0x38..0x3C] */
|
||||
|
||||
/* SP [0x3D..0x3E] */
|
||||
/* SREG [0x3F] */
|
||||
|
||||
#define WDTCR _SFR_MEM8(0x60)
|
||||
#define WDP0 0
|
||||
#define WDP1 1
|
||||
#define WDP2 2
|
||||
#define WDE 3
|
||||
#define WDCE 4
|
||||
|
||||
#define CLKPR _SFR_MEM8(0x61)
|
||||
#define CLKPS0 0
|
||||
#define CLKPS1 1
|
||||
#define CLKPS2 2
|
||||
#define CLKPS3 3
|
||||
#define CLKPCE 7
|
||||
|
||||
/* Reserved [0x62..0x63] */
|
||||
|
||||
#define PRR _SFR_MEM8(0x64)
|
||||
#define PRADC 0
|
||||
#define PRUSART0 1
|
||||
#define PRSPI 2
|
||||
#define PRTIM1 3
|
||||
|
||||
/* Reserved [0x65] */
|
||||
|
||||
#define OSCCAL _SFR_MEM8(0x66)
|
||||
|
||||
/* Reserved [0x67..0x68] */
|
||||
|
||||
#define EICRA _SFR_MEM8(0x69)
|
||||
#define ISC00 0
|
||||
#define ISC01 1
|
||||
|
||||
/* Reserved [0x6A] */
|
||||
|
||||
/* Combine PCMSK0 and PCMSK1 */
|
||||
#define PCMSK _SFR_MEM16(0x6B)
|
||||
|
||||
#define PCMSK0 _SFR_MEM8(0x6B)
|
||||
#define PCINT0 0
|
||||
#define PCINT1 1
|
||||
#define PCINT2 2
|
||||
#define PCINT3 3
|
||||
#define PCINT4 4
|
||||
#define PCINT5 5
|
||||
#define PCINT6 6
|
||||
#define PCINT7 7
|
||||
|
||||
#define PCMSK1 _SFR_MEM8(0x6C)
|
||||
#define PCINT8 0
|
||||
#define PCINT9 1
|
||||
#define PCINT10 2
|
||||
#define PCINT11 3
|
||||
#define PCINT12 4
|
||||
#define PCINT13 5
|
||||
#define PCINT14 6
|
||||
#define PCINT15 7
|
||||
|
||||
/* Reserved [0x6D] */
|
||||
|
||||
#define TIMSK0 _SFR_MEM8(0x6E)
|
||||
#define TOIE0 0
|
||||
#define OCIE0A 1
|
||||
|
||||
#define TIMSK1 _SFR_MEM8(0x6F)
|
||||
#define TOIE1 0
|
||||
#define OCIE1A 1
|
||||
#define OCIE1B 2
|
||||
#define ICIE1 5
|
||||
|
||||
#define TIMSK2 _SFR_MEM8(0x70)
|
||||
#define TOIE2 0
|
||||
#define OCIE2A 1
|
||||
|
||||
/* Reserved [0x71..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 ADPS0 0
|
||||
#define ADPS1 1
|
||||
#define ADPS2 2
|
||||
#define ADIE 3
|
||||
#define ADIF 4
|
||||
#define ADATE 5
|
||||
#define ADSC 6
|
||||
#define ADEN 7
|
||||
|
||||
#define ADCSRB _SFR_MEM8(0x7B)
|
||||
#define ADTS0 0
|
||||
#define ADTS1 1
|
||||
#define ADTS2 2
|
||||
#define ACME 6
|
||||
|
||||
#define ADMUX _SFR_MEM8(0x7C)
|
||||
#define MUX0 0
|
||||
#define MUX1 1
|
||||
#define MUX2 2
|
||||
#define MUX3 3
|
||||
#define MUX4 4
|
||||
#define ADLAR 5
|
||||
#define REFS0 6
|
||||
#define REFS1 7
|
||||
|
||||
/* Reserved [0x7D] */
|
||||
|
||||
#define DIDR0 _SFR_MEM8(0x7E)
|
||||
#define ADC0D 0
|
||||
#define ADC1D 1
|
||||
#define ADC2D 2
|
||||
#define ADC3D 3
|
||||
#define ADC4D 4
|
||||
#define ADC5D 5
|
||||
#define ADC6D 6
|
||||
#define ADC7D 7
|
||||
|
||||
#define DIDR1 _SFR_MEM8(0x7F)
|
||||
#define AIN0D 0
|
||||
#define AIN1D 1
|
||||
|
||||
#define TCCR1A _SFR_MEM8(0X80)
|
||||
#define WGM10 0
|
||||
#define WGM11 1
|
||||
#define COM1B0 4
|
||||
#define COM1B1 5
|
||||
#define COM1A0 6
|
||||
#define COM1A1 7
|
||||
|
||||
#define TCCR1B _SFR_MEM8(0X81)
|
||||
#define CS10 0
|
||||
#define CS11 1
|
||||
#define CS12 2
|
||||
#define WGM12 3
|
||||
#define WGM13 4
|
||||
#define ICES1 6
|
||||
#define ICNC1 7
|
||||
|
||||
#define TCCR1C _SFR_MEM8(0x82)
|
||||
#define FOC1B 6
|
||||
#define FOC1A 7
|
||||
|
||||
/* 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)
|
||||
|
||||
/* Reserved [0x8C..0xAF] */
|
||||
|
||||
#define TCCR2A _SFR_MEM8(0xB0)
|
||||
#define CS20 0
|
||||
#define CS21 1
|
||||
#define CS22 2
|
||||
#define WGM21 3
|
||||
#define COM2A0 4
|
||||
#define COM2A1 5
|
||||
#define WGM20 6
|
||||
#define FOC2A 7
|
||||
|
||||
/* Reserved [0xB1] */
|
||||
|
||||
#define TCNT2 _SFR_MEM8(0xB2)
|
||||
|
||||
#define OCR2A _SFR_MEM8(0xB3)
|
||||
|
||||
/* Reserved [0xB4..0xB5] */
|
||||
|
||||
#define ASSR _SFR_MEM8(0xB6)
|
||||
#define TCR2UB 0
|
||||
#define OCR2UB 1
|
||||
#define TCN2UB 2
|
||||
#define AS2 3
|
||||
#define EXCLK 4
|
||||
|
||||
/* Reserved [0xB7] */
|
||||
|
||||
#define USICR _SFR_MEM8(0xB8)
|
||||
#define USITC 0
|
||||
#define USICLK 1
|
||||
#define USICS0 2
|
||||
#define USICS1 3
|
||||
#define USIWM0 4
|
||||
#define USIWM1 5
|
||||
#define USIOIE 6
|
||||
#define USISIE 7
|
||||
|
||||
#define USISR _SFR_MEM8(0xB9)
|
||||
#define USICNT0 0
|
||||
#define USICNT1 1
|
||||
#define USICNT2 2
|
||||
#define USICNT3 3
|
||||
#define USIDC 4
|
||||
#define USIPF 5
|
||||
#define USIOIF 6
|
||||
#define USISIF 7
|
||||
|
||||
#define USIDR _SFR_MEM8(0xBA)
|
||||
|
||||
/* Reserved [0xBB..0xBF] */
|
||||
|
||||
#define UCSRA _SFR_MEM8(0xC0)
|
||||
#define MPCM 0
|
||||
#define U2X 1
|
||||
#define UPE 2
|
||||
#define DOR 3
|
||||
#define FE 4
|
||||
#define UDRE 5
|
||||
#define TXC 6
|
||||
#define RXC 7
|
||||
|
||||
#define UCSRB _SFR_MEM8(0XC1)
|
||||
#define TXB8 0
|
||||
#define RXB8 1
|
||||
#define UCSZ2 2
|
||||
#define TXEN 3
|
||||
#define RXEN 4
|
||||
#define UDRIE 5
|
||||
#define TXCIE 6
|
||||
#define RXCIE 7
|
||||
|
||||
#define UCSRC _SFR_MEM8(0xC2)
|
||||
#define UCPOL 0
|
||||
#define UCSZ0 1
|
||||
#define UCSZ1 2
|
||||
#define USBS 3
|
||||
#define UPM0 4
|
||||
#define UPM1 5
|
||||
#define UMSEL 6
|
||||
|
||||
/* Reserved [0xC3] */
|
||||
|
||||
/* Combine UBRRL and UBRRH */
|
||||
#define UBRR _SFR_MEM16(0xC4)
|
||||
|
||||
#define UBRRL _SFR_MEM8(0xC4)
|
||||
#define UBRRH _SFR_MEM8(0xC5)
|
||||
|
||||
#define UDR _SFR_MEM8(0XC6)
|
||||
|
||||
/* Reserved [0xC7..0xFF] */
|
||||
|
||||
|
||||
/* Interrupt vectors */
|
||||
/* Vector 0 is the reset vector */
|
||||
/* External Interrupt Request 0 */
|
||||
#define INT0_vect _VECTOR(1)
|
||||
#define SIG_INTERRUPT0 _VECTOR(1)
|
||||
|
||||
/* Pin Change Interrupt Request 0 */
|
||||
#define PCINT0_vect _VECTOR(2)
|
||||
#define SIG_PIN_CHANGE0 _VECTOR(2)
|
||||
|
||||
/* Pin Change Interrupt Request 1 */
|
||||
#define PCINT1_vect _VECTOR(3)
|
||||
#define SIG_PIN_CHANGE1 _VECTOR(3)
|
||||
|
||||
/* Timer/Counter2 Compare Match */
|
||||
#define TIMER2_COMP_vect _VECTOR(4)
|
||||
#define SIG_OUTPUT_COMPARE2 _VECTOR(4)
|
||||
|
||||
/* Timer/Counter2 Overflow */
|
||||
#define TIMER2_OVF_vect _VECTOR(5)
|
||||
#define SIG_OVERFLOW2 _VECTOR(5)
|
||||
|
||||
/* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(6)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(6)
|
||||
|
||||
/* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPA_vect _VECTOR(7)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(7)
|
||||
|
||||
/* Timer/Counter Compare Match B */
|
||||
#define TIMER1_COMPB_vect _VECTOR(8)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(8)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(9)
|
||||
#define SIG_OVERFLOW1 _VECTOR(9)
|
||||
|
||||
/* Timer/Counter0 Compare Match */
|
||||
#define TIMER0_COMP_vect _VECTOR(10)
|
||||
#define SIG_OUTPUT_COMPARE0 _VECTOR(10)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(11)
|
||||
#define SIG_OVERFLOW0 _VECTOR(11)
|
||||
|
||||
/* SPI Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(12)
|
||||
#define SIG_SPI _VECTOR(12)
|
||||
|
||||
/* USART0, Rx Complete */
|
||||
#define USART0_RX_vect _VECTOR(13)
|
||||
#define USART_RX_vect _VECTOR(13) /* Alias */
|
||||
#define SIG_UART_RECV _VECTOR(13)
|
||||
|
||||
/* USART0 Data register Empty */
|
||||
#define USART0_UDRE_vect _VECTOR(14)
|
||||
#define USART_UDRE_vect _VECTOR(14) /* Alias */
|
||||
#define SIG_UART_DATA _VECTOR(14)
|
||||
|
||||
/* USART0, Tx Complete */
|
||||
#define USART0_TX_vect _VECTOR(15)
|
||||
#define USART_TX_vect _VECTOR(15) /* Alias */
|
||||
#define SIG_UART_TRANS _VECTOR(15)
|
||||
|
||||
/* USI Start Condition */
|
||||
#define USI_START_vect _VECTOR(16)
|
||||
#define SIG_USI_START _VECTOR(16)
|
||||
|
||||
/* USI Overflow */
|
||||
#define USI_OVERFLOW_vect _VECTOR(17)
|
||||
#define SIG_USI_OVERFLOW _VECTOR(17)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANALOG_COMP_vect _VECTOR(18)
|
||||
#define SIG_COMPARATOR _VECTOR(18)
|
||||
|
||||
/* ADC Conversion Complete */
|
||||
#define ADC_vect _VECTOR(19)
|
||||
#define SIG_ADC _VECTOR(19)
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_READY_vect _VECTOR(20)
|
||||
#define SIG_EEPROM_READY _VECTOR(20)
|
||||
|
||||
/* Store Program Memory Read */
|
||||
#define SPM_READY_vect _VECTOR(21)
|
||||
#define SIG_SPM_READY _VECTOR(21)
|
||||
|
||||
#define _VECTORS_SIZE 88
|
||||
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 128
|
||||
#define RAMEND 0x4FF
|
||||
#define XRAMEND 0x4FF
|
||||
#define E2END 0x1FF
|
||||
#define E2PAGESIZE 4
|
||||
#define FLASHEND 0x3FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6)
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(2)
|
||||
#define FUSE_BODLEVEL2 (unsigned char)~_BV(3)
|
||||
#define EFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x94
|
||||
#define SIGNATURE_2 0x07
|
||||
|
||||
|
||||
#endif /* _AVR_IOM165_H_ */
|
|
@ -0,0 +1,822 @@
|
|||
/* Copyright (c) 2004,2005,2006 Eric B. Weddington
|
||||
Copyright (c) 2006 Anatoly Sokolov <aesok@post.ru>
|
||||
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: iom165p.h,v 1.2.2.6 2008/10/17 23:27:47 arcanum Exp $ */
|
||||
|
||||
/* avr/iom165p.h - definitions for ATmega165P */
|
||||
|
||||
#ifndef _AVR_IOM165P_H_
|
||||
#define _AVR_IOM165P_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_ "iom165p.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#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 DDG4 4
|
||||
#define DDG3 3
|
||||
#define DDG2 2
|
||||
#define DDG1 1
|
||||
#define DDG0 0
|
||||
|
||||
#define PORTG _SFR_IO8(0x14)
|
||||
#define PG4 4
|
||||
#define PG3 3
|
||||
#define PG2 2
|
||||
#define PG1 1
|
||||
#define PG0 0
|
||||
|
||||
#define TIFR0 _SFR_IO8(0x15)
|
||||
#define TOV0 0
|
||||
#define OCF0A 1
|
||||
|
||||
#define TIFR1 _SFR_IO8(0x16)
|
||||
#define TOV1 0
|
||||
#define OCF1A 1
|
||||
#define OCF1B 2
|
||||
#define ICF1 5
|
||||
|
||||
#define TIFR2 _SFR_IO8(0x17)
|
||||
#define TOV2 0
|
||||
#define OCF2A 1
|
||||
|
||||
/* Reserved [0x18..0x1B] */
|
||||
|
||||
#define EIFR _SFR_IO8(0x1C)
|
||||
#define INTF0 0
|
||||
#define PCIF0 6
|
||||
#define PCIF1 7
|
||||
|
||||
#define EIMSK _SFR_IO8(0x1D)
|
||||
#define INT0 0
|
||||
#define PCIE0 6
|
||||
#define PCIE1 7
|
||||
|
||||
#define GPIOR0 _SFR_IO8(0x1E)
|
||||
|
||||
#define EECR _SFR_IO8(0x1F)
|
||||
#define EERE 0
|
||||
#define EEWE 1
|
||||
#define EEMWE 2
|
||||
#define EERIE 3
|
||||
|
||||
#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 PSR10 0
|
||||
#define PSR2 1
|
||||
#define TSM 7
|
||||
|
||||
#define TCCR0A _SFR_IO8(0x24)
|
||||
#define CS00 0
|
||||
#define CS01 1
|
||||
#define CS02 2
|
||||
#define WGM01 3
|
||||
#define COM0A0 4
|
||||
#define COM0A1 5
|
||||
#define WGM00 6
|
||||
#define FOC0A 7
|
||||
|
||||
/* Reserved [0x25] */
|
||||
|
||||
#define TCNT0 _SFR_IO8(0X26)
|
||||
|
||||
#define OCR0A _SFR_IO8(0X27)
|
||||
|
||||
/* Reserved [0x28..0x29] */
|
||||
|
||||
#define GPIOR1 _SFR_IO8(0x2A)
|
||||
|
||||
#define GPIOR2 _SFR_IO8(0x2B)
|
||||
|
||||
#define SPCR _SFR_IO8(0x2C)
|
||||
#define SPR0 0
|
||||
#define SPR1 1
|
||||
#define CPHA 2
|
||||
#define CPOL 3
|
||||
#define MSTR 4
|
||||
#define DORD 5
|
||||
#define SPE 6
|
||||
#define SPIE 7
|
||||
|
||||
#define SPSR _SFR_IO8(0x2D)
|
||||
#define SPI2X 0
|
||||
#define WCOL 6
|
||||
#define SPIF 7
|
||||
|
||||
#define SPDR _SFR_IO8(0X2E)
|
||||
|
||||
/* Reserved [0x2F] */
|
||||
|
||||
#define ACSR _SFR_IO8(0x30)
|
||||
#define ACIS0 0
|
||||
#define ACIS1 1
|
||||
#define ACIC 2
|
||||
#define ACIE 3
|
||||
#define ACI 4
|
||||
#define ACO 5
|
||||
#define ACBG 6
|
||||
#define ACD 7
|
||||
|
||||
#define OCDR _SFR_IO8(0x31)
|
||||
#define OCDR0 0
|
||||
#define OCDR1 1
|
||||
#define OCDR2 2
|
||||
#define OCDR3 3
|
||||
#define OCDR4 4
|
||||
#define OCDR5 5
|
||||
#define OCDR6 6
|
||||
#define OCD 7 // The datasheet defines this but IMO it should be OCDR7.
|
||||
#define OCDR7 7
|
||||
#define IDRD 7
|
||||
|
||||
/* Reserved [0x32] */
|
||||
|
||||
#define SMCR _SFR_IO8(0x33)
|
||||
#define SE 0
|
||||
#define SM0 1
|
||||
#define SM1 2
|
||||
#define SM2 3
|
||||
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
#define PORF 0
|
||||
#define EXTRF 1
|
||||
#define BORF 2
|
||||
#define WDRF 3
|
||||
#define JTRF 4
|
||||
|
||||
#define MCUCR _SFR_IO8(0X35)
|
||||
#define IVCE 0
|
||||
#define IVSEL 1
|
||||
#define PUD 4
|
||||
#define JTD 7
|
||||
|
||||
/* Reserved [0x36] */
|
||||
|
||||
#define SPMCSR _SFR_IO8(0x37)
|
||||
#define SPMEN 0
|
||||
#define PGERS 1
|
||||
#define PGWRT 2
|
||||
#define BLBSET 3
|
||||
#define RWWSRE 4
|
||||
#define RWWSB 6
|
||||
#define SPMIE 7
|
||||
|
||||
/* Reserved [0x38..0x3C] */
|
||||
|
||||
/* SP [0x3D..0x3E] */
|
||||
/* SREG [0x3F] */
|
||||
|
||||
#define WDTCR _SFR_MEM8(0x60)
|
||||
#define WDP0 0
|
||||
#define WDP1 1
|
||||
#define WDP2 2
|
||||
#define WDE 3
|
||||
#define WDCE 4
|
||||
|
||||
#define CLKPR _SFR_MEM8(0x61)
|
||||
#define CLKPS0 0
|
||||
#define CLKPS1 1
|
||||
#define CLKPS2 2
|
||||
#define CLKPS3 3
|
||||
#define CLKPCE 7
|
||||
|
||||
/* Reserved [0x62..0x63] */
|
||||
|
||||
#define PRR _SFR_MEM8(0x64)
|
||||
#define PRADC 0
|
||||
#define PRUSART0 1
|
||||
#define PRSPI 2
|
||||
#define PRTIM1 3
|
||||
|
||||
/* Reserved [0x65] */
|
||||
|
||||
#define OSCCAL _SFR_MEM8(0x66)
|
||||
|
||||
/* Reserved [0x67..0x68] */
|
||||
|
||||
#define EICRA _SFR_MEM8(0x69)
|
||||
#define ISC00 0
|
||||
#define ISC01 1
|
||||
|
||||
/* Reserved [0x6A] */
|
||||
|
||||
/* Combine PCMSK0 and PCMSK1 */
|
||||
#define PCMSK _SFR_MEM16(0x6B)
|
||||
|
||||
#define PCMSK0 _SFR_MEM8(0x6B)
|
||||
#define PCINT0 0
|
||||
#define PCINT1 1
|
||||
#define PCINT2 2
|
||||
#define PCINT3 3
|
||||
#define PCINT4 4
|
||||
#define PCINT5 5
|
||||
#define PCINT6 6
|
||||
#define PCINT7 7
|
||||
|
||||
#define PCMSK1 _SFR_MEM8(0x6C)
|
||||
#define PCINT8 0
|
||||
#define PCINT9 1
|
||||
#define PCINT10 2
|
||||
#define PCINT11 3
|
||||
#define PCINT12 4
|
||||
#define PCINT13 5
|
||||
#define PCINT14 6
|
||||
#define PCINT15 7
|
||||
|
||||
/* Reserved [0x6D] */
|
||||
|
||||
#define TIMSK0 _SFR_MEM8(0x6E)
|
||||
#define TOIE0 0
|
||||
#define OCIE0A 1
|
||||
|
||||
#define TIMSK1 _SFR_MEM8(0x6F)
|
||||
#define TOIE1 0
|
||||
#define OCIE1A 1
|
||||
#define OCIE1B 2
|
||||
#define ICIE1 5
|
||||
|
||||
#define TIMSK2 _SFR_MEM8(0x70)
|
||||
#define TOIE2 0
|
||||
#define OCIE2A 1
|
||||
|
||||
/* Reserved [0x71..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 ADPS0 0
|
||||
#define ADPS1 1
|
||||
#define ADPS2 2
|
||||
#define ADIE 3
|
||||
#define ADIF 4
|
||||
#define ADATE 5
|
||||
#define ADSC 6
|
||||
#define ADEN 7
|
||||
|
||||
#define ADCSRB _SFR_MEM8(0x7B)
|
||||
#define ADTS0 0
|
||||
#define ADTS1 1
|
||||
#define ADTS2 2
|
||||
#define ACME 6
|
||||
|
||||
#define ADMUX _SFR_MEM8(0x7C)
|
||||
#define MUX0 0
|
||||
#define MUX1 1
|
||||
#define MUX2 2
|
||||
#define MUX3 3
|
||||
#define MUX4 4
|
||||
#define ADLAR 5
|
||||
#define REFS0 6
|
||||
#define REFS1 7
|
||||
|
||||
/* Reserved [0x7D] */
|
||||
|
||||
#define DIDR0 _SFR_MEM8(0x7E)
|
||||
#define ADC0D 0
|
||||
#define ADC1D 1
|
||||
#define ADC2D 2
|
||||
#define ADC3D 3
|
||||
#define ADC4D 4
|
||||
#define ADC5D 5
|
||||
#define ADC6D 6
|
||||
#define ADC7D 7
|
||||
|
||||
#define DIDR1 _SFR_MEM8(0x7F)
|
||||
#define AIN0D 0
|
||||
#define AIN1D 1
|
||||
|
||||
#define TCCR1A _SFR_MEM8(0X80)
|
||||
#define WGM10 0
|
||||
#define WGM11 1
|
||||
#define COM1B0 4
|
||||
#define COM1B1 5
|
||||
#define COM1A0 6
|
||||
#define COM1A1 7
|
||||
|
||||
#define TCCR1B _SFR_MEM8(0X81)
|
||||
#define CS10 0
|
||||
#define CS11 1
|
||||
#define CS12 2
|
||||
#define WGM12 3
|
||||
#define WGM13 4
|
||||
#define ICES1 6
|
||||
#define ICNC1 7
|
||||
|
||||
#define TCCR1C _SFR_MEM8(0x82)
|
||||
#define FOC1B 6
|
||||
#define FOC1A 7
|
||||
|
||||
/* 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)
|
||||
|
||||
/* Reserved [0x8C..0xAF] */
|
||||
|
||||
#define TCCR2A _SFR_MEM8(0xB0)
|
||||
#define CS20 0
|
||||
#define CS21 1
|
||||
#define CS22 2
|
||||
#define WGM21 3
|
||||
#define COM2A0 4
|
||||
#define COM2A1 5
|
||||
#define WGM20 6
|
||||
#define FOC2A 7
|
||||
|
||||
/* Reserved [0xB1] */
|
||||
|
||||
#define TCNT2 _SFR_MEM8(0xB2)
|
||||
|
||||
#define OCR2A _SFR_MEM8(0xB3)
|
||||
|
||||
/* Reserved [0xB4..0xB5] */
|
||||
|
||||
#define ASSR _SFR_MEM8(0xB6)
|
||||
#define TCR2UB 0
|
||||
#define OCR2UB 1
|
||||
#define TCN2UB 2
|
||||
#define AS2 3
|
||||
#define EXCLK 4
|
||||
|
||||
/* Reserved [0xB7] */
|
||||
|
||||
#define USICR _SFR_MEM8(0xB8)
|
||||
#define USITC 0
|
||||
#define USICLK 1
|
||||
#define USICS0 2
|
||||
#define USICS1 3
|
||||
#define USIWM0 4
|
||||
#define USIWM1 5
|
||||
#define USIOIE 6
|
||||
#define USISIE 7
|
||||
|
||||
#define USISR _SFR_MEM8(0xB9)
|
||||
#define USICNT0 0
|
||||
#define USICNT1 1
|
||||
#define USICNT2 2
|
||||
#define USICNT3 3
|
||||
#define USIDC 4
|
||||
#define USIPF 5
|
||||
#define USIOIF 6
|
||||
#define USISIF 7
|
||||
|
||||
#define USIDR _SFR_MEM8(0xBA)
|
||||
|
||||
/* Reserved [0xBB..0xBF] */
|
||||
|
||||
#define UCSR0A _SFR_MEM8(0xC0)
|
||||
#define MPCM0 0
|
||||
#define U2X0 1
|
||||
#define UPE0 2
|
||||
#define DOR0 3
|
||||
#define FE0 4
|
||||
#define UDRE0 5
|
||||
#define TXC0 6
|
||||
#define RXC0 7
|
||||
|
||||
#define UCSR0B _SFR_MEM8(0XC1)
|
||||
#define TXB80 0
|
||||
#define RXB80 1
|
||||
#define UCSZ02 2
|
||||
#define TXEN0 3
|
||||
#define RXEN0 4
|
||||
#define UDRIE0 5
|
||||
#define TXCIE0 6
|
||||
#define RXCIE0 7
|
||||
|
||||
#define UCSR0C _SFR_MEM8(0xC2)
|
||||
#define UCPOL0 0
|
||||
#define UCSZ00 1
|
||||
#define UCSZ01 2
|
||||
#define USBS0 3
|
||||
#define UPM00 4
|
||||
#define UPM01 5
|
||||
#define UMSEL0 6
|
||||
|
||||
/* Reserved [0xC3] */
|
||||
|
||||
/* Combine UBRRL and UBRRH */
|
||||
#define UBRR0 _SFR_MEM16(0xC4)
|
||||
|
||||
#define UBRR0L _SFR_MEM8(0xC4)
|
||||
#define UBRR0H _SFR_MEM8(0xC5)
|
||||
|
||||
#define UDR0 _SFR_MEM8(0XC6)
|
||||
|
||||
/* Reserved [0xC7..0xFF] */
|
||||
|
||||
|
||||
/* Interrupt vectors */
|
||||
/* Vector 0 is the reset vector */
|
||||
/* External Interrupt Request 0 */
|
||||
#define INT0_vect _VECTOR(1)
|
||||
#define SIG_INTERRUPT0 _VECTOR(1)
|
||||
|
||||
/* Pin Change Interrupt Request 0 */
|
||||
#define PCINT0_vect _VECTOR(2)
|
||||
#define SIG_PIN_CHANGE0 _VECTOR(2)
|
||||
|
||||
/* Pin Change Interrupt Request 1 */
|
||||
#define PCINT1_vect _VECTOR(3)
|
||||
#define SIG_PIN_CHANGE1 _VECTOR(3)
|
||||
|
||||
/* Timer/Counter2 Compare Match */
|
||||
#define TIMER2_COMP_vect _VECTOR(4)
|
||||
#define SIG_OUTPUT_COMPARE2 _VECTOR(4)
|
||||
|
||||
/* Timer/Counter2 Overflow */
|
||||
#define TIMER2_OVF_vect _VECTOR(5)
|
||||
#define SIG_OVERFLOW2 _VECTOR(5)
|
||||
|
||||
/* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(6)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(6)
|
||||
|
||||
/* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPA_vect _VECTOR(7)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(7)
|
||||
|
||||
/* Timer/Counter Compare Match B */
|
||||
#define TIMER1_COMPB_vect _VECTOR(8)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(8)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(9)
|
||||
#define SIG_OVERFLOW1 _VECTOR(9)
|
||||
|
||||
/* Timer/Counter0 Compare Match */
|
||||
#define TIMER0_COMP_vect _VECTOR(10)
|
||||
#define SIG_OUTPUT_COMPARE0 _VECTOR(10)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(11)
|
||||
#define SIG_OVERFLOW0 _VECTOR(11)
|
||||
|
||||
/* SPI Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(12)
|
||||
#define SIG_SPI _VECTOR(12)
|
||||
|
||||
/* USART0, Rx Complete */
|
||||
#define USART0_RX_vect _VECTOR(13)
|
||||
#define USART_RX_vect _VECTOR(13) /* Alias */
|
||||
#define SIG_UART_RECV _VECTOR(13)
|
||||
|
||||
/* USART0 Data register Empty */
|
||||
#define USART0_UDRE_vect _VECTOR(14)
|
||||
#define USART_UDRE_vect _VECTOR(14) /* Alias */
|
||||
#define SIG_UART_DATA _VECTOR(14)
|
||||
|
||||
/* USART0, Tx Complete */
|
||||
#define USART0_TX_vect _VECTOR(15)
|
||||
#define USART_TX_vect _VECTOR(15) /* Alias */
|
||||
#define SIG_UART_TRANS _VECTOR(15)
|
||||
|
||||
/* USI Start Condition */
|
||||
#define USI_START_vect _VECTOR(16)
|
||||
#define SIG_USI_START _VECTOR(16)
|
||||
|
||||
/* USI Overflow */
|
||||
#define USI_OVERFLOW_vect _VECTOR(17)
|
||||
#define SIG_USI_OVERFLOW _VECTOR(17)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANALOG_COMP_vect _VECTOR(18)
|
||||
#define SIG_COMPARATOR _VECTOR(18)
|
||||
|
||||
/* ADC Conversion Complete */
|
||||
#define ADC_vect _VECTOR(19)
|
||||
#define SIG_ADC _VECTOR(19)
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_READY_vect _VECTOR(20)
|
||||
#define SIG_EEPROM_READY _VECTOR(20)
|
||||
|
||||
/* Store Program Memory Read */
|
||||
#define SPM_READY_vect _VECTOR(21)
|
||||
#define SIG_SPM_READY _VECTOR(21)
|
||||
|
||||
#define _VECTORS_SIZE 88
|
||||
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 128
|
||||
#define RAMEND 0x4FF
|
||||
#define XRAMEND 0x4FF
|
||||
#define E2END 0x1FF
|
||||
#define E2PAGESIZE 4
|
||||
#define FLASHEND 0x3FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6)
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(2)
|
||||
#define FUSE_BODLEVEL2 (unsigned char)~_BV(3)
|
||||
#define EFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x94
|
||||
#define SIGNATURE_2 0x07
|
||||
|
||||
|
||||
#endif /* _AVR_IOM165P_H_ */
|
|
@ -0,0 +1,91 @@
|
|||
/* Copyright (c) 2004, Theodore A. Roth
|
||||
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: iom168.h,v 1.4.2.5 2008/10/17 23:27:47 arcanum Exp $ */
|
||||
|
||||
#ifndef _AVR_IOM168_H_
|
||||
#define _AVR_IOM168_H_ 1
|
||||
|
||||
#include <avr/iomx8.h>
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 128
|
||||
#define RAMEND 0x4FF
|
||||
#define XRAMEND 0x4FF
|
||||
#define E2END 0x1FF
|
||||
#define E2PAGESIZE 4
|
||||
#define FLASHEND 0x3FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0) /* Select Clock Source */
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1) /* Select Clock Source */
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2) /* Select Clock Source */
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3) /* Select Clock Source */
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4) /* Select start-up time */
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5) /* Select start-up time */
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6) /* Clock output */
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7) /* Divide clock by 8 */
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(0) /* Brown-out Detector trigger level */
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(1) /* Brown-out Detector trigger level */
|
||||
#define FUSE_BODLEVEL2 (unsigned char)~_BV(2) /* Brown-out Detector trigger level */
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3) /* EEPROM memory is preserved through chip erase */
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4) /* Watchdog Timer Always On */
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5) /* Enable Serial programming and Data Downloading */
|
||||
#define FUSE_DWEN (unsigned char)~_BV(6) /* debugWIRE Enable */
|
||||
#define FUSE_RSTDISBL (unsigned char)~_BV(7) /* External reset disable */
|
||||
#define HFUSE_DEFAULT (FUSE_SPIEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define EFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x94
|
||||
#define SIGNATURE_2 0x06
|
||||
|
||||
|
||||
#endif /* _AVR_IOM168_H_ */
|
|
@ -0,0 +1,874 @@
|
|||
/* Copyright (c) 2007 Atmel Corporation
|
||||
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: iom168p.h,v 1.3.2.10 2008/10/17 23:27:48 arcanum Exp $ */
|
||||
|
||||
/* avr/iom168p.h - definitions for ATmega168P. */
|
||||
|
||||
/* 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_ "iom168p.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
|
||||
#ifndef _AVR_IOM168P_H_
|
||||
#define _AVR_IOM168P_H_ 1
|
||||
|
||||
/* Registers and associated bit numbers */
|
||||
|
||||
#define PINB _SFR_IO8(0x03)
|
||||
#define PINB0 0
|
||||
#define PINB1 1
|
||||
#define PINB2 2
|
||||
#define PINB3 3
|
||||
#define PINB4 4
|
||||
#define PINB5 5
|
||||
#define PINB6 6
|
||||
#define PINB7 7
|
||||
|
||||
#define DDRB _SFR_IO8(0x04)
|
||||
#define DDB0 0
|
||||
#define DDB1 1
|
||||
#define DDB2 2
|
||||
#define DDB3 3
|
||||
#define DDB4 4
|
||||
#define DDB5 5
|
||||
#define DDB6 6
|
||||
#define DDB7 7
|
||||
|
||||
#define PORTB _SFR_IO8(0x05)
|
||||
#define PORTB0 0
|
||||
#define PORTB1 1
|
||||
#define PORTB2 2
|
||||
#define PORTB3 3
|
||||
#define PORTB4 4
|
||||
#define PORTB5 5
|
||||
#define PORTB6 6
|
||||
#define PORTB7 7
|
||||
|
||||
#define PINC _SFR_IO8(0x06)
|
||||
#define PINC0 0
|
||||
#define PINC1 1
|
||||
#define PINC2 2
|
||||
#define PINC3 3
|
||||
#define PINC4 4
|
||||
#define PINC5 5
|
||||
#define PINC6 6
|
||||
|
||||
#define DDRC _SFR_IO8(0x07)
|
||||
#define DDC0 0
|
||||
#define DDC1 1
|
||||
#define DDC2 2
|
||||
#define DDC3 3
|
||||
#define DDC4 4
|
||||
#define DDC5 5
|
||||
#define DDC6 6
|
||||
|
||||
#define PORTC _SFR_IO8(0x08)
|
||||
#define PORTC0 0
|
||||
#define PORTC1 1
|
||||
#define PORTC2 2
|
||||
#define PORTC3 3
|
||||
#define PORTC4 4
|
||||
#define PORTC5 5
|
||||
#define PORTC6 6
|
||||
|
||||
#define PIND _SFR_IO8(0x09)
|
||||
#define PIND0 0
|
||||
#define PIND1 1
|
||||
#define PIND2 2
|
||||
#define PIND3 3
|
||||
#define PIND4 4
|
||||
#define PIND5 5
|
||||
#define PIND6 6
|
||||
#define PIND7 7
|
||||
|
||||
#define DDRD _SFR_IO8(0x0A)
|
||||
#define DDD0 0
|
||||
#define DDD1 1
|
||||
#define DDD2 2
|
||||
#define DDD3 3
|
||||
#define DDD4 4
|
||||
#define DDD5 5
|
||||
#define DDD6 6
|
||||
#define DDD7 7
|
||||
|
||||
#define PORTD _SFR_IO8(0x0B)
|
||||
#define PORTD0 0
|
||||
#define PORTD1 1
|
||||
#define PORTD2 2
|
||||
#define PORTD3 3
|
||||
#define PORTD4 4
|
||||
#define PORTD5 5
|
||||
#define PORTD6 6
|
||||
#define PORTD7 7
|
||||
|
||||
#define TIFR0 _SFR_IO8(0x15)
|
||||
#define TOV0 0
|
||||
#define OCF0A 1
|
||||
#define OCF0B 2
|
||||
|
||||
#define TIFR1 _SFR_IO8(0x16)
|
||||
#define TOV1 0
|
||||
#define OCF1A 1
|
||||
#define OCF1B 2
|
||||
#define ICF1 5
|
||||
|
||||
#define TIFR2 _SFR_IO8(0x17)
|
||||
#define TOV2 0
|
||||
#define OCF2A 1
|
||||
#define OCF2B 2
|
||||
|
||||
#define PCIFR _SFR_IO8(0x1B)
|
||||
#define PCIF0 0
|
||||
#define PCIF1 1
|
||||
#define PCIF2 2
|
||||
|
||||
#define EIFR _SFR_IO8(0x1C)
|
||||
#define INTF0 0
|
||||
#define INTF1 1
|
||||
|
||||
#define EIMSK _SFR_IO8(0x1D)
|
||||
#define INT0 0
|
||||
#define INT1 1
|
||||
|
||||
#define GPIOR0 _SFR_IO8(0x1E)
|
||||
#define GPIOR00 0
|
||||
#define GPIOR01 1
|
||||
#define GPIOR02 2
|
||||
#define GPIOR03 3
|
||||
#define GPIOR04 4
|
||||
#define GPIOR05 5
|
||||
#define GPIOR06 6
|
||||
#define GPIOR07 7
|
||||
|
||||
#define EECR _SFR_IO8(0x1F)
|
||||
#define EERE 0
|
||||
#define EEPE 1
|
||||
#define EEMPE 2
|
||||
#define EERIE 3
|
||||
#define EEPM0 4
|
||||
#define EEPM1 5
|
||||
|
||||
#define EEDR _SFR_IO8(0x20)
|
||||
#define EEDR0 0
|
||||
#define EEDR1 1
|
||||
#define EEDR2 2
|
||||
#define EEDR3 3
|
||||
#define EEDR4 4
|
||||
#define EEDR5 5
|
||||
#define EEDR6 6
|
||||
#define EEDR7 7
|
||||
|
||||
#define EEAR _SFR_IO16(0x21)
|
||||
|
||||
#define EEARL _SFR_IO8(0x21)
|
||||
#define EEAR0 0
|
||||
#define EEAR1 1
|
||||
#define EEAR2 2
|
||||
#define EEAR3 3
|
||||
#define EEAR4 4
|
||||
#define EEAR5 5
|
||||
#define EEAR6 6
|
||||
#define EEAR7 7
|
||||
|
||||
#define EEARH _SFR_IO8(0x22)
|
||||
#define EEAR8 0
|
||||
|
||||
#define EEPROM_REG_LOCATIONS 1F2021
|
||||
|
||||
#define GTCCR _SFR_IO8(0x23)
|
||||
#define PSRSYNC 0
|
||||
#define PSRASY 1
|
||||
#define TSM 7
|
||||
|
||||
#define TCCR0A _SFR_IO8(0x24)
|
||||
#define WGM00 0
|
||||
#define WGM01 1
|
||||
#define COM0B0 4
|
||||
#define COM0B1 5
|
||||
#define COM0A0 6
|
||||
#define COM0A1 7
|
||||
|
||||
#define TCCR0B _SFR_IO8(0x25)
|
||||
#define CS00 0
|
||||
#define CS01 1
|
||||
#define CS02 2
|
||||
#define WGM02 3
|
||||
#define FOC0B 6
|
||||
#define FOC0A 7
|
||||
|
||||
#define TCNT0 _SFR_IO8(0x26)
|
||||
#define TCNT0_0 0
|
||||
#define TCNT0_1 1
|
||||
#define TCNT0_2 2
|
||||
#define TCNT0_3 3
|
||||
#define TCNT0_4 4
|
||||
#define TCNT0_5 5
|
||||
#define TCNT0_6 6
|
||||
#define TCNT0_7 7
|
||||
|
||||
#define OCR0A _SFR_IO8(0x27)
|
||||
#define OCROA_0 0
|
||||
#define OCROA_1 1
|
||||
#define OCROA_2 2
|
||||
#define OCROA_3 3
|
||||
#define OCROA_4 4
|
||||
#define OCROA_5 5
|
||||
#define OCROA_6 6
|
||||
#define OCROA_7 7
|
||||
|
||||
#define OCR0B _SFR_IO8(0x28)
|
||||
#define OCR0B_0 0
|
||||
#define OCR0B_1 1
|
||||
#define OCR0B_2 2
|
||||
#define OCR0B_3 3
|
||||
#define OCR0B_4 4
|
||||
#define OCR0B_5 5
|
||||
#define OCR0B_6 6
|
||||
#define OCR0B_7 7
|
||||
|
||||
#define GPIOR1 _SFR_IO8(0x2A)
|
||||
#define GPIOR10 0
|
||||
#define GPIOR11 1
|
||||
#define GPIOR12 2
|
||||
#define GPIOR13 3
|
||||
#define GPIOR14 4
|
||||
#define GPIOR15 5
|
||||
#define GPIOR16 6
|
||||
#define GPIOR17 7
|
||||
|
||||
#define GPIOR2 _SFR_IO8(0x2B)
|
||||
#define GPIOR20 0
|
||||
#define GPIOR21 1
|
||||
#define GPIOR22 2
|
||||
#define GPIOR23 3
|
||||
#define GPIOR24 4
|
||||
#define GPIOR25 5
|
||||
#define GPIOR26 6
|
||||
#define GPIOR27 7
|
||||
|
||||
#define SPCR _SFR_IO8(0x2C)
|
||||
#define SPR0 0
|
||||
#define SPR1 1
|
||||
#define CPHA 2
|
||||
#define CPOL 3
|
||||
#define MSTR 4
|
||||
#define DORD 5
|
||||
#define SPE 6
|
||||
#define SPIE 7
|
||||
|
||||
#define SPSR _SFR_IO8(0x2D)
|
||||
#define SPI2X 0
|
||||
#define WCOL 6
|
||||
#define SPIF 7
|
||||
|
||||
#define SPDR _SFR_IO8(0x2E)
|
||||
#define SPDR0 0
|
||||
#define SPDR1 1
|
||||
#define SPDR2 2
|
||||
#define SPDR3 3
|
||||
#define SPDR4 4
|
||||
#define SPDR5 5
|
||||
#define SPDR6 6
|
||||
#define SPDR7 7
|
||||
|
||||
#define ACSR _SFR_IO8(0x30)
|
||||
#define ACIS0 0
|
||||
#define ACIS1 1
|
||||
#define ACIC 2
|
||||
#define ACIE 3
|
||||
#define ACI 4
|
||||
#define ACO 5
|
||||
#define ACBG 6
|
||||
#define ACD 7
|
||||
|
||||
#define SMCR _SFR_IO8(0x33)
|
||||
#define SE 0
|
||||
#define SM0 1
|
||||
#define SM1 2
|
||||
#define SM2 3
|
||||
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
#define PORF 0
|
||||
#define EXTRF 1
|
||||
#define BORF 2
|
||||
#define WDRF 3
|
||||
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
#define IVCE 0
|
||||
#define IVSEL 1
|
||||
#define PUD 4
|
||||
#define BODSE 5
|
||||
#define BODS 6
|
||||
|
||||
#define SPMCSR _SFR_IO8(0x37)
|
||||
#define SELFPRGEN 0
|
||||
#define PGERS 1
|
||||
#define PGWRT 2
|
||||
#define BLBSET 3
|
||||
#define RWWSRE 4
|
||||
#define RWWSB 6
|
||||
#define SPMIE 7
|
||||
|
||||
#define WDTCSR _SFR_MEM8(0x60)
|
||||
#define WDP0 0
|
||||
#define WDP1 1
|
||||
#define WDP2 2
|
||||
#define WDE 3
|
||||
#define WDCE 4
|
||||
#define WDP3 5
|
||||
#define WDIE 6
|
||||
#define WDIF 7
|
||||
|
||||
#define CLKPR _SFR_MEM8(0x61)
|
||||
#define CLKPS0 0
|
||||
#define CLKPS1 1
|
||||
#define CLKPS2 2
|
||||
#define CLKPS3 3
|
||||
#define CLKPCE 7
|
||||
|
||||
#define PRR _SFR_MEM8(0x64)
|
||||
#define PRADC 0
|
||||
#define PRUSART0 1
|
||||
#define PRSPI 2
|
||||
#define PRTIM1 3
|
||||
#define PRTIM0 5
|
||||
#define PRTIM2 6
|
||||
#define PRTWI 7
|
||||
|
||||
#define OSCCAL _SFR_MEM8(0x66)
|
||||
#define CAL0 0
|
||||
#define CAL1 1
|
||||
#define CAL2 2
|
||||
#define CAL3 3
|
||||
#define CAL4 4
|
||||
#define CAL5 5
|
||||
#define CAL6 6
|
||||
#define CAL7 7
|
||||
|
||||
#define PCICR _SFR_MEM8(0x68)
|
||||
#define PCIE0 0
|
||||
#define PCIE1 1
|
||||
#define PCIE2 2
|
||||
|
||||
#define EICRA _SFR_MEM8(0x69)
|
||||
#define ISC00 0
|
||||
#define ISC01 1
|
||||
#define ISC10 2
|
||||
#define ISC11 3
|
||||
|
||||
#define PCMSK0 _SFR_MEM8(0x6B)
|
||||
#define PCINT0 0
|
||||
#define PCINT1 1
|
||||
#define PCINT2 2
|
||||
#define PCINT3 3
|
||||
#define PCINT4 4
|
||||
#define PCINT5 5
|
||||
#define PCINT6 6
|
||||
#define PCINT7 7
|
||||
|
||||
#define PCMSK1 _SFR_MEM8(0x6C)
|
||||
#define PCINT8 0
|
||||
#define PCINT9 1
|
||||
#define PCINT10 2
|
||||
#define PCINT11 3
|
||||
#define PCINT12 4
|
||||
#define PCINT13 5
|
||||
#define PCINT14 6
|
||||
|
||||
#define PCMSK2 _SFR_MEM8(0x6D)
|
||||
#define PCINT16 0
|
||||
#define PCINT17 1
|
||||
#define PCINT18 2
|
||||
#define PCINT19 3
|
||||
#define PCINT20 4
|
||||
#define PCINT21 5
|
||||
#define PCINT22 6
|
||||
#define PCINT23 7
|
||||
|
||||
#define TIMSK0 _SFR_MEM8(0x6E)
|
||||
#define TOIE0 0
|
||||
#define OCIE0A 1
|
||||
#define OCIE0B 2
|
||||
|
||||
#define TIMSK1 _SFR_MEM8(0x6F)
|
||||
#define TOIE1 0
|
||||
#define OCIE1A 1
|
||||
#define OCIE1B 2
|
||||
#define ICIE1 5
|
||||
|
||||
#define TIMSK2 _SFR_MEM8(0x70)
|
||||
#define TOIE2 0
|
||||
#define OCIE2A 1
|
||||
#define OCIE2B 2
|
||||
|
||||
#ifndef __ASSEMBLER__
|
||||
#define ADC _SFR_MEM16(0x78)
|
||||
#endif
|
||||
#define ADCW _SFR_MEM16(0x78)
|
||||
|
||||
#define ADCL _SFR_MEM8(0x78)
|
||||
#define ADCL0 0
|
||||
#define ADCL1 1
|
||||
#define ADCL2 2
|
||||
#define ADCL3 3
|
||||
#define ADCL4 4
|
||||
#define ADCL5 5
|
||||
#define ADCL6 6
|
||||
#define ADCL7 7
|
||||
|
||||
#define ADCH _SFR_MEM8(0x79)
|
||||
#define ADCH0 0
|
||||
#define ADCH1 1
|
||||
#define ADCH2 2
|
||||
#define ADCH3 3
|
||||
#define ADCH4 4
|
||||
#define ADCH5 5
|
||||
#define ADCH6 6
|
||||
#define ADCH7 7
|
||||
|
||||
#define ADCSRA _SFR_MEM8(0x7A)
|
||||
#define ADPS0 0
|
||||
#define ADPS1 1
|
||||
#define ADPS2 2
|
||||
#define ADIE 3
|
||||
#define ADIF 4
|
||||
#define ADATE 5
|
||||
#define ADSC 6
|
||||
#define ADEN 7
|
||||
|
||||
#define ADCSRB _SFR_MEM8(0x7B)
|
||||
#define ADTS0 0
|
||||
#define ADTS1 1
|
||||
#define ADTS2 2
|
||||
#define ACME 6
|
||||
|
||||
#define ADMUX _SFR_MEM8(0x7C)
|
||||
#define MUX0 0
|
||||
#define MUX1 1
|
||||
#define MUX2 2
|
||||
#define MUX3 3
|
||||
#define ADLAR 5
|
||||
#define REFS0 6
|
||||
#define REFS1 7
|
||||
|
||||
#define DIDR0 _SFR_MEM8(0x7E)
|
||||
#define ADC0D 0
|
||||
#define ADC1D 1
|
||||
#define ADC2D 2
|
||||
#define ADC3D 3
|
||||
#define ADC4D 4
|
||||
#define ADC5D 5
|
||||
|
||||
#define DIDR1 _SFR_MEM8(0x7F)
|
||||
#define AIN0D 0
|
||||
#define AIN1D 1
|
||||
|
||||
#define TCCR1A _SFR_MEM8(0x80)
|
||||
#define WGM10 0
|
||||
#define WGM11 1
|
||||
#define COM1B0 4
|
||||
#define COM1B1 5
|
||||
#define COM1A0 6
|
||||
#define COM1A1 7
|
||||
|
||||
#define TCCR1B _SFR_MEM8(0x81)
|
||||
#define CS10 0
|
||||
#define CS11 1
|
||||
#define CS12 2
|
||||
#define WGM12 3
|
||||
#define WGM13 4
|
||||
#define ICES1 6
|
||||
#define ICNC1 7
|
||||
|
||||
#define TCCR1C _SFR_MEM8(0x82)
|
||||
#define FOC1B 6
|
||||
#define FOC1A 7
|
||||
|
||||
#define TCNT1 _SFR_MEM16(0x84)
|
||||
|
||||
#define TCNT1L _SFR_MEM8(0x84)
|
||||
#define TCNT1L0 0
|
||||
#define TCNT1L1 1
|
||||
#define TCNT1L2 2
|
||||
#define TCNT1L3 3
|
||||
#define TCNT1L4 4
|
||||
#define TCNT1L5 5
|
||||
#define TCNT1L6 6
|
||||
#define TCNT1L7 7
|
||||
|
||||
#define TCNT1H _SFR_MEM8(0x85)
|
||||
#define TCNT1H0 0
|
||||
#define TCNT1H1 1
|
||||
#define TCNT1H2 2
|
||||
#define TCNT1H3 3
|
||||
#define TCNT1H4 4
|
||||
#define TCNT1H5 5
|
||||
#define TCNT1H6 6
|
||||
#define TCNT1H7 7
|
||||
|
||||
#define ICR1 _SFR_MEM16(0x86)
|
||||
|
||||
#define ICR1L _SFR_MEM8(0x86)
|
||||
#define ICR1L0 0
|
||||
#define ICR1L1 1
|
||||
#define ICR1L2 2
|
||||
#define ICR1L3 3
|
||||
#define ICR1L4 4
|
||||
#define ICR1L5 5
|
||||
#define ICR1L6 6
|
||||
#define ICR1L7 7
|
||||
|
||||
#define ICR1H _SFR_MEM8(0x87)
|
||||
#define ICR1H0 0
|
||||
#define ICR1H1 1
|
||||
#define ICR1H2 2
|
||||
#define ICR1H3 3
|
||||
#define ICR1H4 4
|
||||
#define ICR1H5 5
|
||||
#define ICR1H6 6
|
||||
#define ICR1H7 7
|
||||
|
||||
#define OCR1A _SFR_MEM16(0x88)
|
||||
|
||||
#define OCR1AL _SFR_MEM8(0x88)
|
||||
#define OCR1AL0 0
|
||||
#define OCR1AL1 1
|
||||
#define OCR1AL2 2
|
||||
#define OCR1AL3 3
|
||||
#define OCR1AL4 4
|
||||
#define OCR1AL5 5
|
||||
#define OCR1AL6 6
|
||||
#define OCR1AL7 7
|
||||
|
||||
#define OCR1AH _SFR_MEM8(0x89)
|
||||
#define OCR1AH0 0
|
||||
#define OCR1AH1 1
|
||||
#define OCR1AH2 2
|
||||
#define OCR1AH3 3
|
||||
#define OCR1AH4 4
|
||||
#define OCR1AH5 5
|
||||
#define OCR1AH6 6
|
||||
#define OCR1AH7 7
|
||||
|
||||
#define OCR1B _SFR_MEM16(0x8A)
|
||||
|
||||
#define OCR1BL _SFR_MEM8(0x8A)
|
||||
#define OCR1BL0 0
|
||||
#define OCR1BL1 1
|
||||
#define OCR1BL2 2
|
||||
#define OCR1BL3 3
|
||||
#define OCR1BL4 4
|
||||
#define OCR1BL5 5
|
||||
#define OCR1BL6 6
|
||||
#define OCR1BL7 7
|
||||
|
||||
#define OCR1BH _SFR_MEM8(0x8B)
|
||||
#define OCR1BH0 0
|
||||
#define OCR1BH1 1
|
||||
#define OCR1BH2 2
|
||||
#define OCR1BH3 3
|
||||
#define OCR1BH4 4
|
||||
#define OCR1BH5 5
|
||||
#define OCR1BH6 6
|
||||
#define OCR1BH7 7
|
||||
|
||||
#define TCCR2A _SFR_MEM8(0xB0)
|
||||
#define WGM20 0
|
||||
#define WGM21 1
|
||||
#define COM2B0 4
|
||||
#define COM2B1 5
|
||||
#define COM2A0 6
|
||||
#define COM2A1 7
|
||||
|
||||
#define TCCR2B _SFR_MEM8(0xB1)
|
||||
#define CS20 0
|
||||
#define CS21 1
|
||||
#define CS22 2
|
||||
#define WGM22 3
|
||||
#define FOC2B 6
|
||||
#define FOC2A 7
|
||||
|
||||
#define TCNT2 _SFR_MEM8(0xB2)
|
||||
#define TCNT2_0 0
|
||||
#define TCNT2_1 1
|
||||
#define TCNT2_2 2
|
||||
#define TCNT2_3 3
|
||||
#define TCNT2_4 4
|
||||
#define TCNT2_5 5
|
||||
#define TCNT2_6 6
|
||||
#define TCNT2_7 7
|
||||
|
||||
#define OCR2A _SFR_MEM8(0xB3)
|
||||
#define OCR2_0 0
|
||||
#define OCR2_1 1
|
||||
#define OCR2_2 2
|
||||
#define OCR2_3 3
|
||||
#define OCR2_4 4
|
||||
#define OCR2_5 5
|
||||
#define OCR2_6 6
|
||||
#define OCR2_7 7
|
||||
|
||||
#define OCR2B _SFR_MEM8(0xB4)
|
||||
#define OCR2_0 0
|
||||
#define OCR2_1 1
|
||||
#define OCR2_2 2
|
||||
#define OCR2_3 3
|
||||
#define OCR2_4 4
|
||||
#define OCR2_5 5
|
||||
#define OCR2_6 6
|
||||
#define OCR2_7 7
|
||||
|
||||
#define ASSR _SFR_MEM8(0xB6)
|
||||
#define TCR2BUB 0
|
||||
#define TCR2AUB 1
|
||||
#define OCR2BUB 2
|
||||
#define OCR2AUB 3
|
||||
#define TCN2UB 4
|
||||
#define AS2 5
|
||||
#define EXCLK 6
|
||||
|
||||
#define TWBR _SFR_MEM8(0xB8)
|
||||
#define TWBR0 0
|
||||
#define TWBR1 1
|
||||
#define TWBR2 2
|
||||
#define TWBR3 3
|
||||
#define TWBR4 4
|
||||
#define TWBR5 5
|
||||
#define TWBR6 6
|
||||
#define TWBR7 7
|
||||
|
||||
#define TWSR _SFR_MEM8(0xB9)
|
||||
#define TWPS0 0
|
||||
#define TWPS1 1
|
||||
#define TWS3 3
|
||||
#define TWS4 4
|
||||
#define TWS5 5
|
||||
#define TWS6 6
|
||||
#define TWS7 7
|
||||
|
||||
#define TWAR _SFR_MEM8(0xBA)
|
||||
#define TWGCE 0
|
||||
#define TWA0 1
|
||||
#define TWA1 2
|
||||
#define TWA2 3
|
||||
#define TWA3 4
|
||||
#define TWA4 5
|
||||
#define TWA5 6
|
||||
#define TWA6 7
|
||||
|
||||
#define TWDR _SFR_MEM8(0xBB)
|
||||
#define TWD0 0
|
||||
#define TWD1 1
|
||||
#define TWD2 2
|
||||
#define TWD3 3
|
||||
#define TWD4 4
|
||||
#define TWD5 5
|
||||
#define TWD6 6
|
||||
#define TWD7 7
|
||||
|
||||
#define TWCR _SFR_MEM8(0xBC)
|
||||
#define TWIE 0
|
||||
#define TWEN 2
|
||||
#define TWWC 3
|
||||
#define TWSTO 4
|
||||
#define TWSTA 5
|
||||
#define TWEA 6
|
||||
#define TWINT 7
|
||||
|
||||
#define TWAMR _SFR_MEM8(0xBD)
|
||||
#define TWAM0 0
|
||||
#define TWAM1 1
|
||||
#define TWAM2 2
|
||||
#define TWAM3 3
|
||||
#define TWAM4 4
|
||||
#define TWAM5 5
|
||||
#define TWAM6 6
|
||||
|
||||
#define UCSR0A _SFR_MEM8(0xC0)
|
||||
#define MPCM0 0
|
||||
#define U2X0 1
|
||||
#define UPE0 2
|
||||
#define DOR0 3
|
||||
#define FE0 4
|
||||
#define UDRE0 5
|
||||
#define TXC0 6
|
||||
#define RXC0 7
|
||||
|
||||
#define UCSR0B _SFR_MEM8(0xC1)
|
||||
#define TXB80 0
|
||||
#define RXB80 1
|
||||
#define UCSZ02 2
|
||||
#define TXEN0 3
|
||||
#define RXEN0 4
|
||||
#define UDRIE0 5
|
||||
#define TXCIE0 6
|
||||
#define RXCIE0 7
|
||||
|
||||
#define UCSR0C _SFR_MEM8(0xC2)
|
||||
#define UCPOL0 0
|
||||
#define UCSZ00 1
|
||||
#define UCPHA0 1
|
||||
#define UCSZ01 2
|
||||
#define UDORD0 2
|
||||
#define USBS0 3
|
||||
#define UPM00 4
|
||||
#define UPM01 5
|
||||
#define UMSEL00 6
|
||||
#define UMSEL01 7
|
||||
|
||||
#define UBRR0 _SFR_MEM16(0xC4)
|
||||
|
||||
#define UBRR0L _SFR_MEM8(0xC4)
|
||||
#define UBRR0_0 0
|
||||
#define UBRR0_1 1
|
||||
#define UBRR0_2 2
|
||||
#define UBRR0_3 3
|
||||
#define UBRR0_4 4
|
||||
#define UBRR0_5 5
|
||||
#define UBRR0_6 6
|
||||
#define UBRR0_7 7
|
||||
|
||||
#define UBRR0H _SFR_MEM8(0xC5)
|
||||
#define UBRR0_8 0
|
||||
#define UBRR0_9 1
|
||||
#define UBRR0_10 2
|
||||
#define UBRR0_11 3
|
||||
|
||||
#define UDR0 _SFR_MEM8(0xC6)
|
||||
#define UDR0_0 0
|
||||
#define UDR0_1 1
|
||||
#define UDR0_2 2
|
||||
#define UDR0_3 3
|
||||
#define UDR0_4 4
|
||||
#define UDR0_5 5
|
||||
#define UDR0_6 6
|
||||
#define UDR0_7 7
|
||||
|
||||
|
||||
|
||||
/* Interrupt Vectors */
|
||||
/* Interrupt Vector 0 is the reset vector. */
|
||||
#define INT0_vect _VECTOR(1) /* External Interrupt Request 0 */
|
||||
#define INT1_vect _VECTOR(2) /* External Interrupt Request 1 */
|
||||
#define PCINT0_vect _VECTOR(3) /* Pin Change Interrupt Request 0 */
|
||||
#define PCINT1_vect _VECTOR(4) /* Pin Change Interrupt Request 0 */
|
||||
#define PCINT2_vect _VECTOR(5) /* Pin Change Interrupt Request 1 */
|
||||
#define WDT_vect _VECTOR(6) /* Watchdog Time-out Interrupt */
|
||||
#define TIMER2_COMPA_vect _VECTOR(7) /* Timer/Counter2 Compare Match A */
|
||||
#define TIMER2_COMPB_vect _VECTOR(8) /* Timer/Counter2 Compare Match A */
|
||||
#define TIMER2_OVF_vect _VECTOR(9) /* Timer/Counter2 Overflow */
|
||||
#define TIMER1_CAPT_vect _VECTOR(10) /* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_COMPA_vect _VECTOR(11) /* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPB_vect _VECTOR(12) /* Timer/Counter1 Compare Match B */
|
||||
#define TIMER1_OVF_vect _VECTOR(13) /* Timer/Counter1 Overflow */
|
||||
#define TIMER0_COMPA_vect _VECTOR(14) /* TimerCounter0 Compare Match A */
|
||||
#define TIMER0_COMPB_vect _VECTOR(15) /* TimerCounter0 Compare Match B */
|
||||
#define TIMER0_OVF_vect _VECTOR(16) /* Timer/Couner0 Overflow */
|
||||
#define SPI_STC_vect _VECTOR(17) /* SPI Serial Transfer Complete */
|
||||
#define USART_RX_vect _VECTOR(18) /* USART Rx Complete */
|
||||
#define USART_UDRE_vect _VECTOR(19) /* USART, Data Register Empty */
|
||||
#define USART_TX_vect _VECTOR(20) /* USART Tx Complete */
|
||||
#define ADC_vect _VECTOR(21) /* ADC Conversion Complete */
|
||||
#define EE_READY_vect _VECTOR(22) /* EEPROM Ready */
|
||||
#define ANALOG_COMP_vect _VECTOR(23) /* Analog Comparator */
|
||||
#define TWI_vect _VECTOR(24) /* Two-wire Serial Interface */
|
||||
#define SPM_READY_vect _VECTOR(25) /* Store Program Memory Read */
|
||||
|
||||
#define _VECTORS_SIZE (26 * 4)
|
||||
|
||||
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 128
|
||||
#define RAMEND 0x4FF /* Last On-Chip SRAM Location */
|
||||
#define XRAMSIZE 0
|
||||
#define XRAMEND (RAMEND + XRAMSIZE)
|
||||
#define E2END 0x1FF
|
||||
#define E2PAGESIZE 4
|
||||
#define FLASHEND 0x3FFF
|
||||
|
||||
|
||||
|
||||
/* Fuses */
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0) /* Select Clock Source */
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1) /* Select Clock Source */
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2) /* Select Clock Source */
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3) /* Select Clock Source */
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4) /* Select start-up time */
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5) /* Select start-up time */
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6) /* Clock output */
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7) /* Divide clock by 8 */
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(0) /* Brown-out Detector trigger level */
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(1) /* Brown-out Detector trigger level */
|
||||
#define FUSE_BODLEVEL2 (unsigned char)~_BV(2) /* Brown-out Detector trigger level */
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3) /* EEPROM memory is preserved through chip erase */
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4) /* Watchdog Timer Always On */
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5) /* Enable Serial programming and Data Downloading */
|
||||
#define FUSE_DWEN (unsigned char)~_BV(6) /* debugWIRE Enable */
|
||||
#define FUSE_RSTDISBL (unsigned char)~_BV(7) /* External reset disable */
|
||||
#define HFUSE_DEFAULT (FUSE_SPIEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define EFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1)
|
||||
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x94
|
||||
#define SIGNATURE_2 0x0B
|
||||
|
||||
|
||||
#endif /* _AVR_IOM168P_H_ */
|
1107
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom169.h
Normal file
1107
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom169.h
Normal file
File diff suppressed because it is too large
Load diff
1030
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom169p.h
Normal file
1030
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom169p.h
Normal file
File diff suppressed because it is too large
Load diff
|
@ -0,0 +1,75 @@
|
|||
/* Copyright (c) 2007, 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: iom16hva.h,v 1.2.2.5 2008/10/17 23:27:48 arcanum Exp $ */
|
||||
|
||||
/* iom16hva.h - definitions for ATmega16HVA. */
|
||||
|
||||
#ifndef _AVR_IOM16HVA_H_
|
||||
#define _AVR_IOM16HVA_H_ 1
|
||||
|
||||
#include <avr/iomxxhva.h>
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 128
|
||||
#define RAMEND 0x2FF
|
||||
#define XRAMEND 0x2FF
|
||||
#define E2END 0xFF
|
||||
#define E2PAGESIZE 4
|
||||
#define FLASHEND 0x3FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 1
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(0)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(1)
|
||||
#define FUSE_SUT2 (unsigned char)~_BV(2)
|
||||
#define FUSE_SELFPRGEN (unsigned char)~_BV(3)
|
||||
#define FUSE_DWEN (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(6)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(7)
|
||||
#define FUSE_DEFAULT (FUSE_SPIEN)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x94
|
||||
#define SIGNATURE_2 0x0C
|
||||
|
||||
|
||||
#endif /* _AVR_IOM16HVA_H_ */
|
|
@ -0,0 +1,94 @@
|
|||
/* 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 */
|
||||
|
||||
/* avr/iom2560.h - definitions for ATmega2560 */
|
||||
|
||||
#ifndef _AVR_IOM2560_H_
|
||||
#define _AVR_IOM2560_H_ 1
|
||||
|
||||
#include <avr/iomxx0_1.h>
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 256
|
||||
#define RAMEND 0x21FF
|
||||
#define XRAMEND 0xFFFF
|
||||
#define E2END 0xFFF
|
||||
#define E2PAGESIZE 8
|
||||
#define FLASHEND 0x3FFFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6)
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_BODLEVEL2 (unsigned char)~_BV(2)
|
||||
#define EFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x98
|
||||
#define SIGNATURE_2 0x01
|
||||
|
||||
|
||||
#endif /* _AVR_IOM2560_H_ */
|
|
@ -0,0 +1,94 @@
|
|||
/* 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 */
|
||||
|
||||
/* avr/iom2561.h - definitions for ATmega2561 */
|
||||
|
||||
#ifndef _AVR_IOM2561_H_
|
||||
#define _AVR_IOM2561_H_ 1
|
||||
|
||||
#include <avr/iomxx0_1.h>
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 256
|
||||
#define RAMEND 0x21FF
|
||||
#define XRAMEND 0xFFFF
|
||||
#define E2END 0xFFF
|
||||
#define E2PAGESIZE 8
|
||||
#define FLASHEND 0x3FFFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6)
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_BODLEVEL2 (unsigned char)~_BV(2)
|
||||
#define EFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x98
|
||||
#define SIGNATURE_2 0x02
|
||||
|
||||
|
||||
#endif /* _AVR_IOM2561_H_ */
|
696
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom32.h
Normal file
696
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom32.h
Normal file
|
@ -0,0 +1,696 @@
|
|||
/* Copyright (c) 2002, Steinar Haugen
|
||||
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: iom32.h,v 1.11.2.5 2008/10/17 23:27:48 arcanum Exp $ */
|
||||
|
||||
/* avr/iom32.h - definitions for ATmega32 */
|
||||
|
||||
#ifndef _AVR_IOM32_H_
|
||||
#define _AVR_IOM32_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_ "iom32.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* TWI stands for "Two Wire Interface" or "TWI Was I2C(tm)" */
|
||||
#define TWBR _SFR_IO8(0x00)
|
||||
#define TWSR _SFR_IO8(0x01)
|
||||
#define TWAR _SFR_IO8(0x02)
|
||||
#define TWDR _SFR_IO8(0x03)
|
||||
|
||||
/* ADC */
|
||||
#ifndef __ASSEMBLER__
|
||||
#define ADC _SFR_IO16(0x04)
|
||||
#endif
|
||||
#define ADCW _SFR_IO16(0x04)
|
||||
#define ADCL _SFR_IO8(0x04)
|
||||
#define ADCH _SFR_IO8(0x05)
|
||||
#define ADCSRA _SFR_IO8(0x06)
|
||||
#define ADMUX _SFR_IO8(0x07)
|
||||
|
||||
/* analog comparator */
|
||||
#define ACSR _SFR_IO8(0x08)
|
||||
|
||||
/* USART */
|
||||
#define UBRRL _SFR_IO8(0x09)
|
||||
#define UCSRB _SFR_IO8(0x0A)
|
||||
#define UCSRA _SFR_IO8(0x0B)
|
||||
#define UDR _SFR_IO8(0x0C)
|
||||
|
||||
/* SPI */
|
||||
#define SPCR _SFR_IO8(0x0D)
|
||||
#define SPSR _SFR_IO8(0x0E)
|
||||
#define SPDR _SFR_IO8(0x0F)
|
||||
|
||||
/* Port D */
|
||||
#define PIND _SFR_IO8(0x10)
|
||||
#define DDRD _SFR_IO8(0x11)
|
||||
#define PORTD _SFR_IO8(0x12)
|
||||
|
||||
/* Port C */
|
||||
#define PINC _SFR_IO8(0x13)
|
||||
#define DDRC _SFR_IO8(0x14)
|
||||
#define PORTC _SFR_IO8(0x15)
|
||||
|
||||
/* Port B */
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
|
||||
/* Port A */
|
||||
#define PINA _SFR_IO8(0x19)
|
||||
#define DDRA _SFR_IO8(0x1A)
|
||||
#define PORTA _SFR_IO8(0x1B)
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EECR _SFR_IO8(0x1C)
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define EEDR _SFR_IO8(0x1D)
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#define EEAR _SFR_IO16(0x1E)
|
||||
#define EEARL _SFR_IO8(0x1E)
|
||||
#define EEARH _SFR_IO8(0x1F)
|
||||
|
||||
#define UBRRH _SFR_IO8(0x20)
|
||||
#define UCSRC UBRRH
|
||||
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
|
||||
#define ASSR _SFR_IO8(0x22)
|
||||
|
||||
/* Timer 2 */
|
||||
#define OCR2 _SFR_IO8(0x23)
|
||||
#define TCNT2 _SFR_IO8(0x24)
|
||||
#define TCCR2 _SFR_IO8(0x25)
|
||||
|
||||
/* Timer 1 */
|
||||
#define ICR1 _SFR_IO16(0x26)
|
||||
#define ICR1L _SFR_IO8(0x26)
|
||||
#define ICR1H _SFR_IO8(0x27)
|
||||
#define OCR1B _SFR_IO16(0x28)
|
||||
#define OCR1BL _SFR_IO8(0x28)
|
||||
#define OCR1BH _SFR_IO8(0x29)
|
||||
#define OCR1A _SFR_IO16(0x2A)
|
||||
#define OCR1AL _SFR_IO8(0x2A)
|
||||
#define OCR1AH _SFR_IO8(0x2B)
|
||||
#define TCNT1 _SFR_IO16(0x2C)
|
||||
#define TCNT1L _SFR_IO8(0x2C)
|
||||
#define TCNT1H _SFR_IO8(0x2D)
|
||||
#define TCCR1B _SFR_IO8(0x2E)
|
||||
#define TCCR1A _SFR_IO8(0x2F)
|
||||
|
||||
#define SFIOR _SFR_IO8(0x30)
|
||||
|
||||
#define OSCCAL _SFR_IO8(0x31)
|
||||
#define OCDR OSCCAL
|
||||
|
||||
/* Timer 0 */
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
#define MCUCSR MCUSR
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
#define TWCR _SFR_IO8(0x36)
|
||||
|
||||
#define SPMCR _SFR_IO8(0x37)
|
||||
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
|
||||
#define GIFR _SFR_IO8(0x3A)
|
||||
#define GIMSK _SFR_IO8(0x3B)
|
||||
#define GICR GIMSK
|
||||
|
||||
#define OCR0 _SFR_IO8(0x3C)
|
||||
|
||||
/* 0x3D..0x3E SP */
|
||||
|
||||
/* 0x3F SREG */
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
/* 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)
|
||||
|
||||
/* Timer/Counter2 Compare Match */
|
||||
#define TIMER2_COMP_vect _VECTOR(4)
|
||||
#define SIG_OUTPUT_COMPARE2 _VECTOR(4)
|
||||
|
||||
/* Timer/Counter2 Overflow */
|
||||
#define TIMER2_OVF_vect _VECTOR(5)
|
||||
#define SIG_OVERFLOW2 _VECTOR(5)
|
||||
|
||||
/* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(6)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(6)
|
||||
|
||||
/* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPA_vect _VECTOR(7)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(7)
|
||||
|
||||
/* Timer/Counter1 Compare Match B */
|
||||
#define TIMER1_COMPB_vect _VECTOR(8)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(8)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(9)
|
||||
#define SIG_OVERFLOW1 _VECTOR(9)
|
||||
|
||||
/* Timer/Counter0 Compare Match */
|
||||
#define TIMER0_COMP_vect _VECTOR(10)
|
||||
#define SIG_OUTPUT_COMPARE0 _VECTOR(10)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(11)
|
||||
#define SIG_OVERFLOW0 _VECTOR(11)
|
||||
|
||||
/* Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(12)
|
||||
#define SIG_SPI _VECTOR(12)
|
||||
|
||||
/* USART, Rx Complete */
|
||||
#define USART_RXC_vect _VECTOR(13)
|
||||
#define SIG_USART_RECV _VECTOR(13)
|
||||
#define SIG_UART_RECV _VECTOR(13)
|
||||
|
||||
/* USART Data Register Empty */
|
||||
#define USART_UDRE_vect _VECTOR(14)
|
||||
#define SIG_USART_DATA _VECTOR(14)
|
||||
#define SIG_UART_DATA _VECTOR(14)
|
||||
|
||||
/* USART, Tx Complete */
|
||||
#define USART_TXC_vect _VECTOR(15)
|
||||
#define SIG_USART_TRANS _VECTOR(15)
|
||||
#define SIG_UART_TRANS _VECTOR(15)
|
||||
|
||||
/* ADC Conversion Complete */
|
||||
#define ADC_vect _VECTOR(16)
|
||||
#define SIG_ADC _VECTOR(16)
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_RDY_vect _VECTOR(17)
|
||||
#define SIG_EEPROM_READY _VECTOR(17)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANA_COMP_vect _VECTOR(18)
|
||||
#define SIG_COMPARATOR _VECTOR(18)
|
||||
|
||||
/* 2-wire Serial Interface */
|
||||
#define TWI_vect _VECTOR(19)
|
||||
#define SIG_2WIRE_SERIAL _VECTOR(19)
|
||||
|
||||
/* Store Program Memory Ready */
|
||||
#define SPM_RDY_vect _VECTOR(20)
|
||||
#define SIG_SPM_READY _VECTOR(20)
|
||||
|
||||
#define _VECTORS_SIZE 84
|
||||
|
||||
/* Bit numbers */
|
||||
|
||||
/* GICR */
|
||||
#define INT1 7
|
||||
#define INT0 6
|
||||
#define INT2 5
|
||||
#define IVSEL 1
|
||||
#define IVCE 0
|
||||
|
||||
/* GIFR */
|
||||
#define INTF1 7
|
||||
#define INTF0 6
|
||||
#define INTF2 5
|
||||
|
||||
/* TIMSK */
|
||||
#define OCIE2 7
|
||||
#define TOIE2 6
|
||||
#define TICIE1 5
|
||||
#define OCIE1A 4
|
||||
#define OCIE1B 3
|
||||
#define TOIE1 2
|
||||
#define OCIE0 1
|
||||
#define TOIE0 0
|
||||
|
||||
/* TIFR */
|
||||
#define OCF2 7
|
||||
#define TOV2 6
|
||||
#define ICF1 5
|
||||
#define OCF1A 4
|
||||
#define OCF1B 3
|
||||
#define TOV1 2
|
||||
#define OCF0 1
|
||||
#define TOV0 0
|
||||
|
||||
/* SPMCR */
|
||||
#define SPMIE 7
|
||||
#define RWWSB 6
|
||||
/* bit 5 reserved */
|
||||
#define RWWSRE 4
|
||||
#define BLBSET 3
|
||||
#define PGWRT 2
|
||||
#define PGERS 1
|
||||
#define SPMEN 0
|
||||
|
||||
/* TWCR */
|
||||
#define TWINT 7
|
||||
#define TWEA 6
|
||||
#define TWSTA 5
|
||||
#define TWSTO 4
|
||||
#define TWWC 3
|
||||
#define TWEN 2
|
||||
/* bit 1 reserved */
|
||||
#define TWIE 0
|
||||
|
||||
/* TWAR */
|
||||
#define TWA6 7
|
||||
#define TWA5 6
|
||||
#define TWA4 5
|
||||
#define TWA3 4
|
||||
#define TWA2 3
|
||||
#define TWA1 2
|
||||
#define TWA0 1
|
||||
#define TWGCE 0
|
||||
|
||||
/* TWSR */
|
||||
#define TWS7 7
|
||||
#define TWS6 6
|
||||
#define TWS5 5
|
||||
#define TWS4 4
|
||||
#define TWS3 3
|
||||
/* bit 2 reserved */
|
||||
#define TWPS1 1
|
||||
#define TWPS0 0
|
||||
|
||||
/* MCUCR */
|
||||
#define SE 7
|
||||
#define SM2 6
|
||||
#define SM1 5
|
||||
#define SM0 4
|
||||
#define ISC11 3
|
||||
#define ISC10 2
|
||||
#define ISC01 1
|
||||
#define ISC00 0
|
||||
|
||||
/* MCUCSR */
|
||||
#define JTD 7
|
||||
#define ISC2 6
|
||||
/* bit 5 reserved */
|
||||
#define JTRF 4
|
||||
#define WDRF 3
|
||||
#define BORF 2
|
||||
#define EXTRF 1
|
||||
#define PORF 0
|
||||
|
||||
/* SFIOR */
|
||||
#define ADTS2 7
|
||||
#define ADTS1 6
|
||||
#define ADTS0 5
|
||||
/* bit 4 reserved */
|
||||
#define ACME 3
|
||||
#define PUD 2
|
||||
#define PSR2 1
|
||||
#define PSR10 0
|
||||
|
||||
/* TCCR0 */
|
||||
#define FOC0 7
|
||||
#define WGM00 6
|
||||
#define COM01 5
|
||||
#define COM00 4
|
||||
#define WGM01 3
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/* TCCR2 */
|
||||
#define FOC2 7
|
||||
#define WGM20 6
|
||||
#define COM21 5
|
||||
#define COM20 4
|
||||
#define WGM21 3
|
||||
#define CS22 2
|
||||
#define CS21 1
|
||||
#define CS20 0
|
||||
|
||||
/* ASSR */
|
||||
/* bits 7-4 reserved */
|
||||
#define AS2 3
|
||||
#define TCN2UB 2
|
||||
#define OCR2UB 1
|
||||
#define TCR2UB 0
|
||||
|
||||
/* TCCR1A */
|
||||
#define COM1A1 7
|
||||
#define COM1A0 6
|
||||
#define COM1B1 5
|
||||
#define COM1B0 4
|
||||
#define FOC1A 3
|
||||
#define FOC1B 2
|
||||
#define WGM11 1
|
||||
#define WGM10 0
|
||||
|
||||
/* TCCR1B */
|
||||
#define ICNC1 7
|
||||
#define ICES1 6
|
||||
/* bit 5 reserved */
|
||||
#define WGM13 4
|
||||
#define WGM12 3
|
||||
#define CS12 2
|
||||
#define CS11 1
|
||||
#define CS10 0
|
||||
|
||||
/* WDTCR */
|
||||
/* bits 7-5 reserved */
|
||||
#define WDTOE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/* PA7-PA0 = ADC7-ADC0 */
|
||||
/* PORTA */
|
||||
#define PA7 7
|
||||
#define PA6 6
|
||||
#define PA5 5
|
||||
#define PA4 4
|
||||
#define PA3 3
|
||||
#define PA2 2
|
||||
#define PA1 1
|
||||
#define PA0 0
|
||||
|
||||
/* DDRA */
|
||||
#define DDA7 7
|
||||
#define DDA6 6
|
||||
#define DDA5 5
|
||||
#define DDA4 4
|
||||
#define DDA3 3
|
||||
#define DDA2 2
|
||||
#define DDA1 1
|
||||
#define DDA0 0
|
||||
|
||||
/* PINA */
|
||||
#define PINA7 7
|
||||
#define PINA6 6
|
||||
#define PINA5 5
|
||||
#define PINA4 4
|
||||
#define PINA3 3
|
||||
#define PINA2 2
|
||||
#define PINA1 1
|
||||
#define PINA0 0
|
||||
|
||||
/*
|
||||
PB7 = SCK
|
||||
PB6 = MISO
|
||||
PB5 = MOSI
|
||||
PB4 = SS#
|
||||
PB3 = OC0/AIN1
|
||||
PB2 = INT2/AIN0
|
||||
PB1 = T1
|
||||
PB0 = XCK/T0
|
||||
*/
|
||||
|
||||
/* PORTB */
|
||||
#define PB7 7
|
||||
#define PB6 6
|
||||
#define PB5 5
|
||||
#define PB4 4
|
||||
#define PB3 3
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
/* DDRB */
|
||||
#define DDB7 7
|
||||
#define DDB6 6
|
||||
#define DDB5 5
|
||||
#define DDB4 4
|
||||
#define DDB3 3
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
/* PINB */
|
||||
#define PINB7 7
|
||||
#define PINB6 6
|
||||
#define PINB5 5
|
||||
#define PINB4 4
|
||||
#define PINB3 3
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
/*
|
||||
PC7 = TOSC2
|
||||
PC6 = TOSC1
|
||||
PC1 = SDA
|
||||
PC0 = SCL
|
||||
*/
|
||||
/* PORTC */
|
||||
#define PC7 7
|
||||
#define PC6 6
|
||||
#define PC5 5
|
||||
#define PC4 4
|
||||
#define PC3 3
|
||||
#define PC2 2
|
||||
#define PC1 1
|
||||
#define PC0 0
|
||||
|
||||
/* DDRC */
|
||||
#define DDC7 7
|
||||
#define DDC6 6
|
||||
#define DDC5 5
|
||||
#define DDC4 4
|
||||
#define DDC3 3
|
||||
#define DDC2 2
|
||||
#define DDC1 1
|
||||
#define DDC0 0
|
||||
|
||||
/* PINC */
|
||||
#define PINC7 7
|
||||
#define PINC6 6
|
||||
#define PINC5 5
|
||||
#define PINC4 4
|
||||
#define PINC3 3
|
||||
#define PINC2 2
|
||||
#define PINC1 1
|
||||
#define PINC0 0
|
||||
|
||||
/*
|
||||
PD7 = OC2
|
||||
PD6 = ICP
|
||||
PD5 = OC1A
|
||||
PD4 = OC1B
|
||||
PD3 = INT1
|
||||
PD2 = INT0
|
||||
PD1 = TXD
|
||||
PD0 = RXD
|
||||
*/
|
||||
|
||||
/* PORTD */
|
||||
#define PD7 7
|
||||
#define PD6 6
|
||||
#define PD5 5
|
||||
#define PD4 4
|
||||
#define PD3 3
|
||||
#define PD2 2
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
/* DDRD */
|
||||
#define DDD7 7
|
||||
#define DDD6 6
|
||||
#define DDD5 5
|
||||
#define DDD4 4
|
||||
#define DDD3 3
|
||||
#define DDD2 2
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
/* PIND */
|
||||
#define PIND7 7
|
||||
#define PIND6 6
|
||||
#define PIND5 5
|
||||
#define PIND4 4
|
||||
#define PIND3 3
|
||||
#define PIND2 2
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
/* SPSR */
|
||||
#define SPIF 7
|
||||
#define WCOL 6
|
||||
/* bits 5-1 reserved */
|
||||
#define SPI2X 0
|
||||
|
||||
/* SPCR */
|
||||
#define SPIE 7
|
||||
#define SPE 6
|
||||
#define DORD 5
|
||||
#define MSTR 4
|
||||
#define CPOL 3
|
||||
#define CPHA 2
|
||||
#define SPR1 1
|
||||
#define SPR0 0
|
||||
|
||||
/* UCSRA */
|
||||
#define RXC 7
|
||||
#define TXC 6
|
||||
#define UDRE 5
|
||||
#define FE 4
|
||||
#define DOR 3
|
||||
#define PE 2
|
||||
#define U2X 1
|
||||
#define MPCM 0
|
||||
|
||||
/* UCSRB */
|
||||
#define RXCIE 7
|
||||
#define TXCIE 6
|
||||
#define UDRIE 5
|
||||
#define RXEN 4
|
||||
#define TXEN 3
|
||||
#define UCSZ2 2
|
||||
#define RXB8 1
|
||||
#define TXB8 0
|
||||
|
||||
/* UCSRC */
|
||||
#define URSEL 7
|
||||
#define UMSEL 6
|
||||
#define UPM1 5
|
||||
#define UPM0 4
|
||||
#define USBS 3
|
||||
#define UCSZ1 2
|
||||
#define UCSZ0 1
|
||||
#define UCPOL 0
|
||||
|
||||
/* ACSR */
|
||||
#define ACD 7
|
||||
#define ACBG 6
|
||||
#define ACO 5
|
||||
#define ACI 4
|
||||
#define ACIE 3
|
||||
#define ACIC 2
|
||||
#define ACIS1 1
|
||||
#define ACIS0 0
|
||||
|
||||
/* ADCSRA */
|
||||
#define ADEN 7
|
||||
#define ADSC 6
|
||||
#define ADATE 5
|
||||
#define ADIF 4
|
||||
#define ADIE 3
|
||||
#define ADPS2 2
|
||||
#define ADPS1 1
|
||||
#define ADPS0 0
|
||||
|
||||
/* ADMUX */
|
||||
#define REFS1 7
|
||||
#define REFS0 6
|
||||
#define ADLAR 5
|
||||
#define MUX4 4
|
||||
#define MUX3 3
|
||||
#define MUX2 2
|
||||
#define MUX1 1
|
||||
#define MUX0 0
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EERIE 3
|
||||
#define EEMWE 2
|
||||
#define EEWE 1
|
||||
#define EERE 0
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 128
|
||||
#define RAMEND 0x85F
|
||||
#define XRAMEND 0x85F
|
||||
#define E2END 0x3FF
|
||||
#define E2PAGESIZE 4
|
||||
#define FLASHEND 0x7FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 2
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_BODEN (unsigned char)~_BV(6)
|
||||
#define FUSE_BODLEVEL (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL1 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_CKOPT (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x95
|
||||
#define SIGNATURE_2 0x02
|
||||
|
||||
|
||||
#endif /* _AVR_IOM32_H_ */
|
688
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom323.h
Normal file
688
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom323.h
Normal file
|
@ -0,0 +1,688 @@
|
|||
/* Copyright (c) 2002, Marek Michalkiewicz
|
||||
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: iom323.h,v 1.13.2.5 2008/10/17 23:27:48 arcanum Exp $ */
|
||||
|
||||
/* avr/iom323.h - definitions for ATmega323 */
|
||||
|
||||
#ifndef _AVR_IOM323_H_
|
||||
#define _AVR_IOM323_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_ "iom323.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* TWI stands for "Two Wire Interface" or "TWI Was I2C(tm)" */
|
||||
#define TWBR _SFR_IO8(0x00)
|
||||
#define TWSR _SFR_IO8(0x01)
|
||||
#define TWAR _SFR_IO8(0x02)
|
||||
#define TWDR _SFR_IO8(0x03)
|
||||
|
||||
/* ADC */
|
||||
#ifndef __ASSEMBLER__
|
||||
#define ADC _SFR_IO16(0x04)
|
||||
#endif
|
||||
#define ADCW _SFR_IO16(0x04)
|
||||
#define ADCL _SFR_IO8(0x04)
|
||||
#define ADCH _SFR_IO8(0x05)
|
||||
#define ADCSR _SFR_IO8(0x06)
|
||||
#define ADMUX _SFR_IO8(0x07)
|
||||
|
||||
/* analog comparator */
|
||||
#define ACSR _SFR_IO8(0x08)
|
||||
|
||||
/* UART */
|
||||
#define UBRR _SFR_IO8(0x09)
|
||||
#define UBRRL UBRR
|
||||
#define UCSRB _SFR_IO8(0x0A)
|
||||
#define UCSRA _SFR_IO8(0x0B)
|
||||
#define UDR _SFR_IO8(0x0C)
|
||||
|
||||
/* SPI */
|
||||
#define SPCR _SFR_IO8(0x0D)
|
||||
#define SPSR _SFR_IO8(0x0E)
|
||||
#define SPDR _SFR_IO8(0x0F)
|
||||
|
||||
/* Port D */
|
||||
#define PIND _SFR_IO8(0x10)
|
||||
#define DDRD _SFR_IO8(0x11)
|
||||
#define PORTD _SFR_IO8(0x12)
|
||||
|
||||
/* Port C */
|
||||
#define PINC _SFR_IO8(0x13)
|
||||
#define DDRC _SFR_IO8(0x14)
|
||||
#define PORTC _SFR_IO8(0x15)
|
||||
|
||||
/* Port B */
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
|
||||
/* Port A */
|
||||
#define PINA _SFR_IO8(0x19)
|
||||
#define DDRA _SFR_IO8(0x1A)
|
||||
#define PORTA _SFR_IO8(0x1B)
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EECR _SFR_IO8(0x1C)
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define EEDR _SFR_IO8(0x1D)
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#define EEAR _SFR_IO16(0x1E)
|
||||
#define EEARL _SFR_IO8(0x1E)
|
||||
#define EEARH _SFR_IO8(0x1F)
|
||||
|
||||
#define UBRRH _SFR_IO8(0x20)
|
||||
#define UCSRC UBRRH
|
||||
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
|
||||
#define ASSR _SFR_IO8(0x22)
|
||||
|
||||
/* Timer 2 */
|
||||
#define OCR2 _SFR_IO8(0x23)
|
||||
#define TCNT2 _SFR_IO8(0x24)
|
||||
#define TCCR2 _SFR_IO8(0x25)
|
||||
|
||||
/* Timer 1 */
|
||||
#define ICR1 _SFR_IO16(0x26)
|
||||
#define ICR1L _SFR_IO8(0x26)
|
||||
#define ICR1H _SFR_IO8(0x27)
|
||||
#define OCR1B _SFR_IO16(0x28)
|
||||
#define OCR1BL _SFR_IO8(0x28)
|
||||
#define OCR1BH _SFR_IO8(0x29)
|
||||
#define OCR1A _SFR_IO16(0x2A)
|
||||
#define OCR1AL _SFR_IO8(0x2A)
|
||||
#define OCR1AH _SFR_IO8(0x2B)
|
||||
#define TCNT1 _SFR_IO16(0x2C)
|
||||
#define TCNT1L _SFR_IO8(0x2C)
|
||||
#define TCNT1H _SFR_IO8(0x2D)
|
||||
#define TCCR1B _SFR_IO8(0x2E)
|
||||
#define TCCR1A _SFR_IO8(0x2F)
|
||||
|
||||
#define SFIOR _SFR_IO8(0x30)
|
||||
|
||||
#define OSCCAL _SFR_IO8(0x31)
|
||||
|
||||
/* Timer 0 */
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
#define MCUCSR MCUSR
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
#define TWCR _SFR_IO8(0x36)
|
||||
|
||||
#define SPMCR _SFR_IO8(0x37)
|
||||
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
|
||||
#define GIFR _SFR_IO8(0x3A)
|
||||
#define GIMSK _SFR_IO8(0x3B)
|
||||
#define GICR GIMSK
|
||||
|
||||
#define OCR0 _SFR_IO8(0x3C)
|
||||
|
||||
/* 0x3D..0x3E SP */
|
||||
|
||||
/* 0x3F SREG */
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
/* 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)
|
||||
|
||||
/* Timer/Counter2 Compare Match */
|
||||
#define TIMER2_COMP_vect _VECTOR(4)
|
||||
#define SIG_OUTPUT_COMPARE2 _VECTOR(4)
|
||||
|
||||
/* Timer/Counter2 Overflow */
|
||||
#define TIMER2_OVF_vect _VECTOR(5)
|
||||
#define SIG_OVERFLOW2 _VECTOR(5)
|
||||
|
||||
/* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(6)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(6)
|
||||
|
||||
/* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPA_vect _VECTOR(7)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(7)
|
||||
|
||||
/* Timer/Counter1 Compare Match B */
|
||||
#define TIMER1_COMPB_vect _VECTOR(8)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(8)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(9)
|
||||
#define SIG_OVERFLOW1 _VECTOR(9)
|
||||
|
||||
/* Timer/Counter0 Compare Match */
|
||||
#define TIMER0_COMP_vect _VECTOR(10)
|
||||
#define SIG_OUTPUT_COMPARE0 _VECTOR(10)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(11)
|
||||
#define SIG_OVERFLOW0 _VECTOR(11)
|
||||
|
||||
/* Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(12)
|
||||
#define SIG_SPI _VECTOR(12)
|
||||
|
||||
/* USART, Rx Complete */
|
||||
#define USART_RXC_vect _VECTOR(13)
|
||||
#define SIG_UART_RECV _VECTOR(13)
|
||||
|
||||
/* USART Data Register Empty */
|
||||
#define USART_UDRE_vect _VECTOR(14)
|
||||
#define SIG_UART_DATA _VECTOR(14)
|
||||
|
||||
/* USART, Tx Complete */
|
||||
#define USART_TXC_vect _VECTOR(15)
|
||||
#define SIG_UART_TRANS _VECTOR(15)
|
||||
|
||||
/* ADC Conversion Complete */
|
||||
#define ADC_vect _VECTOR(16)
|
||||
#define SIG_ADC _VECTOR(16)
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_RDY_vect _VECTOR(17)
|
||||
#define SIG_EEPROM_READY _VECTOR(17)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANA_COMP_vect _VECTOR(18)
|
||||
#define SIG_COMPARATOR _VECTOR(18)
|
||||
|
||||
/* 2-wire Serial Interface */
|
||||
#define TWI_vect _VECTOR(19)
|
||||
#define SIG_2WIRE_SERIAL _VECTOR(19)
|
||||
|
||||
/* Store Program Memory Ready */
|
||||
#define SPM_RDY_vect _VECTOR(20)
|
||||
|
||||
#define _VECTORS_SIZE 80
|
||||
|
||||
|
||||
/* Bit numbers */
|
||||
|
||||
/* GIMSK */
|
||||
#define INT1 7
|
||||
#define INT0 6
|
||||
#define INT2 5
|
||||
#define IVSEL 1
|
||||
#define IVCE 0
|
||||
|
||||
/* GIFR */
|
||||
#define INTF1 7
|
||||
#define INTF0 6
|
||||
#define INTF2 5
|
||||
|
||||
/* TIMSK */
|
||||
#define OCIE2 7
|
||||
#define TOIE2 6
|
||||
#define TICIE1 5
|
||||
#define OCIE1A 4
|
||||
#define OCIE1B 3
|
||||
#define TOIE1 2
|
||||
#define OCIE0 1
|
||||
#define TOIE0 0
|
||||
|
||||
/* TIFR */
|
||||
#define OCF2 7
|
||||
#define TOV2 6
|
||||
#define ICF1 5
|
||||
#define OCF1A 4
|
||||
#define OCF1B 3
|
||||
#define TOV1 2
|
||||
#define OCF0 1
|
||||
#define TOV0 0
|
||||
|
||||
/* SPMCR */
|
||||
#define SPMIE 7
|
||||
#define ASB 6
|
||||
/* bit 5 reserved */
|
||||
#define ASRE 4
|
||||
#define BLBSET 3
|
||||
#define PGWRT 2
|
||||
#define PGERS 1
|
||||
#define SPMEN 0
|
||||
|
||||
/* TWCR */
|
||||
#define TWINT 7
|
||||
#define TWEA 6
|
||||
#define TWSTA 5
|
||||
#define TWSTO 4
|
||||
#define TWWC 3
|
||||
#define TWEN 2
|
||||
#define TWI_TST 1
|
||||
#define TWIE 0
|
||||
|
||||
/* TWAR */
|
||||
#define TWGCE 0
|
||||
|
||||
/* TWSR */
|
||||
#define TWS7 7
|
||||
#define TWS6 6
|
||||
#define TWS5 5
|
||||
#define TWS4 4
|
||||
#define TWS3 3
|
||||
/* bits 2-0 reserved */
|
||||
|
||||
/* MCUCR */
|
||||
/* bit 7 reserved (SM2?) */
|
||||
#define SE 7
|
||||
#define SM2 6
|
||||
#define SM1 5
|
||||
#define SM0 4
|
||||
#define ISC11 3
|
||||
#define ISC10 2
|
||||
#define ISC01 1
|
||||
#define ISC00 0
|
||||
|
||||
/* MCUCSR */
|
||||
#define JTD 7
|
||||
#define ISC2 6
|
||||
#define EIH 5
|
||||
#define JTRF 4
|
||||
#define WDRF 3
|
||||
#define BORF 2
|
||||
#define EXTRF 1
|
||||
#define PORF 0
|
||||
|
||||
/* SFIOR */
|
||||
#define RPDD 7
|
||||
#define RPDC 6
|
||||
#define RPDB 5
|
||||
#define RPDA 4
|
||||
#define ACME 3
|
||||
#define PUD 2
|
||||
#define PSR2 1
|
||||
#define PSR10 0
|
||||
|
||||
/* TCCR0 */
|
||||
#define FOC0 7
|
||||
#define PWM0 6
|
||||
#define COM01 5
|
||||
#define COM00 4
|
||||
#define CTC0 3
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/* TCCR2 */
|
||||
#define FOC2 7
|
||||
#define PWM2 6
|
||||
#define COM21 5
|
||||
#define COM20 4
|
||||
#define CTC2 3
|
||||
#define CS22 2
|
||||
#define CS21 1
|
||||
#define CS20 0
|
||||
|
||||
/* ASSR */
|
||||
/* bits 7-4 reserved */
|
||||
#define AS2 3
|
||||
#define TCN2UB 2
|
||||
#define OCR2UB 1
|
||||
#define TCR2UB 0
|
||||
|
||||
/* TCCR1A */
|
||||
#define COM1A1 7
|
||||
#define COM1A0 6
|
||||
#define COM1B1 5
|
||||
#define COM1B0 4
|
||||
#define FOC1A 3
|
||||
#define FOC1B 2
|
||||
#define PWM11 1
|
||||
#define PWM10 0
|
||||
|
||||
/* TCCR1B */
|
||||
#define ICNC1 7
|
||||
#define ICES1 6
|
||||
/* bit 5 reserved */
|
||||
#define CTC11 4
|
||||
#define CTC10 3
|
||||
#define CS12 2
|
||||
#define CS11 1
|
||||
#define CS10 0
|
||||
|
||||
/* WDTCR */
|
||||
/* bits 7-5 reserved */
|
||||
#define WDTOE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/* PA7-PA0 = ADC7-ADC0 */
|
||||
/* PORTA */
|
||||
#define PA7 7
|
||||
#define PA6 6
|
||||
#define PA5 5
|
||||
#define PA4 4
|
||||
#define PA3 3
|
||||
#define PA2 2
|
||||
#define PA1 1
|
||||
#define PA0 0
|
||||
|
||||
/* DDRA */
|
||||
#define DDA7 7
|
||||
#define DDA6 6
|
||||
#define DDA5 5
|
||||
#define DDA4 4
|
||||
#define DDA3 3
|
||||
#define DDA2 2
|
||||
#define DDA1 1
|
||||
#define DDA0 0
|
||||
|
||||
/* PINA */
|
||||
#define PINA7 7
|
||||
#define PINA6 6
|
||||
#define PINA5 5
|
||||
#define PINA4 4
|
||||
#define PINA3 3
|
||||
#define PINA2 2
|
||||
#define PINA1 1
|
||||
#define PINA0 0
|
||||
|
||||
/*
|
||||
PB7 = SCK
|
||||
PB6 = MISO
|
||||
PB5 = MOSI
|
||||
PB4 = SS#
|
||||
PB3 = AIN1
|
||||
PB2 = AIN0
|
||||
PB1 = T1
|
||||
PB0 = T0
|
||||
*/
|
||||
|
||||
/* PORTB */
|
||||
#define PB7 7
|
||||
#define PB6 6
|
||||
#define PB5 5
|
||||
#define PB4 4
|
||||
#define PB3 3
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
/* DDRB */
|
||||
#define DDB7 7
|
||||
#define DDB6 6
|
||||
#define DDB5 5
|
||||
#define DDB4 4
|
||||
#define DDB3 3
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
/* PINB */
|
||||
#define PINB7 7
|
||||
#define PINB6 6
|
||||
#define PINB5 5
|
||||
#define PINB4 4
|
||||
#define PINB3 3
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
/*
|
||||
PC7 = TOSC2
|
||||
PC6 = TOSC1
|
||||
PC1 = SDA
|
||||
PC0 = SCL
|
||||
*/
|
||||
/* PORTC */
|
||||
#define PC7 7
|
||||
#define PC6 6
|
||||
#define PC5 5
|
||||
#define PC4 4
|
||||
#define PC3 3
|
||||
#define PC2 2
|
||||
#define PC1 1
|
||||
#define PC0 0
|
||||
|
||||
/* DDRC */
|
||||
#define DDC7 7
|
||||
#define DDC6 6
|
||||
#define DDC5 5
|
||||
#define DDC4 4
|
||||
#define DDC3 3
|
||||
#define DDC2 2
|
||||
#define DDC1 1
|
||||
#define DDC0 0
|
||||
|
||||
/* PINC */
|
||||
#define PINC7 7
|
||||
#define PINC6 6
|
||||
#define PINC5 5
|
||||
#define PINC4 4
|
||||
#define PINC3 3
|
||||
#define PINC2 2
|
||||
#define PINC1 1
|
||||
#define PINC0 0
|
||||
|
||||
/*
|
||||
PD7 = OC2
|
||||
PD6 = ICP
|
||||
PD5 = OC1A
|
||||
PD4 = OC1B
|
||||
PD3 = INT1
|
||||
PD2 = INT0
|
||||
PD1 = TXD
|
||||
PD0 = RXD
|
||||
*/
|
||||
|
||||
/* PORTD */
|
||||
#define PD7 7
|
||||
#define PD6 6
|
||||
#define PD5 5
|
||||
#define PD4 4
|
||||
#define PD3 3
|
||||
#define PD2 2
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
/* DDRD */
|
||||
#define DDD7 7
|
||||
#define DDD6 6
|
||||
#define DDD5 5
|
||||
#define DDD4 4
|
||||
#define DDD3 3
|
||||
#define DDD2 2
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
/* PIND */
|
||||
#define PIND7 7
|
||||
#define PIND6 6
|
||||
#define PIND5 5
|
||||
#define PIND4 4
|
||||
#define PIND3 3
|
||||
#define PIND2 2
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
/*
|
||||
PE2 = ALE
|
||||
PE1 = OC1B
|
||||
PE0 = ICP / INT2
|
||||
*/
|
||||
|
||||
/* SPSR */
|
||||
#define SPIF 7
|
||||
#define WCOL 6
|
||||
#define SPI2X 0
|
||||
|
||||
/* SPCR */
|
||||
#define SPIE 7
|
||||
#define SPE 6
|
||||
#define DORD 5
|
||||
#define MSTR 4
|
||||
#define CPOL 3
|
||||
#define CPHA 2
|
||||
#define SPR1 1
|
||||
#define SPR0 0
|
||||
|
||||
/* UCSRA */
|
||||
#define RXC 7
|
||||
#define TXC 6
|
||||
#define UDRE 5
|
||||
#define FE 4
|
||||
#define DOR 3
|
||||
#define PE 2
|
||||
#define U2X 1
|
||||
#define MPCM 0
|
||||
|
||||
/* UCSRB */
|
||||
#define RXCIE 7
|
||||
#define TXCIE 6
|
||||
#define UDRIE 5
|
||||
#define RXEN 4
|
||||
#define TXEN 3
|
||||
#define UCSZ2 2
|
||||
#define CHR9 2
|
||||
#define RXB8 1
|
||||
#define TXB8 0
|
||||
|
||||
/* UCSRC */
|
||||
#define URSEL 7
|
||||
#define UMSEL 6
|
||||
#define UPM1 5
|
||||
#define UPM0 4
|
||||
#define USBS 3
|
||||
#define UCSZ1 2
|
||||
#define UCSZ0 1
|
||||
#define UCPOL 0
|
||||
|
||||
/* ACSR */
|
||||
#define ACD 7
|
||||
#define AINBG 6
|
||||
#define ACO 5
|
||||
#define ACI 4
|
||||
#define ACIE 3
|
||||
#define ACIC 2
|
||||
#define ACIS1 1
|
||||
#define ACIS0 0
|
||||
|
||||
/* ADCSR */
|
||||
#define ADEN 7
|
||||
#define ADSC 6
|
||||
#define ADFR 5
|
||||
#define ADIF 4
|
||||
#define ADIE 3
|
||||
#define ADPS2 2
|
||||
#define ADPS1 1
|
||||
#define ADPS0 0
|
||||
|
||||
/* ADMUX */
|
||||
#define REFS1 7
|
||||
#define REFS0 6
|
||||
#define ADLAR 5
|
||||
#define MUX4 4
|
||||
#define MUX3 3
|
||||
#define MUX2 2
|
||||
#define MUX1 1
|
||||
#define MUX0 0
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EERIE 3
|
||||
#define EEMWE 2
|
||||
#define EEWE 1
|
||||
#define EERE 0
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 128
|
||||
#define RAMEND 0x85F
|
||||
#define XRAMEND 0x85F
|
||||
#define E2END 0x3FF
|
||||
#define E2PAGESIZE 0
|
||||
#define FLASHEND 0x7FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 2
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_BODEN (unsigned char)~_BV(6)
|
||||
#define FUSE_BODLEVEL (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x95
|
||||
#define SIGNATURE_2 0x01
|
||||
|
||||
|
||||
#endif /* _AVR_IOM323_H_ */
|
|
@ -0,0 +1,88 @@
|
|||
/* Copyright (c) 2005, 2006 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. */
|
||||
|
||||
/* avr/iom324.h - definitions for ATmega324 */
|
||||
|
||||
/* $Id: iom324.h,v 1.3.2.4 2008/08/14 00:08:02 arcanum Exp $ */
|
||||
|
||||
#ifndef _AVR_IOM324_H_
|
||||
#define _AVR_IOM324_H_ 1
|
||||
|
||||
#include <avr/iomxx4.h>
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 128
|
||||
#define RAMEND 0x08FF
|
||||
#define XRAMEND 0x08FF
|
||||
#define E2END 0x3FF
|
||||
#define E2PAGESIZE 4
|
||||
#define FLASHEND 0x7FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6)
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_SUT1 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_BODLEVEL2 (unsigned char)~_BV(2)
|
||||
#define EFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
#endif /* _AVR_IOM324_H_ */
|
821
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom325.h
Normal file
821
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom325.h
Normal file
|
@ -0,0 +1,821 @@
|
|||
/* Copyright (c) 2004, 2005, 2006, 2007 Eric B. Weddington
|
||||
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: iom325.h,v 1.12.2.5 2008/10/17 23:27:48 arcanum Exp $ */
|
||||
|
||||
/* avr/iom325.h - definitions for ATmega325 and ATmega325P. */
|
||||
|
||||
#ifndef _AVR_IOM325_H_
|
||||
#define _AVR_IOM325_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_ "iom325.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#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 DDG4 4
|
||||
#define DDG3 3
|
||||
#define DDG2 2
|
||||
#define DDG1 1
|
||||
#define DDG0 0
|
||||
|
||||
#define PORTG _SFR_IO8(0x14)
|
||||
#define PG4 4
|
||||
#define PG3 3
|
||||
#define PG2 2
|
||||
#define PG1 1
|
||||
#define PG0 0
|
||||
|
||||
#define TIFR0 _SFR_IO8(0x15)
|
||||
#define TOV0 0
|
||||
#define OCF0A 1
|
||||
|
||||
#define TIFR1 _SFR_IO8(0x16)
|
||||
#define TOV1 0
|
||||
#define OCF1A 1
|
||||
#define OCF1B 2
|
||||
#define ICF1 5
|
||||
|
||||
#define TIFR2 _SFR_IO8(0x17)
|
||||
#define TOV2 0
|
||||
#define OCF2A 1
|
||||
|
||||
/* Reserved [0x18..0x1B] */
|
||||
|
||||
#define EIFR _SFR_IO8(0x1C)
|
||||
#define INTF0 0
|
||||
#define PCIF0 4
|
||||
#define PCIF1 5
|
||||
|
||||
#define EIMSK _SFR_IO8(0x1D)
|
||||
#define INT0 0
|
||||
#define PCIE0 4
|
||||
#define PCIE1 5
|
||||
|
||||
#define GPIOR0 _SFR_IO8(0x1E)
|
||||
|
||||
#define EECR _SFR_IO8(0x1F)
|
||||
#define EERE 0
|
||||
#define EEWE 1
|
||||
#define EEMWE 2
|
||||
#define EERIE 3
|
||||
|
||||
#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 PSR10 0
|
||||
#define PSR2 1
|
||||
#define TSM 7
|
||||
|
||||
#define TCCR0A _SFR_IO8(0x24)
|
||||
#define CS00 0
|
||||
#define CS01 1
|
||||
#define CS02 2
|
||||
#define WGM01 3
|
||||
#define COM0A0 4
|
||||
#define COM0A1 5
|
||||
#define WGM00 6
|
||||
#define FOC0A 7
|
||||
|
||||
/* Reserved [0x25] */
|
||||
|
||||
#define TCNT0 _SFR_IO8(0X26)
|
||||
|
||||
#define OCR0A _SFR_IO8(0X27)
|
||||
|
||||
/* Reserved [0x28..0x29] */
|
||||
|
||||
#define GPIOR1 _SFR_IO8(0x2A)
|
||||
|
||||
#define GPIOR2 _SFR_IO8(0x2B)
|
||||
|
||||
#define SPCR _SFR_IO8(0x2C)
|
||||
#define SPR0 0
|
||||
#define SPR1 1
|
||||
#define CPHA 2
|
||||
#define CPOL 3
|
||||
#define MSTR 4
|
||||
#define DORD 5
|
||||
#define SPE 6
|
||||
#define SPIE 7
|
||||
|
||||
#define SPSR _SFR_IO8(0x2D)
|
||||
#define SPI2X 0
|
||||
#define WCOL 6
|
||||
#define SPIF 7
|
||||
|
||||
#define SPDR _SFR_IO8(0X2E)
|
||||
|
||||
/* Reserved [0x2F] */
|
||||
|
||||
#define ACSR _SFR_IO8(0x30)
|
||||
#define ACIS0 0
|
||||
#define ACIS1 1
|
||||
#define ACIC 2
|
||||
#define ACIE 3
|
||||
#define ACI 4
|
||||
#define ACO 5
|
||||
#define ACBG 6
|
||||
#define ACD 7
|
||||
|
||||
#define OCDR _SFR_IO8(0x31)
|
||||
#define OCDR0 0
|
||||
#define OCDR1 1
|
||||
#define OCDR2 2
|
||||
#define OCDR3 3
|
||||
#define OCDR4 4
|
||||
#define OCDR5 5
|
||||
#define OCDR6 6
|
||||
#define OCDR7 7
|
||||
#define IDRD 7
|
||||
|
||||
/* Reserved [0x32] */
|
||||
|
||||
#define SMCR _SFR_IO8(0x33)
|
||||
#define SE 0
|
||||
#define SM0 1
|
||||
#define SM1 2
|
||||
#define SM2 3
|
||||
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
#define PORF 0
|
||||
#define EXTRF 1
|
||||
#define BORF 2
|
||||
#define WDRF 3
|
||||
#define JTRF 4
|
||||
|
||||
#define MCUCR _SFR_IO8(0X35)
|
||||
#define IVCE 0
|
||||
#define IVSEL 1
|
||||
#define PUD 4
|
||||
#if defined(__AVR_ATmega325P__)
|
||||
#define BODSE 5
|
||||
#define BODS 6
|
||||
#endif
|
||||
#define JTD 7
|
||||
|
||||
/* Reserved [0x36] */
|
||||
|
||||
#define SPMCSR _SFR_IO8(0x37)
|
||||
#define SPMEN 0
|
||||
#define PGERS 1
|
||||
#define PGWRT 2
|
||||
#define BLBSET 3
|
||||
#define RWWSRE 4
|
||||
#define RWWSB 6
|
||||
#define SPMIE 7
|
||||
|
||||
/* Reserved [0x38..0x3C] */
|
||||
|
||||
/* SP [0x3D..0x3E] */
|
||||
/* SREG [0x3F] */
|
||||
|
||||
#define WDTCR _SFR_MEM8(0x60)
|
||||
#define WDP0 0
|
||||
#define WDP1 1
|
||||
#define WDP2 2
|
||||
#define WDE 3
|
||||
#define WDCE 4
|
||||
|
||||
#define CLKPR _SFR_MEM8(0x61)
|
||||
#define CLKPS0 0
|
||||
#define CLKPS1 1
|
||||
#define CLKPS2 2
|
||||
#define CLKPS3 3
|
||||
#define CLKPCE 7
|
||||
|
||||
/* Reserved [0x62..0x63] */
|
||||
|
||||
#define PRR _SFR_MEM8(0x64)
|
||||
#define PRADC 0
|
||||
#define PRUSART0 1
|
||||
#define PRSPI 2
|
||||
#define PRTIM1 3
|
||||
|
||||
/* Reserved [0x65] */
|
||||
|
||||
#define OSCCAL _SFR_MEM8(0x66)
|
||||
|
||||
/* Reserved [0x67..0x68] */
|
||||
|
||||
#define EICRA _SFR_MEM8(0x69)
|
||||
#define ISC00 0
|
||||
#define ISC01 1
|
||||
|
||||
/* Reserved [0x6A] */
|
||||
|
||||
#define PCMSK0 _SFR_MEM8(0x6B)
|
||||
#define PCINT0 0
|
||||
#define PCINT1 1
|
||||
#define PCINT2 2
|
||||
#define PCINT3 3
|
||||
#define PCINT4 4
|
||||
#define PCINT5 5
|
||||
#define PCINT6 6
|
||||
#define PCINT7 7
|
||||
|
||||
#define PCMSK1 _SFR_MEM8(0x6C)
|
||||
#define PCINT8 0
|
||||
#define PCINT9 1
|
||||
#define PCINT10 2
|
||||
#define PCINT11 3
|
||||
#define PCINT12 4
|
||||
#define PCINT13 5
|
||||
#define PCINT14 6
|
||||
#define PCINT15 7
|
||||
|
||||
/* Reserved [0x6D] */
|
||||
|
||||
#define TIMSK0 _SFR_MEM8(0x6E)
|
||||
#define TOIE0 0
|
||||
#define OCIE0A 1
|
||||
|
||||
#define TIMSK1 _SFR_MEM8(0x6F)
|
||||
#define TOIE1 0
|
||||
#define OCIE1A 1
|
||||
#define OCIE1B 2
|
||||
#define ICIE1 5
|
||||
|
||||
#define TIMSK2 _SFR_MEM8(0x70)
|
||||
#define TOIE2 0
|
||||
#define OCIE2A 1
|
||||
|
||||
/* Reserved [0x71..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 ADPS0 0
|
||||
#define ADPS1 1
|
||||
#define ADPS2 2
|
||||
#define ADIE 3
|
||||
#define ADIF 4
|
||||
#define ADATE 5
|
||||
#define ADSC 6
|
||||
#define ADEN 7
|
||||
|
||||
#define ADCSRB _SFR_MEM8(0x7B)
|
||||
#define ADTS0 0
|
||||
#define ADTS1 1
|
||||
#define ADTS2 2
|
||||
#define ACME 6
|
||||
|
||||
#define ADMUX _SFR_MEM8(0x7C)
|
||||
#define MUX0 0
|
||||
#define MUX1 1
|
||||
#define MUX2 2
|
||||
#define MUX3 3
|
||||
#define MUX4 4
|
||||
#define ADLAR 5
|
||||
#define REFS0 6
|
||||
#define REFS1 7
|
||||
|
||||
/* Reserved [0x7D] */
|
||||
|
||||
#define DIDR0 _SFR_MEM8(0x7E)
|
||||
#define ADC0D 0
|
||||
#define ADC1D 1
|
||||
#define ADC2D 2
|
||||
#define ADC3D 3
|
||||
#define ADC4D 4
|
||||
#define ADC5D 5
|
||||
#define ADC6D 6
|
||||
#define ADC7D 7
|
||||
|
||||
#define DIDR1 _SFR_MEM8(0x7F)
|
||||
#define AIN0D 0
|
||||
#define AIN1D 1
|
||||
|
||||
#define TCCR1A _SFR_MEM8(0X80)
|
||||
#define WGM10 0
|
||||
#define WGM11 1
|
||||
#define COM1B0 4
|
||||
#define COM1B1 5
|
||||
#define COM1A0 6
|
||||
#define COM1A1 7
|
||||
|
||||
#define TCCR1B _SFR_MEM8(0X81)
|
||||
#define CS10 0
|
||||
#define CS11 1
|
||||
#define CS12 2
|
||||
#define WGM12 3
|
||||
#define WGM13 4
|
||||
#define ICES1 6
|
||||
#define ICNC1 7
|
||||
|
||||
#define TCCR1C _SFR_MEM8(0x82)
|
||||
#define FOC1B 6
|
||||
#define FOC1A 7
|
||||
|
||||
/* 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)
|
||||
|
||||
/* Reserved [0x8C..0xAF] */
|
||||
|
||||
#define TCCR2A _SFR_MEM8(0xB0)
|
||||
#define CS20 0
|
||||
#define CS21 1
|
||||
#define CS22 2
|
||||
#define WGM21 3
|
||||
#define COM2A0 4
|
||||
#define COM2A1 5
|
||||
#define WGM20 6
|
||||
#define FOC2A 7
|
||||
|
||||
/* Reserved [0xB1] */
|
||||
|
||||
#define TCNT2 _SFR_MEM8(0xB2)
|
||||
|
||||
#define OCR2A _SFR_MEM8(0xB3)
|
||||
|
||||
/* Reserved [0xB4..0xB5] */
|
||||
|
||||
#define ASSR _SFR_MEM8(0xB6)
|
||||
#define TCR2UB 0
|
||||
#define OCR2UB 1
|
||||
#define TCN2UB 2
|
||||
#define AS2 3
|
||||
#define EXCLK 4
|
||||
|
||||
/* Reserved [0xB7] */
|
||||
|
||||
#define USICR _SFR_MEM8(0xB8)
|
||||
#define USITC 0
|
||||
#define USICLK 1
|
||||
#define USICS0 2
|
||||
#define USICS1 3
|
||||
#define USIWM0 4
|
||||
#define USIWM1 5
|
||||
#define USIOIE 6
|
||||
#define USISIE 7
|
||||
|
||||
#define USISR _SFR_MEM8(0xB9)
|
||||
#define USICNT0 0
|
||||
#define USICNT1 1
|
||||
#define USICNT2 2
|
||||
#define USICNT3 3
|
||||
#define USIDC 4
|
||||
#define USIPF 5
|
||||
#define USIOIF 6
|
||||
#define USISIF 7
|
||||
|
||||
#define USIDR _SFR_MEM8(0xBA)
|
||||
|
||||
/* Reserved [0xBB..0xBF] */
|
||||
|
||||
#define UCSR0A _SFR_MEM8(0xC0)
|
||||
#define MPCM0 0
|
||||
#define U2X0 1
|
||||
#define UPE0 2
|
||||
#define DOR0 3
|
||||
#define FE0 4
|
||||
#define UDRE0 5
|
||||
#define TXC0 6
|
||||
#define RXC0 7
|
||||
|
||||
#define UCSR0B _SFR_MEM8(0XC1)
|
||||
#define TXB80 0
|
||||
#define RXB80 1
|
||||
#define UCSZ02 2
|
||||
#define TXEN0 3
|
||||
#define RXEN0 4
|
||||
#define UDRIE0 5
|
||||
#define TXCIE0 6
|
||||
#define RXCIE0 7
|
||||
|
||||
#define UCSR0C _SFR_MEM8(0xC2)
|
||||
#define UCPOL0 0
|
||||
#define UCSZ00 1
|
||||
#define UCSZ01 2
|
||||
#define USBS0 3
|
||||
#define UPM00 4
|
||||
#define UPM01 5
|
||||
#define UMSEL0 6
|
||||
|
||||
/* 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..0xFF] */
|
||||
|
||||
|
||||
/* Interrupt vectors */
|
||||
/* Vector 0 is the reset vector */
|
||||
/* External Interrupt Request 0 */
|
||||
#define INT0_vect _VECTOR(1)
|
||||
#define SIG_INTERRUPT0 _VECTOR(1)
|
||||
|
||||
/* Pin Change Interrupt Request 0 */
|
||||
#define PCINT0_vect _VECTOR(2)
|
||||
#define SIG_PIN_CHANGE0 _VECTOR(2)
|
||||
|
||||
/* Pin Change Interrupt Request 1 */
|
||||
#define PCINT1_vect _VECTOR(3)
|
||||
#define SIG_PIN_CHANGE1 _VECTOR(3)
|
||||
|
||||
/* Timer/Counter2 Compare Match */
|
||||
#define TIMER2_COMP_vect _VECTOR(4)
|
||||
#define SIG_OUTPUT_COMPARE2 _VECTOR(4)
|
||||
|
||||
/* Timer/Counter2 Overflow */
|
||||
#define TIMER2_OVF_vect _VECTOR(5)
|
||||
#define SIG_OVERFLOW2 _VECTOR(5)
|
||||
|
||||
/* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(6)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(6)
|
||||
|
||||
/* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPA_vect _VECTOR(7)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(7)
|
||||
|
||||
/* Timer/Counter Compare Match B */
|
||||
#define TIMER1_COMPB_vect _VECTOR(8)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(8)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(9)
|
||||
#define SIG_OVERFLOW1 _VECTOR(9)
|
||||
|
||||
/* Timer/Counter0 Compare Match */
|
||||
#define TIMER0_COMP_vect _VECTOR(10)
|
||||
#define SIG_OUTPUT_COMPARE0 _VECTOR(10)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(11)
|
||||
#define SIG_OVERFLOW0 _VECTOR(11)
|
||||
|
||||
/* SPI Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(12)
|
||||
#define SIG_SPI _VECTOR(12)
|
||||
|
||||
/* USART0, Rx Complete */
|
||||
#define USART0_RX_vect _VECTOR(13)
|
||||
#define SIG_UART_RECV _VECTOR(13)
|
||||
|
||||
/* USART0 Data register Empty */
|
||||
#define USART0_UDRE_vect _VECTOR(14)
|
||||
#define SIG_UART_DATA _VECTOR(14)
|
||||
|
||||
/* USART0, Tx Complete */
|
||||
#define USART0_TX_vect _VECTOR(15)
|
||||
#define SIG_UART_TRANS _VECTOR(15)
|
||||
|
||||
/* USI Start Condition */
|
||||
#define USI_START_vect _VECTOR(16)
|
||||
#define SIG_USI_START _VECTOR(16)
|
||||
|
||||
/* USI Overflow */
|
||||
#define USI_OVERFLOW_vect _VECTOR(17)
|
||||
#define SIG_USI_OVERFLOW _VECTOR(17)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANALOG_COMP_vect _VECTOR(18)
|
||||
#define SIG_COMPARATOR _VECTOR(18)
|
||||
|
||||
/* ADC Conversion Complete */
|
||||
#define ADC_vect _VECTOR(19)
|
||||
#define SIG_ADC _VECTOR(19)
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_READY_vect _VECTOR(20)
|
||||
#define SIG_EEPROM_READY _VECTOR(20)
|
||||
|
||||
/* Store Program Memory Read */
|
||||
#define SPM_READY_vect _VECTOR(21)
|
||||
#define SIG_SPM_READY _VECTOR(21)
|
||||
|
||||
/* Vector 22 is Reserved */
|
||||
|
||||
#define _VECTORS_SIZE 92
|
||||
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 128
|
||||
#define RAMEND 0x8FF
|
||||
#define XRAMEND 0x8FF
|
||||
#define E2END 0x3FF
|
||||
#define E2PAGESIZE 4
|
||||
#define FLASHEND 0x7FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6)
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_RSTDISBL (unsigned char)~_BV(0)
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(2)
|
||||
#define EFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x95
|
||||
#define SIGNATURE_2 0x05
|
||||
|
||||
|
||||
#endif /* _AVR_IOM325_H_ */
|
|
@ -0,0 +1,911 @@
|
|||
/* Copyright (c) 2004, 2005, 2006, 2007 Eric B. Weddington
|
||||
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: iom3250.h,v 1.12.2.6 2008/10/17 23:27:48 arcanum Exp $ */
|
||||
|
||||
/* avr/iom3250.h - definitions for ATmega3250 and ATmega3250P. */
|
||||
|
||||
#ifndef _AVR_IOM3250_H_
|
||||
#define _AVR_IOM3250_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_ "iom3250.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#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 DDG4 4
|
||||
#define DDG3 3
|
||||
#define DDG2 2
|
||||
#define DDG1 1
|
||||
#define DDG0 0
|
||||
|
||||
#define PORTG _SFR_IO8(0x14)
|
||||
#define PG4 4
|
||||
#define PG3 3
|
||||
#define PG2 2
|
||||
#define PG1 1
|
||||
#define PG0 0
|
||||
|
||||
#define TIFR0 _SFR_IO8(0x15)
|
||||
#define TOV0 0
|
||||
#define OCF0A 1
|
||||
|
||||
#define TIFR1 _SFR_IO8(0x16)
|
||||
#define TOV1 0
|
||||
#define OCF1A 1
|
||||
#define OCF1B 2
|
||||
#define ICF1 5
|
||||
|
||||
#define TIFR2 _SFR_IO8(0x17)
|
||||
#define TOV2 0
|
||||
#define OCF2A 1
|
||||
|
||||
/* Reserved [0x18..0x1B] */
|
||||
|
||||
#define EIFR _SFR_IO8(0x1C)
|
||||
#define INTF0 0
|
||||
#define PCIF0 4
|
||||
#define PCIF1 5
|
||||
#define PCIF2 6
|
||||
#define PCIF3 7
|
||||
|
||||
#define EIMSK _SFR_IO8(0x1D)
|
||||
#define INT0 0
|
||||
#define PCIE0 4
|
||||
#define PCIE1 5
|
||||
#define PCIE2 6
|
||||
#define PCIE3 7
|
||||
|
||||
#define GPIOR0 _SFR_IO8(0x1E)
|
||||
|
||||
#define EECR _SFR_IO8(0x1F)
|
||||
#define EERE 0
|
||||
#define EEWE 1
|
||||
#define EEMWE 2
|
||||
#define EERIE 3
|
||||
|
||||
#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 PSR10 0
|
||||
#define PSR2 1
|
||||
#define TSM 7
|
||||
|
||||
#define TCCR0A _SFR_IO8(0x24)
|
||||
#define CS00 0
|
||||
#define CS01 1
|
||||
#define CS02 2
|
||||
#define WGM01 3
|
||||
#define COM0A0 4
|
||||
#define COM0A1 5
|
||||
#define WGM00 6
|
||||
#define FOC0A 7
|
||||
|
||||
/* Reserved [0x25] */
|
||||
|
||||
#define TCNT0 _SFR_IO8(0X26)
|
||||
|
||||
#define OCR0A _SFR_IO8(0X27)
|
||||
|
||||
/* Reserved [0x28..0x29] */
|
||||
|
||||
#define GPIOR1 _SFR_IO8(0x2A)
|
||||
|
||||
#define GPIOR2 _SFR_IO8(0x2B)
|
||||
|
||||
#define SPCR _SFR_IO8(0x2C)
|
||||
#define SPR0 0
|
||||
#define SPR1 1
|
||||
#define CPHA 2
|
||||
#define CPOL 3
|
||||
#define MSTR 4
|
||||
#define DORD 5
|
||||
#define SPE 6
|
||||
#define SPIE 7
|
||||
|
||||
#define SPSR _SFR_IO8(0x2D)
|
||||
#define SPI2X 0
|
||||
#define WCOL 6
|
||||
#define SPIF 7
|
||||
|
||||
#define SPDR _SFR_IO8(0X2E)
|
||||
|
||||
/* Reserved [0x2F] */
|
||||
|
||||
#define ACSR _SFR_IO8(0x30)
|
||||
#define ACIS0 0
|
||||
#define ACIS1 1
|
||||
#define ACIC 2
|
||||
#define ACIE 3
|
||||
#define ACI 4
|
||||
#define ACO 5
|
||||
#define ACBG 6
|
||||
#define ACD 7
|
||||
|
||||
#define OCDR _SFR_IO8(0x31)
|
||||
#define OCDR0 0
|
||||
#define OCDR1 1
|
||||
#define OCDR2 2
|
||||
#define OCDR3 3
|
||||
#define OCDR4 4
|
||||
#define OCDR5 5
|
||||
#define OCDR6 6
|
||||
#define OCDR7 7
|
||||
#define IDRD 7
|
||||
|
||||
/* Reserved [0x32] */
|
||||
|
||||
#define SMCR _SFR_IO8(0x33)
|
||||
#define SE 0
|
||||
#define SM0 1
|
||||
#define SM1 2
|
||||
#define SM2 3
|
||||
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
#define PORF 0
|
||||
#define EXTRF 1
|
||||
#define BORF 2
|
||||
#define WDRF 3
|
||||
#define JTRF 4
|
||||
|
||||
#define MCUCR _SFR_IO8(0X35)
|
||||
#define IVCE 0
|
||||
#define IVSEL 1
|
||||
#define PUD 4
|
||||
#if defined(__AVR_ATmega3250P__)
|
||||
#define BODSE 5
|
||||
#define BODS 6
|
||||
#endif
|
||||
#define JTD 7
|
||||
|
||||
/* Reserved [0x36] */
|
||||
|
||||
#define SPMCSR _SFR_IO8(0x37)
|
||||
#define SPMEN 0
|
||||
#define PGERS 1
|
||||
#define PGWRT 2
|
||||
#define BLBSET 3
|
||||
#define RWWSRE 4
|
||||
#define RWWSB 6
|
||||
#define SPMIE 7
|
||||
|
||||
/* Reserved [0x38..0x3C] */
|
||||
|
||||
/* SP [0x3D..0x3E] */
|
||||
/* SREG [0x3F] */
|
||||
|
||||
#define WDTCR _SFR_MEM8(0x60)
|
||||
#define WDP0 0
|
||||
#define WDP1 1
|
||||
#define WDP2 2
|
||||
#define WDE 3
|
||||
#define WDCE 4
|
||||
|
||||
#define CLKPR _SFR_MEM8(0x61)
|
||||
#define CLKPS0 0
|
||||
#define CLKPS1 1
|
||||
#define CLKPS2 2
|
||||
#define CLKPS3 3
|
||||
#define CLKPCE 7
|
||||
|
||||
/* Reserved [0x62..0x63] */
|
||||
|
||||
#define PRR _SFR_MEM8(0x64)
|
||||
#define PRADC 0
|
||||
#define PRUSART0 1
|
||||
#define PRSPI 2
|
||||
#define PRTIM1 3
|
||||
|
||||
/* Reserved [0x65] */
|
||||
|
||||
#define OSCCAL _SFR_MEM8(0x66)
|
||||
|
||||
/* Reserved [0x67..0x68] */
|
||||
|
||||
#define EICRA _SFR_MEM8(0x69)
|
||||
#define ISC00 0
|
||||
#define ISC01 1
|
||||
|
||||
/* Reserved [0x6A] */
|
||||
|
||||
#define PCMSK0 _SFR_MEM8(0x6B)
|
||||
#define PCINT0 0
|
||||
#define PCINT1 1
|
||||
#define PCINT2 2
|
||||
#define PCINT3 3
|
||||
#define PCINT4 4
|
||||
#define PCINT5 5
|
||||
#define PCINT6 6
|
||||
#define PCINT7 7
|
||||
|
||||
#define PCMSK1 _SFR_MEM8(0x6C)
|
||||
#define PCINT8 0
|
||||
#define PCINT9 1
|
||||
#define PCINT10 2
|
||||
#define PCINT11 3
|
||||
#define PCINT12 4
|
||||
#define PCINT13 5
|
||||
#define PCINT14 6
|
||||
#define PCINT15 7
|
||||
|
||||
#define PCMSK2 _SFR_MEM8(0x6D)
|
||||
#define PCINT16 0
|
||||
#define PCINT17 1
|
||||
#define PCINT18 2
|
||||
#define PCINT19 3
|
||||
#define PCINT20 4
|
||||
#define PCINT21 5
|
||||
#define PCINT22 6
|
||||
#define PCINT23 7
|
||||
|
||||
#define TIMSK0 _SFR_MEM8(0x6E)
|
||||
#define TOIE0 0
|
||||
#define OCIE0A 1
|
||||
|
||||
#define TIMSK1 _SFR_MEM8(0x6F)
|
||||
#define TOIE1 0
|
||||
#define OCIE1A 1
|
||||
#define OCIE1B 2
|
||||
#define ICIE1 5
|
||||
|
||||
#define TIMSK2 _SFR_MEM8(0x70)
|
||||
#define TOIE2 0
|
||||
#define OCIE2A 1
|
||||
|
||||
/* Reserved [0x71..0x72] */
|
||||
|
||||
#define PCMSK3 _SFR_MEM8(0x73)
|
||||
#define PCINT24 0
|
||||
#define PCINT25 1
|
||||
#define PCINT26 2
|
||||
#define PCINT27 3
|
||||
#define PCINT28 4
|
||||
#define PCINT29 5
|
||||
#define PCINT30 6
|
||||
|
||||
/* Reserved [0x74..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 ADPS0 0
|
||||
#define ADPS1 1
|
||||
#define ADPS2 2
|
||||
#define ADIE 3
|
||||
#define ADIF 4
|
||||
#define ADATE 5
|
||||
#define ADSC 6
|
||||
#define ADEN 7
|
||||
|
||||
#define ADCSRB _SFR_MEM8(0x7B)
|
||||
#define ADTS0 0
|
||||
#define ADTS1 1
|
||||
#define ADTS2 2
|
||||
#define ACME 6
|
||||
|
||||
#define ADMUX _SFR_MEM8(0x7C)
|
||||
#define MUX0 0
|
||||
#define MUX1 1
|
||||
#define MUX2 2
|
||||
#define MUX3 3
|
||||
#define MUX4 4
|
||||
#define ADLAR 5
|
||||
#define REFS0 6
|
||||
#define REFS1 7
|
||||
|
||||
/* Reserved [0x7D] */
|
||||
|
||||
#define DIDR0 _SFR_MEM8(0x7E)
|
||||
#define ADC0D 0
|
||||
#define ADC1D 1
|
||||
#define ADC2D 2
|
||||
#define ADC3D 3
|
||||
#define ADC4D 4
|
||||
#define ADC5D 5
|
||||
#define ADC6D 6
|
||||
#define ADC7D 7
|
||||
|
||||
#define DIDR1 _SFR_MEM8(0x7F)
|
||||
#define AIN0D 0
|
||||
#define AIN1D 1
|
||||
|
||||
#define TCCR1A _SFR_MEM8(0X80)
|
||||
#define WGM10 0
|
||||
#define WGM11 1
|
||||
#define COM1B0 4
|
||||
#define COM1B1 5
|
||||
#define COM1A0 6
|
||||
#define COM1A1 7
|
||||
|
||||
#define TCCR1B _SFR_MEM8(0X81)
|
||||
#define CS10 0
|
||||
#define CS11 1
|
||||
#define CS12 2
|
||||
#define WGM12 3
|
||||
#define WGM13 4
|
||||
#define ICES1 6
|
||||
#define ICNC1 7
|
||||
|
||||
#define TCCR1C _SFR_MEM8(0x82)
|
||||
#define FOC1B 6
|
||||
#define FOC1A 7
|
||||
|
||||
/* 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)
|
||||
|
||||
/* Reserved [0x8C..0xAF] */
|
||||
|
||||
#define TCCR2A _SFR_MEM8(0xB0)
|
||||
#define CS20 0
|
||||
#define CS21 1
|
||||
#define CS22 2
|
||||
#define WGM21 3
|
||||
#define COM2A0 4
|
||||
#define COM2A1 5
|
||||
#define WGM20 6
|
||||
#define FOC2A 7
|
||||
|
||||
/* Reserved [0xB1] */
|
||||
|
||||
#define TCNT2 _SFR_MEM8(0xB2)
|
||||
|
||||
#define OCR2A _SFR_MEM8(0xB3)
|
||||
|
||||
/* Reserved [0xB4..0xB5] */
|
||||
|
||||
#define ASSR _SFR_MEM8(0xB6)
|
||||
#define TCR2UB 0
|
||||
#define OCR2UB 1
|
||||
#define TCN2UB 2
|
||||
#define AS2 3
|
||||
#define EXCLK 4
|
||||
|
||||
/* Reserved [0xB7] */
|
||||
|
||||
#define USICR _SFR_MEM8(0xB8)
|
||||
#define USITC 0
|
||||
#define USICLK 1
|
||||
#define USICS0 2
|
||||
#define USICS1 3
|
||||
#define USIWM0 4
|
||||
#define USIWM1 5
|
||||
#define USIOIE 6
|
||||
#define USISIE 7
|
||||
|
||||
#define USISR _SFR_MEM8(0xB9)
|
||||
#define USICNT0 0
|
||||
#define USICNT1 1
|
||||
#define USICNT2 2
|
||||
#define USICNT3 3
|
||||
#define USIDC 4
|
||||
#define USIPF 5
|
||||
#define USIOIF 6
|
||||
#define USISIF 7
|
||||
|
||||
#define USIDR _SFR_MEM8(0xBA)
|
||||
|
||||
/* Reserved [0xBB..0xBF] */
|
||||
|
||||
#define UCSR0A _SFR_MEM8(0xC0)
|
||||
#define MPCM0 0
|
||||
#define U2X0 1
|
||||
#define UPE0 2
|
||||
#define DOR0 3
|
||||
#define FE0 4
|
||||
#define UDRE0 5
|
||||
#define TXC0 6
|
||||
#define RXC0 7
|
||||
|
||||
#define UCSR0B _SFR_MEM8(0XC1)
|
||||
#define TXB80 0
|
||||
#define RXB80 1
|
||||
#define UCSZ02 2
|
||||
#define TXEN0 3
|
||||
#define RXEN0 4
|
||||
#define UDRIE0 5
|
||||
#define TXCIE0 6
|
||||
#define RXCIE0 7
|
||||
|
||||
#define UCSR0C _SFR_MEM8(0xC2)
|
||||
#define UCPOL0 0
|
||||
#define UCSZ00 1
|
||||
#define UCSZ01 2
|
||||
#define USBS0 3
|
||||
#define UPM00 4
|
||||
#define UPM01 5
|
||||
#define UMSEL0 6
|
||||
|
||||
/* 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..0xD7] */
|
||||
|
||||
#define PINH _SFR_MEM8(0xD8)
|
||||
#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(0xD9)
|
||||
#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(0xDA)
|
||||
#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(0xDB)
|
||||
#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(0xDC)
|
||||
#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(0xDD)
|
||||
#define PJ6 6
|
||||
#define PJ5 5
|
||||
#define PJ4 4
|
||||
#define PJ3 3
|
||||
#define PJ2 2
|
||||
#define PJ1 1
|
||||
#define PJ0 0
|
||||
|
||||
/* Reserved [0xDE..0xFF] */
|
||||
|
||||
|
||||
/* Interrupt vectors */
|
||||
/* Vector 0 is the reset vector */
|
||||
/* External Interrupt Request 0 */
|
||||
#define INT0_vect _VECTOR(1)
|
||||
#define SIG_INTERRUPT0 _VECTOR(1)
|
||||
|
||||
/* Pin Change Interrupt Request 0 */
|
||||
#define PCINT0_vect _VECTOR(2)
|
||||
#define SIG_PIN_CHANGE0 _VECTOR(2)
|
||||
|
||||
/* Pin Change Interrupt Request 1 */
|
||||
#define PCINT1_vect _VECTOR(3)
|
||||
#define SIG_PIN_CHANGE1 _VECTOR(3)
|
||||
|
||||
/* Timer/Counter2 Compare Match */
|
||||
#define TIMER2_COMP_vect _VECTOR(4)
|
||||
#define SIG_OUTPUT_COMPARE2 _VECTOR(4)
|
||||
|
||||
/* Timer/Counter2 Overflow */
|
||||
#define TIMER2_OVF_vect _VECTOR(5)
|
||||
#define SIG_OVERFLOW2 _VECTOR(5)
|
||||
|
||||
/* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(6)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(6)
|
||||
|
||||
/* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPA_vect _VECTOR(7)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(7)
|
||||
|
||||
/* Timer/Counter Compare Match B */
|
||||
#define TIMER1_COMPB_vect _VECTOR(8)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(8)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(9)
|
||||
#define SIG_OVERFLOW1 _VECTOR(9)
|
||||
|
||||
/* Timer/Counter0 Compare Match */
|
||||
#define TIMER0_COMP_vect _VECTOR(10)
|
||||
#define SIG_OUTPUT_COMPARE0 _VECTOR(10)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(11)
|
||||
#define SIG_OVERFLOW0 _VECTOR(11)
|
||||
|
||||
/* SPI Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(12)
|
||||
#define SIG_SPI _VECTOR(12)
|
||||
|
||||
/* USART, Rx Complete */
|
||||
#define USART_RX_vect _VECTOR(13)
|
||||
#define USART0_RX_vect _VECTOR(13) /* Alias */
|
||||
#define SIG_UART_RECV _VECTOR(13)
|
||||
|
||||
/* USART Data register Empty */
|
||||
#define USART_UDRE_vect _VECTOR(14)
|
||||
#define USART0_UDRE_vect _VECTOR(14) /* Alias */
|
||||
#define SIG_UART_DATA _VECTOR(14)
|
||||
|
||||
/* USART0, Tx Complete */
|
||||
#define USART0_TX_vect _VECTOR(15)
|
||||
#define USART_TX_vect _VECTOR(15) /* Alias */
|
||||
#define SIG_UART_TRANS _VECTOR(15)
|
||||
|
||||
/* USI Start Condition */
|
||||
#define USI_START_vect _VECTOR(16)
|
||||
#define SIG_USI_START _VECTOR(16)
|
||||
|
||||
/* USI Overflow */
|
||||
#define USI_OVERFLOW_vect _VECTOR(17)
|
||||
#define SIG_USI_OVERFLOW _VECTOR(17)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANALOG_COMP_vect _VECTOR(18)
|
||||
#define SIG_COMPARATOR _VECTOR(18)
|
||||
|
||||
/* ADC Conversion Complete */
|
||||
#define ADC_vect _VECTOR(19)
|
||||
#define SIG_ADC _VECTOR(19)
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_READY_vect _VECTOR(20)
|
||||
#define SIG_EEPROM_READY _VECTOR(20)
|
||||
|
||||
/* Store Program Memory Read */
|
||||
#define SPM_READY_vect _VECTOR(21)
|
||||
#define SIG_SPM_READY _VECTOR(21)
|
||||
|
||||
/* Pin Change Interrupt Request 2 */
|
||||
#define PCINT2_vect _VECTOR(23)
|
||||
#define SIG_PIN_CHANGE2 _VECTOR(23)
|
||||
|
||||
/* Pin Change Interrupt Request 3 */
|
||||
#define PCINT3_vect _VECTOR(24)
|
||||
#define SIG_PIN_CHANGE3 _VECTOR(24)
|
||||
|
||||
#define _VECTORS_SIZE 100
|
||||
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 128
|
||||
#define RAMEND 0x8FF
|
||||
#define XRAMEND 0x8FF
|
||||
#define E2END 0x3FF
|
||||
#define E2PAGESIZE 4
|
||||
#define FLASHEND 0x7FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6)
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_RSTDISBL (unsigned char)~_BV(0)
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(2)
|
||||
#define EFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x95
|
||||
#define SIGNATURE_2 0x06
|
||||
|
||||
|
||||
#endif /* _AVR_IOM3250_H_ */
|
|
@ -0,0 +1,875 @@
|
|||
/* Copyright (c) 2007 Atmel Corporation
|
||||
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: iom328p.h,v 1.3.2.12 2008/10/17 23:27:49 arcanum Exp $ */
|
||||
|
||||
/* avr/iom328p.h - definitions for ATmega328P. */
|
||||
|
||||
/* 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_ "iom328p.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
|
||||
#ifndef _AVR_IOM328P_H_
|
||||
#define _AVR_IOM328P_H_ 1
|
||||
|
||||
/* Registers and associated bit numbers */
|
||||
|
||||
#define PINB _SFR_IO8(0x03)
|
||||
#define PINB0 0
|
||||
#define PINB1 1
|
||||
#define PINB2 2
|
||||
#define PINB3 3
|
||||
#define PINB4 4
|
||||
#define PINB5 5
|
||||
#define PINB6 6
|
||||
#define PINB7 7
|
||||
|
||||
#define DDRB _SFR_IO8(0x04)
|
||||
#define DDB0 0
|
||||
#define DDB1 1
|
||||
#define DDB2 2
|
||||
#define DDB3 3
|
||||
#define DDB4 4
|
||||
#define DDB5 5
|
||||
#define DDB6 6
|
||||
#define DDB7 7
|
||||
|
||||
#define PORTB _SFR_IO8(0x05)
|
||||
#define PORTB0 0
|
||||
#define PORTB1 1
|
||||
#define PORTB2 2
|
||||
#define PORTB3 3
|
||||
#define PORTB4 4
|
||||
#define PORTB5 5
|
||||
#define PORTB6 6
|
||||
#define PORTB7 7
|
||||
|
||||
#define PINC _SFR_IO8(0x06)
|
||||
#define PINC0 0
|
||||
#define PINC1 1
|
||||
#define PINC2 2
|
||||
#define PINC3 3
|
||||
#define PINC4 4
|
||||
#define PINC5 5
|
||||
#define PINC6 6
|
||||
|
||||
#define DDRC _SFR_IO8(0x07)
|
||||
#define DDC0 0
|
||||
#define DDC1 1
|
||||
#define DDC2 2
|
||||
#define DDC3 3
|
||||
#define DDC4 4
|
||||
#define DDC5 5
|
||||
#define DDC6 6
|
||||
|
||||
#define PORTC _SFR_IO8(0x08)
|
||||
#define PORTC0 0
|
||||
#define PORTC1 1
|
||||
#define PORTC2 2
|
||||
#define PORTC3 3
|
||||
#define PORTC4 4
|
||||
#define PORTC5 5
|
||||
#define PORTC6 6
|
||||
|
||||
#define PIND _SFR_IO8(0x09)
|
||||
#define PIND0 0
|
||||
#define PIND1 1
|
||||
#define PIND2 2
|
||||
#define PIND3 3
|
||||
#define PIND4 4
|
||||
#define PIND5 5
|
||||
#define PIND6 6
|
||||
#define PIND7 7
|
||||
|
||||
#define DDRD _SFR_IO8(0x0A)
|
||||
#define DDD0 0
|
||||
#define DDD1 1
|
||||
#define DDD2 2
|
||||
#define DDD3 3
|
||||
#define DDD4 4
|
||||
#define DDD5 5
|
||||
#define DDD6 6
|
||||
#define DDD7 7
|
||||
|
||||
#define PORTD _SFR_IO8(0x0B)
|
||||
#define PORTD0 0
|
||||
#define PORTD1 1
|
||||
#define PORTD2 2
|
||||
#define PORTD3 3
|
||||
#define PORTD4 4
|
||||
#define PORTD5 5
|
||||
#define PORTD6 6
|
||||
#define PORTD7 7
|
||||
|
||||
#define TIFR0 _SFR_IO8(0x15)
|
||||
#define TOV0 0
|
||||
#define OCF0A 1
|
||||
#define OCF0B 2
|
||||
|
||||
#define TIFR1 _SFR_IO8(0x16)
|
||||
#define TOV1 0
|
||||
#define OCF1A 1
|
||||
#define OCF1B 2
|
||||
#define ICF1 5
|
||||
|
||||
#define TIFR2 _SFR_IO8(0x17)
|
||||
#define TOV2 0
|
||||
#define OCF2A 1
|
||||
#define OCF2B 2
|
||||
|
||||
#define PCIFR _SFR_IO8(0x1B)
|
||||
#define PCIF0 0
|
||||
#define PCIF1 1
|
||||
#define PCIF2 2
|
||||
|
||||
#define EIFR _SFR_IO8(0x1C)
|
||||
#define INTF0 0
|
||||
#define INTF1 1
|
||||
|
||||
#define EIMSK _SFR_IO8(0x1D)
|
||||
#define INT0 0
|
||||
#define INT1 1
|
||||
|
||||
#define GPIOR0 _SFR_IO8(0x1E)
|
||||
#define GPIOR00 0
|
||||
#define GPIOR01 1
|
||||
#define GPIOR02 2
|
||||
#define GPIOR03 3
|
||||
#define GPIOR04 4
|
||||
#define GPIOR05 5
|
||||
#define GPIOR06 6
|
||||
#define GPIOR07 7
|
||||
|
||||
#define EECR _SFR_IO8(0x1F)
|
||||
#define EERE 0
|
||||
#define EEPE 1
|
||||
#define EEMPE 2
|
||||
#define EERIE 3
|
||||
#define EEPM0 4
|
||||
#define EEPM1 5
|
||||
|
||||
#define EEDR _SFR_IO8(0x20)
|
||||
#define EEDR0 0
|
||||
#define EEDR1 1
|
||||
#define EEDR2 2
|
||||
#define EEDR3 3
|
||||
#define EEDR4 4
|
||||
#define EEDR5 5
|
||||
#define EEDR6 6
|
||||
#define EEDR7 7
|
||||
|
||||
#define EEAR _SFR_IO16(0x21)
|
||||
|
||||
#define EEARL _SFR_IO8(0x21)
|
||||
#define EEAR0 0
|
||||
#define EEAR1 1
|
||||
#define EEAR2 2
|
||||
#define EEAR3 3
|
||||
#define EEAR4 4
|
||||
#define EEAR5 5
|
||||
#define EEAR6 6
|
||||
#define EEAR7 7
|
||||
|
||||
#define EEARH _SFR_IO8(0x22)
|
||||
#define EEAR8 0
|
||||
#define EEAR9 1
|
||||
|
||||
#define _EEPROM_REG_LOCATIONS_ 1F2021
|
||||
|
||||
#define GTCCR _SFR_IO8(0x23)
|
||||
#define PSRSYNC 0
|
||||
#define PSRASY 1
|
||||
#define TSM 7
|
||||
|
||||
#define TCCR0A _SFR_IO8(0x24)
|
||||
#define WGM00 0
|
||||
#define WGM01 1
|
||||
#define COM0B0 4
|
||||
#define COM0B1 5
|
||||
#define COM0A0 6
|
||||
#define COM0A1 7
|
||||
|
||||
#define TCCR0B _SFR_IO8(0x25)
|
||||
#define CS00 0
|
||||
#define CS01 1
|
||||
#define CS02 2
|
||||
#define WGM02 3
|
||||
#define FOC0B 6
|
||||
#define FOC0A 7
|
||||
|
||||
#define TCNT0 _SFR_IO8(0x26)
|
||||
#define TCNT0_0 0
|
||||
#define TCNT0_1 1
|
||||
#define TCNT0_2 2
|
||||
#define TCNT0_3 3
|
||||
#define TCNT0_4 4
|
||||
#define TCNT0_5 5
|
||||
#define TCNT0_6 6
|
||||
#define TCNT0_7 7
|
||||
|
||||
#define OCR0A _SFR_IO8(0x27)
|
||||
#define OCROA_0 0
|
||||
#define OCROA_1 1
|
||||
#define OCROA_2 2
|
||||
#define OCROA_3 3
|
||||
#define OCROA_4 4
|
||||
#define OCROA_5 5
|
||||
#define OCROA_6 6
|
||||
#define OCROA_7 7
|
||||
|
||||
#define OCR0B _SFR_IO8(0x28)
|
||||
#define OCR0B_0 0
|
||||
#define OCR0B_1 1
|
||||
#define OCR0B_2 2
|
||||
#define OCR0B_3 3
|
||||
#define OCR0B_4 4
|
||||
#define OCR0B_5 5
|
||||
#define OCR0B_6 6
|
||||
#define OCR0B_7 7
|
||||
|
||||
#define GPIOR1 _SFR_IO8(0x2A)
|
||||
#define GPIOR10 0
|
||||
#define GPIOR11 1
|
||||
#define GPIOR12 2
|
||||
#define GPIOR13 3
|
||||
#define GPIOR14 4
|
||||
#define GPIOR15 5
|
||||
#define GPIOR16 6
|
||||
#define GPIOR17 7
|
||||
|
||||
#define GPIOR2 _SFR_IO8(0x2B)
|
||||
#define GPIOR20 0
|
||||
#define GPIOR21 1
|
||||
#define GPIOR22 2
|
||||
#define GPIOR23 3
|
||||
#define GPIOR24 4
|
||||
#define GPIOR25 5
|
||||
#define GPIOR26 6
|
||||
#define GPIOR27 7
|
||||
|
||||
#define SPCR _SFR_IO8(0x2C)
|
||||
#define SPR0 0
|
||||
#define SPR1 1
|
||||
#define CPHA 2
|
||||
#define CPOL 3
|
||||
#define MSTR 4
|
||||
#define DORD 5
|
||||
#define SPE 6
|
||||
#define SPIE 7
|
||||
|
||||
#define SPSR _SFR_IO8(0x2D)
|
||||
#define SPI2X 0
|
||||
#define WCOL 6
|
||||
#define SPIF 7
|
||||
|
||||
#define SPDR _SFR_IO8(0x2E)
|
||||
#define SPDR0 0
|
||||
#define SPDR1 1
|
||||
#define SPDR2 2
|
||||
#define SPDR3 3
|
||||
#define SPDR4 4
|
||||
#define SPDR5 5
|
||||
#define SPDR6 6
|
||||
#define SPDR7 7
|
||||
|
||||
#define ACSR _SFR_IO8(0x30)
|
||||
#define ACIS0 0
|
||||
#define ACIS1 1
|
||||
#define ACIC 2
|
||||
#define ACIE 3
|
||||
#define ACI 4
|
||||
#define ACO 5
|
||||
#define ACBG 6
|
||||
#define ACD 7
|
||||
|
||||
#define SMCR _SFR_IO8(0x33)
|
||||
#define SE 0
|
||||
#define SM0 1
|
||||
#define SM1 2
|
||||
#define SM2 3
|
||||
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
#define PORF 0
|
||||
#define EXTRF 1
|
||||
#define BORF 2
|
||||
#define WDRF 3
|
||||
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
#define IVCE 0
|
||||
#define IVSEL 1
|
||||
#define PUD 4
|
||||
#define BODSE 5
|
||||
#define BODS 6
|
||||
|
||||
#define SPMCSR _SFR_IO8(0x37)
|
||||
#define SELFPRGEN 0
|
||||
#define PGERS 1
|
||||
#define PGWRT 2
|
||||
#define BLBSET 3
|
||||
#define RWWSRE 4
|
||||
#define RWWSB 6
|
||||
#define SPMIE 7
|
||||
|
||||
#define WDTCSR _SFR_MEM8(0x60)
|
||||
#define WDP0 0
|
||||
#define WDP1 1
|
||||
#define WDP2 2
|
||||
#define WDE 3
|
||||
#define WDCE 4
|
||||
#define WDP3 5
|
||||
#define WDIE 6
|
||||
#define WDIF 7
|
||||
|
||||
#define CLKPR _SFR_MEM8(0x61)
|
||||
#define CLKPS0 0
|
||||
#define CLKPS1 1
|
||||
#define CLKPS2 2
|
||||
#define CLKPS3 3
|
||||
#define CLKPCE 7
|
||||
|
||||
#define PRR _SFR_MEM8(0x64)
|
||||
#define PRADC 0
|
||||
#define PRUSART0 1
|
||||
#define PRSPI 2
|
||||
#define PRTIM1 3
|
||||
#define PRTIM0 5
|
||||
#define PRTIM2 6
|
||||
#define PRTWI 7
|
||||
|
||||
#define OSCCAL _SFR_MEM8(0x66)
|
||||
#define CAL0 0
|
||||
#define CAL1 1
|
||||
#define CAL2 2
|
||||
#define CAL3 3
|
||||
#define CAL4 4
|
||||
#define CAL5 5
|
||||
#define CAL6 6
|
||||
#define CAL7 7
|
||||
|
||||
#define PCICR _SFR_MEM8(0x68)
|
||||
#define PCIE0 0
|
||||
#define PCIE1 1
|
||||
#define PCIE2 2
|
||||
|
||||
#define EICRA _SFR_MEM8(0x69)
|
||||
#define ISC00 0
|
||||
#define ISC01 1
|
||||
#define ISC10 2
|
||||
#define ISC11 3
|
||||
|
||||
#define PCMSK0 _SFR_MEM8(0x6B)
|
||||
#define PCINT0 0
|
||||
#define PCINT1 1
|
||||
#define PCINT2 2
|
||||
#define PCINT3 3
|
||||
#define PCINT4 4
|
||||
#define PCINT5 5
|
||||
#define PCINT6 6
|
||||
#define PCINT7 7
|
||||
|
||||
#define PCMSK1 _SFR_MEM8(0x6C)
|
||||
#define PCINT8 0
|
||||
#define PCINT9 1
|
||||
#define PCINT10 2
|
||||
#define PCINT11 3
|
||||
#define PCINT12 4
|
||||
#define PCINT13 5
|
||||
#define PCINT14 6
|
||||
|
||||
#define PCMSK2 _SFR_MEM8(0x6D)
|
||||
#define PCINT16 0
|
||||
#define PCINT17 1
|
||||
#define PCINT18 2
|
||||
#define PCINT19 3
|
||||
#define PCINT20 4
|
||||
#define PCINT21 5
|
||||
#define PCINT22 6
|
||||
#define PCINT23 7
|
||||
|
||||
#define TIMSK0 _SFR_MEM8(0x6E)
|
||||
#define TOIE0 0
|
||||
#define OCIE0A 1
|
||||
#define OCIE0B 2
|
||||
|
||||
#define TIMSK1 _SFR_MEM8(0x6F)
|
||||
#define TOIE1 0
|
||||
#define OCIE1A 1
|
||||
#define OCIE1B 2
|
||||
#define ICIE1 5
|
||||
|
||||
#define TIMSK2 _SFR_MEM8(0x70)
|
||||
#define TOIE2 0
|
||||
#define OCIE2A 1
|
||||
#define OCIE2B 2
|
||||
|
||||
#ifndef __ASSEMBLER__
|
||||
#define ADC _SFR_MEM16(0x78)
|
||||
#endif
|
||||
#define ADCW _SFR_MEM16(0x78)
|
||||
|
||||
#define ADCL _SFR_MEM8(0x78)
|
||||
#define ADCL0 0
|
||||
#define ADCL1 1
|
||||
#define ADCL2 2
|
||||
#define ADCL3 3
|
||||
#define ADCL4 4
|
||||
#define ADCL5 5
|
||||
#define ADCL6 6
|
||||
#define ADCL7 7
|
||||
|
||||
#define ADCH _SFR_MEM8(0x79)
|
||||
#define ADCH0 0
|
||||
#define ADCH1 1
|
||||
#define ADCH2 2
|
||||
#define ADCH3 3
|
||||
#define ADCH4 4
|
||||
#define ADCH5 5
|
||||
#define ADCH6 6
|
||||
#define ADCH7 7
|
||||
|
||||
#define ADCSRA _SFR_MEM8(0x7A)
|
||||
#define ADPS0 0
|
||||
#define ADPS1 1
|
||||
#define ADPS2 2
|
||||
#define ADIE 3
|
||||
#define ADIF 4
|
||||
#define ADATE 5
|
||||
#define ADSC 6
|
||||
#define ADEN 7
|
||||
|
||||
#define ADCSRB _SFR_MEM8(0x7B)
|
||||
#define ADTS0 0
|
||||
#define ADTS1 1
|
||||
#define ADTS2 2
|
||||
#define ACME 6
|
||||
|
||||
#define ADMUX _SFR_MEM8(0x7C)
|
||||
#define MUX0 0
|
||||
#define MUX1 1
|
||||
#define MUX2 2
|
||||
#define MUX3 3
|
||||
#define ADLAR 5
|
||||
#define REFS0 6
|
||||
#define REFS1 7
|
||||
|
||||
#define DIDR0 _SFR_MEM8(0x7E)
|
||||
#define ADC0D 0
|
||||
#define ADC1D 1
|
||||
#define ADC2D 2
|
||||
#define ADC3D 3
|
||||
#define ADC4D 4
|
||||
#define ADC5D 5
|
||||
|
||||
#define DIDR1 _SFR_MEM8(0x7F)
|
||||
#define AIN0D 0
|
||||
#define AIN1D 1
|
||||
|
||||
#define TCCR1A _SFR_MEM8(0x80)
|
||||
#define WGM10 0
|
||||
#define WGM11 1
|
||||
#define COM1B0 4
|
||||
#define COM1B1 5
|
||||
#define COM1A0 6
|
||||
#define COM1A1 7
|
||||
|
||||
#define TCCR1B _SFR_MEM8(0x81)
|
||||
#define CS10 0
|
||||
#define CS11 1
|
||||
#define CS12 2
|
||||
#define WGM12 3
|
||||
#define WGM13 4
|
||||
#define ICES1 6
|
||||
#define ICNC1 7
|
||||
|
||||
#define TCCR1C _SFR_MEM8(0x82)
|
||||
#define FOC1B 6
|
||||
#define FOC1A 7
|
||||
|
||||
#define TCNT1 _SFR_MEM16(0x84)
|
||||
|
||||
#define TCNT1L _SFR_MEM8(0x84)
|
||||
#define TCNT1L0 0
|
||||
#define TCNT1L1 1
|
||||
#define TCNT1L2 2
|
||||
#define TCNT1L3 3
|
||||
#define TCNT1L4 4
|
||||
#define TCNT1L5 5
|
||||
#define TCNT1L6 6
|
||||
#define TCNT1L7 7
|
||||
|
||||
#define TCNT1H _SFR_MEM8(0x85)
|
||||
#define TCNT1H0 0
|
||||
#define TCNT1H1 1
|
||||
#define TCNT1H2 2
|
||||
#define TCNT1H3 3
|
||||
#define TCNT1H4 4
|
||||
#define TCNT1H5 5
|
||||
#define TCNT1H6 6
|
||||
#define TCNT1H7 7
|
||||
|
||||
#define ICR1 _SFR_MEM16(0x86)
|
||||
|
||||
#define ICR1L _SFR_MEM8(0x86)
|
||||
#define ICR1L0 0
|
||||
#define ICR1L1 1
|
||||
#define ICR1L2 2
|
||||
#define ICR1L3 3
|
||||
#define ICR1L4 4
|
||||
#define ICR1L5 5
|
||||
#define ICR1L6 6
|
||||
#define ICR1L7 7
|
||||
|
||||
#define ICR1H _SFR_MEM8(0x87)
|
||||
#define ICR1H0 0
|
||||
#define ICR1H1 1
|
||||
#define ICR1H2 2
|
||||
#define ICR1H3 3
|
||||
#define ICR1H4 4
|
||||
#define ICR1H5 5
|
||||
#define ICR1H6 6
|
||||
#define ICR1H7 7
|
||||
|
||||
#define OCR1A _SFR_MEM16(0x88)
|
||||
|
||||
#define OCR1AL _SFR_MEM8(0x88)
|
||||
#define OCR1AL0 0
|
||||
#define OCR1AL1 1
|
||||
#define OCR1AL2 2
|
||||
#define OCR1AL3 3
|
||||
#define OCR1AL4 4
|
||||
#define OCR1AL5 5
|
||||
#define OCR1AL6 6
|
||||
#define OCR1AL7 7
|
||||
|
||||
#define OCR1AH _SFR_MEM8(0x89)
|
||||
#define OCR1AH0 0
|
||||
#define OCR1AH1 1
|
||||
#define OCR1AH2 2
|
||||
#define OCR1AH3 3
|
||||
#define OCR1AH4 4
|
||||
#define OCR1AH5 5
|
||||
#define OCR1AH6 6
|
||||
#define OCR1AH7 7
|
||||
|
||||
#define OCR1B _SFR_MEM16(0x8A)
|
||||
|
||||
#define OCR1BL _SFR_MEM8(0x8A)
|
||||
#define OCR1BL0 0
|
||||
#define OCR1BL1 1
|
||||
#define OCR1BL2 2
|
||||
#define OCR1BL3 3
|
||||
#define OCR1BL4 4
|
||||
#define OCR1BL5 5
|
||||
#define OCR1BL6 6
|
||||
#define OCR1BL7 7
|
||||
|
||||
#define OCR1BH _SFR_MEM8(0x8B)
|
||||
#define OCR1BH0 0
|
||||
#define OCR1BH1 1
|
||||
#define OCR1BH2 2
|
||||
#define OCR1BH3 3
|
||||
#define OCR1BH4 4
|
||||
#define OCR1BH5 5
|
||||
#define OCR1BH6 6
|
||||
#define OCR1BH7 7
|
||||
|
||||
#define TCCR2A _SFR_MEM8(0xB0)
|
||||
#define WGM20 0
|
||||
#define WGM21 1
|
||||
#define COM2B0 4
|
||||
#define COM2B1 5
|
||||
#define COM2A0 6
|
||||
#define COM2A1 7
|
||||
|
||||
#define TCCR2B _SFR_MEM8(0xB1)
|
||||
#define CS20 0
|
||||
#define CS21 1
|
||||
#define CS22 2
|
||||
#define WGM22 3
|
||||
#define FOC2B 6
|
||||
#define FOC2A 7
|
||||
|
||||
#define TCNT2 _SFR_MEM8(0xB2)
|
||||
#define TCNT2_0 0
|
||||
#define TCNT2_1 1
|
||||
#define TCNT2_2 2
|
||||
#define TCNT2_3 3
|
||||
#define TCNT2_4 4
|
||||
#define TCNT2_5 5
|
||||
#define TCNT2_6 6
|
||||
#define TCNT2_7 7
|
||||
|
||||
#define OCR2A _SFR_MEM8(0xB3)
|
||||
#define OCR2_0 0
|
||||
#define OCR2_1 1
|
||||
#define OCR2_2 2
|
||||
#define OCR2_3 3
|
||||
#define OCR2_4 4
|
||||
#define OCR2_5 5
|
||||
#define OCR2_6 6
|
||||
#define OCR2_7 7
|
||||
|
||||
#define OCR2B _SFR_MEM8(0xB4)
|
||||
#define OCR2_0 0
|
||||
#define OCR2_1 1
|
||||
#define OCR2_2 2
|
||||
#define OCR2_3 3
|
||||
#define OCR2_4 4
|
||||
#define OCR2_5 5
|
||||
#define OCR2_6 6
|
||||
#define OCR2_7 7
|
||||
|
||||
#define ASSR _SFR_MEM8(0xB6)
|
||||
#define TCR2BUB 0
|
||||
#define TCR2AUB 1
|
||||
#define OCR2BUB 2
|
||||
#define OCR2AUB 3
|
||||
#define TCN2UB 4
|
||||
#define AS2 5
|
||||
#define EXCLK 6
|
||||
|
||||
#define TWBR _SFR_MEM8(0xB8)
|
||||
#define TWBR0 0
|
||||
#define TWBR1 1
|
||||
#define TWBR2 2
|
||||
#define TWBR3 3
|
||||
#define TWBR4 4
|
||||
#define TWBR5 5
|
||||
#define TWBR6 6
|
||||
#define TWBR7 7
|
||||
|
||||
#define TWSR _SFR_MEM8(0xB9)
|
||||
#define TWPS0 0
|
||||
#define TWPS1 1
|
||||
#define TWS3 3
|
||||
#define TWS4 4
|
||||
#define TWS5 5
|
||||
#define TWS6 6
|
||||
#define TWS7 7
|
||||
|
||||
#define TWAR _SFR_MEM8(0xBA)
|
||||
#define TWGCE 0
|
||||
#define TWA0 1
|
||||
#define TWA1 2
|
||||
#define TWA2 3
|
||||
#define TWA3 4
|
||||
#define TWA4 5
|
||||
#define TWA5 6
|
||||
#define TWA6 7
|
||||
|
||||
#define TWDR _SFR_MEM8(0xBB)
|
||||
#define TWD0 0
|
||||
#define TWD1 1
|
||||
#define TWD2 2
|
||||
#define TWD3 3
|
||||
#define TWD4 4
|
||||
#define TWD5 5
|
||||
#define TWD6 6
|
||||
#define TWD7 7
|
||||
|
||||
#define TWCR _SFR_MEM8(0xBC)
|
||||
#define TWIE 0
|
||||
#define TWEN 2
|
||||
#define TWWC 3
|
||||
#define TWSTO 4
|
||||
#define TWSTA 5
|
||||
#define TWEA 6
|
||||
#define TWINT 7
|
||||
|
||||
#define TWAMR _SFR_MEM8(0xBD)
|
||||
#define TWAM0 0
|
||||
#define TWAM1 1
|
||||
#define TWAM2 2
|
||||
#define TWAM3 3
|
||||
#define TWAM4 4
|
||||
#define TWAM5 5
|
||||
#define TWAM6 6
|
||||
|
||||
#define UCSR0A _SFR_MEM8(0xC0)
|
||||
#define MPCM0 0
|
||||
#define U2X0 1
|
||||
#define UPE0 2
|
||||
#define DOR0 3
|
||||
#define FE0 4
|
||||
#define UDRE0 5
|
||||
#define TXC0 6
|
||||
#define RXC0 7
|
||||
|
||||
#define UCSR0B _SFR_MEM8(0xC1)
|
||||
#define TXB80 0
|
||||
#define RXB80 1
|
||||
#define UCSZ02 2
|
||||
#define TXEN0 3
|
||||
#define RXEN0 4
|
||||
#define UDRIE0 5
|
||||
#define TXCIE0 6
|
||||
#define RXCIE0 7
|
||||
|
||||
#define UCSR0C _SFR_MEM8(0xC2)
|
||||
#define UCPOL0 0
|
||||
#define UCSZ00 1
|
||||
#define UCPHA0 1
|
||||
#define UCSZ01 2
|
||||
#define UDORD0 2
|
||||
#define USBS0 3
|
||||
#define UPM00 4
|
||||
#define UPM01 5
|
||||
#define UMSEL00 6
|
||||
#define UMSEL01 7
|
||||
|
||||
#define UBRR0 _SFR_MEM16(0xC4)
|
||||
|
||||
#define UBRR0L _SFR_MEM8(0xC4)
|
||||
#define UBRR0_0 0
|
||||
#define UBRR0_1 1
|
||||
#define UBRR0_2 2
|
||||
#define UBRR0_3 3
|
||||
#define UBRR0_4 4
|
||||
#define UBRR0_5 5
|
||||
#define UBRR0_6 6
|
||||
#define UBRR0_7 7
|
||||
|
||||
#define UBRR0H _SFR_MEM8(0xC5)
|
||||
#define UBRR0_8 0
|
||||
#define UBRR0_9 1
|
||||
#define UBRR0_10 2
|
||||
#define UBRR0_11 3
|
||||
|
||||
#define UDR0 _SFR_MEM8(0xC6)
|
||||
#define UDR0_0 0
|
||||
#define UDR0_1 1
|
||||
#define UDR0_2 2
|
||||
#define UDR0_3 3
|
||||
#define UDR0_4 4
|
||||
#define UDR0_5 5
|
||||
#define UDR0_6 6
|
||||
#define UDR0_7 7
|
||||
|
||||
|
||||
|
||||
/* Interrupt Vectors */
|
||||
/* Interrupt Vector 0 is the reset vector. */
|
||||
#define INT0_vect _VECTOR(1) /* External Interrupt Request 0 */
|
||||
#define INT1_vect _VECTOR(2) /* External Interrupt Request 1 */
|
||||
#define PCINT0_vect _VECTOR(3) /* Pin Change Interrupt Request 0 */
|
||||
#define PCINT1_vect _VECTOR(4) /* Pin Change Interrupt Request 0 */
|
||||
#define PCINT2_vect _VECTOR(5) /* Pin Change Interrupt Request 1 */
|
||||
#define WDT_vect _VECTOR(6) /* Watchdog Time-out Interrupt */
|
||||
#define TIMER2_COMPA_vect _VECTOR(7) /* Timer/Counter2 Compare Match A */
|
||||
#define TIMER2_COMPB_vect _VECTOR(8) /* Timer/Counter2 Compare Match A */
|
||||
#define TIMER2_OVF_vect _VECTOR(9) /* Timer/Counter2 Overflow */
|
||||
#define TIMER1_CAPT_vect _VECTOR(10) /* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_COMPA_vect _VECTOR(11) /* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPB_vect _VECTOR(12) /* Timer/Counter1 Compare Match B */
|
||||
#define TIMER1_OVF_vect _VECTOR(13) /* Timer/Counter1 Overflow */
|
||||
#define TIMER0_COMPA_vect _VECTOR(14) /* TimerCounter0 Compare Match A */
|
||||
#define TIMER0_COMPB_vect _VECTOR(15) /* TimerCounter0 Compare Match B */
|
||||
#define TIMER0_OVF_vect _VECTOR(16) /* Timer/Couner0 Overflow */
|
||||
#define SPI_STC_vect _VECTOR(17) /* SPI Serial Transfer Complete */
|
||||
#define USART_RX_vect _VECTOR(18) /* USART Rx Complete */
|
||||
#define USART_UDRE_vect _VECTOR(19) /* USART, Data Register Empty */
|
||||
#define USART_TX_vect _VECTOR(20) /* USART Tx Complete */
|
||||
#define ADC_vect _VECTOR(21) /* ADC Conversion Complete */
|
||||
#define EE_READY_vect _VECTOR(22) /* EEPROM Ready */
|
||||
#define ANALOG_COMP_vect _VECTOR(23) /* Analog Comparator */
|
||||
#define TWI_vect _VECTOR(24) /* Two-wire Serial Interface */
|
||||
#define SPM_READY_vect _VECTOR(25) /* Store Program Memory Read */
|
||||
|
||||
#define _VECTORS_SIZE (26 * 4)
|
||||
|
||||
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 128
|
||||
#define RAMEND 0x8FF /* Last On-Chip SRAM Location */
|
||||
#define XRAMSIZE 0
|
||||
#define XRAMEND (RAMEND + XRAMSIZE)
|
||||
#define E2END 0x3FF
|
||||
#define E2PAGESIZE 4
|
||||
#define FLASHEND 0x7FFF
|
||||
|
||||
|
||||
|
||||
/* Fuses */
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0) /* Select Clock Source */
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1) /* Select Clock Source */
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2) /* Select Clock Source */
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3) /* Select Clock Source */
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4) /* Select start-up time */
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5) /* Select start-up time */
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6) /* Clock output */
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7) /* Divide clock by 8 */
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(0) /* Brown-out Detector trigger level */
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(1) /* Brown-out Detector trigger level */
|
||||
#define FUSE_BODLEVEL2 (unsigned char)~_BV(2) /* Brown-out Detector trigger level */
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3) /* EEPROM memory is preserved through chip erase */
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4) /* Watchdog Timer Always On */
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5) /* Enable Serial programming and Data Downloading */
|
||||
#define FUSE_DWEN (unsigned char)~_BV(6) /* debugWIRE Enable */
|
||||
#define FUSE_RSTDISBL (unsigned char)~_BV(7) /* External reset disable */
|
||||
#define HFUSE_DEFAULT (FUSE_SPIEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define EFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1)
|
||||
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x95
|
||||
#define SIGNATURE_2 0x0F
|
||||
|
||||
|
||||
#endif /* _AVR_IOM328P_H_ */
|
1003
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom329.h
Normal file
1003
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom329.h
Normal file
File diff suppressed because it is too large
Load diff
1155
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom3290.h
Normal file
1155
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom3290.h
Normal file
File diff suppressed because it is too large
Load diff
1146
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom32c1.h
Normal file
1146
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom32c1.h
Normal file
File diff suppressed because it is too large
Load diff
|
@ -0,0 +1,885 @@
|
|||
/* Copyright (c) 2007 Atmel Corporation
|
||||
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: iom32hvb.h,v 1.3.2.4 2008/08/06 22:45:05 arcanum Exp $ */
|
||||
|
||||
/* avr/iom32hvb.h - definitions for ATmega32HVB. */
|
||||
|
||||
/* 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_ "iom32hvb.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
|
||||
#ifndef _AVR_IOM32HVB_H_
|
||||
#define _AVR_IOM32HVB_H_ 1
|
||||
|
||||
/* Registers and associated bit numbers */
|
||||
|
||||
#define PINA _SFR_IO8(0x00)
|
||||
#define PINA0 0
|
||||
#define PINA1 1
|
||||
#define PINA2 2
|
||||
#define PINA3 3
|
||||
|
||||
#define DDRA _SFR_IO8(0x01)
|
||||
#define DDA0 0
|
||||
#define DDA1 1
|
||||
#define DDA2 2
|
||||
#define DDA3 3
|
||||
|
||||
#define PORTA _SFR_IO8(0x02)
|
||||
#define PORTA0 0
|
||||
#define PORTA1 1
|
||||
#define PORTA2 2
|
||||
#define PORTA3 3
|
||||
|
||||
#define PINB _SFR_IO8(0x03)
|
||||
#define PINB0 0
|
||||
#define PINB1 1
|
||||
#define PINB2 2
|
||||
#define PINB3 3
|
||||
#define PINB4 4
|
||||
#define PINB5 5
|
||||
#define PINB6 6
|
||||
#define PINB7 7
|
||||
|
||||
#define DDRB _SFR_IO8(0x04)
|
||||
#define DDB0 0
|
||||
#define DDB1 1
|
||||
#define DDB2 2
|
||||
#define DDB3 3
|
||||
#define DDB4 4
|
||||
#define DDB5 5
|
||||
#define DDB6 6
|
||||
#define DDB7 7
|
||||
|
||||
#define PORTB _SFR_IO8(0x05)
|
||||
#define PORTB0 0
|
||||
#define PORTB1 1
|
||||
#define PORTB2 2
|
||||
#define PORTB3 3
|
||||
#define PORTB4 4
|
||||
#define PORTB5 5
|
||||
#define PORTB6 6
|
||||
#define PORTB7 7
|
||||
|
||||
#define PINC _SFR_IO8(0x06)
|
||||
#define PINC0 0
|
||||
#define PINC1 1
|
||||
#define PINC2 2
|
||||
#define PINC3 3
|
||||
#define PINC4 4
|
||||
|
||||
#define PORTC _SFR_IO8(0x08)
|
||||
#define PORTC0 0
|
||||
#define PORTC1 1
|
||||
#define PORTC2 2
|
||||
#define PORTC3 3
|
||||
#define PORTC4 4
|
||||
#define PORTC5 5
|
||||
|
||||
#define TIFR0 _SFR_IO8(0x15)
|
||||
#define TOV0 0
|
||||
#define OCF0A 1
|
||||
#define OCF0B 2
|
||||
#define ICF0 3
|
||||
|
||||
#define TIFR1 _SFR_IO8(0x16)
|
||||
#define TOV1 0
|
||||
#define OCF1A 1
|
||||
#define OCF1B 2
|
||||
#define ICF1 3
|
||||
|
||||
#define OSICSR _SFR_IO8(0x17)
|
||||
#define OSIEN 0
|
||||
#define OSIST 1
|
||||
#define OSISEL0 4
|
||||
|
||||
#define PCIFR _SFR_IO8(0x1B)
|
||||
#define PCIF0 0
|
||||
#define PCIF1 1
|
||||
|
||||
#define EIFR _SFR_IO8(0x1C)
|
||||
#define INTF0 0
|
||||
#define INTF1 1
|
||||
#define INTF2 2
|
||||
#define INTF3 3
|
||||
|
||||
#define EIMSK _SFR_IO8(0x1D)
|
||||
#define INT0 0
|
||||
#define INT1 1
|
||||
#define INT2 2
|
||||
#define INT3 3
|
||||
|
||||
#define GPIOR0 _SFR_IO8(0x1E)
|
||||
#define GPIOR00 0
|
||||
#define GPIOR01 1
|
||||
#define GPIOR02 2
|
||||
#define GPIOR03 3
|
||||
#define GPIOR04 4
|
||||
#define GPIOR05 5
|
||||
#define GPIOR06 6
|
||||
#define GPIOR07 7
|
||||
|
||||
#define EECR _SFR_IO8(0x1F)
|
||||
#define EERE 0
|
||||
#define EEPE 1
|
||||
#define EEMPE 2
|
||||
#define EERIE 3
|
||||
#define EEPM0 4
|
||||
#define EEPM1 5
|
||||
|
||||
#define EEDR _SFR_IO8(0x20)
|
||||
#define EEDR0 0
|
||||
#define EEDR1 1
|
||||
#define EEDR2 2
|
||||
#define EEDR3 3
|
||||
#define EEDR4 4
|
||||
#define EEDR5 5
|
||||
#define EEDR6 6
|
||||
#define EEDR7 7
|
||||
|
||||
#define EEAR _SFR_IO16(0x21)
|
||||
|
||||
#define EEARL _SFR_IO8(0x21)
|
||||
#define EEAR0 0
|
||||
#define EEAR1 1
|
||||
#define EEAR2 2
|
||||
#define EEAR3 3
|
||||
#define EEAR4 4
|
||||
#define EEAR5 5
|
||||
#define EEAR6 6
|
||||
#define EEAR7 7
|
||||
|
||||
#define EEARH _SFR_IO8(0x22)
|
||||
#define EEAR8 0
|
||||
#define EEAR9 1
|
||||
|
||||
#define GTCCR _SFR_IO8(0x23)
|
||||
#define PSRSYNC 0
|
||||
#define TSM 7
|
||||
|
||||
#define TCCR0A _SFR_IO8(0x24)
|
||||
#define WGM00 0
|
||||
#define ICS0 3
|
||||
#define ICES0 4
|
||||
#define ICNC0 5
|
||||
#define ICEN0 6
|
||||
#define TCW0 7
|
||||
|
||||
#define TCCR0B _SFR_IO8(0x25)
|
||||
#define CS00 0
|
||||
#define CS01 1
|
||||
#define CS02 2
|
||||
|
||||
#define TCNT0 _SFR_IO16(0x26)
|
||||
|
||||
#define TCNT0L _SFR_IO8(0x26)
|
||||
#define TCNT0L0 0
|
||||
#define TCNT0L1 1
|
||||
#define TCNT0L2 2
|
||||
#define TCNT0L3 3
|
||||
#define TCNT0L4 4
|
||||
#define TCNT0L5 5
|
||||
#define TCNT0L6 6
|
||||
#define TCNT0L7 7
|
||||
|
||||
#define TCNT0H _SFR_IO8(0x27)
|
||||
#define TCNT0H0 0
|
||||
#define TCNT0H1 1
|
||||
#define TCNT0H2 2
|
||||
#define TCNT0H3 3
|
||||
#define TCNT0H4 4
|
||||
#define TCNT0H5 5
|
||||
#define TCNT0H6 6
|
||||
#define TCNT0H7 7
|
||||
|
||||
#define OCR0A _SFR_IO8(0x28)
|
||||
#define OCR0A0 0
|
||||
#define OCR0A1 1
|
||||
#define OCR0A2 2
|
||||
#define OCR0A3 3
|
||||
#define OCR0A4 4
|
||||
#define OCR0A5 5
|
||||
#define OCR0A6 6
|
||||
#define OCR0A7 7
|
||||
|
||||
#define OCR0B _SFR_IO8(0x29)
|
||||
#define OCR0B0 0
|
||||
#define OCR0B1 1
|
||||
#define OCR0B2 2
|
||||
#define OCR0B3 3
|
||||
#define OCR0B4 4
|
||||
#define OCR0B5 5
|
||||
#define OCR0B6 6
|
||||
#define OCR0B7 7
|
||||
|
||||
#define GPIOR1 _SFR_IO8(0x2A)
|
||||
#define GPIOR10 0
|
||||
#define GPIOR11 1
|
||||
#define GPIOR12 2
|
||||
#define GPIOR13 3
|
||||
#define GPIOR14 4
|
||||
#define GPIOR15 5
|
||||
#define GPIOR16 6
|
||||
#define GPIOR17 7
|
||||
|
||||
#define GPIOR2 _SFR_IO8(0x2B)
|
||||
#define GPIOR20 0
|
||||
#define GPIOR21 1
|
||||
#define GPIOR22 2
|
||||
#define GPIOR23 3
|
||||
#define GPIOR24 4
|
||||
#define GPIOR25 5
|
||||
#define GPIOR26 6
|
||||
#define GPIOR27 7
|
||||
|
||||
#define SPCR _SFR_IO8(0x2C)
|
||||
#define SPR0 0
|
||||
#define SPR1 1
|
||||
#define CPHA 2
|
||||
#define CPOL 3
|
||||
#define MSTR 4
|
||||
#define DORD 5
|
||||
#define SPE 6
|
||||
#define SPIE 7
|
||||
|
||||
#define SPSR _SFR_IO8(0x2D)
|
||||
#define SPI2X 0
|
||||
#define WCOL 6
|
||||
#define SPIF 7
|
||||
|
||||
#define SPDR _SFR_IO8(0x2E)
|
||||
#define SPDR0 0
|
||||
#define SPDR1 1
|
||||
#define SPDR2 2
|
||||
#define SPDR3 3
|
||||
#define SPDR4 4
|
||||
#define SPDR5 5
|
||||
#define SPDR6 6
|
||||
#define SPDR7 7
|
||||
|
||||
#define SMCR _SFR_IO8(0x33)
|
||||
#define SE 0
|
||||
#define SM0 1
|
||||
#define SM1 2
|
||||
#define SM2 3
|
||||
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
#define PORF 0
|
||||
#define EXTRF 1
|
||||
#define BODRF 2
|
||||
#define WDRF 3
|
||||
#define OCDRF 4
|
||||
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
#define IVCE 0
|
||||
#define IVSEL 1
|
||||
#define PUD 4
|
||||
#define CKOE 5
|
||||
|
||||
#define SPMCSR _SFR_IO8(0x37)
|
||||
#define SPMEN 0
|
||||
#define PGERS 1
|
||||
#define PGWRT 2
|
||||
#define LBSET 3
|
||||
#define RWWSRE 4
|
||||
#define SIGRD 5
|
||||
#define RWWSB 6
|
||||
#define SPMIE 7
|
||||
|
||||
#define WDTCSR _SFR_MEM8(0x60)
|
||||
#define WDP0 0
|
||||
#define WDP1 1
|
||||
#define WDP2 2
|
||||
#define WDE 3
|
||||
#define WDCE 4
|
||||
#define WDP3 5
|
||||
#define WDIE 6
|
||||
#define WDIF 7
|
||||
|
||||
#define CLKPR _SFR_MEM8(0x61)
|
||||
#define CLKPS0 0
|
||||
#define CLKPS1 1
|
||||
#define CLKPCE 7
|
||||
|
||||
#define PRR0 _SFR_MEM8(0x64)
|
||||
#define PRVADC 0
|
||||
#define PRTIM0 1
|
||||
#define PRTIM1 2
|
||||
#define PRSPI 3
|
||||
#define PRVRM 5
|
||||
#define PRTWI 6
|
||||
|
||||
#define FOSCCAL _SFR_MEM8(0x66)
|
||||
#define FCAL0 0
|
||||
#define FCAL1 1
|
||||
#define FCAL2 2
|
||||
#define FCAL3 3
|
||||
#define FCAL4 4
|
||||
#define FCAL5 5
|
||||
#define FCAL6 6
|
||||
#define FCAL7 7
|
||||
|
||||
#define PCICR _SFR_MEM8(0x68)
|
||||
#define PCIE0 0
|
||||
#define PCIE1 1
|
||||
|
||||
#define EICRA _SFR_MEM8(0x69)
|
||||
#define ISC00 0
|
||||
#define ISC01 1
|
||||
#define ISC10 2
|
||||
#define ISC11 3
|
||||
#define ISC20 4
|
||||
#define ISC21 5
|
||||
#define ISC30 6
|
||||
#define ISC31 7
|
||||
|
||||
#define PCMSK0 _SFR_MEM8(0x6B)
|
||||
#define PCINT0 0
|
||||
#define PCINT1 1
|
||||
#define PCINT2 2
|
||||
#define PCINT3 3
|
||||
|
||||
#define PCMSK1 _SFR_MEM8(0x6C)
|
||||
#define PCINT4 0
|
||||
#define PCINT5 1
|
||||
#define PCINT6 2
|
||||
#define PCINT7 3
|
||||
#define PCINT8 4
|
||||
#define PCINT9 5
|
||||
#define PCINT10 6
|
||||
#define PCINT11 7
|
||||
|
||||
#define TIMSK0 _SFR_MEM8(0x6E)
|
||||
#define TOIE0 0
|
||||
#define OCIE0A 1
|
||||
#define OCIE0B 2
|
||||
#define ICIE0 3
|
||||
|
||||
#define TIMSK1 _SFR_MEM8(0x6F)
|
||||
#define TOIE1 0
|
||||
#define OCIE1A 1
|
||||
#define OCIE1B 2
|
||||
#define ICIE1 3
|
||||
|
||||
#define VADC _SFR_MEM16(0x78)
|
||||
|
||||
#define VADCL _SFR_MEM8(0x78)
|
||||
#define VADC0 0
|
||||
#define VADC1 1
|
||||
#define VADC2 2
|
||||
#define VADC3 3
|
||||
#define VADC4 4
|
||||
#define VADC5 5
|
||||
#define VADC6 6
|
||||
#define VADC7 7
|
||||
|
||||
#define VADCH _SFR_MEM8(0x79)
|
||||
#define VADC8 0
|
||||
#define VADC9 1
|
||||
#define VADC10 2
|
||||
#define VADC11 3
|
||||
|
||||
#define VADCSR _SFR_MEM8(0x7A)
|
||||
#define VADCCIE 0
|
||||
#define VADCCIF 1
|
||||
#define VADSC 2
|
||||
#define VADEN 3
|
||||
|
||||
#define VADMUX _SFR_MEM8(0x7C)
|
||||
#define VADMUX0 0
|
||||
#define VADMUX1 1
|
||||
#define VADMUX2 2
|
||||
#define VADMUX3 3
|
||||
|
||||
#define DIDR0 _SFR_MEM8(0x7E)
|
||||
#define PA0DID 0
|
||||
#define PA1DID 1
|
||||
|
||||
#define TCCR1A _SFR_MEM8(0x80)
|
||||
#define WGM10 0
|
||||
#define ICS1 3
|
||||
#define ICES1 4
|
||||
#define ICNC1 5
|
||||
#define ICEN1 6
|
||||
#define TCW1 7
|
||||
|
||||
#define TCCR1B _SFR_MEM8(0x81)
|
||||
#define CS10 0
|
||||
#define CS11 1
|
||||
#define CS12 2
|
||||
|
||||
#define TCNT1 _SFR_MEM16(0x84)
|
||||
|
||||
#define TCNT1L _SFR_MEM8(0x84)
|
||||
#define TCNT1L0 0
|
||||
#define TCNT1L1 1
|
||||
#define TCNT1L2 2
|
||||
#define TCNT1L3 3
|
||||
#define TCNT1L4 4
|
||||
#define TCNT1L5 5
|
||||
#define TCNT1L6 6
|
||||
#define TCNT1L7 7
|
||||
|
||||
#define TCNT1H _SFR_MEM8(0x85)
|
||||
#define TCNT1H0 0
|
||||
#define TCNT1H1 1
|
||||
#define TCNT1H2 2
|
||||
#define TCNT1H3 3
|
||||
#define TCNT1H4 4
|
||||
#define TCNT1H5 5
|
||||
#define TCNT1H6 6
|
||||
#define TCNT1H7 7
|
||||
|
||||
#define OCR1A _SFR_MEM8(0x88)
|
||||
#define OCR1A0 0
|
||||
#define OCR1A1 1
|
||||
#define OCR1A2 2
|
||||
#define OCR1A3 3
|
||||
#define OCR1A4 4
|
||||
#define OCR1A5 5
|
||||
#define OCR1A6 6
|
||||
#define OCR1A7 7
|
||||
|
||||
#define OCR1B _SFR_MEM8(0x89)
|
||||
#define OCR1B0 0
|
||||
#define OCR1B1 1
|
||||
#define OCR1B2 2
|
||||
#define OCR1B3 3
|
||||
#define OCR1B4 4
|
||||
#define OCR1B5 5
|
||||
#define OCR1B6 6
|
||||
#define OCR1B7 7
|
||||
|
||||
#define TWBR _SFR_MEM8(0xB8)
|
||||
#define TWBR0 0
|
||||
#define TWBR1 1
|
||||
#define TWBR2 2
|
||||
#define TWBR3 3
|
||||
#define TWBR4 4
|
||||
#define TWBR5 5
|
||||
#define TWBR6 6
|
||||
#define TWBR7 7
|
||||
|
||||
#define TWSR _SFR_MEM8(0xB9)
|
||||
#define TWPS0 0
|
||||
#define TWPS1 1
|
||||
#define TWS3 3
|
||||
#define TWS4 4
|
||||
#define TWS5 5
|
||||
#define TWS6 6
|
||||
#define TWS7 7
|
||||
|
||||
#define TWAR _SFR_MEM8(0xBA)
|
||||
#define TWGCE 0
|
||||
#define TWA0 1
|
||||
#define TWA1 2
|
||||
#define TWA2 3
|
||||
#define TWA3 4
|
||||
#define TWA4 5
|
||||
#define TWA5 6
|
||||
#define TWA6 7
|
||||
|
||||
#define TWDR _SFR_MEM8(0xBB)
|
||||
#define TWD0 0
|
||||
#define TWD1 1
|
||||
#define TWD2 2
|
||||
#define TWD3 3
|
||||
#define TWD4 4
|
||||
#define TWD5 5
|
||||
#define TWD6 6
|
||||
#define TWD7 7
|
||||
|
||||
#define TWCR _SFR_MEM8(0xBC)
|
||||
#define TWIE 0
|
||||
#define TWEN 2
|
||||
#define TWWC 3
|
||||
#define TWSTO 4
|
||||
#define TWSTA 5
|
||||
#define TWEA 6
|
||||
#define TWINT 7
|
||||
|
||||
#define TWAMR _SFR_MEM8(0xBD)
|
||||
#define TWAM0 0
|
||||
#define TWAM1 1
|
||||
#define TWAM2 2
|
||||
#define TWAM3 3
|
||||
#define TWAM4 4
|
||||
#define TWAM5 5
|
||||
#define TWAM6 6
|
||||
|
||||
#define TWBCSR _SFR_MEM8(0xBE)
|
||||
#define TWBCIP 0
|
||||
#define TWBDT0 1
|
||||
#define TWBDT1 2
|
||||
#define TWBCIE 6
|
||||
#define TWBCIF 7
|
||||
|
||||
#define ROCR _SFR_MEM8(0xC8)
|
||||
#define ROCWIE 0
|
||||
#define ROCWIF 1
|
||||
#define ROCD 4
|
||||
#define ROCS 7
|
||||
|
||||
#define BGCCR _SFR_MEM8(0xD0)
|
||||
#define BGCC0 0
|
||||
#define BGCC1 1
|
||||
#define BGCC2 2
|
||||
#define BGCC3 3
|
||||
#define BGCC4 4
|
||||
#define BGCC5 5
|
||||
|
||||
#define BGCRR _SFR_MEM8(0xD1)
|
||||
#define BGCR0 0
|
||||
#define BGCR1 1
|
||||
#define BGCR2 2
|
||||
#define BGCR3 3
|
||||
#define BGCR4 4
|
||||
#define BGCR5 5
|
||||
#define BGCR6 6
|
||||
#define BGCR7 7
|
||||
|
||||
#define BGCSR _SFR_MEM8(0xD2)
|
||||
#define BGSCDIE 0
|
||||
#define BGSCDIF 1
|
||||
#define BGSCDE 4
|
||||
#define BGD 5
|
||||
|
||||
#define CHGDCSR _SFR_MEM8(0xD4)
|
||||
#define CHGDIE 0
|
||||
#define CHGDIF 1
|
||||
#define CHGDISC0 2
|
||||
#define CHGDISC1 3
|
||||
#define BATTPVL 4
|
||||
|
||||
#define CADAC _SFR_MEM32(0xE0)
|
||||
|
||||
#define CADAC0 _SFR_MEM8(0xE0)
|
||||
#define CADAC00 0
|
||||
#define CADAC01 1
|
||||
#define CADAC02 2
|
||||
#define CADAC03 3
|
||||
#define CADAC04 4
|
||||
#define CADAC05 5
|
||||
#define CADAC06 6
|
||||
#define CADAC07 7
|
||||
|
||||
#define CADAC1 _SFR_MEM8(0xE1)
|
||||
#define CADAC08 0
|
||||
#define CADAC09 1
|
||||
#define CADAC10 2
|
||||
#define CADAC11 3
|
||||
#define CADAC12 4
|
||||
#define CADAC13 5
|
||||
#define CADAC14 6
|
||||
#define CADAC15 7
|
||||
|
||||
#define CADAC2 _SFR_MEM8(0xE2)
|
||||
#define CADAC16 0
|
||||
#define CADAC17 1
|
||||
#define CADAC18 2
|
||||
#define CADAC19 3
|
||||
#define CADAC20 4
|
||||
#define CADAC21 5
|
||||
#define CADAC22 6
|
||||
#define CADAC23 7
|
||||
|
||||
#define CADAC3 _SFR_MEM8(0xE3)
|
||||
#define CADAC24 0
|
||||
#define CADAC25 1
|
||||
#define CADAC26 2
|
||||
#define CADAC27 3
|
||||
#define CADAC28 4
|
||||
#define CADAC29 5
|
||||
#define CADAC30 6
|
||||
#define CADAC31 7
|
||||
|
||||
#define CADIC _SFR_MEM16(0xE4)
|
||||
|
||||
#define CADICL _SFR_MEM8(0xE4)
|
||||
#define CADICL0 0
|
||||
#define CADICL1 1
|
||||
#define CADICL2 2
|
||||
#define CADICL3 3
|
||||
#define CADICL4 4
|
||||
#define CADICL5 5
|
||||
#define CADICL6 6
|
||||
#define CADICL7 7
|
||||
|
||||
#define CADICH _SFR_MEM8(0xE5)
|
||||
#define CADICH0 0
|
||||
#define CADICH1 1
|
||||
#define CADICH2 2
|
||||
#define CADICH3 3
|
||||
#define CADICH4 4
|
||||
#define CADICH5 5
|
||||
#define CADICH6 6
|
||||
#define CADICH7 7
|
||||
|
||||
#define CADCSRA _SFR_MEM8(0xE6)
|
||||
#define CADSE 0
|
||||
#define CADSI0 1
|
||||
#define CADSI1 2
|
||||
#define CADAS0 3
|
||||
#define CADAS1 4
|
||||
#define CADUB 5
|
||||
#define CADPOL 6
|
||||
#define CADEN 7
|
||||
|
||||
#define CADCSRB _SFR_MEM8(0xE7)
|
||||
#define CADICIF 0
|
||||
#define CADRCIF 1
|
||||
#define CADACIF 2
|
||||
#define CADICIE 4
|
||||
#define CADRCIE 5
|
||||
#define CADACIE 6
|
||||
|
||||
#define CADCSRC _SFR_MEM8(0xE8)
|
||||
#define CADVSE 0
|
||||
|
||||
#define CADRCC _SFR_MEM8(0xE9)
|
||||
#define CADRCC0 0
|
||||
#define CADRCC1 1
|
||||
#define CADRCC2 2
|
||||
#define CADRCC3 3
|
||||
#define CADRCC4 4
|
||||
#define CADRCC5 5
|
||||
#define CADRCC6 6
|
||||
#define CADRCC7 7
|
||||
|
||||
#define CADRDC _SFR_MEM8(0xEA)
|
||||
#define CADRDC0 0
|
||||
#define CADRDC1 1
|
||||
#define CADRDC2 2
|
||||
#define CADRDC3 3
|
||||
#define CADRDC4 4
|
||||
#define CADRDC5 5
|
||||
#define CADRDC6 6
|
||||
#define CADRDC7 7
|
||||
|
||||
#define FCSR _SFR_MEM8(0xF0)
|
||||
#define CFE 0
|
||||
#define DFE 1
|
||||
#define CPS 2
|
||||
#define DUVRD 3
|
||||
|
||||
#define CBCR _SFR_MEM8(0xF1)
|
||||
#define CBE1 0
|
||||
#define CBE2 1
|
||||
#define CBE3 2
|
||||
#define CBE4 3
|
||||
|
||||
#define BPIMSK _SFR_MEM8(0xF2)
|
||||
#define CHCIE 0
|
||||
#define DHCIE 1
|
||||
#define COCIE 2
|
||||
#define DOCIE 3
|
||||
#define SCIE 4
|
||||
|
||||
#define BPIFR _SFR_MEM8(0xF3)
|
||||
#define CHCIF 0
|
||||
#define DHCIF 1
|
||||
#define COCIF 2
|
||||
#define DOCIF 3
|
||||
#define SCIF 4
|
||||
|
||||
#define BPSCD _SFR_MEM8(0xF5)
|
||||
#define SCDL0 0
|
||||
#define SCDL1 1
|
||||
#define SCDL2 2
|
||||
#define SCDL3 3
|
||||
#define SCDL4 4
|
||||
#define SCDL5 5
|
||||
#define SCDL6 6
|
||||
#define SCDL7 7
|
||||
|
||||
#define BPDOCD _SFR_MEM8(0xF6)
|
||||
#define DOCDL0 0
|
||||
#define DOCDL1 1
|
||||
#define DOCDL2 2
|
||||
#define DOCDL3 3
|
||||
#define DOCDL4 4
|
||||
#define DOCDL5 5
|
||||
#define DOCDL6 6
|
||||
#define DOCDL7 7
|
||||
|
||||
#define BPCOCD _SFR_MEM8(0xF7)
|
||||
#define COCDL0 0
|
||||
#define COCDL1 1
|
||||
#define COCDL2 2
|
||||
#define COCDL3 3
|
||||
#define COCDL4 4
|
||||
#define COCDL5 5
|
||||
#define COCDL6 6
|
||||
#define COCDL7 7
|
||||
|
||||
#define BPDHCD _SFR_MEM8(0xF8)
|
||||
#define DHCDL0 0
|
||||
#define DHCDL1 1
|
||||
#define DHCDL2 2
|
||||
#define DHCDL3 3
|
||||
#define DHCDL4 4
|
||||
#define DHCDL5 5
|
||||
#define DHCDL6 6
|
||||
#define DHCDL7 7
|
||||
|
||||
#define BPCHCD _SFR_MEM8(0xF9)
|
||||
#define CHCDL0 0
|
||||
#define CHCDL1 1
|
||||
#define CHCDL2 2
|
||||
#define CHCDL3 3
|
||||
#define CHCDL4 4
|
||||
#define CHCDL5 5
|
||||
#define CHCDL6 6
|
||||
#define CHCDL7 7
|
||||
|
||||
#define BPSCTR _SFR_MEM8(0xFA)
|
||||
#define SCPT0 0
|
||||
#define SCPT1 1
|
||||
#define SCPT2 2
|
||||
#define SCPT3 3
|
||||
#define SCPT4 4
|
||||
#define SCPT5 5
|
||||
#define SCPT6 6
|
||||
|
||||
#define BPOCTR _SFR_MEM8(0xFB)
|
||||
#define OCPT0 0
|
||||
#define OCPT1 1
|
||||
#define OCPT2 2
|
||||
#define OCPT3 3
|
||||
#define OCPT4 4
|
||||
#define OCPT5 5
|
||||
|
||||
#define BPHCTR _SFR_MEM8(0xFC)
|
||||
#define HCPT0 0
|
||||
#define HCPT1 1
|
||||
#define HCPT2 2
|
||||
#define HCPT3 3
|
||||
#define HCPT4 4
|
||||
#define HCPT5 5
|
||||
|
||||
#define BPCR _SFR_MEM8(0xFD)
|
||||
#define CHCD 0
|
||||
#define DHCD 1
|
||||
#define COCD 2
|
||||
#define DOCD 3
|
||||
#define SCD 4
|
||||
#define EPID 5
|
||||
|
||||
#define BPPLR _SFR_MEM8(0xFE)
|
||||
#define BPPL 0
|
||||
#define BPPLE 1
|
||||
|
||||
|
||||
|
||||
/* Interrupt Vectors */
|
||||
/* Interrupt Vector 0 is the reset vector. */
|
||||
|
||||
#define BPINT_vect _VECTOR(1) /* Battery Protection Interrupt */
|
||||
#define VREGMON_vect _VECTOR(2) /* Voltage regulator monitor interrupt */
|
||||
#define INT0_vect _VECTOR(3) /* External Interrupt Request 0 */
|
||||
#define INT1_vect _VECTOR(4) /* External Interrupt Request 1 */
|
||||
#define INT2_vect _VECTOR(5) /* External Interrupt Request 2 */
|
||||
#define INT3_vect _VECTOR(6) /* External Interrupt Request 3 */
|
||||
#define PCINT0_vect _VECTOR(7) /* Pin Change Interrupt 0 */
|
||||
#define PCINT1_vect _VECTOR(8) /* Pin Change Interrupt 1 */
|
||||
#define WDT_vect _VECTOR(9) /* Watchdog Timeout Interrupt */
|
||||
#define BGSCD_vect _VECTOR(10) /* Bandgap Buffer Short Circuit Detected */
|
||||
#define CHDET_vect _VECTOR(11) /* Charger Detect */
|
||||
#define TIMER1_IC_vect _VECTOR(12) /* Timer 1 Input capture */
|
||||
#define TIMER1_COMPA_vect _VECTOR(13) /* Timer 1 Compare Match A */
|
||||
#define TIMER1_COMPB_vect _VECTOR(14) /* Timer 1 Compare Match B */
|
||||
#define TIMER1_OVF_vect _VECTOR(15) /* Timer 1 overflow */
|
||||
#define TIMER0_IC_vect _VECTOR(16) /* Timer 0 Input Capture */
|
||||
#define TIMER0_COMPA_vect _VECTOR(17) /* Timer 0 Comapre Match A */
|
||||
#define TIMER0_COMPB_vect _VECTOR(18) /* Timer 0 Compare Match B */
|
||||
#define TIMER0_OVF_vect _VECTOR(19) /* Timer 0 Overflow */
|
||||
#define TWIBUSCD_vect _VECTOR(20) /* Two-Wire Bus Connect/Disconnect */
|
||||
#define TWI_vect _VECTOR(21) /* Two-Wire Serial Interface */
|
||||
#define SPI_STC_vect _VECTOR(22) /* SPI Serial transfer complete */
|
||||
#define VADC_vect _VECTOR(23) /* Voltage ADC Conversion Complete */
|
||||
#define CCADC_CONV_vect _VECTOR(24) /* Coulomb Counter ADC Conversion Complete */
|
||||
#define CCADC_REG_CUR_vect _VECTOR(25) /* Coloumb Counter ADC Regular Current */
|
||||
#define CCADC_ACC_vect _VECTOR(26) /* Coloumb Counter ADC Accumulator */
|
||||
#define EE_READY_vect _VECTOR(27) /* EEPROM Ready */
|
||||
#define SPM_vect _VECTOR(28) /* SPM Ready */
|
||||
|
||||
#define _VECTORS_SIZE (29 * 4)
|
||||
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 64
|
||||
#define RAMEND 0x8FF /* Last On-Chip SRAM Location */
|
||||
#define XRAMSIZE 0
|
||||
#define XRAMEND (RAMEND + XRAMSIZE)
|
||||
#define E2END 0x3FF
|
||||
#define FLASHEND 0x7FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 2
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_WDTON (unsigned char)~_BV(7) /* Watchdog Timer Always On */
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(6) /* EEPROM memory is preserved through chip erase */
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5) /* Enable Serial programming and Data Downloading */
|
||||
#define FUSE_SUT2 (unsigned char)~_BV(4) /* Select start-up time */
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(3) /* Select start-up time */
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(2) /* Select start-up time */
|
||||
#define FUSE_OSCSEL1 (unsigned char)~_BV(1) /* Oscillator Select */
|
||||
#define FUSE_OSCSEL0 (unsigned char)~_BV(0) /* Oscillator Select */
|
||||
#define LFUSE_DEFAULT (FUSE_OSCSEL0 & FUSE_SPIEN)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0) /* Select Reset Vector */
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1) /* Select Boot Size */
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2) /* Select Boot Size */
|
||||
#define FUSE_DWEN (unsigned char)~_BV(3) /* Enable debugWire */
|
||||
#define FUSE_DUVRDINIT (unsigned char)~_BV(4) /* Reset Value of DUVRDRegister */
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_DUVRDINIT)
|
||||
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
|
||||
|
||||
#endif /* _AVR_IOM32HVB_H_ */
|
1394
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom32m1.h
Normal file
1394
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom32m1.h
Normal file
File diff suppressed because it is too large
Load diff
1504
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom32u4.h
Normal file
1504
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom32u4.h
Normal file
File diff suppressed because it is too large
Load diff
1411
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom32u6.h
Normal file
1411
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom32u6.h
Normal file
File diff suppressed because it is too large
Load diff
768
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom406.h
Normal file
768
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom406.h
Normal file
|
@ -0,0 +1,768 @@
|
|||
/* Copyright (c) 2006, Pieter Conradie
|
||||
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: iom406.h,v 1.3.2.5 2008/10/17 23:27:49 arcanum Exp $ */
|
||||
|
||||
/* avr/iom406.h - definitions for ATmega406 */
|
||||
|
||||
#ifndef _AVR_IOM406_H_
|
||||
#define _AVR_IOM406_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_ "iom406.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
#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
|
||||
|
||||
/* Reserved [0x06..0x07] */
|
||||
|
||||
#define PORTC _SFR_IO8(0x08)
|
||||
#define PC0 0
|
||||
|
||||
#define PIND _SFR_IO8(0x09)
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
#define DDRD _SFR_IO8(0x0A)
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
#define PORTD _SFR_IO8(0x0B)
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
/* Reserved [0x0C..0x14] */
|
||||
|
||||
/* Timer/Counter0 Interrupt Flag Register */
|
||||
#define TIFR0 _SFR_IO8(0x15)
|
||||
#define OCF0B 2
|
||||
#define OCF0A 1
|
||||
#define TOV0 0
|
||||
|
||||
/* Timer/Counter1 Interrupt Flag Register */
|
||||
#define TIFR1 _SFR_IO8(0x16)
|
||||
#define OCF1A 1
|
||||
#define TOV1 0
|
||||
|
||||
/* Reserved [0x17..0x1A] */
|
||||
|
||||
/* Pin Change Interrupt Control Register */
|
||||
#define PCIFR _SFR_IO8(0x1B)
|
||||
#define PCIF1 1
|
||||
#define PCIF0 0
|
||||
|
||||
/* External Interrupt Flag Register */
|
||||
#define EIFR _SFR_IO8(0x1C)
|
||||
#define INTF3 3
|
||||
#define INTF2 2
|
||||
#define INTF1 1
|
||||
#define INTF0 0
|
||||
|
||||
/* External Interrupt MaSK register */
|
||||
#define EIMSK _SFR_IO8(0x1D)
|
||||
#define INT3 3
|
||||
#define INT2 2
|
||||
#define INT1 1
|
||||
#define INT0 0
|
||||
|
||||
/* General Purpose I/O Register 0 */
|
||||
#define GPIOR0 _SFR_IO8(0x1E)
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EECR _SFR_IO8(0x1F)
|
||||
#define EEPM1 5
|
||||
#define EEPM0 4
|
||||
#define EERIE 3
|
||||
#define EEMPE 2
|
||||
#define EEPE 1
|
||||
#define EERE 0
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define EEDR _SFR_IO8(0x20)
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#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
|
||||
|
||||
/* General Timer/Counter Control Register */
|
||||
#define GTCCR _SFR_IO8(0x23)
|
||||
#define TSM 7
|
||||
#define PSRSYNC 0
|
||||
|
||||
/* Timer/Counter Control Register A */
|
||||
#define TCCR0A _SFR_IO8(0x24)
|
||||
#define COM0A1 7
|
||||
#define COM0A0 6
|
||||
#define COM0B1 5
|
||||
#define COM0B0 4
|
||||
#define WGM01 1
|
||||
#define WGM00 0
|
||||
|
||||
/* Timer/Counter Control Register B */
|
||||
#define TCCR0B _SFR_IO8(0x25)
|
||||
#define FOC0A 7
|
||||
#define FOC0B 6
|
||||
#define WGM02 3
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/* Timer/Counter 0 */
|
||||
#define TCNT0 _SFR_IO8(0x26)
|
||||
|
||||
/* Output Compare Register A */
|
||||
#define OCR0A _SFR_IO8(0x27)
|
||||
|
||||
/* Output Compare Register B */
|
||||
#define OCR0B _SFR_IO8(0x28)
|
||||
|
||||
/* Reserved [0x29] */
|
||||
|
||||
/* General Purpose I/O Register 1 */
|
||||
#define GPIOR1 _SFR_IO8(0x2A)
|
||||
|
||||
/* General Purpose I/O Register 2 */
|
||||
#define GPIOR2 _SFR_IO8(0x2B)
|
||||
|
||||
/* Reserved [0x2C..0x30] */
|
||||
|
||||
/* On-chip Debug Register */
|
||||
#define OCDR _SFR_IO8(0x31)
|
||||
|
||||
/* Reserved [0x32] */
|
||||
|
||||
/* Sleep Mode Control Register */
|
||||
#define SMCR _SFR_IO8(0x33)
|
||||
#define SM2 3
|
||||
#define SM1 2
|
||||
#define SM0 1
|
||||
#define SE 0
|
||||
|
||||
/* MCU Status Register */
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
#define JTRF 4
|
||||
#define WDRF 3
|
||||
#define BODRF 2
|
||||
#define EXTRF 1
|
||||
#define PORF 0
|
||||
|
||||
/* MCU general Control Register */
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
#define JTD 7
|
||||
#define PUD 4
|
||||
#define IVSEL 1
|
||||
#define IVCE 0
|
||||
|
||||
/* Reserved [0x36] */
|
||||
|
||||
/* Store Program Memory Control and Status Register */
|
||||
#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 [0x36..0x3C] */
|
||||
|
||||
/* 0x3D..0x3E SP */
|
||||
|
||||
/* 0x3F SREG */
|
||||
|
||||
/* Extended I/O registers */
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#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
|
||||
|
||||
/* Reserved [0x61] */
|
||||
|
||||
/* Wake-up Timer Control and Status Register */
|
||||
#define WUTCSR _SFR_MEM8(0x62)
|
||||
#define WUTIF 7
|
||||
#define WUTIE 6
|
||||
#define WUTCF 5
|
||||
#define WUTR 4
|
||||
#define WUTE 3
|
||||
#define WUTP2 2
|
||||
#define WUTP1 1
|
||||
#define WUTP0 0
|
||||
|
||||
/* Reserved [0x63] */
|
||||
|
||||
/* Power Reduction Register 0 */
|
||||
#define PRR0 _SFR_MEM8(0x64)
|
||||
#define PRTWI 3
|
||||
#define PRTIM1 2
|
||||
#define PRTIM0 1
|
||||
#define PRVADC 0
|
||||
|
||||
/* Reserved [0x65] */
|
||||
|
||||
/* Fast Oscillator Calibration Register */
|
||||
#define FOSCCAL _SFR_MEM8(0x66)
|
||||
|
||||
/* Reserved [0x67] */
|
||||
|
||||
/* Pin Change Interrupt Control Register */
|
||||
#define PCICR _SFR_MEM8(0x68)
|
||||
#define PCIE1 1
|
||||
#define PCIE0 0
|
||||
|
||||
/* External Interrupt Control Register A */
|
||||
#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
|
||||
|
||||
/* Reserved [0x6A] */
|
||||
|
||||
/* Pin Change Mask Register 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
|
||||
|
||||
/* Pin Change Mask Register 1 */
|
||||
#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
|
||||
|
||||
/* Reserved [0x6D] */
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register 0 */
|
||||
#define TIMSK0 _SFR_MEM8(0x6E)
|
||||
#define OCIE0B 2
|
||||
#define OCIE0A 1
|
||||
#define TOIE0 0
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register 1 */
|
||||
#define TIMSK1 _SFR_MEM8(0x6F)
|
||||
#define OCIE1A 1
|
||||
#define TOIE1 0
|
||||
|
||||
/* Reserved [0x70..0x77] */
|
||||
|
||||
/* V-ADC Data Register */
|
||||
#define VADC _SFR_MEM16(0x78)
|
||||
#define VADCL _SFR_MEM8(0x78)
|
||||
#define VADCH _SFR_MEM8(0x79)
|
||||
|
||||
/* V-ADC Control and Status Register */
|
||||
#define VADCSR _SFR_MEM8(0x7A)
|
||||
#define VADEN 3
|
||||
#define VADSC 2
|
||||
#define VADCCIF 1
|
||||
#define VADCCIE 0
|
||||
|
||||
/* Reserved [0x7B] */
|
||||
|
||||
/* V-ADC Multiplexer Selection Register */
|
||||
#define VADMUX _SFR_MEM8(0x7C)
|
||||
#define VADMUX3 3
|
||||
#define VADMUX2 2
|
||||
#define VADMUX1 1
|
||||
#define VADMUX0 0
|
||||
|
||||
/* Reserved [0x7D] */
|
||||
|
||||
/* Digital Input Disable Register 0 */
|
||||
#define DIDR0 _SFR_MEM8(0x7E)
|
||||
#define VADC3D 3
|
||||
#define VADC2D 2
|
||||
#define VADC1D 1
|
||||
#define VADC0D 0
|
||||
|
||||
/* Reserved [0x82..0x83] */
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define TCCR1B _SFR_MEM8(0x81)
|
||||
#define CTC1 3
|
||||
#define CS12 2
|
||||
#define CS11 1
|
||||
#define CS10 0
|
||||
|
||||
/* Reserved [0x82..0x83] */
|
||||
|
||||
/* Timer/Counter 1 */
|
||||
#define TCNT1 _SFR_MEM16(0x84)
|
||||
#define TCNT1L _SFR_MEM8(0x84)
|
||||
#define TCNT1H _SFR_MEM8(0x85)
|
||||
|
||||
/* Reserved [0x86..0x87] */
|
||||
|
||||
/* Timer/Counter1 Output Compare Register A */
|
||||
#define OCR1A _SFR_MEM16(0x88)
|
||||
#define OCR1AL _SFR_MEM8(0x88)
|
||||
#define OCR1AH _SFR_MEM8(0x89)
|
||||
|
||||
/* Reserved [0x8A..0xB7] */
|
||||
|
||||
/* 2-wire Serial Interface Bit Rate Register */
|
||||
#define TWBR _SFR_MEM8(0xB8)
|
||||
|
||||
/* 2-wire Serial Interface Status Register */
|
||||
#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
|
||||
|
||||
/* 2-wire Serial Interface Address Register */
|
||||
#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
|
||||
|
||||
/* 2-wire Serial Interface Data Register */
|
||||
#define TWDR _SFR_MEM8(0xBB)
|
||||
|
||||
/* 2-wire Serial Interface Control Register */
|
||||
#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
|
||||
|
||||
/* 2-wire Serial (Slave) Address Mask Register */
|
||||
#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
|
||||
|
||||
/* 2-wire Serial Bus Control and Status Register */
|
||||
#define TWBCSR _SFR_MEM8(0xBE)
|
||||
#define TWBCIF 7
|
||||
#define TWBCIE 6
|
||||
#define TWBDT1 2
|
||||
#define TWBDT0 1
|
||||
#define TWBCIP 0
|
||||
|
||||
/* Reserved [0xBF] */
|
||||
|
||||
/* Clock Control Status Register */
|
||||
#define CCSR _SFR_MEM8(0xC0)
|
||||
#define XOE 1
|
||||
#define ACS 0
|
||||
|
||||
/* Reserved [0xC1..0xCF] */
|
||||
|
||||
/* Bandgap Calibration C Register */
|
||||
#define BGCCR _SFR_MEM8(0xD0)
|
||||
#define BGEN 7
|
||||
#define BGCC5 5
|
||||
#define BGCC4 4
|
||||
#define BGCC3 3
|
||||
#define BGCC2 2
|
||||
#define BGCC1 1
|
||||
#define BGCC0 0
|
||||
|
||||
/* Bandgap Calibration R Register */
|
||||
#define BGCRR _SFR_MEM8(0xD1)
|
||||
#define BGCR7 7
|
||||
#define BGCR6 6
|
||||
#define BGCR5 5
|
||||
#define BGCR4 4
|
||||
#define BGCR3 3
|
||||
#define BGCR2 2
|
||||
#define BGCR1 1
|
||||
#define BGCR0 0
|
||||
|
||||
/* Reserved [0xD2..0xDF] */
|
||||
|
||||
/* CC-ADC Accumulate Current */
|
||||
/* TODO: Add _SFR_MEM32 */
|
||||
/* #define CADAC _SFR_MEM32(0xE0) */
|
||||
#define CADAC0 _SFR_MEM8(0xE0)
|
||||
#define CADAC1 _SFR_MEM8(0xE1)
|
||||
#define CADAC2 _SFR_MEM8(0xE2)
|
||||
#define CADAC3 _SFR_MEM8(0xE3)
|
||||
|
||||
/* CC-ADC Control and Status Register A */
|
||||
#define CADCSRA _SFR_MEM8(0xE4)
|
||||
#define CADEN 7
|
||||
#define CADUB 5
|
||||
#define CADAS1 4
|
||||
#define CADAS0 3
|
||||
#define CADSI1 2
|
||||
#define CADSI0 1
|
||||
#define CADSE 0
|
||||
|
||||
/* CC-ADC Control and Status Register B */
|
||||
#define CADCSRB _SFR_MEM8(0xE5)
|
||||
#define CADACIE 6
|
||||
#define CADRCIE 5
|
||||
#define CADICIE 4
|
||||
#define CADACIF 2
|
||||
#define CADRCIF 1
|
||||
#define CADICIF 0
|
||||
|
||||
/* CC-ADC Regular Charge Current */
|
||||
#define CADRCC _SFR_MEM8(0xE6)
|
||||
|
||||
/* CC-ADC Regular Discharge Current */
|
||||
#define CADRDC _SFR_MEM8(0xE7)
|
||||
|
||||
/* CC-ADC Instantaneous Current */
|
||||
#define CADIC _SFR_MEM16(0xE8)
|
||||
#define CADICL _SFR_MEM8(0xE8)
|
||||
#define CADICH _SFR_MEM8(0xE9)
|
||||
|
||||
/* Reserved [0xEA..0xEF] */
|
||||
|
||||
/* FET Control and Status Register */
|
||||
#define FCSR _SFR_MEM8(0xF0)
|
||||
#define PWMOC 5
|
||||
#define PWMOPC 4
|
||||
#define CPS 3
|
||||
#define DFE 2
|
||||
#define CFE 1
|
||||
#define PFD 0
|
||||
|
||||
/* Cell Balancing Control Register */
|
||||
#define CBCR _SFR_MEM8(0xF1)
|
||||
#define CBE4 3
|
||||
#define CBE3 2
|
||||
#define CBE2 1
|
||||
#define CBE1 0
|
||||
|
||||
/* Battery Protection Interrupt Register */
|
||||
#define BPIR _SFR_MEM8(0xF2)
|
||||
#define DUVIF 7
|
||||
#define COCIF 6
|
||||
#define DOCIF 5
|
||||
#define SCIF 4
|
||||
#define DUVIE 3
|
||||
#define COCIE 2
|
||||
#define DOCIE 1
|
||||
#define SCIE 0
|
||||
|
||||
/* Battery Protection Deep Under Voltage Register */
|
||||
#define BPDUV _SFR_MEM8(0xF3)
|
||||
#define DUVT1 5
|
||||
#define DUVT0 4
|
||||
#define DUDL3 3
|
||||
#define DUDL2 2
|
||||
#define DUDL1 1
|
||||
#define DUDL0 0
|
||||
|
||||
/* Battery Protection Short-circuit Detection Level Register */
|
||||
#define BPSCD _SFR_MEM8(0xF4)
|
||||
#define SCDL3 3
|
||||
#define SCDL2 2
|
||||
#define SCDL1 1
|
||||
#define SCDL0 0
|
||||
|
||||
/* Battery Protection Over-current Detection Level Register */
|
||||
#define BPOCD _SFR_MEM8(0xF5)
|
||||
#define DCDL3 7
|
||||
#define DCDL2 6
|
||||
#define DCDL1 5
|
||||
#define DCDL0 4
|
||||
#define CCDL3 3
|
||||
#define CCDL2 2
|
||||
#define CCDL1 1
|
||||
#define CCDL0 0
|
||||
|
||||
/* Current Battery Protection Timing Register */
|
||||
#define CBPTR _SFR_MEM8(0xF6)
|
||||
#define SCPT3 7
|
||||
#define SCPT2 6
|
||||
#define SCPT1 5
|
||||
#define SCPT0 4
|
||||
#define OCPT3 3
|
||||
#define OCPT2 2
|
||||
#define OCPT1 1
|
||||
#define OCPT0 0
|
||||
|
||||
/* Battery Protection Control Register */
|
||||
#define BPCR _SFR_MEM8(0xF7)
|
||||
#define DUVD 3
|
||||
#define SCD 2
|
||||
#define DCD 1
|
||||
#define CCD 0
|
||||
|
||||
/* Battery Protection Parameter Lock Register */
|
||||
#define BPPLR _SFR_MEM8(0xF8)
|
||||
#define BPPLE 1
|
||||
#define BPPL 0
|
||||
|
||||
/* Reserved [0xF9..0xFF] */
|
||||
|
||||
/* Interrupt vectors */
|
||||
/* Battery Protection Interrupt */
|
||||
#define BPINT_vect _VECTOR(1)
|
||||
|
||||
|
||||
/* External Interrupt Request 0 */
|
||||
#define INT0_vect _VECTOR(2)
|
||||
|
||||
|
||||
/* External Interrupt Request 1 */
|
||||
#define INT1_vect _VECTOR(3)
|
||||
|
||||
|
||||
/* External Interrupt Request 2 */
|
||||
#define INT2_vect _VECTOR(4)
|
||||
|
||||
|
||||
/* External Interrupt Request 3 */
|
||||
#define INT3_vect _VECTOR(5)
|
||||
|
||||
|
||||
/* Pin Change Interrupt 0 */
|
||||
#define PCINT0_vect _VECTOR(6)
|
||||
|
||||
|
||||
/* Pin Change Interrupt 1 */
|
||||
#define PCINT1_vect _VECTOR(7)
|
||||
|
||||
|
||||
/* Watchdog Timeout Interrupt */
|
||||
#define WDT_vect _VECTOR(8)
|
||||
|
||||
|
||||
/* Wakeup timer overflow */
|
||||
#define WAKE_UP_vect _VECTOR(9)
|
||||
|
||||
|
||||
/* Timer/Counter 1 Compare Match */
|
||||
#define TIM1_COMP_vect _VECTOR(10)
|
||||
|
||||
|
||||
/* Timer/Counter 1 Overflow */
|
||||
#define TIM1_OVF_vect _VECTOR(11)
|
||||
|
||||
|
||||
/* Timer/Counter0 Compare A Match */
|
||||
#define TIM0_COMPA_vect _VECTOR(12)
|
||||
|
||||
|
||||
/* Timer/Counter0 Compare B Match */
|
||||
#define TIM0_COMPB_vect _VECTOR(13)
|
||||
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIM0_OVF_vect _VECTOR(14)
|
||||
|
||||
|
||||
/* Two-Wire Bus Connect/Disconnect */
|
||||
#define TWI_BUS_CD_vect _VECTOR(15)
|
||||
|
||||
|
||||
/* Two-Wire Serial Interface */
|
||||
#define TWI_vect _VECTOR(16)
|
||||
|
||||
|
||||
/* Voltage ADC Conversion Complete */
|
||||
#define VADC_vect _VECTOR(17)
|
||||
|
||||
|
||||
/* Coulomb Counter ADC Conversion Complete */
|
||||
#define CCADC_CONV_vect _VECTOR(18)
|
||||
|
||||
/* Coloumb Counter ADC Regular Current */
|
||||
#define CCADC_REG_CUR_vect _VECTOR(19)
|
||||
|
||||
|
||||
/* Coloumb Counter ADC Accumulator */
|
||||
#define CCADC_ACC_vect _VECTOR(20)
|
||||
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_READY_vect _VECTOR(21)
|
||||
|
||||
|
||||
/* Store Program Memory Ready */
|
||||
#define SPM_READY_vect _VECTOR(22)
|
||||
|
||||
#define _VECTORS_SIZE 92
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 128
|
||||
#define RAMEND 0x8FF
|
||||
#define XRAMEND 0x8FF
|
||||
#define E2END 0x1FF
|
||||
#define E2PAGESIZE 4
|
||||
#define FLASHEND 0x9FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 2
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL (unsigned char)~_BV(0)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(1)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(2)
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(3)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(4)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(5)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(6)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_SUT0 & FUSE_BOOTSZ0 & FUSE_BOOTSZ1)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(0)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(1)
|
||||
#define HFUSE_DEFAULT (FUSE_JTAGEN)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x95
|
||||
#define SIGNATURE_2 0x07
|
||||
|
||||
|
||||
#endif /* _AVR_IOM406_H_ */
|
|
@ -0,0 +1,87 @@
|
|||
/* Copyright (c) 2004, Theodore A. Roth
|
||||
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: iom48.h,v 1.3.2.3 2008/08/14 00:08:03 arcanum Exp $ */
|
||||
|
||||
#ifndef _AVR_IOM48_H_
|
||||
#define _AVR_IOM48_H_ 1
|
||||
|
||||
#include <avr/iomx8.h>
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 64
|
||||
#define RAMEND 0x2FF
|
||||
#define XRAMEND 0x2FF
|
||||
#define E2END 0xFF
|
||||
#define E2PAGESIZE 4
|
||||
#define FLASHEND 0xFFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0) /* Select Clock Source */
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1) /* Select Clock Source */
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2) /* Select Clock Source */
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3) /* Select Clock Source */
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4) /* Select start-up time */
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5) /* Select start-up time */
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6) /* Clock output */
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7) /* Divide clock by 8 */
|
||||
#define LFUSE_DEFAULT (FUSE_CKDIV8 & FUSE_SUT0 & FUSE_CKSEL3 & FUSE_CKSEL2 & FUSE_CKSEL0)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(0) /* Brown-out Detector trigger level */
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(1) /* Brown-out Detector trigger level */
|
||||
#define FUSE_BODLEVEL2 (unsigned char)~_BV(2) /* Brown-out Detector trigger level */
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3) /* EEPROM memory is preserved through chip erase */
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4) /* Watchdog Timer Always On */
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5) /* Enable Serial programming and Data Downloading */
|
||||
#define FUSE_DWEN (unsigned char)~_BV(6) /* debugWIRE Enable */
|
||||
#define FUSE_RSTDISBL (unsigned char)~_BV(7) /* External reset disable */
|
||||
#define HFUSE_DEFAULT (FUSE_SPIEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_SELFPRGEN (unsigned char)~_BV(0) /* Self Programming Enable */
|
||||
#define EFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x92
|
||||
#define SIGNATURE_2 0x05
|
||||
|
||||
|
||||
#endif /* _AVR_IOM48_H_ */
|
868
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom48p.h
Normal file
868
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom48p.h
Normal file
|
@ -0,0 +1,868 @@
|
|||
/* Copyright (c) 2007 Atmel Corporation
|
||||
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: iom48p.h,v 1.3.2.11 2008/10/17 23:27:49 arcanum Exp $ */
|
||||
|
||||
/* avr/iom48p.h - definitions for ATmega48P. */
|
||||
|
||||
/* 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_ "iom48p.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
|
||||
#ifndef _AVR_IOM48P_H_
|
||||
#define _AVR_IOM48P_H_ 1
|
||||
|
||||
/* Registers and associated bit numbers */
|
||||
|
||||
#define PINB _SFR_IO8(0x03)
|
||||
#define PINB0 0
|
||||
#define PINB1 1
|
||||
#define PINB2 2
|
||||
#define PINB3 3
|
||||
#define PINB4 4
|
||||
#define PINB5 5
|
||||
#define PINB6 6
|
||||
#define PINB7 7
|
||||
|
||||
#define DDRB _SFR_IO8(0x04)
|
||||
#define DDB0 0
|
||||
#define DDB1 1
|
||||
#define DDB2 2
|
||||
#define DDB3 3
|
||||
#define DDB4 4
|
||||
#define DDB5 5
|
||||
#define DDB6 6
|
||||
#define DDB7 7
|
||||
|
||||
#define PORTB _SFR_IO8(0x05)
|
||||
#define PORTB0 0
|
||||
#define PORTB1 1
|
||||
#define PORTB2 2
|
||||
#define PORTB3 3
|
||||
#define PORTB4 4
|
||||
#define PORTB5 5
|
||||
#define PORTB6 6
|
||||
#define PORTB7 7
|
||||
|
||||
#define PINC _SFR_IO8(0x06)
|
||||
#define PINC0 0
|
||||
#define PINC1 1
|
||||
#define PINC2 2
|
||||
#define PINC3 3
|
||||
#define PINC4 4
|
||||
#define PINC5 5
|
||||
#define PINC6 6
|
||||
|
||||
#define DDRC _SFR_IO8(0x07)
|
||||
#define DDC0 0
|
||||
#define DDC1 1
|
||||
#define DDC2 2
|
||||
#define DDC3 3
|
||||
#define DDC4 4
|
||||
#define DDC5 5
|
||||
#define DDC6 6
|
||||
|
||||
#define PORTC _SFR_IO8(0x08)
|
||||
#define PORTC0 0
|
||||
#define PORTC1 1
|
||||
#define PORTC2 2
|
||||
#define PORTC3 3
|
||||
#define PORTC4 4
|
||||
#define PORTC5 5
|
||||
#define PORTC6 6
|
||||
|
||||
#define PIND _SFR_IO8(0x09)
|
||||
#define PIND0 0
|
||||
#define PIND1 1
|
||||
#define PIND2 2
|
||||
#define PIND3 3
|
||||
#define PIND4 4
|
||||
#define PIND5 5
|
||||
#define PIND6 6
|
||||
#define PIND7 7
|
||||
|
||||
#define DDRD _SFR_IO8(0x0A)
|
||||
#define DDD0 0
|
||||
#define DDD1 1
|
||||
#define DDD2 2
|
||||
#define DDD3 3
|
||||
#define DDD4 4
|
||||
#define DDD5 5
|
||||
#define DDD6 6
|
||||
#define DDD7 7
|
||||
|
||||
#define PORTD _SFR_IO8(0x0B)
|
||||
#define PORTD0 0
|
||||
#define PORTD1 1
|
||||
#define PORTD2 2
|
||||
#define PORTD3 3
|
||||
#define PORTD4 4
|
||||
#define PORTD5 5
|
||||
#define PORTD6 6
|
||||
#define PORTD7 7
|
||||
|
||||
#define TIFR0 _SFR_IO8(0x15)
|
||||
#define TOV0 0
|
||||
#define OCF0A 1
|
||||
#define OCF0B 2
|
||||
|
||||
#define TIFR1 _SFR_IO8(0x16)
|
||||
#define TOV1 0
|
||||
#define OCF1A 1
|
||||
#define OCF1B 2
|
||||
#define ICF1 5
|
||||
|
||||
#define TIFR2 _SFR_IO8(0x17)
|
||||
#define TOV2 0
|
||||
#define OCF2A 1
|
||||
#define OCF2B 2
|
||||
|
||||
#define PCIFR _SFR_IO8(0x1B)
|
||||
#define PCIF0 0
|
||||
#define PCIF1 1
|
||||
#define PCIF2 2
|
||||
|
||||
#define EIFR _SFR_IO8(0x1C)
|
||||
#define INTF0 0
|
||||
#define INTF1 1
|
||||
|
||||
#define EIMSK _SFR_IO8(0x1D)
|
||||
#define INT0 0
|
||||
#define INT1 1
|
||||
|
||||
#define GPIOR0 _SFR_IO8(0x1E)
|
||||
#define GPIOR00 0
|
||||
#define GPIOR01 1
|
||||
#define GPIOR02 2
|
||||
#define GPIOR03 3
|
||||
#define GPIOR04 4
|
||||
#define GPIOR05 5
|
||||
#define GPIOR06 6
|
||||
#define GPIOR07 7
|
||||
|
||||
#define EECR _SFR_IO8(0x1F)
|
||||
#define EERE 0
|
||||
#define EEPE 1
|
||||
#define EEMPE 2
|
||||
#define EERIE 3
|
||||
#define EEPM0 4
|
||||
#define EEPM1 5
|
||||
|
||||
#define EEDR _SFR_IO8(0x20)
|
||||
#define EEDR0 0
|
||||
#define EEDR1 1
|
||||
#define EEDR2 2
|
||||
#define EEDR3 3
|
||||
#define EEDR4 4
|
||||
#define EEDR5 5
|
||||
#define EEDR6 6
|
||||
#define EEDR7 7
|
||||
|
||||
#define EEARL _SFR_IO8(0x21)
|
||||
#define EEAR0 0
|
||||
#define EEAR1 1
|
||||
#define EEAR2 2
|
||||
#define EEAR3 3
|
||||
#define EEAR4 4
|
||||
#define EEAR5 5
|
||||
#define EEAR6 6
|
||||
#define EEAR7 7
|
||||
|
||||
/* Only valid for ATmega88P-168P-328P */
|
||||
/* EEARH _SFR_IO8(0x22) */
|
||||
|
||||
#define EEPROM_REG_LOCATIONS 1F2021
|
||||
|
||||
#define GTCCR _SFR_IO8(0x23)
|
||||
#define PSRSYNC 0
|
||||
#define PSRASY 1
|
||||
#define TSM 7
|
||||
|
||||
#define TCCR0A _SFR_IO8(0x24)
|
||||
#define WGM00 0
|
||||
#define WGM01 1
|
||||
#define COM0B0 4
|
||||
#define COM0B1 5
|
||||
#define COM0A0 6
|
||||
#define COM0A1 7
|
||||
|
||||
#define TCCR0B _SFR_IO8(0x25)
|
||||
#define CS00 0
|
||||
#define CS01 1
|
||||
#define CS02 2
|
||||
#define WGM02 3
|
||||
#define FOC0B 6
|
||||
#define FOC0A 7
|
||||
|
||||
#define TCNT0 _SFR_IO8(0x26)
|
||||
#define TCNT0_0 0
|
||||
#define TCNT0_1 1
|
||||
#define TCNT0_2 2
|
||||
#define TCNT0_3 3
|
||||
#define TCNT0_4 4
|
||||
#define TCNT0_5 5
|
||||
#define TCNT0_6 6
|
||||
#define TCNT0_7 7
|
||||
|
||||
#define OCR0A _SFR_IO8(0x27)
|
||||
#define OCROA_0 0
|
||||
#define OCROA_1 1
|
||||
#define OCROA_2 2
|
||||
#define OCROA_3 3
|
||||
#define OCROA_4 4
|
||||
#define OCROA_5 5
|
||||
#define OCROA_6 6
|
||||
#define OCROA_7 7
|
||||
|
||||
#define OCR0B _SFR_IO8(0x28)
|
||||
#define OCR0B_0 0
|
||||
#define OCR0B_1 1
|
||||
#define OCR0B_2 2
|
||||
#define OCR0B_3 3
|
||||
#define OCR0B_4 4
|
||||
#define OCR0B_5 5
|
||||
#define OCR0B_6 6
|
||||
#define OCR0B_7 7
|
||||
|
||||
#define GPIOR1 _SFR_IO8(0x2A)
|
||||
#define GPIOR10 0
|
||||
#define GPIOR11 1
|
||||
#define GPIOR12 2
|
||||
#define GPIOR13 3
|
||||
#define GPIOR14 4
|
||||
#define GPIOR15 5
|
||||
#define GPIOR16 6
|
||||
#define GPIOR17 7
|
||||
|
||||
#define GPIOR2 _SFR_IO8(0x2B)
|
||||
#define GPIOR20 0
|
||||
#define GPIOR21 1
|
||||
#define GPIOR22 2
|
||||
#define GPIOR23 3
|
||||
#define GPIOR24 4
|
||||
#define GPIOR25 5
|
||||
#define GPIOR26 6
|
||||
#define GPIOR27 7
|
||||
|
||||
#define SPCR _SFR_IO8(0x2C)
|
||||
#define SPR0 0
|
||||
#define SPR1 1
|
||||
#define CPHA 2
|
||||
#define CPOL 3
|
||||
#define MSTR 4
|
||||
#define DORD 5
|
||||
#define SPE 6
|
||||
#define SPIE 7
|
||||
|
||||
#define SPSR _SFR_IO8(0x2D)
|
||||
#define SPI2X 0
|
||||
#define WCOL 6
|
||||
#define SPIF 7
|
||||
|
||||
#define SPDR _SFR_IO8(0x2E)
|
||||
#define SPDR0 0
|
||||
#define SPDR1 1
|
||||
#define SPDR2 2
|
||||
#define SPDR3 3
|
||||
#define SPDR4 4
|
||||
#define SPDR5 5
|
||||
#define SPDR6 6
|
||||
#define SPDR7 7
|
||||
|
||||
#define ACSR _SFR_IO8(0x30)
|
||||
#define ACIS0 0
|
||||
#define ACIS1 1
|
||||
#define ACIC 2
|
||||
#define ACIE 3
|
||||
#define ACI 4
|
||||
#define ACO 5
|
||||
#define ACBG 6
|
||||
#define ACD 7
|
||||
|
||||
#define SMCR _SFR_IO8(0x33)
|
||||
#define SE 0
|
||||
#define SM0 1
|
||||
#define SM1 2
|
||||
#define SM2 3
|
||||
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
#define PORF 0
|
||||
#define EXTRF 1
|
||||
#define BORF 2
|
||||
#define WDRF 3
|
||||
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
#define PUD 4
|
||||
#define BODSE 5
|
||||
#define BODS 6
|
||||
|
||||
#define SPMCSR _SFR_IO8(0x37)
|
||||
#define SELFPRGEN 0
|
||||
#define PGERS 1
|
||||
#define PGWRT 2
|
||||
#define BLBSET 3
|
||||
#define RWWSRE 4
|
||||
#define RWWSB 6
|
||||
#define SPMIE 7
|
||||
|
||||
#define WDTCSR _SFR_MEM8(0x60)
|
||||
#define WDP0 0
|
||||
#define WDP1 1
|
||||
#define WDP2 2
|
||||
#define WDE 3
|
||||
#define WDCE 4
|
||||
#define WDP3 5
|
||||
#define WDIE 6
|
||||
#define WDIF 7
|
||||
|
||||
#define CLKPR _SFR_MEM8(0x61)
|
||||
#define CLKPS0 0
|
||||
#define CLKPS1 1
|
||||
#define CLKPS2 2
|
||||
#define CLKPS3 3
|
||||
#define CLKPCE 7
|
||||
|
||||
#define PRR _SFR_MEM8(0x64)
|
||||
#define PRADC 0
|
||||
#define PRUSART0 1
|
||||
#define PRSPI 2
|
||||
#define PRTIM1 3
|
||||
#define PRTIM0 5
|
||||
#define PRTIM2 6
|
||||
#define PRTWI 7
|
||||
|
||||
#define OSCCAL _SFR_MEM8(0x66)
|
||||
#define CAL0 0
|
||||
#define CAL1 1
|
||||
#define CAL2 2
|
||||
#define CAL3 3
|
||||
#define CAL4 4
|
||||
#define CAL5 5
|
||||
#define CAL6 6
|
||||
#define CAL7 7
|
||||
|
||||
#define PCICR _SFR_MEM8(0x68)
|
||||
#define PCIE0 0
|
||||
#define PCIE1 1
|
||||
#define PCIE2 2
|
||||
|
||||
#define EICRA _SFR_MEM8(0x69)
|
||||
#define ISC00 0
|
||||
#define ISC01 1
|
||||
#define ISC10 2
|
||||
#define ISC11 3
|
||||
|
||||
#define PCMSK0 _SFR_MEM8(0x6B)
|
||||
#define PCINT0 0
|
||||
#define PCINT1 1
|
||||
#define PCINT2 2
|
||||
#define PCINT3 3
|
||||
#define PCINT4 4
|
||||
#define PCINT5 5
|
||||
#define PCINT6 6
|
||||
#define PCINT7 7
|
||||
|
||||
#define PCMSK1 _SFR_MEM8(0x6C)
|
||||
#define PCINT8 0
|
||||
#define PCINT9 1
|
||||
#define PCINT10 2
|
||||
#define PCINT11 3
|
||||
#define PCINT12 4
|
||||
#define PCINT13 5
|
||||
#define PCINT14 6
|
||||
|
||||
#define PCMSK2 _SFR_MEM8(0x6D)
|
||||
#define PCINT16 0
|
||||
#define PCINT17 1
|
||||
#define PCINT18 2
|
||||
#define PCINT19 3
|
||||
#define PCINT20 4
|
||||
#define PCINT21 5
|
||||
#define PCINT22 6
|
||||
#define PCINT23 7
|
||||
|
||||
#define TIMSK0 _SFR_MEM8(0x6E)
|
||||
#define TOIE0 0
|
||||
#define OCIE0A 1
|
||||
#define OCIE0B 2
|
||||
|
||||
#define TIMSK1 _SFR_MEM8(0x6F)
|
||||
#define TOIE1 0
|
||||
#define OCIE1A 1
|
||||
#define OCIE1B 2
|
||||
#define ICIE1 5
|
||||
|
||||
#define TIMSK2 _SFR_MEM8(0x70)
|
||||
#define TOIE2 0
|
||||
#define OCIE2A 1
|
||||
#define OCIE2B 2
|
||||
|
||||
#ifndef __ASSEMBLER__
|
||||
#define ADC _SFR_MEM16(0x78)
|
||||
#endif
|
||||
#define ADCW _SFR_MEM16(0x78)
|
||||
|
||||
#define ADCL _SFR_MEM8(0x78)
|
||||
#define ADCL0 0
|
||||
#define ADCL1 1
|
||||
#define ADCL2 2
|
||||
#define ADCL3 3
|
||||
#define ADCL4 4
|
||||
#define ADCL5 5
|
||||
#define ADCL6 6
|
||||
#define ADCL7 7
|
||||
|
||||
#define ADCH _SFR_MEM8(0x79)
|
||||
#define ADCH0 0
|
||||
#define ADCH1 1
|
||||
#define ADCH2 2
|
||||
#define ADCH3 3
|
||||
#define ADCH4 4
|
||||
#define ADCH5 5
|
||||
#define ADCH6 6
|
||||
#define ADCH7 7
|
||||
|
||||
#define ADCSRA _SFR_MEM8(0x7A)
|
||||
#define ADPS0 0
|
||||
#define ADPS1 1
|
||||
#define ADPS2 2
|
||||
#define ADIE 3
|
||||
#define ADIF 4
|
||||
#define ADATE 5
|
||||
#define ADSC 6
|
||||
#define ADEN 7
|
||||
|
||||
#define ADCSRB _SFR_MEM8(0x7B)
|
||||
#define ADTS0 0
|
||||
#define ADTS1 1
|
||||
#define ADTS2 2
|
||||
#define ACME 6
|
||||
|
||||
#define ADMUX _SFR_MEM8(0x7C)
|
||||
#define MUX0 0
|
||||
#define MUX1 1
|
||||
#define MUX2 2
|
||||
#define MUX3 3
|
||||
#define ADLAR 5
|
||||
#define REFS0 6
|
||||
#define REFS1 7
|
||||
|
||||
#define DIDR0 _SFR_MEM8(0x7E)
|
||||
#define ADC0D 0
|
||||
#define ADC1D 1
|
||||
#define ADC2D 2
|
||||
#define ADC3D 3
|
||||
#define ADC4D 4
|
||||
#define ADC5D 5
|
||||
|
||||
#define DIDR1 _SFR_MEM8(0x7F)
|
||||
#define AIN0D 0
|
||||
#define AIN1D 1
|
||||
|
||||
#define TCCR1A _SFR_MEM8(0x80)
|
||||
#define WGM10 0
|
||||
#define WGM11 1
|
||||
#define COM1B0 4
|
||||
#define COM1B1 5
|
||||
#define COM1A0 6
|
||||
#define COM1A1 7
|
||||
|
||||
#define TCCR1B _SFR_MEM8(0x81)
|
||||
#define CS10 0
|
||||
#define CS11 1
|
||||
#define CS12 2
|
||||
#define WGM12 3
|
||||
#define WGM13 4
|
||||
#define ICES1 6
|
||||
#define ICNC1 7
|
||||
|
||||
#define TCCR1C _SFR_MEM8(0x82)
|
||||
#define FOC1B 6
|
||||
#define FOC1A 7
|
||||
|
||||
#define TCNT1 _SFR_MEM16(0x84)
|
||||
|
||||
#define TCNT1L _SFR_MEM8(0x84)
|
||||
#define TCNT1L0 0
|
||||
#define TCNT1L1 1
|
||||
#define TCNT1L2 2
|
||||
#define TCNT1L3 3
|
||||
#define TCNT1L4 4
|
||||
#define TCNT1L5 5
|
||||
#define TCNT1L6 6
|
||||
#define TCNT1L7 7
|
||||
|
||||
#define TCNT1H _SFR_MEM8(0x85)
|
||||
#define TCNT1H0 0
|
||||
#define TCNT1H1 1
|
||||
#define TCNT1H2 2
|
||||
#define TCNT1H3 3
|
||||
#define TCNT1H4 4
|
||||
#define TCNT1H5 5
|
||||
#define TCNT1H6 6
|
||||
#define TCNT1H7 7
|
||||
|
||||
#define ICR1 _SFR_MEM16(0x86)
|
||||
|
||||
#define ICR1L _SFR_MEM8(0x86)
|
||||
#define ICR1L0 0
|
||||
#define ICR1L1 1
|
||||
#define ICR1L2 2
|
||||
#define ICR1L3 3
|
||||
#define ICR1L4 4
|
||||
#define ICR1L5 5
|
||||
#define ICR1L6 6
|
||||
#define ICR1L7 7
|
||||
|
||||
#define ICR1H _SFR_MEM8(0x87)
|
||||
#define ICR1H0 0
|
||||
#define ICR1H1 1
|
||||
#define ICR1H2 2
|
||||
#define ICR1H3 3
|
||||
#define ICR1H4 4
|
||||
#define ICR1H5 5
|
||||
#define ICR1H6 6
|
||||
#define ICR1H7 7
|
||||
|
||||
#define OCR1A _SFR_MEM16(0x88)
|
||||
|
||||
#define OCR1AL _SFR_MEM8(0x88)
|
||||
#define OCR1AL0 0
|
||||
#define OCR1AL1 1
|
||||
#define OCR1AL2 2
|
||||
#define OCR1AL3 3
|
||||
#define OCR1AL4 4
|
||||
#define OCR1AL5 5
|
||||
#define OCR1AL6 6
|
||||
#define OCR1AL7 7
|
||||
|
||||
#define OCR1AH _SFR_MEM8(0x89)
|
||||
#define OCR1AH0 0
|
||||
#define OCR1AH1 1
|
||||
#define OCR1AH2 2
|
||||
#define OCR1AH3 3
|
||||
#define OCR1AH4 4
|
||||
#define OCR1AH5 5
|
||||
#define OCR1AH6 6
|
||||
#define OCR1AH7 7
|
||||
|
||||
#define OCR1B _SFR_MEM16(0x8A)
|
||||
|
||||
#define OCR1BL _SFR_MEM8(0x8A)
|
||||
#define OCR1BL0 0
|
||||
#define OCR1BL1 1
|
||||
#define OCR1BL2 2
|
||||
#define OCR1BL3 3
|
||||
#define OCR1BL4 4
|
||||
#define OCR1BL5 5
|
||||
#define OCR1BL6 6
|
||||
#define OCR1BL7 7
|
||||
|
||||
#define OCR1BH _SFR_MEM8(0x8B)
|
||||
#define OCR1BH0 0
|
||||
#define OCR1BH1 1
|
||||
#define OCR1BH2 2
|
||||
#define OCR1BH3 3
|
||||
#define OCR1BH4 4
|
||||
#define OCR1BH5 5
|
||||
#define OCR1BH6 6
|
||||
#define OCR1BH7 7
|
||||
|
||||
#define TCCR2A _SFR_MEM8(0xB0)
|
||||
#define WGM20 0
|
||||
#define WGM21 1
|
||||
#define COM2B0 4
|
||||
#define COM2B1 5
|
||||
#define COM2A0 6
|
||||
#define COM2A1 7
|
||||
|
||||
#define TCCR2B _SFR_MEM8(0xB1)
|
||||
#define CS20 0
|
||||
#define CS21 1
|
||||
#define CS22 2
|
||||
#define WGM22 3
|
||||
#define FOC2B 6
|
||||
#define FOC2A 7
|
||||
|
||||
#define TCNT2 _SFR_MEM8(0xB2)
|
||||
#define TCNT2_0 0
|
||||
#define TCNT2_1 1
|
||||
#define TCNT2_2 2
|
||||
#define TCNT2_3 3
|
||||
#define TCNT2_4 4
|
||||
#define TCNT2_5 5
|
||||
#define TCNT2_6 6
|
||||
#define TCNT2_7 7
|
||||
|
||||
#define OCR2A _SFR_MEM8(0xB3)
|
||||
#define OCR2_0 0
|
||||
#define OCR2_1 1
|
||||
#define OCR2_2 2
|
||||
#define OCR2_3 3
|
||||
#define OCR2_4 4
|
||||
#define OCR2_5 5
|
||||
#define OCR2_6 6
|
||||
#define OCR2_7 7
|
||||
|
||||
#define OCR2B _SFR_MEM8(0xB4)
|
||||
#define OCR2_0 0
|
||||
#define OCR2_1 1
|
||||
#define OCR2_2 2
|
||||
#define OCR2_3 3
|
||||
#define OCR2_4 4
|
||||
#define OCR2_5 5
|
||||
#define OCR2_6 6
|
||||
#define OCR2_7 7
|
||||
|
||||
#define ASSR _SFR_MEM8(0xB6)
|
||||
#define TCR2BUB 0
|
||||
#define TCR2AUB 1
|
||||
#define OCR2BUB 2
|
||||
#define OCR2AUB 3
|
||||
#define TCN2UB 4
|
||||
#define AS2 5
|
||||
#define EXCLK 6
|
||||
|
||||
#define TWBR _SFR_MEM8(0xB8)
|
||||
#define TWBR0 0
|
||||
#define TWBR1 1
|
||||
#define TWBR2 2
|
||||
#define TWBR3 3
|
||||
#define TWBR4 4
|
||||
#define TWBR5 5
|
||||
#define TWBR6 6
|
||||
#define TWBR7 7
|
||||
|
||||
#define TWSR _SFR_MEM8(0xB9)
|
||||
#define TWPS0 0
|
||||
#define TWPS1 1
|
||||
#define TWS3 3
|
||||
#define TWS4 4
|
||||
#define TWS5 5
|
||||
#define TWS6 6
|
||||
#define TWS7 7
|
||||
|
||||
#define TWAR _SFR_MEM8(0xBA)
|
||||
#define TWGCE 0
|
||||
#define TWA0 1
|
||||
#define TWA1 2
|
||||
#define TWA2 3
|
||||
#define TWA3 4
|
||||
#define TWA4 5
|
||||
#define TWA5 6
|
||||
#define TWA6 7
|
||||
|
||||
#define TWDR _SFR_MEM8(0xBB)
|
||||
#define TWD0 0
|
||||
#define TWD1 1
|
||||
#define TWD2 2
|
||||
#define TWD3 3
|
||||
#define TWD4 4
|
||||
#define TWD5 5
|
||||
#define TWD6 6
|
||||
#define TWD7 7
|
||||
|
||||
#define TWCR _SFR_MEM8(0xBC)
|
||||
#define TWIE 0
|
||||
#define TWEN 2
|
||||
#define TWWC 3
|
||||
#define TWSTO 4
|
||||
#define TWSTA 5
|
||||
#define TWEA 6
|
||||
#define TWINT 7
|
||||
|
||||
#define TWAMR _SFR_MEM8(0xBD)
|
||||
#define TWAM0 0
|
||||
#define TWAM1 1
|
||||
#define TWAM2 2
|
||||
#define TWAM3 3
|
||||
#define TWAM4 4
|
||||
#define TWAM5 5
|
||||
#define TWAM6 6
|
||||
|
||||
#define UCSR0A _SFR_MEM8(0xC0)
|
||||
#define MPCM0 0
|
||||
#define U2X0 1
|
||||
#define UPE0 2
|
||||
#define DOR0 3
|
||||
#define FE0 4
|
||||
#define UDRE0 5
|
||||
#define TXC0 6
|
||||
#define RXC0 7
|
||||
|
||||
#define UCSR0B _SFR_MEM8(0xC1)
|
||||
#define TXB80 0
|
||||
#define RXB80 1
|
||||
#define UCSZ02 2
|
||||
#define TXEN0 3
|
||||
#define RXEN0 4
|
||||
#define UDRIE0 5
|
||||
#define TXCIE0 6
|
||||
#define RXCIE0 7
|
||||
|
||||
#define UCSR0C _SFR_MEM8(0xC2)
|
||||
#define UCPOL0 0
|
||||
#define UCSZ00 1
|
||||
#define UCPHA0 1
|
||||
#define UCSZ01 2
|
||||
#define UDORD0 2
|
||||
#define USBS0 3
|
||||
#define UPM00 4
|
||||
#define UPM01 5
|
||||
#define UMSEL00 6
|
||||
#define UMSEL01 7
|
||||
|
||||
#define UBRR0 _SFR_MEM16(0xC4)
|
||||
|
||||
#define UBRR0L _SFR_MEM8(0xC4)
|
||||
#define UBRR0_0 0
|
||||
#define UBRR0_1 1
|
||||
#define UBRR0_2 2
|
||||
#define UBRR0_3 3
|
||||
#define UBRR0_4 4
|
||||
#define UBRR0_5 5
|
||||
#define UBRR0_6 6
|
||||
#define UBRR0_7 7
|
||||
|
||||
#define UBRR0H _SFR_MEM8(0xC5)
|
||||
#define UBRR0_8 0
|
||||
#define UBRR0_9 1
|
||||
#define UBRR0_10 2
|
||||
#define UBRR0_11 3
|
||||
|
||||
#define UDR0 _SFR_MEM8(0xC6)
|
||||
#define UDR0_0 0
|
||||
#define UDR0_1 1
|
||||
#define UDR0_2 2
|
||||
#define UDR0_3 3
|
||||
#define UDR0_4 4
|
||||
#define UDR0_5 5
|
||||
#define UDR0_6 6
|
||||
#define UDR0_7 7
|
||||
|
||||
|
||||
|
||||
/* Interrupt Vectors */
|
||||
/* Interrupt Vector 0 is the reset vector. */
|
||||
#define INT0_vect _VECTOR(1) /* External Interrupt Request 0 */
|
||||
#define INT1_vect _VECTOR(2) /* External Interrupt Request 1 */
|
||||
#define PCINT0_vect _VECTOR(3) /* Pin Change Interrupt Request 0 */
|
||||
#define PCINT1_vect _VECTOR(4) /* Pin Change Interrupt Request 0 */
|
||||
#define PCINT2_vect _VECTOR(5) /* Pin Change Interrupt Request 1 */
|
||||
#define WDT_vect _VECTOR(6) /* Watchdog Time-out Interrupt */
|
||||
#define TIMER2_COMPA_vect _VECTOR(7) /* Timer/Counter2 Compare Match A */
|
||||
#define TIMER2_COMPB_vect _VECTOR(8) /* Timer/Counter2 Compare Match A */
|
||||
#define TIMER2_OVF_vect _VECTOR(9) /* Timer/Counter2 Overflow */
|
||||
#define TIMER1_CAPT_vect _VECTOR(10) /* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_COMPA_vect _VECTOR(11) /* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPB_vect _VECTOR(12) /* Timer/Counter1 Compare Match B */
|
||||
#define TIMER1_OVF_vect _VECTOR(13) /* Timer/Counter1 Overflow */
|
||||
#define TIMER0_COMPA_vect _VECTOR(14) /* TimerCounter0 Compare Match A */
|
||||
#define TIMER0_COMPB_vect _VECTOR(15) /* TimerCounter0 Compare Match B */
|
||||
#define TIMER0_OVF_vect _VECTOR(16) /* Timer/Couner0 Overflow */
|
||||
#define SPI_STC_vect _VECTOR(17) /* SPI Serial Transfer Complete */
|
||||
#define USART_RX_vect _VECTOR(18) /* USART Rx Complete */
|
||||
#define USART_UDRE_vect _VECTOR(19) /* USART, Data Register Empty */
|
||||
#define USART_TX_vect _VECTOR(20) /* USART Tx Complete */
|
||||
#define ADC_vect _VECTOR(21) /* ADC Conversion Complete */
|
||||
#define EE_READY_vect _VECTOR(22) /* EEPROM Ready */
|
||||
#define ANALOG_COMP_vect _VECTOR(23) /* Analog Comparator */
|
||||
#define TWI_vect _VECTOR(24) /* Two-wire Serial Interface */
|
||||
#define SPM_READY_vect _VECTOR(25) /* Store Program Memory Read */
|
||||
|
||||
#define _VECTORS_SIZE (26 * 2)
|
||||
|
||||
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 64
|
||||
#define RAMEND 0x2FF /* Last On-Chip SRAM Location */
|
||||
#define XRAMSIZE 0
|
||||
#define XRAMEND (RAMEND + XRAMSIZE)
|
||||
#define E2END 0xFF
|
||||
#define E2PAGESIZE 4
|
||||
#define FLASHEND 0xFFF
|
||||
|
||||
|
||||
|
||||
/* Fuses */
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0) /* Select Clock Source */
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1) /* Select Clock Source */
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2) /* Select Clock Source */
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3) /* Select Clock Source */
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4) /* Select start-up time */
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5) /* Select start-up time */
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6) /* Clock output */
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7) /* Divide clock by 8 */
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(0) /* Brown-out Detector trigger level */
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(1) /* Brown-out Detector trigger level */
|
||||
#define FUSE_BODLEVEL2 (unsigned char)~_BV(2) /* Brown-out Detector trigger level */
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3) /* EEPROM memory is preserved through chip erase */
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4) /* Watchdog Timer Always On */
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5) /* Enable Serial programming and Data Downloading */
|
||||
#define FUSE_DWEN (unsigned char)~_BV(6) /* debugWIRE Enable */
|
||||
#define FUSE_RSTDISBL (unsigned char)~_BV(7) /* External reset disable */
|
||||
#define HFUSE_DEFAULT (FUSE_SPIEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_SELFPRGEN (unsigned char)~_BV(0) /* Self Programming Enable */
|
||||
#define EFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x92
|
||||
#define SIGNATURE_2 0x0A
|
||||
|
||||
|
||||
#endif /* _AVR_IOM48P_H_ */
|
1227
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom64.h
Normal file
1227
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom64.h
Normal file
File diff suppressed because it is too large
Load diff
|
@ -0,0 +1,94 @@
|
|||
/* 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: iom640.h,v 1.2.2.5 2008/10/17 23:27:49 arcanum Exp $ */
|
||||
|
||||
/* avr/iom640.h - definitions for ATmega640 */
|
||||
|
||||
#ifndef _AVR_IOM640_H_
|
||||
#define _AVR_IOM640_H_ 1
|
||||
|
||||
#include <avr/iomxx0_1.h>
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 256
|
||||
#define RAMEND 0x21FF
|
||||
#define XRAMEND 0xFFFF
|
||||
#define E2END 0xFFF
|
||||
#define E2PAGESIZE 8
|
||||
#define FLASHEND 0xFFFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6)
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_BODLEVEL2 (unsigned char)~_BV(2)
|
||||
#define EFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x96
|
||||
#define SIGNATURE_2 0x08
|
||||
|
||||
|
||||
#endif /* _AVR_IOM640_H_ */
|
|
@ -0,0 +1,94 @@
|
|||
/* 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. */
|
||||
|
||||
/* avr/iom644.h - definitions for ATmega644 */
|
||||
|
||||
/* $Id: iom644.h,v 1.2.2.5 2008/10/17 23:27:50 arcanum Exp $ */
|
||||
|
||||
#ifndef _AVR_IOM644_H_
|
||||
#define _AVR_IOM644_H_ 1
|
||||
|
||||
#include <avr/iomxx4.h>
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 256
|
||||
#define RAMEND 0x10FF
|
||||
#define XRAMEND 0x10FF
|
||||
#define E2END 0x7FF
|
||||
#define E2PAGESIZE 8
|
||||
#define FLASHEND 0xFFFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6)
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_SUT1 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_BODLEVEL2 (unsigned char)~_BV(2)
|
||||
#define EFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x96
|
||||
#define SIGNATURE_2 0x09
|
||||
|
||||
|
||||
#endif /* _AVR_IOM644_H_ */
|
816
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom645.h
Normal file
816
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom645.h
Normal file
|
@ -0,0 +1,816 @@
|
|||
/* Copyright (c) 2004,2005,2006 Eric B. Weddington
|
||||
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: iom645.h,v 1.11.2.5 2008/10/17 23:27:50 arcanum Exp $ */
|
||||
|
||||
/* avr/iom645.h - definitions for ATmega645 */
|
||||
|
||||
#ifndef _AVR_IOM645_H_
|
||||
#define _AVR_IOM645_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_ "iom645.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#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 DDG4 4
|
||||
#define DDG3 3
|
||||
#define DDG2 2
|
||||
#define DDG1 1
|
||||
#define DDG0 0
|
||||
|
||||
#define PORTG _SFR_IO8(0x14)
|
||||
#define PG4 4
|
||||
#define PG3 3
|
||||
#define PG2 2
|
||||
#define PG1 1
|
||||
#define PG0 0
|
||||
|
||||
#define TIFR0 _SFR_IO8(0x15)
|
||||
#define TOV0 0
|
||||
#define OCF0A 1
|
||||
|
||||
#define TIFR1 _SFR_IO8(0x16)
|
||||
#define TOV1 0
|
||||
#define OCF1A 1
|
||||
#define OCF1B 2
|
||||
#define ICF1 5
|
||||
|
||||
#define TIFR2 _SFR_IO8(0x17)
|
||||
#define TOV2 0
|
||||
#define OCF2A 1
|
||||
|
||||
/* Reserved [0x18..0x1B] */
|
||||
|
||||
#define EIFR _SFR_IO8(0x1C)
|
||||
#define INTF0 0
|
||||
#define PCIF0 4
|
||||
#define PCIF1 5
|
||||
|
||||
#define EIMSK _SFR_IO8(0x1D)
|
||||
#define INT0 0
|
||||
#define PCIE0 4
|
||||
#define PCIE1 5
|
||||
|
||||
#define GPIOR0 _SFR_IO8(0x1E)
|
||||
|
||||
#define EECR _SFR_IO8(0x1F)
|
||||
#define EERE 0
|
||||
#define EEWE 1
|
||||
#define EEMWE 2
|
||||
#define EERIE 3
|
||||
|
||||
#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 PSR10 0
|
||||
#define PSR2 1
|
||||
#define TSM 7
|
||||
|
||||
#define TCCR0A _SFR_IO8(0x24)
|
||||
#define CS00 0
|
||||
#define CS01 1
|
||||
#define CS02 2
|
||||
#define WGM01 3
|
||||
#define COM0A0 4
|
||||
#define COM0A1 5
|
||||
#define WGM00 6
|
||||
#define FOC0A 7
|
||||
|
||||
/* Reserved [0x25] */
|
||||
|
||||
#define TCNT0 _SFR_IO8(0X26)
|
||||
|
||||
#define OCR0A _SFR_IO8(0X27)
|
||||
|
||||
/* Reserved [0x28..0x29] */
|
||||
|
||||
#define GPIOR1 _SFR_IO8(0x2A)
|
||||
|
||||
#define GPIOR2 _SFR_IO8(0x2B)
|
||||
|
||||
#define SPCR _SFR_IO8(0x2C)
|
||||
#define SPR0 0
|
||||
#define SPR1 1
|
||||
#define CPHA 2
|
||||
#define CPOL 3
|
||||
#define MSTR 4
|
||||
#define DORD 5
|
||||
#define SPE 6
|
||||
#define SPIE 7
|
||||
|
||||
#define SPSR _SFR_IO8(0x2D)
|
||||
#define SPI2X 0
|
||||
#define WCOL 6
|
||||
#define SPIF 7
|
||||
|
||||
#define SPDR _SFR_IO8(0X2E)
|
||||
|
||||
/* Reserved [0x2F] */
|
||||
|
||||
#define ACSR _SFR_IO8(0x30)
|
||||
#define ACIS0 0
|
||||
#define ACIS1 1
|
||||
#define ACIC 2
|
||||
#define ACIE 3
|
||||
#define ACI 4
|
||||
#define ACO 5
|
||||
#define ACBG 6
|
||||
#define ACD 7
|
||||
|
||||
#define OCDR _SFR_IO8(0x31)
|
||||
#define OCDR0 0
|
||||
#define OCDR1 1
|
||||
#define OCDR2 2
|
||||
#define OCDR3 3
|
||||
#define OCDR4 4
|
||||
#define OCDR5 5
|
||||
#define OCDR6 6
|
||||
#define OCDR7 7
|
||||
#define IDRD 7
|
||||
|
||||
/* Reserved [0x32] */
|
||||
|
||||
#define SMCR _SFR_IO8(0x33)
|
||||
#define SE 0
|
||||
#define SM0 1
|
||||
#define SM1 2
|
||||
#define SM2 3
|
||||
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
#define PORF 0
|
||||
#define EXTRF 1
|
||||
#define BORF 2
|
||||
#define WDRF 3
|
||||
#define JTRF 4
|
||||
|
||||
#define MCUCR _SFR_IO8(0X35)
|
||||
#define IVCE 0
|
||||
#define IVSEL 1
|
||||
#define PUD 4
|
||||
#define JTD 7
|
||||
|
||||
/* Reserved [0x36] */
|
||||
|
||||
#define SPMCSR _SFR_IO8(0x37)
|
||||
#define SPMEN 0
|
||||
#define PGERS 1
|
||||
#define PGWRT 2
|
||||
#define BLBSET 3
|
||||
#define RWWSRE 4
|
||||
#define RWWSB 6
|
||||
#define SPMIE 7
|
||||
|
||||
/* Reserved [0x38..0x3C] */
|
||||
|
||||
/* SP [0x3D..0x3E] */
|
||||
/* SREG [0x3F] */
|
||||
|
||||
#define WDTCR _SFR_MEM8(0x60)
|
||||
#define WDP0 0
|
||||
#define WDP1 1
|
||||
#define WDP2 2
|
||||
#define WDE 3
|
||||
#define WDCE 4
|
||||
|
||||
#define CLKPR _SFR_MEM8(0x61)
|
||||
#define CLKPS0 0
|
||||
#define CLKPS1 1
|
||||
#define CLKPS2 2
|
||||
#define CLKPS3 3
|
||||
#define CLKPCE 7
|
||||
|
||||
/* Reserved [0x62..0x63] */
|
||||
|
||||
#define PRR _SFR_MEM8(0x64)
|
||||
#define PRADC 0
|
||||
#define PRUSART0 1
|
||||
#define PRSPI 2
|
||||
#define PRTIM1 3
|
||||
|
||||
/* Reserved [0x65] */
|
||||
|
||||
#define OSCCAL _SFR_MEM8(0x66)
|
||||
|
||||
/* Reserved [0x67..0x68] */
|
||||
|
||||
#define EICRA _SFR_MEM8(0x69)
|
||||
#define ISC00 0
|
||||
#define ISC01 1
|
||||
|
||||
/* Reserved [0x6A] */
|
||||
|
||||
#define PCMSK0 _SFR_MEM8(0x6B)
|
||||
#define PCINT0 0
|
||||
#define PCINT1 1
|
||||
#define PCINT2 2
|
||||
#define PCINT3 3
|
||||
#define PCINT4 4
|
||||
#define PCINT5 5
|
||||
#define PCINT6 6
|
||||
#define PCINT7 7
|
||||
|
||||
#define PCMSK1 _SFR_MEM8(0x6C)
|
||||
#define PCINT8 0
|
||||
#define PCINT9 1
|
||||
#define PCINT10 2
|
||||
#define PCINT11 3
|
||||
#define PCINT12 4
|
||||
#define PCINT13 5
|
||||
#define PCINT14 6
|
||||
#define PCINT15 7
|
||||
|
||||
/* Reserved [0x6D] */
|
||||
|
||||
#define TIMSK0 _SFR_MEM8(0x6E)
|
||||
#define TOIE0 0
|
||||
#define OCIE0A 1
|
||||
|
||||
#define TIMSK1 _SFR_MEM8(0x6F)
|
||||
#define TOIE1 0
|
||||
#define OCIE1A 1
|
||||
#define OCIE1B 2
|
||||
#define ICIE1 5
|
||||
|
||||
#define TIMSK2 _SFR_MEM8(0x70)
|
||||
#define TOIE2 0
|
||||
#define OCIE2A 1
|
||||
|
||||
/* Reserved [0x71..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 ADPS0 0
|
||||
#define ADPS1 1
|
||||
#define ADPS2 2
|
||||
#define ADIE 3
|
||||
#define ADIF 4
|
||||
#define ADATE 5
|
||||
#define ADSC 6
|
||||
#define ADEN 7
|
||||
|
||||
#define ADCSRB _SFR_MEM8(0x7B)
|
||||
#define ADTS0 0
|
||||
#define ADTS1 1
|
||||
#define ADTS2 2
|
||||
#define ACME 6
|
||||
|
||||
#define ADMUX _SFR_MEM8(0x7C)
|
||||
#define MUX0 0
|
||||
#define MUX1 1
|
||||
#define MUX2 2
|
||||
#define MUX3 3
|
||||
#define MUX4 4
|
||||
#define ADLAR 5
|
||||
#define REFS0 6
|
||||
#define REFS1 7
|
||||
|
||||
/* Reserved [0x7D] */
|
||||
|
||||
#define DIDR0 _SFR_MEM8(0x7E)
|
||||
#define ADC0D 0
|
||||
#define ADC1D 1
|
||||
#define ADC2D 2
|
||||
#define ADC3D 3
|
||||
#define ADC4D 4
|
||||
#define ADC5D 5
|
||||
#define ADC6D 6
|
||||
#define ADC7D 7
|
||||
|
||||
#define DIDR1 _SFR_MEM8(0x7F)
|
||||
#define AIN0D 0
|
||||
#define AIN1D 1
|
||||
|
||||
#define TCCR1A _SFR_MEM8(0X80)
|
||||
#define WGM10 0
|
||||
#define WGM11 1
|
||||
#define COM1B0 4
|
||||
#define COM1B1 5
|
||||
#define COM1A0 6
|
||||
#define COM1A1 7
|
||||
|
||||
#define TCCR1B _SFR_MEM8(0X81)
|
||||
#define CS10 0
|
||||
#define CS11 1
|
||||
#define CS12 2
|
||||
#define WGM12 3
|
||||
#define WGM13 4
|
||||
#define ICES1 6
|
||||
#define ICNC1 7
|
||||
|
||||
#define TCCR1C _SFR_MEM8(0x82)
|
||||
#define FOC1B 6
|
||||
#define FOC1A 7
|
||||
|
||||
/* 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)
|
||||
|
||||
/* Reserved [0x8C..0xAF] */
|
||||
|
||||
#define TCCR2A _SFR_MEM8(0xB0)
|
||||
#define CS20 0
|
||||
#define CS21 1
|
||||
#define CS22 2
|
||||
#define WGM21 3
|
||||
#define COM2A0 4
|
||||
#define COM2A1 5
|
||||
#define WGM20 6
|
||||
#define FOC2A 7
|
||||
|
||||
/* Reserved [0xB1] */
|
||||
|
||||
#define TCNT2 _SFR_MEM8(0xB2)
|
||||
|
||||
#define OCR2A _SFR_MEM8(0xB3)
|
||||
|
||||
/* Reserved [0xB4..0xB5] */
|
||||
|
||||
#define ASSR _SFR_MEM8(0xB6)
|
||||
#define TCR2UB 0
|
||||
#define OCR2UB 1
|
||||
#define TCN2UB 2
|
||||
#define AS2 3
|
||||
#define EXCLK 4
|
||||
|
||||
/* Reserved [0xB7] */
|
||||
|
||||
#define USICR _SFR_MEM8(0xB8)
|
||||
#define USITC 0
|
||||
#define USICLK 1
|
||||
#define USICS0 2
|
||||
#define USICS1 3
|
||||
#define USIWM0 4
|
||||
#define USIWM1 5
|
||||
#define USIOIE 6
|
||||
#define USISIE 7
|
||||
|
||||
#define USISR _SFR_MEM8(0xB9)
|
||||
#define USICNT0 0
|
||||
#define USICNT1 1
|
||||
#define USICNT2 2
|
||||
#define USICNT3 3
|
||||
#define USIDC 4
|
||||
#define USIPF 5
|
||||
#define USIOIF 6
|
||||
#define USISIF 7
|
||||
|
||||
#define USIDR _SFR_MEM8(0xBA)
|
||||
|
||||
/* Reserved [0xBB..0xBF] */
|
||||
|
||||
#define UCSR0A _SFR_MEM8(0xC0)
|
||||
#define MPCM0 0
|
||||
#define U2X0 1
|
||||
#define UPE0 2
|
||||
#define DOR0 3
|
||||
#define FE0 4
|
||||
#define UDRE0 5
|
||||
#define TXC0 6
|
||||
#define RXC0 7
|
||||
|
||||
#define UCSR0B _SFR_MEM8(0XC1)
|
||||
#define TXB80 0
|
||||
#define RXB80 1
|
||||
#define UCSZ02 2
|
||||
#define TXEN0 3
|
||||
#define RXEN0 4
|
||||
#define UDRIE0 5
|
||||
#define TXCIE0 6
|
||||
#define RXCIE0 7
|
||||
|
||||
#define UCSR0C _SFR_MEM8(0xC2)
|
||||
#define UCPOL0 0
|
||||
#define UCSZ00 1
|
||||
#define UCSZ01 2
|
||||
#define USBS0 3
|
||||
#define UPM00 4
|
||||
#define UPM01 5
|
||||
#define UMSEL0 6
|
||||
|
||||
/* 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..0xFF] */
|
||||
|
||||
|
||||
/* Interrupt vectors */
|
||||
/* Vector 0 is the reset vector */
|
||||
/* External Interrupt Request 0 */
|
||||
#define INT0_vect _VECTOR(1)
|
||||
#define SIG_INTERRUPT0 _VECTOR(1)
|
||||
|
||||
/* Pin Change Interrupt Request 0 */
|
||||
#define PCINT0_vect _VECTOR(2)
|
||||
#define SIG_PIN_CHANGE0 _VECTOR(2)
|
||||
|
||||
/* Pin Change Interrupt Request 1 */
|
||||
#define PCINT1_vect _VECTOR(3)
|
||||
#define SIG_PIN_CHANGE1 _VECTOR(3)
|
||||
|
||||
/* Timer/Counter2 Compare Match */
|
||||
#define TIMER2_COMP_vect _VECTOR(4)
|
||||
#define SIG_OUTPUT_COMPARE2 _VECTOR(4)
|
||||
|
||||
/* Timer/Counter2 Overflow */
|
||||
#define TIMER2_OVF_vect _VECTOR(5)
|
||||
#define SIG_OVERFLOW2 _VECTOR(5)
|
||||
|
||||
/* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(6)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(6)
|
||||
|
||||
/* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPA_vect _VECTOR(7)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(7)
|
||||
|
||||
/* Timer/Counter Compare Match B */
|
||||
#define TIMER1_COMPB_vect _VECTOR(8)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(8)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(9)
|
||||
#define SIG_OVERFLOW1 _VECTOR(9)
|
||||
|
||||
/* Timer/Counter0 Compare Match */
|
||||
#define TIMER0_COMP_vect _VECTOR(10)
|
||||
#define SIG_OUTPUT_COMPARE0 _VECTOR(10)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(11)
|
||||
#define SIG_OVERFLOW0 _VECTOR(11)
|
||||
|
||||
/* SPI Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(12)
|
||||
#define SIG_SPI _VECTOR(12)
|
||||
|
||||
/* USART0, Rx Complete */
|
||||
#define USART0_RX_vect _VECTOR(13)
|
||||
#define SIG_UART_RECV _VECTOR(13)
|
||||
|
||||
/* USART0 Data register Empty */
|
||||
#define USART0_UDRE_vect _VECTOR(14)
|
||||
#define SIG_UART_DATA _VECTOR(14)
|
||||
|
||||
/* USART0, Tx Complete */
|
||||
#define USART0_TX_vect _VECTOR(15)
|
||||
#define SIG_UART_TRANS _VECTOR(15)
|
||||
|
||||
/* USI Start Condition */
|
||||
#define USI_START_vect _VECTOR(16)
|
||||
#define SIG_USI_START _VECTOR(16)
|
||||
|
||||
/* USI Overflow */
|
||||
#define USI_OVERFLOW_vect _VECTOR(17)
|
||||
#define SIG_USI_OVERFLOW _VECTOR(17)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANALOG_COMP_vect _VECTOR(18)
|
||||
#define SIG_COMPARATOR _VECTOR(18)
|
||||
|
||||
/* ADC Conversion Complete */
|
||||
#define ADC_vect _VECTOR(19)
|
||||
#define SIG_ADC _VECTOR(19)
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_READY_vect _VECTOR(20)
|
||||
#define SIG_EEPROM_READY _VECTOR(20)
|
||||
|
||||
/* Store Program Memory Read */
|
||||
#define SPM_READY_vect _VECTOR(21)
|
||||
#define SIG_SPM_READY _VECTOR(21)
|
||||
|
||||
/* Vector 22 is Reserved */
|
||||
|
||||
#define _VECTORS_SIZE 92
|
||||
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 256
|
||||
#define RAMEND 0x10FF
|
||||
#define XRAMEND 0x10FF
|
||||
#define E2END 0x7FF
|
||||
#define E2PAGESIZE 8
|
||||
#define FLASHEND 0xFFFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6)
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_RSTDISBL (unsigned char)~_BV(0)
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(2)
|
||||
#define EFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x96
|
||||
#define SIGNATURE_2 0x05
|
||||
|
||||
|
||||
#endif /* _AVR_IOM645_H_ */
|
|
@ -0,0 +1,907 @@
|
|||
/* Copyright (c) 2004,2005,2006 Eric B. Weddington
|
||||
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: iom6450.h,v 1.11.2.6 2008/10/17 23:27:50 arcanum Exp $ */
|
||||
|
||||
/* avr/iom6450.h - definitions for ATmega6450 */
|
||||
|
||||
#ifndef _AVR_IOM6450_H_
|
||||
#define _AVR_IOM6450_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_ "iom6450.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#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 DDG4 4
|
||||
#define DDG3 3
|
||||
#define DDG2 2
|
||||
#define DDG1 1
|
||||
#define DDG0 0
|
||||
|
||||
#define PORTG _SFR_IO8(0x14)
|
||||
#define PG4 4
|
||||
#define PG3 3
|
||||
#define PG2 2
|
||||
#define PG1 1
|
||||
#define PG0 0
|
||||
|
||||
#define TIFR0 _SFR_IO8(0x15)
|
||||
#define TOV0 0
|
||||
#define OCF0A 1
|
||||
|
||||
#define TIFR1 _SFR_IO8(0x16)
|
||||
#define TOV1 0
|
||||
#define OCF1A 1
|
||||
#define OCF1B 2
|
||||
#define ICF1 5
|
||||
|
||||
#define TIFR2 _SFR_IO8(0x17)
|
||||
#define TOV2 0
|
||||
#define OCF2A 1
|
||||
|
||||
/* Reserved [0x18..0x1B] */
|
||||
|
||||
#define EIFR _SFR_IO8(0x1C)
|
||||
#define INTF0 0
|
||||
#define PCIF0 4
|
||||
#define PCIF1 5
|
||||
#define PCIF2 6
|
||||
#define PCIF3 7
|
||||
|
||||
#define EIMSK _SFR_IO8(0x1D)
|
||||
#define INT0 0
|
||||
#define PCIE0 4
|
||||
#define PCIE1 5
|
||||
#define PCIE2 6
|
||||
#define PCIE3 7
|
||||
|
||||
#define GPIOR0 _SFR_IO8(0x1E)
|
||||
|
||||
#define EECR _SFR_IO8(0x1F)
|
||||
#define EERE 0
|
||||
#define EEWE 1
|
||||
#define EEMWE 2
|
||||
#define EERIE 3
|
||||
|
||||
#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 PSR10 0
|
||||
#define PSR2 1
|
||||
#define TSM 7
|
||||
|
||||
#define TCCR0A _SFR_IO8(0x24)
|
||||
#define CS00 0
|
||||
#define CS01 1
|
||||
#define CS02 2
|
||||
#define WGM01 3
|
||||
#define COM0A0 4
|
||||
#define COM0A1 5
|
||||
#define WGM00 6
|
||||
#define FOC0A 7
|
||||
|
||||
/* Reserved [0x25] */
|
||||
|
||||
#define TCNT0 _SFR_IO8(0X26)
|
||||
|
||||
#define OCR0A _SFR_IO8(0X27)
|
||||
|
||||
/* Reserved [0x28..0x29] */
|
||||
|
||||
#define GPIOR1 _SFR_IO8(0x2A)
|
||||
|
||||
#define GPIOR2 _SFR_IO8(0x2B)
|
||||
|
||||
#define SPCR _SFR_IO8(0x2C)
|
||||
#define SPR0 0
|
||||
#define SPR1 1
|
||||
#define CPHA 2
|
||||
#define CPOL 3
|
||||
#define MSTR 4
|
||||
#define DORD 5
|
||||
#define SPE 6
|
||||
#define SPIE 7
|
||||
|
||||
#define SPSR _SFR_IO8(0x2D)
|
||||
#define SPI2X 0
|
||||
#define WCOL 6
|
||||
#define SPIF 7
|
||||
|
||||
#define SPDR _SFR_IO8(0X2E)
|
||||
|
||||
/* Reserved [0x2F] */
|
||||
|
||||
#define ACSR _SFR_IO8(0x30)
|
||||
#define ACIS0 0
|
||||
#define ACIS1 1
|
||||
#define ACIC 2
|
||||
#define ACIE 3
|
||||
#define ACI 4
|
||||
#define ACO 5
|
||||
#define ACBG 6
|
||||
#define ACD 7
|
||||
|
||||
#define OCDR _SFR_IO8(0x31)
|
||||
#define OCDR0 0
|
||||
#define OCDR1 1
|
||||
#define OCDR2 2
|
||||
#define OCDR3 3
|
||||
#define OCDR4 4
|
||||
#define OCDR5 5
|
||||
#define OCDR6 6
|
||||
#define OCDR7 7
|
||||
#define IDRD 7
|
||||
|
||||
/* Reserved [0x32] */
|
||||
|
||||
#define SMCR _SFR_IO8(0x33)
|
||||
#define SE 0
|
||||
#define SM0 1
|
||||
#define SM1 2
|
||||
#define SM2 3
|
||||
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
#define PORF 0
|
||||
#define EXTRF 1
|
||||
#define BORF 2
|
||||
#define WDRF 3
|
||||
#define JTRF 4
|
||||
|
||||
#define MCUCR _SFR_IO8(0X35)
|
||||
#define IVCE 0
|
||||
#define IVSEL 1
|
||||
#define PUD 4
|
||||
#define JTD 7
|
||||
|
||||
/* Reserved [0x36] */
|
||||
|
||||
#define SPMCSR _SFR_IO8(0x37)
|
||||
#define SPMEN 0
|
||||
#define PGERS 1
|
||||
#define PGWRT 2
|
||||
#define BLBSET 3
|
||||
#define RWWSRE 4
|
||||
#define RWWSB 6
|
||||
#define SPMIE 7
|
||||
|
||||
/* Reserved [0x38..0x3C] */
|
||||
|
||||
/* SP [0x3D..0x3E] */
|
||||
/* SREG [0x3F] */
|
||||
|
||||
#define WDTCR _SFR_MEM8(0x60)
|
||||
#define WDP0 0
|
||||
#define WDP1 1
|
||||
#define WDP2 2
|
||||
#define WDE 3
|
||||
#define WDCE 4
|
||||
|
||||
#define CLKPR _SFR_MEM8(0x61)
|
||||
#define CLKPS0 0
|
||||
#define CLKPS1 1
|
||||
#define CLKPS2 2
|
||||
#define CLKPS3 3
|
||||
#define CLKPCE 7
|
||||
|
||||
/* Reserved [0x62..0x63] */
|
||||
|
||||
#define PRR _SFR_MEM8(0x64)
|
||||
#define PRADC 0
|
||||
#define PRUSART0 1
|
||||
#define PRSPI 2
|
||||
#define PRTIM1 3
|
||||
|
||||
/* Reserved [0x65] */
|
||||
|
||||
#define OSCCAL _SFR_MEM8(0x66)
|
||||
|
||||
/* Reserved [0x67..0x68] */
|
||||
|
||||
#define EICRA _SFR_MEM8(0x69)
|
||||
#define ISC00 0
|
||||
#define ISC01 1
|
||||
|
||||
/* Reserved [0x6A] */
|
||||
|
||||
#define PCMSK0 _SFR_MEM8(0x6B)
|
||||
#define PCINT0 0
|
||||
#define PCINT1 1
|
||||
#define PCINT2 2
|
||||
#define PCINT3 3
|
||||
#define PCINT4 4
|
||||
#define PCINT5 5
|
||||
#define PCINT6 6
|
||||
#define PCINT7 7
|
||||
|
||||
#define PCMSK1 _SFR_MEM8(0x6C)
|
||||
#define PCINT8 0
|
||||
#define PCINT9 1
|
||||
#define PCINT10 2
|
||||
#define PCINT11 3
|
||||
#define PCINT12 4
|
||||
#define PCINT13 5
|
||||
#define PCINT14 6
|
||||
#define PCINT15 7
|
||||
|
||||
#define PCMSK2 _SFR_MEM8(0x6D)
|
||||
#define PCINT16 0
|
||||
#define PCINT17 1
|
||||
#define PCINT18 2
|
||||
#define PCINT19 3
|
||||
#define PCINT20 4
|
||||
#define PCINT21 5
|
||||
#define PCINT22 6
|
||||
#define PCINT23 7
|
||||
|
||||
#define TIMSK0 _SFR_MEM8(0x6E)
|
||||
#define TOIE0 0
|
||||
#define OCIE0A 1
|
||||
|
||||
#define TIMSK1 _SFR_MEM8(0x6F)
|
||||
#define TOIE1 0
|
||||
#define OCIE1A 1
|
||||
#define OCIE1B 2
|
||||
#define ICIE1 5
|
||||
|
||||
#define TIMSK2 _SFR_MEM8(0x70)
|
||||
#define TOIE2 0
|
||||
#define OCIE2A 1
|
||||
|
||||
/* Reserved [0x71..0x72] */
|
||||
|
||||
#define PCMSK3 _SFR_MEM8(0x73)
|
||||
#define PCINT24 0
|
||||
#define PCINT25 1
|
||||
#define PCINT26 2
|
||||
#define PCINT27 3
|
||||
#define PCINT28 4
|
||||
#define PCINT29 5
|
||||
#define PCINT30 6
|
||||
|
||||
/* Reserved [0x74..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 ADPS0 0
|
||||
#define ADPS1 1
|
||||
#define ADPS2 2
|
||||
#define ADIE 3
|
||||
#define ADIF 4
|
||||
#define ADATE 5
|
||||
#define ADSC 6
|
||||
#define ADEN 7
|
||||
|
||||
#define ADCSRB _SFR_MEM8(0x7B)
|
||||
#define ADTS0 0
|
||||
#define ADTS1 1
|
||||
#define ADTS2 2
|
||||
#define ACME 6
|
||||
|
||||
#define ADMUX _SFR_MEM8(0x7C)
|
||||
#define MUX0 0
|
||||
#define MUX1 1
|
||||
#define MUX2 2
|
||||
#define MUX3 3
|
||||
#define MUX4 4
|
||||
#define ADLAR 5
|
||||
#define REFS0 6
|
||||
#define REFS1 7
|
||||
|
||||
/* Reserved [0x7D] */
|
||||
|
||||
#define DIDR0 _SFR_MEM8(0x7E)
|
||||
#define ADC0D 0
|
||||
#define ADC1D 1
|
||||
#define ADC2D 2
|
||||
#define ADC3D 3
|
||||
#define ADC4D 4
|
||||
#define ADC5D 5
|
||||
#define ADC6D 6
|
||||
#define ADC7D 7
|
||||
|
||||
#define DIDR1 _SFR_MEM8(0x7F)
|
||||
#define AIN0D 0
|
||||
#define AIN1D 1
|
||||
|
||||
#define TCCR1A _SFR_MEM8(0X80)
|
||||
#define WGM10 0
|
||||
#define WGM11 1
|
||||
#define COM1B0 4
|
||||
#define COM1B1 5
|
||||
#define COM1A0 6
|
||||
#define COM1A1 7
|
||||
|
||||
#define TCCR1B _SFR_MEM8(0X81)
|
||||
#define CS10 0
|
||||
#define CS11 1
|
||||
#define CS12 2
|
||||
#define WGM12 3
|
||||
#define WGM13 4
|
||||
#define ICES1 6
|
||||
#define ICNC1 7
|
||||
|
||||
#define TCCR1C _SFR_MEM8(0x82)
|
||||
#define FOC1B 6
|
||||
#define FOC1A 7
|
||||
|
||||
/* 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)
|
||||
|
||||
/* Reserved [0x8C..0xAF] */
|
||||
|
||||
#define TCCR2A _SFR_MEM8(0xB0)
|
||||
#define CS20 0
|
||||
#define CS21 1
|
||||
#define CS22 2
|
||||
#define WGM21 3
|
||||
#define COM2A0 4
|
||||
#define COM2A1 5
|
||||
#define WGM20 6
|
||||
#define FOC2A 7
|
||||
|
||||
/* Reserved [0xB1] */
|
||||
|
||||
#define TCNT2 _SFR_MEM8(0xB2)
|
||||
|
||||
#define OCR2A _SFR_MEM8(0xB3)
|
||||
|
||||
/* Reserved [0xB4..0xB5] */
|
||||
|
||||
#define ASSR _SFR_MEM8(0xB6)
|
||||
#define TCR2UB 0
|
||||
#define OCR2UB 1
|
||||
#define TCN2UB 2
|
||||
#define AS2 3
|
||||
#define EXCLK 4
|
||||
|
||||
/* Reserved [0xB7] */
|
||||
|
||||
#define USICR _SFR_MEM8(0xB8)
|
||||
#define USITC 0
|
||||
#define USICLK 1
|
||||
#define USICS0 2
|
||||
#define USICS1 3
|
||||
#define USIWM0 4
|
||||
#define USIWM1 5
|
||||
#define USIOIE 6
|
||||
#define USISIE 7
|
||||
|
||||
#define USISR _SFR_MEM8(0xB9)
|
||||
#define USICNT0 0
|
||||
#define USICNT1 1
|
||||
#define USICNT2 2
|
||||
#define USICNT3 3
|
||||
#define USIDC 4
|
||||
#define USIPF 5
|
||||
#define USIOIF 6
|
||||
#define USISIF 7
|
||||
|
||||
#define USIDR _SFR_MEM8(0xBA)
|
||||
|
||||
/* Reserved [0xBB..0xBF] */
|
||||
|
||||
#define UCSR0A _SFR_MEM8(0xC0)
|
||||
#define MPCM0 0
|
||||
#define U2X0 1
|
||||
#define UPE0 2
|
||||
#define DOR0 3
|
||||
#define FE0 4
|
||||
#define UDRE0 5
|
||||
#define TXC0 6
|
||||
#define RXC0 7
|
||||
|
||||
#define UCSR0B _SFR_MEM8(0XC1)
|
||||
#define TXB80 0
|
||||
#define RXB80 1
|
||||
#define UCSZ02 2
|
||||
#define TXEN0 3
|
||||
#define RXEN0 4
|
||||
#define UDRIE0 5
|
||||
#define TXCIE0 6
|
||||
#define RXCIE0 7
|
||||
|
||||
#define UCSR0C _SFR_MEM8(0xC2)
|
||||
#define UCPOL0 0
|
||||
#define UCSZ00 1
|
||||
#define UCSZ01 2
|
||||
#define USBS0 3
|
||||
#define UPM00 4
|
||||
#define UPM01 5
|
||||
#define UMSEL0 6
|
||||
|
||||
/* 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..0xD7] */
|
||||
|
||||
#define PINH _SFR_MEM8(0xD8)
|
||||
#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(0xD9)
|
||||
#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(0xDA)
|
||||
#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(0xDB)
|
||||
#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(0xDC)
|
||||
#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(0xDD)
|
||||
#define PJ6 6
|
||||
#define PJ5 5
|
||||
#define PJ4 4
|
||||
#define PJ3 3
|
||||
#define PJ2 2
|
||||
#define PJ1 1
|
||||
#define PJ0 0
|
||||
|
||||
/* Reserved [0xDE..0xFF] */
|
||||
|
||||
|
||||
/* Interrupt vectors */
|
||||
/* Vector 0 is the reset vector */
|
||||
/* External Interrupt Request 0 */
|
||||
#define INT0_vect _VECTOR(1)
|
||||
#define SIG_INTERRUPT0 _VECTOR(1)
|
||||
|
||||
/* Pin Change Interrupt Request 0 */
|
||||
#define PCINT0_vect _VECTOR(2)
|
||||
#define SIG_PIN_CHANGE0 _VECTOR(2)
|
||||
|
||||
/* Pin Change Interrupt Request 1 */
|
||||
#define PCINT1_vect _VECTOR(3)
|
||||
#define SIG_PIN_CHANGE1 _VECTOR(3)
|
||||
|
||||
/* Timer/Counter2 Compare Match */
|
||||
#define TIMER2_COMP_vect _VECTOR(4)
|
||||
#define SIG_OUTPUT_COMPARE2 _VECTOR(4)
|
||||
|
||||
/* Timer/Counter2 Overflow */
|
||||
#define TIMER2_OVF_vect _VECTOR(5)
|
||||
#define SIG_OVERFLOW2 _VECTOR(5)
|
||||
|
||||
/* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(6)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(6)
|
||||
|
||||
/* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPA_vect _VECTOR(7)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(7)
|
||||
|
||||
/* Timer/Counter Compare Match B */
|
||||
#define TIMER1_COMPB_vect _VECTOR(8)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(8)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(9)
|
||||
#define SIG_OVERFLOW1 _VECTOR(9)
|
||||
|
||||
/* Timer/Counter0 Compare Match */
|
||||
#define TIMER0_COMP_vect _VECTOR(10)
|
||||
#define SIG_OUTPUT_COMPARE0 _VECTOR(10)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(11)
|
||||
#define SIG_OVERFLOW0 _VECTOR(11)
|
||||
|
||||
/* SPI Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(12)
|
||||
#define SIG_SPI _VECTOR(12)
|
||||
|
||||
/* USART, Rx Complete */
|
||||
#define USART_RX_vect _VECTOR(13)
|
||||
#define USART0_RX_vect _VECTOR(13) /* Alias */
|
||||
#define SIG_UART_RECV _VECTOR(13)
|
||||
|
||||
/* USART Data register Empty */
|
||||
#define USART_UDRE_vect _VECTOR(14)
|
||||
#define USART0_UDRE_vect _VECTOR(14) /* Alias */
|
||||
#define SIG_UART_DATA _VECTOR(14)
|
||||
|
||||
/* USART0, Tx Complete */
|
||||
#define USART0_TX_vect _VECTOR(15)
|
||||
#define USART_TX_vect _VECTOR(15) /* Alias */
|
||||
#define SIG_UART_TRANS _VECTOR(15)
|
||||
|
||||
/* USI Start Condition */
|
||||
#define USI_START_vect _VECTOR(16)
|
||||
#define SIG_USI_START _VECTOR(16)
|
||||
|
||||
/* USI Overflow */
|
||||
#define USI_OVERFLOW_vect _VECTOR(17)
|
||||
#define SIG_USI_OVERFLOW _VECTOR(17)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANALOG_COMP_vect _VECTOR(18)
|
||||
#define SIG_COMPARATOR _VECTOR(18)
|
||||
|
||||
/* ADC Conversion Complete */
|
||||
#define ADC_vect _VECTOR(19)
|
||||
#define SIG_ADC _VECTOR(19)
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_READY_vect _VECTOR(20)
|
||||
#define SIG_EEPROM_READY _VECTOR(20)
|
||||
|
||||
/* Store Program Memory Read */
|
||||
#define SPM_READY_vect _VECTOR(21)
|
||||
#define SIG_SPM_READY _VECTOR(21)
|
||||
|
||||
/* Pin Change Interrupt Request 2 */
|
||||
#define PCINT2_vect _VECTOR(23)
|
||||
#define SIG_PIN_CHANGE2 _VECTOR(23)
|
||||
|
||||
/* Pin Change Interrupt Request 3 */
|
||||
#define PCINT3_vect _VECTOR(24)
|
||||
#define SIG_PIN_CHANGE3 _VECTOR(24)
|
||||
|
||||
#define _VECTORS_SIZE 100
|
||||
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 256
|
||||
#define RAMEND 0x10FF
|
||||
#define XRAMEND 0x10FF
|
||||
#define E2END 0x7FF
|
||||
#define E2PAGESIZE 8
|
||||
#define FLASHEND 0xFFFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6)
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_RSTDISBL (unsigned char)~_BV(0)
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(2)
|
||||
#define EFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x96
|
||||
#define SIGNATURE_2 0x06
|
||||
|
||||
|
||||
#endif /* _AVR_IOM6450_H_ */
|
992
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom649.h
Normal file
992
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom649.h
Normal file
|
@ -0,0 +1,992 @@
|
|||
/* Copyright (c) 2004 Eric B. Weddington
|
||||
Copyright (c) 2005,2006 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. */
|
||||
|
||||
/* avr/iom649.h - definitions for ATmega649 */
|
||||
|
||||
#ifndef _AVR_IOM649_H_
|
||||
#define _AVR_IOM649_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_ "iom649.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#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 DDG4 4
|
||||
#define DDG3 3
|
||||
#define DDG2 2
|
||||
#define DDG1 1
|
||||
#define DDG0 0
|
||||
|
||||
#define PORTG _SFR_IO8(0x14)
|
||||
#define PG4 4
|
||||
#define PG3 3
|
||||
#define PG2 2
|
||||
#define PG1 1
|
||||
#define PG0 0
|
||||
|
||||
#define TIFR0 _SFR_IO8(0x15)
|
||||
#define TOV0 0
|
||||
#define OCF0A 1
|
||||
|
||||
#define TIFR1 _SFR_IO8(0x16)
|
||||
#define TOV1 0
|
||||
#define OCF1A 1
|
||||
#define OCF1B 2
|
||||
#define ICF1 5
|
||||
|
||||
#define TIFR2 _SFR_IO8(0x17)
|
||||
#define TOV2 0
|
||||
#define OCF2A 1
|
||||
|
||||
/* Reserved [0x18..0x1B] */
|
||||
|
||||
#define EIFR _SFR_IO8(0x1C)
|
||||
#define INTF0 0
|
||||
#define PCIF0 4
|
||||
#define PCIF1 5
|
||||
|
||||
#define EIMSK _SFR_IO8(0x1D)
|
||||
#define INT0 0
|
||||
#define PCIE0 4
|
||||
#define PCIE1 5
|
||||
|
||||
#define GPIOR0 _SFR_IO8(0x1E)
|
||||
|
||||
#define EECR _SFR_IO8(0x1F)
|
||||
#define EERIE 3
|
||||
#define EEMWE 2
|
||||
#define EEWE 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 PSR10 0
|
||||
#define PSR2 1
|
||||
#define TSM 7
|
||||
|
||||
#define TCCR0A _SFR_IO8(0x24)
|
||||
#define CS00 0
|
||||
#define CS01 1
|
||||
#define CS02 2
|
||||
#define WGM01 3
|
||||
#define COM0A0 4
|
||||
#define COM0A1 5
|
||||
#define WGM00 6
|
||||
#define FOC0A 7
|
||||
|
||||
/* Reserved [0x25] */
|
||||
|
||||
#define TCNT0 _SFR_IO8(0X26)
|
||||
|
||||
#define OCR0A _SFR_IO8(0X27)
|
||||
|
||||
/* Reserved [0x28..0x29] */
|
||||
|
||||
#define GPIOR1 _SFR_IO8(0x2A)
|
||||
|
||||
#define GPIOR2 _SFR_IO8(0x2B)
|
||||
|
||||
#define SPCR _SFR_IO8(0x2C)
|
||||
#define SPR0 0
|
||||
#define SPR1 1
|
||||
#define CPHA 2
|
||||
#define CPOL 3
|
||||
#define MSTR 4
|
||||
#define DORD 5
|
||||
#define SPE 6
|
||||
#define SPIE 7
|
||||
|
||||
#define SPSR _SFR_IO8(0x2D)
|
||||
#define SPI2X 0
|
||||
#define WCOL 6
|
||||
#define SPIF 7
|
||||
|
||||
#define SPDR _SFR_IO8(0X2E)
|
||||
|
||||
/* Reserved [0x2F] */
|
||||
|
||||
#define ACSR _SFR_IO8(0x30)
|
||||
#define ACIS0 0
|
||||
#define ACIS1 1
|
||||
#define ACIC 2
|
||||
#define ACIE 3
|
||||
#define ACI 4
|
||||
#define ACO 5
|
||||
#define ACBG 6
|
||||
#define ACD 7
|
||||
|
||||
#define OCDR _SFR_IO8(0x31)
|
||||
#define OCDR0 0
|
||||
#define OCDR1 1
|
||||
#define OCDR2 2
|
||||
#define OCDR3 3
|
||||
#define OCDR4 4
|
||||
#define OCDR5 5
|
||||
#define OCDR6 6
|
||||
#define OCDR7 7
|
||||
#define IDRD 7
|
||||
|
||||
/* Reserved [0x32] */
|
||||
|
||||
#define SMCR _SFR_IO8(0x33)
|
||||
#define SE 0
|
||||
#define SM0 1
|
||||
#define SM1 2
|
||||
#define SM2 3
|
||||
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
#define PORF 0
|
||||
#define EXTRF 1
|
||||
#define BORF 2
|
||||
#define WDRF 3
|
||||
#define JTRF 4
|
||||
|
||||
#define MCUCR _SFR_IO8(0X35)
|
||||
#define IVCE 0
|
||||
#define IVSEL 1
|
||||
#define PUD 4
|
||||
#define JTD 7
|
||||
|
||||
/* Reserved [0x36] */
|
||||
|
||||
#define SPMCSR _SFR_IO8(0x37)
|
||||
#define SPMEN 0
|
||||
#define PGERS 1
|
||||
#define PGWRT 2
|
||||
#define BLBSET 3
|
||||
#define RWWSRE 4
|
||||
#define RWWSB 6
|
||||
#define SPMIE 7
|
||||
|
||||
/* Reserved [0x38..0x3C] */
|
||||
|
||||
/* SP [0x3D..0x3E] */
|
||||
/* SREG [0x3F] */
|
||||
|
||||
#define WDTCR _SFR_MEM8(0x60)
|
||||
#define WDP0 0
|
||||
#define WDP1 1
|
||||
#define WDP2 2
|
||||
#define WDE 3
|
||||
#define WDCE 4
|
||||
|
||||
#define CLKPR _SFR_MEM8(0x61)
|
||||
#define CLKPS0 0
|
||||
#define CLKPS1 1
|
||||
#define CLKPS2 2
|
||||
#define CLKPS3 3
|
||||
#define CLKPCE 7
|
||||
|
||||
/* Reserved [0x62..0x63] */
|
||||
|
||||
#define PRR _SFR_MEM8(0x64)
|
||||
#define PRADC 0
|
||||
#define PRUSART0 1
|
||||
#define PRSPI 2
|
||||
#define PRTIM1 3
|
||||
#define PRLCD 4
|
||||
|
||||
/* Reserved [0x65] */
|
||||
|
||||
#define OSCCAL _SFR_MEM8(0x66)
|
||||
|
||||
/* Reserved [0x67..0x68] */
|
||||
|
||||
#define EICRA _SFR_MEM8(0x69)
|
||||
#define ISC00 0
|
||||
#define ISC01 1
|
||||
|
||||
/* Reserved [0x6A] */
|
||||
|
||||
#define PCMSK0 _SFR_MEM8(0x6B)
|
||||
#define PCINT0 0
|
||||
#define PCINT1 1
|
||||
#define PCINT2 2
|
||||
#define PCINT3 3
|
||||
#define PCINT4 4
|
||||
#define PCINT5 5
|
||||
#define PCINT6 6
|
||||
#define PCINT7 7
|
||||
|
||||
#define PCMSK1 _SFR_MEM8(0x6C)
|
||||
#define PCINT8 0
|
||||
#define PCINT9 1
|
||||
#define PCINT10 2
|
||||
#define PCINT11 3
|
||||
#define PCINT12 4
|
||||
#define PCINT13 5
|
||||
#define PCINT14 6
|
||||
#define PCINT15 7
|
||||
|
||||
/* Reserved [0x6D] */
|
||||
|
||||
#define TIMSK0 _SFR_MEM8(0x6E)
|
||||
#define TOIE0 0
|
||||
#define OCIE0A 1
|
||||
|
||||
#define TIMSK1 _SFR_MEM8(0x6F)
|
||||
#define TOIE1 0
|
||||
#define OCIE1A 1
|
||||
#define OCIE1B 2
|
||||
#define ICIE1 5
|
||||
|
||||
#define TIMSK2 _SFR_MEM8(0x70)
|
||||
#define TOIE2 0
|
||||
#define OCIE2A 1
|
||||
|
||||
/* Reserved [0x71..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 ADPS0 0
|
||||
#define ADPS1 1
|
||||
#define ADPS2 2
|
||||
#define ADIE 3
|
||||
#define ADIF 4
|
||||
#define ADATE 5
|
||||
#define ADSC 6
|
||||
#define ADEN 7
|
||||
|
||||
#define ADCSRB _SFR_MEM8(0x7B)
|
||||
#define ADTS0 0
|
||||
#define ADTS1 1
|
||||
#define ADTS2 2
|
||||
#define ACME 6
|
||||
|
||||
#define ADMUX _SFR_MEM8(0x7C)
|
||||
#define MUX0 0
|
||||
#define MUX1 1
|
||||
#define MUX2 2
|
||||
#define MUX3 3
|
||||
#define MUX4 4
|
||||
#define ADLAR 5
|
||||
#define REFS0 6
|
||||
#define REFS1 7
|
||||
|
||||
/* Reserved [0x7D] */
|
||||
|
||||
#define DIDR0 _SFR_MEM8(0x7E)
|
||||
#define ADC0D 0
|
||||
#define ADC1D 1
|
||||
#define ADC2D 2
|
||||
#define ADC3D 3
|
||||
#define ADC4D 4
|
||||
#define ADC5D 5
|
||||
#define ADC6D 6
|
||||
#define ADC7D 7
|
||||
|
||||
#define DIDR1 _SFR_MEM8(0x7F)
|
||||
#define AIN0D 0
|
||||
#define AIN1D 1
|
||||
|
||||
#define TCCR1A _SFR_MEM8(0X80)
|
||||
#define WGM10 0
|
||||
#define WGM11 1
|
||||
#define COM1B0 4
|
||||
#define COM1B1 5
|
||||
#define COM1A0 6
|
||||
#define COM1A1 7
|
||||
|
||||
#define TCCR1B _SFR_MEM8(0X81)
|
||||
#define CS10 0
|
||||
#define CS11 1
|
||||
#define CS12 2
|
||||
#define WGM12 3
|
||||
#define WGM13 4
|
||||
#define ICES1 6
|
||||
#define ICNC1 7
|
||||
|
||||
#define TCCR1C _SFR_MEM8(0x82)
|
||||
#define FOC1B 6
|
||||
#define FOC1A 7
|
||||
|
||||
/* 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)
|
||||
|
||||
/* Reserved [0x8C..0xAF] */
|
||||
|
||||
#define TCCR2A _SFR_MEM8(0xB0)
|
||||
#define CS20 0
|
||||
#define CS21 1
|
||||
#define CS22 2
|
||||
#define WGM21 3
|
||||
#define COM2A0 4
|
||||
#define COM2A1 5
|
||||
#define WGM20 6
|
||||
#define FOC2A 7
|
||||
|
||||
/* Reserved [0xB1] */
|
||||
|
||||
#define TCNT2 _SFR_MEM8(0xB2)
|
||||
|
||||
#define OCR2A _SFR_MEM8(0xB3)
|
||||
|
||||
/* Reserved [0xB4..0xB5] */
|
||||
|
||||
#define ASSR _SFR_MEM8(0xB6)
|
||||
#define TCR2UB 0
|
||||
#define OCR2UB 1
|
||||
#define TCN2UB 2
|
||||
#define AS2 3
|
||||
#define EXCLK 4
|
||||
|
||||
/* Reserved [0xB7] */
|
||||
|
||||
#define USICR _SFR_MEM8(0xB8)
|
||||
#define USITC 0
|
||||
#define USICLK 1
|
||||
#define USICS0 2
|
||||
#define USICS1 3
|
||||
#define USIWM0 4
|
||||
#define USIWM1 5
|
||||
#define USIOIE 6
|
||||
#define USISIE 7
|
||||
|
||||
#define USISR _SFR_MEM8(0xB9)
|
||||
#define USICNT0 0
|
||||
#define USICNT1 1
|
||||
#define USICNT2 2
|
||||
#define USICNT3 3
|
||||
#define USIDC 4
|
||||
#define USIPF 5
|
||||
#define USIOIF 6
|
||||
#define USISIF 7
|
||||
|
||||
#define USIDR _SFR_MEM8(0xBA)
|
||||
|
||||
/* Reserved [0xBB..0xBF] */
|
||||
|
||||
#define UCSR0A _SFR_MEM8(0xC0)
|
||||
#define MPCM0 0
|
||||
#define U2X0 1
|
||||
#define UPE0 2
|
||||
#define DOR0 3
|
||||
#define FE0 4
|
||||
#define UDRE0 5
|
||||
#define TXC0 6
|
||||
#define RXC0 7
|
||||
|
||||
#define UCSR0B _SFR_MEM8(0XC1)
|
||||
#define TXB80 0
|
||||
#define RXB80 1
|
||||
#define UCSZ02 2
|
||||
#define TXEN0 3
|
||||
#define RXEN0 4
|
||||
#define UDRIE0 5
|
||||
#define TXCIE0 6
|
||||
#define RXCIE0 7
|
||||
|
||||
#define UCSR0C _SFR_MEM8(0xC2)
|
||||
#define UCPOL0 0
|
||||
#define UCSZ00 1
|
||||
#define UCSZ01 2
|
||||
#define USBS0 3
|
||||
#define UPM00 4
|
||||
#define UPM01 5
|
||||
#define UMSEL0 6
|
||||
|
||||
/* 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..0xE3] */
|
||||
|
||||
#define LCDCRA _SFR_MEM8(0XE4)
|
||||
#define LCDBL 0
|
||||
#define LCDIE 3
|
||||
#define LCDIF 4
|
||||
#define LCDAB 6
|
||||
#define LCDEN 7
|
||||
|
||||
#define LCDCRB _SFR_MEM8(0XE5)
|
||||
#define LCDPM0 0
|
||||
#define LCDPM1 1
|
||||
#define LCDPM2 2
|
||||
#define LCDMUX0 4
|
||||
#define LCDMUX1 5
|
||||
#define LCD2B 6
|
||||
#define LCDCS 7
|
||||
|
||||
#define LCDFRR _SFR_MEM8(0XE6)
|
||||
#define LCDCD0 0
|
||||
#define LCDCD1 1
|
||||
#define LCDCD2 2
|
||||
#define LCDPS0 4
|
||||
#define LCDPS1 5
|
||||
#define LCDPS2 6
|
||||
|
||||
#define LCDCCR _SFR_MEM8(0XE7)
|
||||
#define LCDCC0 0
|
||||
#define LCDCC1 1
|
||||
#define LCDCC2 2
|
||||
#define LCDCC3 3
|
||||
#define LCDDC0 5
|
||||
#define LCDDC1 6
|
||||
#define LCDDC2 7
|
||||
|
||||
/* Reserved [0xE8..0xEB] */
|
||||
|
||||
#define LCDDR00 _SFR_MEM8(0XEC)
|
||||
#define SEG000 0
|
||||
#define SEG001 1
|
||||
#define SEG002 2
|
||||
#define SEG003 3
|
||||
#define SEG004 4
|
||||
#define SEG005 5
|
||||
#define SEG006 6
|
||||
#define SEG007 7
|
||||
|
||||
#define LCDDR01 _SFR_MEM8(0XED)
|
||||
#define SEG008 0
|
||||
#define SEG009 1
|
||||
#define SEG010 2
|
||||
#define SEG011 3
|
||||
#define SEG012 4
|
||||
#define SEG013 5
|
||||
#define SEG014 6
|
||||
#define SEG015 7
|
||||
|
||||
#define LCDDR02 _SFR_MEM8(0XEE)
|
||||
#define SEG016 0
|
||||
#define SEG017 1
|
||||
#define SEG018 2
|
||||
#define SEG019 3
|
||||
#define SEG020 4
|
||||
#define SEG021 5
|
||||
#define SEG022 6
|
||||
#define SEG023 7
|
||||
|
||||
#define LCDDR03 _SFR_MEM8(0XEF)
|
||||
#define SEG024 0
|
||||
|
||||
/* Reserved [0xF0] */
|
||||
|
||||
#define LCDDR05 _SFR_MEM8(0XF1)
|
||||
#define SEG100 0
|
||||
#define SEG101 1
|
||||
#define SEG102 2
|
||||
#define SEG103 3
|
||||
#define SEG104 4
|
||||
#define SEG105 5
|
||||
#define SEG106 6
|
||||
#define SEG107 7
|
||||
|
||||
#define LCDDR06 _SFR_MEM8(0XF2)
|
||||
#define SEG108 0
|
||||
#define SEG109 1
|
||||
#define SEG110 2
|
||||
#define SEG111 3
|
||||
#define SEG112 4
|
||||
#define SEG113 5
|
||||
#define SEG114 6
|
||||
#define SEG115 7
|
||||
|
||||
#define LCDDR07 _SFR_MEM8(0XF3)
|
||||
#define SEG116 0
|
||||
#define SEG117 1
|
||||
#define SEG118 2
|
||||
#define SEG119 3
|
||||
#define SEG120 4
|
||||
#define SEG121 5
|
||||
#define SEG122 6
|
||||
#define SEG123 7
|
||||
|
||||
#define LCDDR08 _SFR_MEM8(0XF4)
|
||||
#define SEG124 0
|
||||
|
||||
/* Reserved [0xF5] */
|
||||
|
||||
#define LCDDR10 _SFR_MEM8(0XF6)
|
||||
#define SEG200 0
|
||||
#define SEG201 1
|
||||
#define SEG202 2
|
||||
#define SEG203 3
|
||||
#define SEG204 4
|
||||
#define SEG205 5
|
||||
#define SEG206 6
|
||||
#define SEG207 7
|
||||
|
||||
#define LCDDR11 _SFR_MEM8(0XF7)
|
||||
#define SEG208 0
|
||||
#define SEG209 1
|
||||
#define SEG210 2
|
||||
#define SEG211 3
|
||||
#define SEG212 4
|
||||
#define SEG213 5
|
||||
#define SEG214 6
|
||||
#define SEG215 7
|
||||
|
||||
#define LCDDR12 _SFR_MEM8(0XF8)
|
||||
#define SEG216 0
|
||||
#define SEG217 1
|
||||
#define SEG218 2
|
||||
#define SEG219 3
|
||||
#define SEG220 4
|
||||
#define SEG221 5
|
||||
#define SEG222 6
|
||||
#define SEG223 7
|
||||
|
||||
#define LCDDR13 _SFR_MEM8(0XF9)
|
||||
#define SEG224 0
|
||||
|
||||
/* Reserved [0xFA] */
|
||||
|
||||
#define LCDDR15 _SFR_MEM8(0XFB)
|
||||
#define SEG300 0
|
||||
#define SEG301 1
|
||||
#define SEG302 2
|
||||
#define SEG303 3
|
||||
#define SEG304 4
|
||||
#define SEG305 5
|
||||
#define SEG306 6
|
||||
#define SEG307 7
|
||||
|
||||
#define LCDDR16 _SFR_MEM8(0XFC)
|
||||
#define SEG308 0
|
||||
#define SEG309 1
|
||||
#define SEG310 2
|
||||
#define SEG311 3
|
||||
#define SEG312 4
|
||||
#define SEG313 5
|
||||
#define SEG314 6
|
||||
#define SEG315 7
|
||||
|
||||
#define LCDDR17 _SFR_MEM8(0XFD)
|
||||
#define SEG316 0
|
||||
#define SEG217 1
|
||||
#define SEG318 2
|
||||
#define SEG319 3
|
||||
#define SEG320 4
|
||||
#define SEG321 5
|
||||
#define SEG322 6
|
||||
#define SEG323 7
|
||||
|
||||
#define LCDDR18 _SFR_MEM8(0XFE)
|
||||
#define SEG324 0
|
||||
|
||||
/* Reserved [0xFF] */
|
||||
|
||||
/* Interrupt vectors */
|
||||
/* Vector 0 is the reset vector */
|
||||
/* External Interrupt Request 0 */
|
||||
#define INT0_vect _VECTOR(1)
|
||||
#define SIG_INTERRUPT0 _VECTOR(1)
|
||||
|
||||
/* Pin Change Interrupt Request 0 */
|
||||
#define PCINT0_vect _VECTOR(2)
|
||||
#define SIG_PIN_CHANGE0 _VECTOR(2)
|
||||
|
||||
/* Pin Change Interrupt Request 1 */
|
||||
#define PCINT1_vect _VECTOR(3)
|
||||
#define SIG_PIN_CHANGE1 _VECTOR(3)
|
||||
|
||||
/* Timer/Counter2 Compare Match */
|
||||
#define TIMER2_COMP_vect _VECTOR(4)
|
||||
#define SIG_OUTPUT_COMPARE2 _VECTOR(4)
|
||||
|
||||
/* Timer/Counter2 Overflow */
|
||||
#define TIMER2_OVF_vect _VECTOR(5)
|
||||
#define SIG_OVERFLOW2 _VECTOR(5)
|
||||
|
||||
/* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(6)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(6)
|
||||
|
||||
/* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPA_vect _VECTOR(7)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(7)
|
||||
|
||||
/* Timer/Counter Compare Match B */
|
||||
#define TIMER1_COMPB_vect _VECTOR(8)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(8)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(9)
|
||||
#define SIG_OVERFLOW1 _VECTOR(9)
|
||||
|
||||
/* Timer/Counter0 Compare Match */
|
||||
#define TIMER0_COMP_vect _VECTOR(10)
|
||||
#define SIG_OUTPUT_COMPARE0 _VECTOR(10)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(11)
|
||||
#define SIG_OVERFLOW0 _VECTOR(11)
|
||||
|
||||
/* SPI Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(12)
|
||||
#define SIG_SPI _VECTOR(12)
|
||||
|
||||
/* USART0, Rx Complete */
|
||||
#define USART0_RX_vect _VECTOR(13)
|
||||
#define SIG_UART_RECV _VECTOR(13)
|
||||
|
||||
/* USART0 Data register Empty */
|
||||
#define USART0_UDRE_vect _VECTOR(14)
|
||||
#define SIG_UART_DATA _VECTOR(14)
|
||||
|
||||
/* USART0, Tx Complete */
|
||||
#define USART0_TX_vect _VECTOR(15)
|
||||
#define SIG_UART_TRANS _VECTOR(15)
|
||||
|
||||
/* USI Start Condition */
|
||||
#define USI_START_vect _VECTOR(16)
|
||||
#define SIG_USI_START _VECTOR(16)
|
||||
|
||||
/* USI Overflow */
|
||||
#define USI_OVERFLOW_vect _VECTOR(17)
|
||||
#define SIG_USI_OVERFLOW _VECTOR(17)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANALOG_COMP_vect _VECTOR(18)
|
||||
#define SIG_COMPARATOR _VECTOR(18)
|
||||
|
||||
/* ADC Conversion Complete */
|
||||
#define ADC_vect _VECTOR(19)
|
||||
#define SIG_ADC _VECTOR(19)
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_READY_vect _VECTOR(20)
|
||||
#define SIG_EEPROM_READY _VECTOR(20)
|
||||
|
||||
/* Store Program Memory Read */
|
||||
#define SPM_READY_vect _VECTOR(21)
|
||||
#define SIG_SPM_READY _VECTOR(21)
|
||||
|
||||
/* LCD Start of Frame */
|
||||
#define LCD_vect _VECTOR(22)
|
||||
#define SIG_LCD _VECTOR(22)
|
||||
|
||||
#define _VECTORS_SIZE 92
|
||||
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 256
|
||||
#define RAMEND 0x10FF
|
||||
#define XRAMEND 0x10FF
|
||||
#define E2END 0x7FF
|
||||
#define E2PAGESIZE 8
|
||||
#define FLASHEND 0xFFFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6)
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_JTAGEN (unsigned char)~_BV(6)
|
||||
#define FUSE_OCDEN (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_RSTDISBL (unsigned char)~_BV(0)
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(2)
|
||||
#define EFUSE_DEFAULT (0xFF)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x96
|
||||
#define SIGNATURE_2 0x03
|
||||
|
||||
|
||||
#endif /* _AVR_IOM649_H_ */
|
1144
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom6490.h
Normal file
1144
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom6490.h
Normal file
File diff suppressed because it is too large
Load diff
614
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom8.h
Normal file
614
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom8.h
Normal file
|
@ -0,0 +1,614 @@
|
|||
/* Copyright (c) 2002, Marek Michalkiewicz
|
||||
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: iom8.h,v 1.14.2.6 2008/10/17 23:27:50 arcanum Exp $ */
|
||||
|
||||
/* avr/iom8.h - definitions for ATmega8 */
|
||||
|
||||
#ifndef _AVR_IOM8_H_
|
||||
#define _AVR_IOM8_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_ "iom8.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* TWI stands for "Two Wire Interface" or "TWI Was I2C(tm)" */
|
||||
#define TWBR _SFR_IO8(0x00)
|
||||
#define TWSR _SFR_IO8(0x01)
|
||||
#define TWAR _SFR_IO8(0x02)
|
||||
#define TWDR _SFR_IO8(0x03)
|
||||
|
||||
/* ADC */
|
||||
#define ADCW _SFR_IO16(0x04)
|
||||
#ifndef __ASSEMBLER__
|
||||
#define ADC _SFR_IO16(0x04)
|
||||
#endif
|
||||
#define ADCL _SFR_IO8(0x04)
|
||||
#define ADCH _SFR_IO8(0x05)
|
||||
#define ADCSR _SFR_IO8(0x06)
|
||||
#define ADCSRA _SFR_IO8(0x06) /* Changed in 2486H-AVR-09/02 */
|
||||
#define ADMUX _SFR_IO8(0x07)
|
||||
|
||||
/* analog comparator */
|
||||
#define ACSR _SFR_IO8(0x08)
|
||||
|
||||
/* USART */
|
||||
#define UBRRL _SFR_IO8(0x09)
|
||||
#define UCSRB _SFR_IO8(0x0A)
|
||||
#define UCSRA _SFR_IO8(0x0B)
|
||||
#define UDR _SFR_IO8(0x0C)
|
||||
|
||||
/* SPI */
|
||||
#define SPCR _SFR_IO8(0x0D)
|
||||
#define SPSR _SFR_IO8(0x0E)
|
||||
#define SPDR _SFR_IO8(0x0F)
|
||||
|
||||
/* Port D */
|
||||
#define PIND _SFR_IO8(0x10)
|
||||
#define DDRD _SFR_IO8(0x11)
|
||||
#define PORTD _SFR_IO8(0x12)
|
||||
|
||||
/* Port C */
|
||||
#define PINC _SFR_IO8(0x13)
|
||||
#define DDRC _SFR_IO8(0x14)
|
||||
#define PORTC _SFR_IO8(0x15)
|
||||
|
||||
/* Port B */
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EECR _SFR_IO8(0x1C)
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define EEDR _SFR_IO8(0x1D)
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#define EEAR _SFR_IO16(0x1E)
|
||||
#define EEARL _SFR_IO8(0x1E)
|
||||
#define EEARH _SFR_IO8(0x1F)
|
||||
|
||||
#define UCSRC _SFR_IO8(0x20)
|
||||
#define UBRRH _SFR_IO8(0x20)
|
||||
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
#define ASSR _SFR_IO8(0x22)
|
||||
|
||||
/* Timer 2 */
|
||||
#define OCR2 _SFR_IO8(0x23)
|
||||
#define TCNT2 _SFR_IO8(0x24)
|
||||
#define TCCR2 _SFR_IO8(0x25)
|
||||
|
||||
/* Timer 1 */
|
||||
#define ICR1 _SFR_IO16(0x26)
|
||||
#define ICR1L _SFR_IO8(0x26)
|
||||
#define ICR1H _SFR_IO8(0x27)
|
||||
#define OCR1B _SFR_IO16(0x28)
|
||||
#define OCR1BL _SFR_IO8(0x28)
|
||||
#define OCR1BH _SFR_IO8(0x29)
|
||||
#define OCR1A _SFR_IO16(0x2A)
|
||||
#define OCR1AL _SFR_IO8(0x2A)
|
||||
#define OCR1AH _SFR_IO8(0x2B)
|
||||
#define TCNT1 _SFR_IO16(0x2C)
|
||||
#define TCNT1L _SFR_IO8(0x2C)
|
||||
#define TCNT1H _SFR_IO8(0x2D)
|
||||
#define TCCR1B _SFR_IO8(0x2E)
|
||||
#define TCCR1A _SFR_IO8(0x2F)
|
||||
|
||||
#define SFIOR _SFR_IO8(0x30)
|
||||
|
||||
#define OSCCAL _SFR_IO8(0x31)
|
||||
|
||||
/* Timer 0 */
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
#define MCUCSR _SFR_IO8(0x34)
|
||||
#define MCUSR _SFR_IO8(0x34) /* Defined as an alias for MCUCSR. */
|
||||
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
#define TWCR _SFR_IO8(0x36)
|
||||
|
||||
#define SPMCR _SFR_IO8(0x37)
|
||||
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
|
||||
#define GIFR _SFR_IO8(0x3A)
|
||||
#define GIMSK _SFR_IO8(0x3B)
|
||||
#define GICR _SFR_IO8(0x3B) /* Changed in 2486H-AVR-09/02 */
|
||||
|
||||
/* 0x3C reserved (OCR0?) */
|
||||
|
||||
/* 0x3D..0x3E SP */
|
||||
|
||||
/* 0x3F SREG */
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
/* 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)
|
||||
|
||||
/* Timer/Counter2 Compare Match */
|
||||
#define TIMER2_COMP_vect _VECTOR(3)
|
||||
#define SIG_OUTPUT_COMPARE2 _VECTOR(3)
|
||||
|
||||
/* Timer/Counter2 Overflow */
|
||||
#define TIMER2_OVF_vect _VECTOR(4)
|
||||
#define SIG_OVERFLOW2 _VECTOR(4)
|
||||
|
||||
/* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(5)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(5)
|
||||
|
||||
/* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPA_vect _VECTOR(6)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(6)
|
||||
|
||||
/* Timer/Counter1 Compare Match B */
|
||||
#define TIMER1_COMPB_vect _VECTOR(7)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(7)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(8)
|
||||
#define SIG_OVERFLOW1 _VECTOR(8)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(9)
|
||||
#define SIG_OVERFLOW0 _VECTOR(9)
|
||||
|
||||
/* Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(10)
|
||||
#define SIG_SPI _VECTOR(10)
|
||||
|
||||
/* USART, Rx Complete */
|
||||
#define USART_RXC_vect _VECTOR(11)
|
||||
#define SIG_UART_RECV _VECTOR(11)
|
||||
|
||||
/* USART Data Register Empty */
|
||||
#define USART_UDRE_vect _VECTOR(12)
|
||||
#define SIG_UART_DATA _VECTOR(12)
|
||||
|
||||
/* USART, Tx Complete */
|
||||
#define USART_TXC_vect _VECTOR(13)
|
||||
#define SIG_UART_TRANS _VECTOR(13)
|
||||
|
||||
/* ADC Conversion Complete */
|
||||
#define ADC_vect _VECTOR(14)
|
||||
#define SIG_ADC _VECTOR(14)
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_RDY_vect _VECTOR(15)
|
||||
#define SIG_EEPROM_READY _VECTOR(15)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANA_COMP_vect _VECTOR(16)
|
||||
#define SIG_COMPARATOR _VECTOR(16)
|
||||
|
||||
/* 2-wire Serial Interface */
|
||||
#define TWI_vect _VECTOR(17)
|
||||
#define SIG_2WIRE_SERIAL _VECTOR(17)
|
||||
|
||||
/* Store Program Memory Ready */
|
||||
#define SPM_RDY_vect _VECTOR(18)
|
||||
#define SIG_SPM_READY _VECTOR(18)
|
||||
|
||||
#define _VECTORS_SIZE 38
|
||||
|
||||
/* Bit numbers */
|
||||
|
||||
/* GIMSK / GICR */
|
||||
#define INT1 7
|
||||
#define INT0 6
|
||||
#define IVSEL 1
|
||||
#define IVCE 0
|
||||
|
||||
/* GIFR */
|
||||
#define INTF1 7
|
||||
#define INTF0 6
|
||||
|
||||
/* TIMSK */
|
||||
#define OCIE2 7
|
||||
#define TOIE2 6
|
||||
#define TICIE1 5
|
||||
#define OCIE1A 4
|
||||
#define OCIE1B 3
|
||||
#define TOIE1 2
|
||||
/* bit 1 reserved (OCIE0?) */
|
||||
#define TOIE0 0
|
||||
|
||||
/* TIFR */
|
||||
#define OCF2 7
|
||||
#define TOV2 6
|
||||
#define ICF1 5
|
||||
#define OCF1A 4
|
||||
#define OCF1B 3
|
||||
#define TOV1 2
|
||||
/* bit 1 reserved (OCF0?) */
|
||||
#define TOV0 0
|
||||
|
||||
/* SPMCR */
|
||||
#define SPMIE 7
|
||||
#define RWWSB 6
|
||||
/* bit 5 reserved */
|
||||
#define RWWSRE 4
|
||||
#define BLBSET 3
|
||||
#define PGWRT 2
|
||||
#define PGERS 1
|
||||
#define SPMEN 0
|
||||
|
||||
/* TWCR */
|
||||
#define TWINT 7
|
||||
#define TWEA 6
|
||||
#define TWSTA 5
|
||||
#define TWSTO 4
|
||||
#define TWWC 3
|
||||
#define TWEN 2
|
||||
/* bit 1 reserved (TWI_TST?) */
|
||||
#define TWIE 0
|
||||
|
||||
/* TWAR */
|
||||
#define TWA6 7
|
||||
#define TWA5 6
|
||||
#define TWA4 5
|
||||
#define TWA3 4
|
||||
#define TWA2 3
|
||||
#define TWA1 2
|
||||
#define TWA0 1
|
||||
#define TWGCE 0
|
||||
|
||||
/* TWSR */
|
||||
#define TWS7 7
|
||||
#define TWS6 6
|
||||
#define TWS5 5
|
||||
#define TWS4 4
|
||||
#define TWS3 3
|
||||
/* bit 2 reserved */
|
||||
#define TWPS1 1
|
||||
#define TWPS0 0
|
||||
|
||||
/* MCUCR */
|
||||
#define SE 7
|
||||
#define SM2 6
|
||||
#define SM1 5
|
||||
#define SM0 4
|
||||
#define ISC11 3
|
||||
#define ISC10 2
|
||||
#define ISC01 1
|
||||
#define ISC00 0
|
||||
|
||||
/* MCUCSR */
|
||||
/* bits 7-4 reserved */
|
||||
#define WDRF 3
|
||||
#define BORF 2
|
||||
#define EXTRF 1
|
||||
#define PORF 0
|
||||
|
||||
/*
|
||||
The ADHSM bit has been removed from all documentation,
|
||||
as being not needed at all since the comparator has proven
|
||||
to be fast enough even without feeding it more power.
|
||||
*/
|
||||
|
||||
/* SFIOR */
|
||||
/* bits 7-5 reserved */
|
||||
#define ACME 3
|
||||
#define PUD 2
|
||||
#define PSR2 1
|
||||
#define PSR10 0
|
||||
|
||||
/* TCCR0 */
|
||||
/* bits 7-3 reserved */
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/* TCCR2 */
|
||||
#define FOC2 7
|
||||
#define WGM20 6
|
||||
#define COM21 5
|
||||
#define COM20 4
|
||||
#define WGM21 3
|
||||
#define CS22 2
|
||||
#define CS21 1
|
||||
#define CS20 0
|
||||
|
||||
/* ASSR */
|
||||
/* bits 7-4 reserved */
|
||||
#define AS2 3
|
||||
#define TCN2UB 2
|
||||
#define OCR2UB 1
|
||||
#define TCR2UB 0
|
||||
|
||||
/* TCCR1A */
|
||||
#define COM1A1 7
|
||||
#define COM1A0 6
|
||||
#define COM1B1 5
|
||||
#define COM1B0 4
|
||||
#define FOC1A 3
|
||||
#define FOC1B 2
|
||||
#define WGM11 1
|
||||
#define WGM10 0
|
||||
|
||||
/* TCCR1B */
|
||||
#define ICNC1 7
|
||||
#define ICES1 6
|
||||
/* bit 5 reserved */
|
||||
#define WGM13 4
|
||||
#define WGM12 3
|
||||
#define CS12 2
|
||||
#define CS11 1
|
||||
#define CS10 0
|
||||
|
||||
/* WDTCR */
|
||||
/* bits 7-5 reserved */
|
||||
#define WDCE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/* UBRRH */
|
||||
#define URSEL 7
|
||||
|
||||
/* UCSRC */
|
||||
#define URSEL 7
|
||||
#define UMSEL 6
|
||||
#define UPM1 5
|
||||
#define UPM0 4
|
||||
#define USBS 3
|
||||
#define UCSZ1 2
|
||||
#define UCSZ0 1
|
||||
#define UCPOL 0
|
||||
|
||||
/* PORTB */
|
||||
#define PB7 7
|
||||
#define PB6 6
|
||||
#define PB5 5
|
||||
#define PB4 4
|
||||
#define PB3 3
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
/* DDRB */
|
||||
#define DDB7 7
|
||||
#define DDB6 6
|
||||
#define DDB5 5
|
||||
#define DDB4 4
|
||||
#define DDB3 3
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
/* PINB */
|
||||
#define PINB7 7
|
||||
#define PINB6 6
|
||||
#define PINB5 5
|
||||
#define PINB4 4
|
||||
#define PINB3 3
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
/* PORTC */
|
||||
#define PC6 6
|
||||
#define PC5 5
|
||||
#define PC4 4
|
||||
#define PC3 3
|
||||
#define PC2 2
|
||||
#define PC1 1
|
||||
#define PC0 0
|
||||
|
||||
/* DDRC */
|
||||
#define DDC6 6
|
||||
#define DDC5 5
|
||||
#define DDC4 4
|
||||
#define DDC3 3
|
||||
#define DDC2 2
|
||||
#define DDC1 1
|
||||
#define DDC0 0
|
||||
|
||||
/* PINC */
|
||||
#define PINC6 6
|
||||
#define PINC5 5
|
||||
#define PINC4 4
|
||||
#define PINC3 3
|
||||
#define PINC2 2
|
||||
#define PINC1 1
|
||||
#define PINC0 0
|
||||
|
||||
/* PORTD */
|
||||
#define PD7 7
|
||||
#define PD6 6
|
||||
#define PD5 5
|
||||
#define PD4 4
|
||||
#define PD3 3
|
||||
#define PD2 2
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
/* DDRD */
|
||||
#define DDD7 7
|
||||
#define DDD6 6
|
||||
#define DDD5 5
|
||||
#define DDD4 4
|
||||
#define DDD3 3
|
||||
#define DDD2 2
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
/* PIND */
|
||||
#define PIND7 7
|
||||
#define PIND6 6
|
||||
#define PIND5 5
|
||||
#define PIND4 4
|
||||
#define PIND3 3
|
||||
#define PIND2 2
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
/* SPSR */
|
||||
#define SPIF 7
|
||||
#define WCOL 6
|
||||
#define SPI2X 0
|
||||
|
||||
/* SPCR */
|
||||
#define SPIE 7
|
||||
#define SPE 6
|
||||
#define DORD 5
|
||||
#define MSTR 4
|
||||
#define CPOL 3
|
||||
#define CPHA 2
|
||||
#define SPR1 1
|
||||
#define SPR0 0
|
||||
|
||||
/* UCSRA */
|
||||
#define RXC 7
|
||||
#define TXC 6
|
||||
#define UDRE 5
|
||||
#define FE 4
|
||||
#define DOR 3
|
||||
#define PE 2
|
||||
#define U2X 1
|
||||
#define MPCM 0
|
||||
|
||||
/* UCSRB */
|
||||
#define RXCIE 7
|
||||
#define TXCIE 6
|
||||
#define UDRIE 5
|
||||
#define RXEN 4
|
||||
#define TXEN 3
|
||||
#define UCSZ2 2
|
||||
#define RXB8 1
|
||||
#define TXB8 0
|
||||
|
||||
/* ACSR */
|
||||
#define ACD 7
|
||||
#define ACBG 6
|
||||
#define ACO 5
|
||||
#define ACI 4
|
||||
#define ACIE 3
|
||||
#define ACIC 2
|
||||
#define ACIS1 1
|
||||
#define ACIS0 0
|
||||
|
||||
/* ADCSR / ADCSRA */
|
||||
#define ADEN 7
|
||||
#define ADSC 6
|
||||
#define ADFR 5
|
||||
#define ADIF 4
|
||||
#define ADIE 3
|
||||
#define ADPS2 2
|
||||
#define ADPS1 1
|
||||
#define ADPS0 0
|
||||
|
||||
/* ADMUX */
|
||||
#define REFS1 7
|
||||
#define REFS0 6
|
||||
#define ADLAR 5
|
||||
/* bit 4 reserved */
|
||||
#define MUX3 3
|
||||
#define MUX2 2
|
||||
#define MUX1 1
|
||||
#define MUX0 0
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EERIE 3
|
||||
#define EEMWE 2
|
||||
#define EEWE 1
|
||||
#define EERE 0
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 64
|
||||
#define RAMEND 0x45F
|
||||
#define XRAMEND 0x45F
|
||||
#define E2END 0x1FF
|
||||
#define E2PAGESIZE 4
|
||||
#define FLASHEND 0x1FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 2
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_BODEN (unsigned char)~_BV(6)
|
||||
#define FUSE_BODLEVEL (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_SUT0 & FUSE_CKSEL3 & FUSE_CKSEL2 & FUSE_CKSEL1)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_CKOPT (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(6)
|
||||
#define FUSE_RSTDISBL (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_SPIEN & FUSE_BOOTSZ1 & FUSE_BOOTSZ0)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x93
|
||||
#define SIGNATURE_2 0x07
|
||||
|
||||
|
||||
#endif /* _AVR_IOM8_H_ */
|
|
@ -0,0 +1,636 @@
|
|||
/* Copyright (c) 2002, Steinar Haugen
|
||||
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: iom8515.h,v 1.10.2.5 2008/10/17 23:27:50 arcanum Exp $ */
|
||||
|
||||
/* avr/iom8515.h - definitions for ATmega8515 */
|
||||
|
||||
#ifndef _AVR_IOM8515_H_
|
||||
#define _AVR_IOM8515_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_ "iom8515.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* Oscillator Calibration Register */
|
||||
#define OSCCAL _SFR_IO8(0x04)
|
||||
|
||||
/* Input Pins, Port E */
|
||||
#define PINE _SFR_IO8(0x05)
|
||||
|
||||
/* Data Direction Register, Port E */
|
||||
#define DDRE _SFR_IO8(0x06)
|
||||
|
||||
/* Data Register, Port E */
|
||||
#define PORTE _SFR_IO8(0x07)
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACSR _SFR_IO8(0x08)
|
||||
|
||||
/* USART Baud Rate Register */
|
||||
#define UBRRL _SFR_IO8(0x09)
|
||||
|
||||
/* USART Control and Status Register B */
|
||||
#define UCSRB _SFR_IO8(0x0A)
|
||||
|
||||
/* USART Control and Status Register A */
|
||||
#define UCSRA _SFR_IO8(0x0B)
|
||||
|
||||
/* USART I/O Data Register */
|
||||
#define UDR _SFR_IO8(0x0C)
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPCR _SFR_IO8(0x0D)
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPSR _SFR_IO8(0x0E)
|
||||
|
||||
/* SPI I/O Data Register */
|
||||
#define SPDR _SFR_IO8(0x0F)
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND _SFR_IO8(0x10)
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDRD _SFR_IO8(0x11)
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PORTD _SFR_IO8(0x12)
|
||||
|
||||
/* Input Pins, Port C */
|
||||
#define PINC _SFR_IO8(0x13)
|
||||
|
||||
/* Data Direction Register, Port C */
|
||||
#define DDRC _SFR_IO8(0x14)
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PORTC _SFR_IO8(0x15)
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
|
||||
/* Input Pins, Port A */
|
||||
#define PINA _SFR_IO8(0x19)
|
||||
|
||||
/* Data Direction Register, Port A */
|
||||
#define DDRA _SFR_IO8(0x1A)
|
||||
|
||||
/* Data Register, Port A */
|
||||
#define PORTA _SFR_IO8(0x1B)
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EECR _SFR_IO8(0x1C)
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define EEDR _SFR_IO8(0x1D)
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#define EEAR _SFR_IO16(0x1E)
|
||||
#define EEARL _SFR_IO8(0x1E)
|
||||
#define EEARH _SFR_IO8(0x1F)
|
||||
|
||||
/* USART Baud Rate Register HI */
|
||||
/* USART Control and Status Register C */
|
||||
#define UBRRH _SFR_IO8(0x20)
|
||||
#define UCSRC UBRRH
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
|
||||
/* T/C 1 Input Capture Register */
|
||||
#define ICR1 _SFR_IO16(0x24)
|
||||
#define ICR1L _SFR_IO8(0x24)
|
||||
#define ICR1H _SFR_IO8(0x25)
|
||||
|
||||
/* Timer/Counter1 Output Compare Register B */
|
||||
#define OCR1B _SFR_IO16(0x28)
|
||||
#define OCR1BL _SFR_IO8(0x28)
|
||||
#define OCR1BH _SFR_IO8(0x29)
|
||||
|
||||
/* Timer/Counter1 Output Compare Register A */
|
||||
#define OCR1A _SFR_IO16(0x2A)
|
||||
#define OCR1AL _SFR_IO8(0x2A)
|
||||
#define OCR1AH _SFR_IO8(0x2B)
|
||||
|
||||
/* Timer/Counter 1 */
|
||||
#define TCNT1 _SFR_IO16(0x2C)
|
||||
#define TCNT1L _SFR_IO8(0x2C)
|
||||
#define TCNT1H _SFR_IO8(0x2D)
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define TCCR1B _SFR_IO8(0x2E)
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define TCCR1A _SFR_IO8(0x2F)
|
||||
|
||||
/* Special Function IO Register */
|
||||
#define SFIOR _SFR_IO8(0x30)
|
||||
|
||||
/* Timer/Counter 0 Output Compare Register */
|
||||
#define OCR0 _SFR_IO8(0x31)
|
||||
|
||||
/* Timer/Counter 0 */
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
/* MCU Control and Status Register */
|
||||
#define MCUCSR _SFR_IO8(0x34)
|
||||
|
||||
/* MCU Control Register */
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
/* Extended MCU Control Register */
|
||||
#define EMCUCR _SFR_IO8(0x36)
|
||||
|
||||
/* Store Program Memory Control Register */
|
||||
#define SPMCR _SFR_IO8(0x37)
|
||||
|
||||
/* Timer/Counter Interrupt Flag register */
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define GIFR _SFR_IO8(0x3A)
|
||||
|
||||
/* General Interrupt Control Register */
|
||||
#define GICR _SFR_IO8(0x3B)
|
||||
|
||||
/* 0x3D..0x3E SP */
|
||||
|
||||
/* 0x3F SREG */
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
/* 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)
|
||||
|
||||
/* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(3)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(3)
|
||||
|
||||
/* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPA_vect _VECTOR(4)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(4)
|
||||
|
||||
/* Timer/Counter1 Compare MatchB */
|
||||
#define TIMER1_COMPB_vect _VECTOR(5)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(5)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(6)
|
||||
#define SIG_OVERFLOW1 _VECTOR(6)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(7)
|
||||
#define SIG_OVERFLOW0 _VECTOR(7)
|
||||
|
||||
/* Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(8)
|
||||
#define SIG_SPI _VECTOR(8)
|
||||
|
||||
/* UART, Rx Complete */
|
||||
#define USART_RX_vect _VECTOR(9)
|
||||
#define UART_RX_vect _VECTOR(9) /* For compatability only */
|
||||
#define SIG_UART_RECV _VECTOR(9) /* For compatability only */
|
||||
|
||||
/* UART Data Register Empty */
|
||||
#define USART_UDRE_vect _VECTOR(10)
|
||||
#define UART_UDRE_vect _VECTOR(10) /* For compatability only */
|
||||
#define SIG_UART_DATA _VECTOR(10) /* For compatability only */
|
||||
|
||||
/* UART, Tx Complete */
|
||||
#define USART_TX_vect _VECTOR(11)
|
||||
#define UART_TX_vect _VECTOR(11) /* For compatability only */
|
||||
#define SIG_UART_TRANS _VECTOR(11) /* For compatability only */
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANA_COMP_vect _VECTOR(12)
|
||||
#define SIG_COMPARATOR _VECTOR(12)
|
||||
|
||||
/* External Interrupt Request 2 */
|
||||
#define INT2_vect _VECTOR(13)
|
||||
#define SIG_INTERRUPT2 _VECTOR(13)
|
||||
|
||||
/* Timer 0 Compare Match */
|
||||
#define TIMER0_COMP_vect _VECTOR(14)
|
||||
#define SIG_OUTPUT_COMPARE0 _VECTOR(14)
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_RDY_vect _VECTOR(15)
|
||||
#define SIG_EEPROM_READY _VECTOR(15)
|
||||
|
||||
/* Store Program Memory Ready */
|
||||
#define SPM_RDY_vect _VECTOR(16)
|
||||
#define SIG_SPM_READY _VECTOR(16)
|
||||
|
||||
#define _VECTORS_SIZE 34
|
||||
|
||||
/*
|
||||
The Register Bit names are represented by their bit number (0-7).
|
||||
*/
|
||||
|
||||
/* General Interrupt Control Register */
|
||||
#define INT1 7
|
||||
#define INT0 6
|
||||
#define INT2 5
|
||||
#define IVSEL 1
|
||||
#define IVCE 0
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define INTF1 7
|
||||
#define INTF0 6
|
||||
#define INTF2 5
|
||||
|
||||
/* Timer/Counter Interrupt MaSK Register */
|
||||
#define TOIE1 7
|
||||
#define OCIE1A 6
|
||||
#define OCIE1B 5
|
||||
#define TICIE1 3
|
||||
#define TOIE0 1
|
||||
#define OCIE0 0
|
||||
|
||||
/* Timer/Counter Interrupt Flag Register */
|
||||
#define TOV1 7
|
||||
#define OCF1A 6
|
||||
#define OCF1B 5
|
||||
#define ICF1 3
|
||||
#define TOV0 1
|
||||
#define OCF0 0
|
||||
|
||||
/* Store Program Memory Control Register */
|
||||
#define SPMIE 7
|
||||
#define RWWSB 6
|
||||
#define RWWSRE 4
|
||||
#define BLBSET 3
|
||||
#define PGWRT 2
|
||||
#define PGERS 1
|
||||
#define SPMEN 0
|
||||
|
||||
/* Extended MCU Control Register */
|
||||
#define SM0 7
|
||||
#define SRL2 6
|
||||
#define SRL1 5
|
||||
#define SRL0 4
|
||||
#define SRW01 3
|
||||
#define SRW00 2
|
||||
#define SRW11 1
|
||||
#define ISC2 0
|
||||
|
||||
/* MCU Control Register */
|
||||
#define SRE 7
|
||||
#define SRW10 6
|
||||
#define SE 5
|
||||
#define SM1 4
|
||||
#define ISC11 3
|
||||
#define ISC10 2
|
||||
#define ISC01 1
|
||||
#define ISC00 0
|
||||
|
||||
/* MCU Control and Status Register */
|
||||
#define SM2 5
|
||||
#define WDRF 3
|
||||
#define BORF 2
|
||||
#define EXTRF 1
|
||||
#define PORF 0
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define FOC0 7
|
||||
#define WGM00 6
|
||||
#define COM01 5
|
||||
#define COM00 4
|
||||
#define WGM01 3
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/* Special Function IO Register */
|
||||
#define XMBK 6
|
||||
#define XMM2 5
|
||||
#define XMM1 4
|
||||
#define XMM0 3
|
||||
#define PUD 2
|
||||
#define PSR10 0
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define COM1A1 7
|
||||
#define COM1A0 6
|
||||
#define COM1B1 5
|
||||
#define COM1B0 4
|
||||
#define FOC1A 3
|
||||
#define FOC1B 2
|
||||
#define WGM11 1
|
||||
#define WGM10 0
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define ICNC1 7
|
||||
#define ICES1 6
|
||||
#define WGM13 4
|
||||
#define WGM12 3
|
||||
#define CS12 2
|
||||
#define CS11 1
|
||||
#define CS10 0
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDCE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/* USART Control and Status Register C */
|
||||
#define URSEL 7
|
||||
#define UMSEL 6
|
||||
#define UPM1 5
|
||||
#define UPM0 4
|
||||
#define USBS 3
|
||||
#define UCSZ1 2
|
||||
#define UCSZ0 1
|
||||
#define UCPOL 0
|
||||
|
||||
/* Data Register, Port A */
|
||||
#define PA7 7
|
||||
#define PA6 6
|
||||
#define PA5 5
|
||||
#define PA4 4
|
||||
#define PA3 3
|
||||
#define PA2 2
|
||||
#define PA1 1
|
||||
#define PA0 0
|
||||
|
||||
/* Data Direction Register, Port A */
|
||||
#define DDA7 7
|
||||
#define DDA6 6
|
||||
#define DDA5 5
|
||||
#define DDA4 4
|
||||
#define DDA3 3
|
||||
#define DDA2 2
|
||||
#define DDA1 1
|
||||
#define DDA0 0
|
||||
|
||||
/* Input Pins, Port A */
|
||||
#define PINA7 7
|
||||
#define PINA6 6
|
||||
#define PINA5 5
|
||||
#define PINA4 4
|
||||
#define PINA3 3
|
||||
#define PINA2 2
|
||||
#define PINA1 1
|
||||
#define PINA0 0
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PB7 7
|
||||
#define PB6 6
|
||||
#define PB5 5
|
||||
#define PB4 4
|
||||
#define PB3 3
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDB7 7
|
||||
#define DDB6 6
|
||||
#define DDB5 5
|
||||
#define DDB4 4
|
||||
#define DDB3 3
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB7 7
|
||||
#define PINB6 6
|
||||
#define PINB5 5
|
||||
#define PINB4 4
|
||||
#define PINB3 3
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PC7 7
|
||||
#define PC6 6
|
||||
#define PC5 5
|
||||
#define PC4 4
|
||||
#define PC3 3
|
||||
#define PC2 2
|
||||
#define PC1 1
|
||||
#define PC0 0
|
||||
|
||||
/* Data Direction Register, Port C */
|
||||
#define DDC7 7
|
||||
#define DDC6 6
|
||||
#define DDC5 5
|
||||
#define DDC4 4
|
||||
#define DDC3 3
|
||||
#define DDC2 2
|
||||
#define DDC1 1
|
||||
#define DDC0 0
|
||||
|
||||
/* Input Pins, Port C */
|
||||
#define PINC7 7
|
||||
#define PINC6 6
|
||||
#define PINC5 5
|
||||
#define PINC4 4
|
||||
#define PINC3 3
|
||||
#define PINC2 2
|
||||
#define PINC1 1
|
||||
#define PINC0 0
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PD7 7
|
||||
#define PD6 6
|
||||
#define PD5 5
|
||||
#define PD4 4
|
||||
#define PD3 3
|
||||
#define PD2 2
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDD7 7
|
||||
#define DDD6 6
|
||||
#define DDD5 5
|
||||
#define DDD4 4
|
||||
#define DDD3 3
|
||||
#define DDD2 2
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND7 7
|
||||
#define PIND6 6
|
||||
#define PIND5 5
|
||||
#define PIND4 4
|
||||
#define PIND3 3
|
||||
#define PIND2 2
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPIF 7
|
||||
#define WCOL 6
|
||||
#define SPI2X 0
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPIE 7
|
||||
#define SPE 6
|
||||
#define DORD 5
|
||||
#define MSTR 4
|
||||
#define CPOL 3
|
||||
#define CPHA 2
|
||||
#define SPR1 1
|
||||
#define SPR0 0
|
||||
|
||||
/* USART Control and Status Register A */
|
||||
#define RXC 7
|
||||
#define TXC 6
|
||||
#define UDRE 5
|
||||
#define FE 4
|
||||
#define DOR 3
|
||||
#define PE 2
|
||||
#define U2X 1
|
||||
#define MPCM 0
|
||||
|
||||
/* USART Control and Status Register B */
|
||||
#define RXCIE 7
|
||||
#define TXCIE 6
|
||||
#define UDRIE 5
|
||||
#define RXEN 4
|
||||
#define TXEN 3
|
||||
#define UCSZ2 2
|
||||
#define RXB8 1
|
||||
#define TXB8 0
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACD 7
|
||||
#define ACBG 6
|
||||
#define ACO 5
|
||||
#define ACI 4
|
||||
#define ACIE 3
|
||||
#define ACIC 2
|
||||
#define ACIS1 1
|
||||
#define ACIS0 0
|
||||
|
||||
/* Data Register, Port E */
|
||||
#define PE2 2
|
||||
#define PE1 1
|
||||
#define PE0 0
|
||||
|
||||
/* Data Direction Register, Port E */
|
||||
#define DDE2 2
|
||||
#define DDE1 1
|
||||
#define DDE0 0
|
||||
|
||||
/* Input Pins, Port E */
|
||||
#define PINE2 2
|
||||
#define PINE1 1
|
||||
#define PINE0 0
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EERIE 3
|
||||
#define EEMWE 2
|
||||
#define EEWE 1
|
||||
#define EERE 0
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 64
|
||||
#define RAMEND 0x25F /* Last On-Chip SRAM Location */
|
||||
#define XRAMEND 0xFFFF
|
||||
#define E2END 0x1FF
|
||||
#define E2PAGESIZE 4
|
||||
#define FLASHEND 0x1FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 2
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_BODEN (unsigned char)~_BV(6)
|
||||
#define FUSE_BODLEVEL (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL1 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_CKOPT (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(6)
|
||||
#define FUSE_S8515C (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x93
|
||||
#define SIGNATURE_2 0x06
|
||||
|
||||
|
||||
#endif /* _AVR_IOM8515_H_ */
|
|
@ -0,0 +1,715 @@
|
|||
/* Copyright (c) 2002, Steinar Haugen
|
||||
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: iom8535.h,v 1.11.2.5 2008/10/17 23:27:50 arcanum Exp $ */
|
||||
|
||||
/* avr/iom8535.h - definitions for ATmega8535 */
|
||||
|
||||
#ifndef _AVR_IOM8535_H_
|
||||
#define _AVR_IOM8535_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_ "iom8535.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
/* I/O registers */
|
||||
|
||||
/* TWI stands for "Two Wire Interface" or "TWI Was I2C(tm)" */
|
||||
#define TWBR _SFR_IO8(0x00)
|
||||
#define TWSR _SFR_IO8(0x01)
|
||||
#define TWAR _SFR_IO8(0x02)
|
||||
#define TWDR _SFR_IO8(0x03)
|
||||
|
||||
/* ADC Data register */
|
||||
#ifndef __ASSEMBLER__
|
||||
#define ADC _SFR_IO16(0x04)
|
||||
#endif
|
||||
#define ADCW _SFR_IO16(0x04)
|
||||
#define ADCL _SFR_IO8(0x04)
|
||||
#define ADCH _SFR_IO8(0x05)
|
||||
|
||||
/* ADC Control and Status Register */
|
||||
#define ADCSRA _SFR_IO8(0x06)
|
||||
|
||||
/* ADC MUX */
|
||||
#define ADMUX _SFR_IO8(0x07)
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACSR _SFR_IO8(0x08)
|
||||
|
||||
/* USART Baud Rate Register */
|
||||
#define UBRRL _SFR_IO8(0x09)
|
||||
|
||||
/* USART Control and Status Register B */
|
||||
#define UCSRB _SFR_IO8(0x0A)
|
||||
|
||||
/* USART Control and Status Register A */
|
||||
#define UCSRA _SFR_IO8(0x0B)
|
||||
|
||||
/* USART I/O Data Register */
|
||||
#define UDR _SFR_IO8(0x0C)
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPCR _SFR_IO8(0x0D)
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPSR _SFR_IO8(0x0E)
|
||||
|
||||
/* SPI I/O Data Register */
|
||||
#define SPDR _SFR_IO8(0x0F)
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND _SFR_IO8(0x10)
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDRD _SFR_IO8(0x11)
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PORTD _SFR_IO8(0x12)
|
||||
|
||||
/* Input Pins, Port C */
|
||||
#define PINC _SFR_IO8(0x13)
|
||||
|
||||
/* Data Direction Register, Port C */
|
||||
#define DDRC _SFR_IO8(0x14)
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PORTC _SFR_IO8(0x15)
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB _SFR_IO8(0x16)
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDRB _SFR_IO8(0x17)
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PORTB _SFR_IO8(0x18)
|
||||
|
||||
/* Input Pins, Port A */
|
||||
#define PINA _SFR_IO8(0x19)
|
||||
|
||||
/* Data Direction Register, Port A */
|
||||
#define DDRA _SFR_IO8(0x1A)
|
||||
|
||||
/* Data Register, Port A */
|
||||
#define PORTA _SFR_IO8(0x1B)
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EECR _SFR_IO8(0x1C)
|
||||
|
||||
/* EEPROM Data Register */
|
||||
#define EEDR _SFR_IO8(0x1D)
|
||||
|
||||
/* EEPROM Address Register */
|
||||
#define EEAR _SFR_IO16(0x1E)
|
||||
#define EEARL _SFR_IO8(0x1E)
|
||||
#define EEARH _SFR_IO8(0x1F)
|
||||
|
||||
/* USART Baud Rate Register HI */
|
||||
/* USART Control and Status Register C */
|
||||
#define UBRRH _SFR_IO8(0x20)
|
||||
#define UCSRC UBRRH
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDTCR _SFR_IO8(0x21)
|
||||
|
||||
/* Asynchronous mode Status Register */
|
||||
#define ASSR _SFR_IO8(0x22)
|
||||
|
||||
/* Timer/Counter2 Output Compare Register */
|
||||
#define OCR2 _SFR_IO8(0x23)
|
||||
|
||||
/* Timer/Counter 2 */
|
||||
#define TCNT2 _SFR_IO8(0x24)
|
||||
|
||||
/* Timer/Counter 2 Control Register */
|
||||
#define TCCR2 _SFR_IO8(0x25)
|
||||
|
||||
/* T/C 1 Input Capture Register */
|
||||
#define ICR1 _SFR_IO16(0x26)
|
||||
#define ICR1L _SFR_IO8(0x26)
|
||||
#define ICR1H _SFR_IO8(0x27)
|
||||
|
||||
/* Timer/Counter1 Output Compare Register B */
|
||||
#define OCR1B _SFR_IO16(0x28)
|
||||
#define OCR1BL _SFR_IO8(0x28)
|
||||
#define OCR1BH _SFR_IO8(0x29)
|
||||
|
||||
/* Timer/Counter1 Output Compare Register A */
|
||||
#define OCR1A _SFR_IO16(0x2A)
|
||||
#define OCR1AL _SFR_IO8(0x2A)
|
||||
#define OCR1AH _SFR_IO8(0x2B)
|
||||
|
||||
/* Timer/Counter 1 */
|
||||
#define TCNT1 _SFR_IO16(0x2C)
|
||||
#define TCNT1L _SFR_IO8(0x2C)
|
||||
#define TCNT1H _SFR_IO8(0x2D)
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define TCCR1B _SFR_IO8(0x2E)
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define TCCR1A _SFR_IO8(0x2F)
|
||||
|
||||
/* Special Function IO Register */
|
||||
#define SFIOR _SFR_IO8(0x30)
|
||||
|
||||
/* Oscillator Calibration Register */
|
||||
#define OSCCAL _SFR_IO8(0x31)
|
||||
|
||||
/* Timer/Counter 0 */
|
||||
#define TCNT0 _SFR_IO8(0x32)
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define TCCR0 _SFR_IO8(0x33)
|
||||
|
||||
/* MCU Control and Status Register */
|
||||
#define MCUCSR _SFR_IO8(0x34)
|
||||
|
||||
/* MCU Control Register */
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
|
||||
/* TWI Control Register */
|
||||
#define TWCR _SFR_IO8(0x36)
|
||||
|
||||
/* Store Program Memory Control Register */
|
||||
#define SPMCR _SFR_IO8(0x37)
|
||||
|
||||
/* Timer/Counter Interrupt Flag register */
|
||||
#define TIFR _SFR_IO8(0x38)
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define TIMSK _SFR_IO8(0x39)
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define GIFR _SFR_IO8(0x3A)
|
||||
|
||||
/* General Interrupt MaSK register */
|
||||
#define GICR _SFR_IO8(0x3B)
|
||||
|
||||
/* Timer/Counter 0 Output Compare Register */
|
||||
#define OCR0 _SFR_IO8(0x3C)
|
||||
|
||||
/* 0x3D..0x3E SP */
|
||||
|
||||
/* 0x3F SREG */
|
||||
|
||||
/* Interrupt vectors */
|
||||
|
||||
/* External Interrupt 0 */
|
||||
#define INT0_vect _VECTOR(1)
|
||||
#define SIG_INTERRUPT0 _VECTOR(1)
|
||||
|
||||
/* External Interrupt 1 */
|
||||
#define INT1_vect _VECTOR(2)
|
||||
#define SIG_INTERRUPT1 _VECTOR(2)
|
||||
|
||||
/* Timer/Counter2 Compare Match */
|
||||
#define TIMER2_COMP_vect _VECTOR(3)
|
||||
#define SIG_OUTPUT_COMPARE2 _VECTOR(3)
|
||||
|
||||
/* Timer/Counter2 Overflow */
|
||||
#define TIMER2_OVF_vect _VECTOR(4)
|
||||
#define SIG_OVERFLOW2 _VECTOR(4)
|
||||
|
||||
/* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_CAPT_vect _VECTOR(5)
|
||||
#define SIG_INPUT_CAPTURE1 _VECTOR(5)
|
||||
|
||||
/* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPA_vect _VECTOR(6)
|
||||
#define SIG_OUTPUT_COMPARE1A _VECTOR(6)
|
||||
|
||||
/* Timer/Counter1 Compare Match B */
|
||||
#define TIMER1_COMPB_vect _VECTOR(7)
|
||||
#define SIG_OUTPUT_COMPARE1B _VECTOR(7)
|
||||
|
||||
/* Timer/Counter1 Overflow */
|
||||
#define TIMER1_OVF_vect _VECTOR(8)
|
||||
#define SIG_OVERFLOW1 _VECTOR(8)
|
||||
|
||||
/* Timer/Counter0 Overflow */
|
||||
#define TIMER0_OVF_vect _VECTOR(9)
|
||||
#define SIG_OVERFLOW0 _VECTOR(9)
|
||||
|
||||
/* SPI Serial Transfer Complete */
|
||||
#define SPI_STC_vect _VECTOR(10)
|
||||
#define SIG_SPI _VECTOR(10)
|
||||
|
||||
/* USART, RX Complete */
|
||||
#define USART_RX_vect _VECTOR(11)
|
||||
#define SIG_UART_RECV _VECTOR(11)
|
||||
|
||||
/* USART Data Register Empty */
|
||||
#define USART_UDRE_vect _VECTOR(12)
|
||||
#define SIG_UART_DATA _VECTOR(12)
|
||||
|
||||
/* USART, TX Complete */
|
||||
#define USART_TX_vect _VECTOR(13)
|
||||
#define SIG_UART_TRANS _VECTOR(13)
|
||||
|
||||
/* ADC Conversion Complete */
|
||||
#define ADC_vect _VECTOR(14)
|
||||
#define SIG_ADC _VECTOR(14)
|
||||
|
||||
/* EEPROM Ready */
|
||||
#define EE_RDY_vect _VECTOR(15)
|
||||
#define SIG_EEPROM_READY _VECTOR(15)
|
||||
|
||||
/* Analog Comparator */
|
||||
#define ANA_COMP_vect _VECTOR(16)
|
||||
#define SIG_COMPARATOR _VECTOR(16)
|
||||
|
||||
/* Two-wire Serial Interface */
|
||||
#define TWI_vect _VECTOR(17)
|
||||
#define SIG_2WIRE_SERIAL _VECTOR(17)
|
||||
|
||||
/* External Interrupt Request 2 */
|
||||
#define INT2_vect _VECTOR(18)
|
||||
#define SIG_INTERRUPT2 _VECTOR(18)
|
||||
|
||||
/* TimerCounter0 Compare Match */
|
||||
#define TIMER0_COMP_vect _VECTOR(19)
|
||||
#define SIG_OUTPUT_COMPARE0 _VECTOR(19)
|
||||
|
||||
/* Store Program Memory Read */
|
||||
#define SPM_RDY_vect _VECTOR(20)
|
||||
#define SIG_SPM_READY _VECTOR(20)
|
||||
|
||||
#define _VECTORS_SIZE 42
|
||||
|
||||
/*
|
||||
The Register Bit names are represented by their bit number (0-7).
|
||||
*/
|
||||
|
||||
/* General Interrupt Control Register */
|
||||
#define INT1 7
|
||||
#define INT0 6
|
||||
#define INT2 5
|
||||
#define IVSEL 1
|
||||
#define IVCE 0
|
||||
|
||||
/* General Interrupt Flag Register */
|
||||
#define INTF1 7
|
||||
#define INTF0 6
|
||||
#define INTF2 5
|
||||
|
||||
/* Timer/Counter Interrupt MaSK register */
|
||||
#define OCIE2 7
|
||||
#define TOIE2 6
|
||||
#define TICIE1 5
|
||||
#define OCIE1A 4
|
||||
#define OCIE1B 3
|
||||
#define TOIE1 2
|
||||
#define OCIE0 1
|
||||
#define TOIE0 0
|
||||
|
||||
/* Timer/Counter Interrupt Flag register */
|
||||
#define OCF2 7
|
||||
#define TOV2 6
|
||||
#define ICF1 5
|
||||
#define OCF1A 4
|
||||
#define OCF1B 3
|
||||
#define TOV1 2
|
||||
#define OCF0 1
|
||||
#define TOV0 0
|
||||
|
||||
/* Store Program Memory Control Register */
|
||||
#define SPMIE 7
|
||||
#define RWWSB 6
|
||||
#define RWWSRE 4
|
||||
#define BLBSET 3
|
||||
#define PGWRT 2
|
||||
#define PGERS 1
|
||||
#define SPMEN 0
|
||||
|
||||
/* TWI Control Register */
|
||||
#define TWINT 7
|
||||
#define TWEA 6
|
||||
#define TWSTA 5
|
||||
#define TWSTO 4
|
||||
#define TWWC 3
|
||||
#define TWEN 2
|
||||
#define TWIE 0
|
||||
|
||||
/* MCU Control Register */
|
||||
#define SM2 7
|
||||
#define SE 6
|
||||
#define SM1 5
|
||||
#define SM0 4
|
||||
#define ISC11 3
|
||||
#define ISC10 2
|
||||
#define ISC01 1
|
||||
#define ISC00 0
|
||||
|
||||
/* MCU Control and Status Register */
|
||||
#define ISC2 6
|
||||
#define WDRF 3
|
||||
#define BORF 2
|
||||
#define EXTRF 1
|
||||
#define PORF 0
|
||||
|
||||
/* Timer/Counter 0 Control Register */
|
||||
#define FOC0 7
|
||||
#define WGM00 6
|
||||
#define COM01 5
|
||||
#define COM00 4
|
||||
#define WGM01 3
|
||||
#define CS02 2
|
||||
#define CS01 1
|
||||
#define CS00 0
|
||||
|
||||
/*
|
||||
The ADHSM bit has been removed from all documentation,
|
||||
as being not needed at all since the comparator has proven
|
||||
to be fast enough even without feeding it more power.
|
||||
*/
|
||||
|
||||
/* Special Function IO Register */
|
||||
#define ADTS2 7
|
||||
#define ADTS1 6
|
||||
#define ADTS0 5
|
||||
#define ACME 3
|
||||
#define PUD 2
|
||||
#define PSR2 1
|
||||
#define PSR10 0
|
||||
|
||||
/* Timer/Counter 1 Control Register */
|
||||
#define COM1A1 7
|
||||
#define COM1A0 6
|
||||
#define COM1B1 5
|
||||
#define COM1B0 4
|
||||
#define FOC1A 3
|
||||
#define FOC1B 2
|
||||
#define WGM11 1
|
||||
#define WGM10 0
|
||||
|
||||
/* Timer/Counter 1 Control and Status Register */
|
||||
#define ICNC1 7
|
||||
#define ICES1 6
|
||||
#define WGM13 4
|
||||
#define WGM12 3
|
||||
#define CS12 2
|
||||
#define CS11 1
|
||||
#define CS10 0
|
||||
|
||||
/* Timer/Counter 2 Control Register */
|
||||
#define FOC2 7
|
||||
#define WGM20 6
|
||||
#define COM21 5
|
||||
#define COM20 4
|
||||
#define WGM21 3
|
||||
#define CS22 2
|
||||
#define CS21 1
|
||||
#define CS20 0
|
||||
|
||||
/* Asynchronous mode Status Register */
|
||||
#define AS2 3
|
||||
#define TCN2UB 2
|
||||
#define OCR2UB 1
|
||||
#define TCR2UB 0
|
||||
|
||||
/* Watchdog Timer Control Register */
|
||||
#define WDCE 4
|
||||
#define WDE 3
|
||||
#define WDP2 2
|
||||
#define WDP1 1
|
||||
#define WDP0 0
|
||||
|
||||
/* USART Control and Status Register C */
|
||||
#define URSEL 7
|
||||
#define UMSEL 6
|
||||
#define UPM1 5
|
||||
#define UPM0 4
|
||||
#define USBS 3
|
||||
#define UCSZ1 2
|
||||
#define UCSZ0 1
|
||||
#define UCPOL 0
|
||||
|
||||
/* Data Register, Port A */
|
||||
#define PA7 7
|
||||
#define PA6 6
|
||||
#define PA5 5
|
||||
#define PA4 4
|
||||
#define PA3 3
|
||||
#define PA2 2
|
||||
#define PA1 1
|
||||
#define PA0 0
|
||||
|
||||
/* Data Direction Register, Port A */
|
||||
#define DDA7 7
|
||||
#define DDA6 6
|
||||
#define DDA5 5
|
||||
#define DDA4 4
|
||||
#define DDA3 3
|
||||
#define DDA2 2
|
||||
#define DDA1 1
|
||||
#define DDA0 0
|
||||
|
||||
/* Input Pins, Port A */
|
||||
#define PINA7 7
|
||||
#define PINA6 6
|
||||
#define PINA5 5
|
||||
#define PINA4 4
|
||||
#define PINA3 3
|
||||
#define PINA2 2
|
||||
#define PINA1 1
|
||||
#define PINA0 0
|
||||
|
||||
/* Data Register, Port B */
|
||||
#define PB7 7
|
||||
#define PB6 6
|
||||
#define PB5 5
|
||||
#define PB4 4
|
||||
#define PB3 3
|
||||
#define PB2 2
|
||||
#define PB1 1
|
||||
#define PB0 0
|
||||
|
||||
/* Data Direction Register, Port B */
|
||||
#define DDB7 7
|
||||
#define DDB6 6
|
||||
#define DDB5 5
|
||||
#define DDB4 4
|
||||
#define DDB3 3
|
||||
#define DDB2 2
|
||||
#define DDB1 1
|
||||
#define DDB0 0
|
||||
|
||||
/* Input Pins, Port B */
|
||||
#define PINB7 7
|
||||
#define PINB6 6
|
||||
#define PINB5 5
|
||||
#define PINB4 4
|
||||
#define PINB3 3
|
||||
#define PINB2 2
|
||||
#define PINB1 1
|
||||
#define PINB0 0
|
||||
|
||||
/* Data Register, Port C */
|
||||
#define PC7 7
|
||||
#define PC6 6
|
||||
#define PC5 5
|
||||
#define PC4 4
|
||||
#define PC3 3
|
||||
#define PC2 2
|
||||
#define PC1 1
|
||||
#define PC0 0
|
||||
|
||||
/* Data Direction Register, Port C */
|
||||
#define DDC7 7
|
||||
#define DDC6 6
|
||||
#define DDC5 5
|
||||
#define DDC4 4
|
||||
#define DDC3 3
|
||||
#define DDC2 2
|
||||
#define DDC1 1
|
||||
#define DDC0 0
|
||||
|
||||
/* Input Pins, Port C */
|
||||
#define PINC7 7
|
||||
#define PINC6 6
|
||||
#define PINC5 5
|
||||
#define PINC4 4
|
||||
#define PINC3 3
|
||||
#define PINC2 2
|
||||
#define PINC1 1
|
||||
#define PINC0 0
|
||||
|
||||
/* Data Register, Port D */
|
||||
#define PD7 7
|
||||
#define PD6 6
|
||||
#define PD5 5
|
||||
#define PD4 4
|
||||
#define PD3 3
|
||||
#define PD2 2
|
||||
#define PD1 1
|
||||
#define PD0 0
|
||||
|
||||
/* Data Direction Register, Port D */
|
||||
#define DDD7 7
|
||||
#define DDD6 6
|
||||
#define DDD5 5
|
||||
#define DDD4 4
|
||||
#define DDD3 3
|
||||
#define DDD2 2
|
||||
#define DDD1 1
|
||||
#define DDD0 0
|
||||
|
||||
/* Input Pins, Port D */
|
||||
#define PIND7 7
|
||||
#define PIND6 6
|
||||
#define PIND5 5
|
||||
#define PIND4 4
|
||||
#define PIND3 3
|
||||
#define PIND2 2
|
||||
#define PIND1 1
|
||||
#define PIND0 0
|
||||
|
||||
/* SPI Status Register */
|
||||
#define SPIF 7
|
||||
#define WCOL 6
|
||||
#define SPI2X 0
|
||||
|
||||
/* SPI Control Register */
|
||||
#define SPIE 7
|
||||
#define SPE 6
|
||||
#define DORD 5
|
||||
#define MSTR 4
|
||||
#define CPOL 3
|
||||
#define CPHA 2
|
||||
#define SPR1 1
|
||||
#define SPR0 0
|
||||
|
||||
/* USART Control and Status Register A */
|
||||
#define RXC 7
|
||||
#define TXC 6
|
||||
#define UDRE 5
|
||||
#define FE 4
|
||||
#define DOR 3
|
||||
#define PE 2
|
||||
#define U2X 1
|
||||
#define MPCM 0
|
||||
|
||||
/* USART Control and Status Register B */
|
||||
#define RXCIE 7
|
||||
#define TXCIE 6
|
||||
#define UDRIE 5
|
||||
#define RXEN 4
|
||||
#define TXEN 3
|
||||
#define UCSZ2 2
|
||||
#define RXB8 1
|
||||
#define TXB8 0
|
||||
|
||||
/* Analog Comparator Control and Status Register */
|
||||
#define ACD 7
|
||||
#define ACBG 6
|
||||
#define ACO 5
|
||||
#define ACI 4
|
||||
#define ACIE 3
|
||||
#define ACIC 2
|
||||
#define ACIS1 1
|
||||
#define ACIS0 0
|
||||
|
||||
/* ADC Multiplexer Selection Register */
|
||||
#define REFS1 7
|
||||
#define REFS0 6
|
||||
#define ADLAR 5
|
||||
#define MUX4 4
|
||||
#define MUX3 3
|
||||
#define MUX2 2
|
||||
#define MUX1 1
|
||||
#define MUX0 0
|
||||
|
||||
/* ADC Control and Status Register */
|
||||
#define ADEN 7
|
||||
#define ADSC 6
|
||||
#define ADATE 5
|
||||
#define ADIF 4
|
||||
#define ADIE 3
|
||||
#define ADPS2 2
|
||||
#define ADPS1 1
|
||||
#define ADPS0 0
|
||||
|
||||
/* TWI (Slave) Address Register */
|
||||
#define TWGCE 0
|
||||
|
||||
/* TWI Status Register */
|
||||
#define TWS7 7
|
||||
#define TWS6 6
|
||||
#define TWS5 5
|
||||
#define TWS4 4
|
||||
#define TWS3 3
|
||||
#define TWPS1 1
|
||||
#define TWPS0 0
|
||||
|
||||
/* EEPROM Control Register */
|
||||
#define EERIE 3
|
||||
#define EEMWE 2
|
||||
#define EEWE 1
|
||||
#define EERE 0
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 64
|
||||
#define RAMEND 0x25F /* Last On-Chip SRAM Location */
|
||||
#define XRAMEND 0x25F
|
||||
#define E2END 0x1FF
|
||||
#define E2PAGESIZE 4
|
||||
#define FLASHEND 0x1FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
|
||||
#define FUSE_MEMORY_SIZE 2
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0)
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1)
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2)
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3)
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4)
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5)
|
||||
#define FUSE_BODEN (unsigned char)~_BV(6)
|
||||
#define FUSE_BODLEVEL (unsigned char)~_BV(7)
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL1 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_SUT1)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3)
|
||||
#define FUSE_CKOPT (unsigned char)~_BV(4)
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5)
|
||||
#define FUSE_WDTON (unsigned char)~_BV(6)
|
||||
#define FUSE_S8535C (unsigned char)~_BV(7)
|
||||
#define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x93
|
||||
#define SIGNATURE_2 0x08
|
||||
|
||||
|
||||
#endif /* _AVR_IOM8535_H_ */
|
|
@ -0,0 +1,91 @@
|
|||
/* Copyright (c) 2004, Theodore A. Roth
|
||||
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: iom88.h,v 1.4.2.5 2008/10/17 23:27:50 arcanum Exp $ */
|
||||
|
||||
#ifndef _AVR_IOM88_H_
|
||||
#define _AVR_IOM88_H_ 1
|
||||
|
||||
#include <avr/iomx8.h>
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 64
|
||||
#define RAMEND 0x4FF
|
||||
#define XRAMEND 0x4FF
|
||||
#define E2END 0x1FF
|
||||
#define E2PAGESIZE 4
|
||||
#define FLASHEND 0x1FFF
|
||||
|
||||
|
||||
/* Fuses */
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0) /* Select Clock Source */
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1) /* Select Clock Source */
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2) /* Select Clock Source */
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3) /* Select Clock Source */
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4) /* Select start-up time */
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5) /* Select start-up time */
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6) /* Clock output */
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7) /* Divide clock by 8 */
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(0) /* Brown-out Detector trigger level */
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(1) /* Brown-out Detector trigger level */
|
||||
#define FUSE_BODLEVEL2 (unsigned char)~_BV(2) /* Brown-out Detector trigger level */
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3) /* EEPROM memory is preserved through chip erase */
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4) /* Watchdog Timer Always On */
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5) /* Enable Serial programming and Data Downloading */
|
||||
#define FUSE_DWEN (unsigned char)~_BV(6) /* debugWIRE Enable */
|
||||
#define FUSE_RSTDISBL (unsigned char)~_BV(7) /* External reset disable */
|
||||
#define HFUSE_DEFAULT (FUSE_SPIEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define EFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1)
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x93
|
||||
#define SIGNATURE_2 0x0A
|
||||
|
||||
|
||||
#endif /* _AVR_IOM88_H_ */
|
874
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom88p.h
Normal file
874
arduino-0018-windows/hardware/tools/avr/avr/include/avr/iom88p.h
Normal file
|
@ -0,0 +1,874 @@
|
|||
/* Copyright (c) 2007 Atmel Corporation
|
||||
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: iom88p.h,v 1.3.2.11 2008/10/17 23:27:51 arcanum Exp $ */
|
||||
|
||||
/* avr/iom88p.h - definitions for ATmega88P. */
|
||||
|
||||
/* 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_ "iom88p.h"
|
||||
#else
|
||||
# error "Attempt to include more than one <avr/ioXXX.h> file."
|
||||
#endif
|
||||
|
||||
|
||||
#ifndef _AVR_IOM88P_H_
|
||||
#define _AVR_IOM88P_H_ 1
|
||||
|
||||
/* Registers and associated bit numbers */
|
||||
|
||||
#define PINB _SFR_IO8(0x03)
|
||||
#define PINB0 0
|
||||
#define PINB1 1
|
||||
#define PINB2 2
|
||||
#define PINB3 3
|
||||
#define PINB4 4
|
||||
#define PINB5 5
|
||||
#define PINB6 6
|
||||
#define PINB7 7
|
||||
|
||||
#define DDRB _SFR_IO8(0x04)
|
||||
#define DDB0 0
|
||||
#define DDB1 1
|
||||
#define DDB2 2
|
||||
#define DDB3 3
|
||||
#define DDB4 4
|
||||
#define DDB5 5
|
||||
#define DDB6 6
|
||||
#define DDB7 7
|
||||
|
||||
#define PORTB _SFR_IO8(0x05)
|
||||
#define PORTB0 0
|
||||
#define PORTB1 1
|
||||
#define PORTB2 2
|
||||
#define PORTB3 3
|
||||
#define PORTB4 4
|
||||
#define PORTB5 5
|
||||
#define PORTB6 6
|
||||
#define PORTB7 7
|
||||
|
||||
#define PINC _SFR_IO8(0x06)
|
||||
#define PINC0 0
|
||||
#define PINC1 1
|
||||
#define PINC2 2
|
||||
#define PINC3 3
|
||||
#define PINC4 4
|
||||
#define PINC5 5
|
||||
#define PINC6 6
|
||||
|
||||
#define DDRC _SFR_IO8(0x07)
|
||||
#define DDC0 0
|
||||
#define DDC1 1
|
||||
#define DDC2 2
|
||||
#define DDC3 3
|
||||
#define DDC4 4
|
||||
#define DDC5 5
|
||||
#define DDC6 6
|
||||
|
||||
#define PORTC _SFR_IO8(0x08)
|
||||
#define PORTC0 0
|
||||
#define PORTC1 1
|
||||
#define PORTC2 2
|
||||
#define PORTC3 3
|
||||
#define PORTC4 4
|
||||
#define PORTC5 5
|
||||
#define PORTC6 6
|
||||
|
||||
#define PIND _SFR_IO8(0x09)
|
||||
#define PIND0 0
|
||||
#define PIND1 1
|
||||
#define PIND2 2
|
||||
#define PIND3 3
|
||||
#define PIND4 4
|
||||
#define PIND5 5
|
||||
#define PIND6 6
|
||||
#define PIND7 7
|
||||
|
||||
#define DDRD _SFR_IO8(0x0A)
|
||||
#define DDD0 0
|
||||
#define DDD1 1
|
||||
#define DDD2 2
|
||||
#define DDD3 3
|
||||
#define DDD4 4
|
||||
#define DDD5 5
|
||||
#define DDD6 6
|
||||
#define DDD7 7
|
||||
|
||||
#define PORTD _SFR_IO8(0x0B)
|
||||
#define PORTD0 0
|
||||
#define PORTD1 1
|
||||
#define PORTD2 2
|
||||
#define PORTD3 3
|
||||
#define PORTD4 4
|
||||
#define PORTD5 5
|
||||
#define PORTD6 6
|
||||
#define PORTD7 7
|
||||
|
||||
#define TIFR0 _SFR_IO8(0x15)
|
||||
#define TOV0 0
|
||||
#define OCF0A 1
|
||||
#define OCF0B 2
|
||||
|
||||
#define TIFR1 _SFR_IO8(0x16)
|
||||
#define TOV1 0
|
||||
#define OCF1A 1
|
||||
#define OCF1B 2
|
||||
#define ICF1 5
|
||||
|
||||
#define TIFR2 _SFR_IO8(0x17)
|
||||
#define TOV2 0
|
||||
#define OCF2A 1
|
||||
#define OCF2B 2
|
||||
|
||||
#define PCIFR _SFR_IO8(0x1B)
|
||||
#define PCIF0 0
|
||||
#define PCIF1 1
|
||||
#define PCIF2 2
|
||||
|
||||
#define EIFR _SFR_IO8(0x1C)
|
||||
#define INTF0 0
|
||||
#define INTF1 1
|
||||
|
||||
#define EIMSK _SFR_IO8(0x1D)
|
||||
#define INT0 0
|
||||
#define INT1 1
|
||||
|
||||
#define GPIOR0 _SFR_IO8(0x1E)
|
||||
#define GPIOR00 0
|
||||
#define GPIOR01 1
|
||||
#define GPIOR02 2
|
||||
#define GPIOR03 3
|
||||
#define GPIOR04 4
|
||||
#define GPIOR05 5
|
||||
#define GPIOR06 6
|
||||
#define GPIOR07 7
|
||||
|
||||
#define EECR _SFR_IO8(0x1F)
|
||||
#define EERE 0
|
||||
#define EEPE 1
|
||||
#define EEMPE 2
|
||||
#define EERIE 3
|
||||
#define EEPM0 4
|
||||
#define EEPM1 5
|
||||
|
||||
#define EEDR _SFR_IO8(0x20)
|
||||
#define EEDR0 0
|
||||
#define EEDR1 1
|
||||
#define EEDR2 2
|
||||
#define EEDR3 3
|
||||
#define EEDR4 4
|
||||
#define EEDR5 5
|
||||
#define EEDR6 6
|
||||
#define EEDR7 7
|
||||
|
||||
#define EEAR _SFR_IO16(0x21)
|
||||
|
||||
#define EEARL _SFR_IO8(0x21)
|
||||
#define EEAR0 0
|
||||
#define EEAR1 1
|
||||
#define EEAR2 2
|
||||
#define EEAR3 3
|
||||
#define EEAR4 4
|
||||
#define EEAR5 5
|
||||
#define EEAR6 6
|
||||
#define EEAR7 7
|
||||
|
||||
#define EEARH _SFR_IO8(0x22)
|
||||
#define EEAR8 0
|
||||
|
||||
#define EEPROM_REG_LOCATIONS 1F2021
|
||||
|
||||
#define GTCCR _SFR_IO8(0x23)
|
||||
#define PSRSYNC 0
|
||||
#define PSRASY 1
|
||||
#define TSM 7
|
||||
|
||||
#define TCCR0A _SFR_IO8(0x24)
|
||||
#define WGM00 0
|
||||
#define WGM01 1
|
||||
#define COM0B0 4
|
||||
#define COM0B1 5
|
||||
#define COM0A0 6
|
||||
#define COM0A1 7
|
||||
|
||||
#define TCCR0B _SFR_IO8(0x25)
|
||||
#define CS00 0
|
||||
#define CS01 1
|
||||
#define CS02 2
|
||||
#define WGM02 3
|
||||
#define FOC0B 6
|
||||
#define FOC0A 7
|
||||
|
||||
#define TCNT0 _SFR_IO8(0x26)
|
||||
#define TCNT0_0 0
|
||||
#define TCNT0_1 1
|
||||
#define TCNT0_2 2
|
||||
#define TCNT0_3 3
|
||||
#define TCNT0_4 4
|
||||
#define TCNT0_5 5
|
||||
#define TCNT0_6 6
|
||||
#define TCNT0_7 7
|
||||
|
||||
#define OCR0A _SFR_IO8(0x27)
|
||||
#define OCROA_0 0
|
||||
#define OCROA_1 1
|
||||
#define OCROA_2 2
|
||||
#define OCROA_3 3
|
||||
#define OCROA_4 4
|
||||
#define OCROA_5 5
|
||||
#define OCROA_6 6
|
||||
#define OCROA_7 7
|
||||
|
||||
#define OCR0B _SFR_IO8(0x28)
|
||||
#define OCR0B_0 0
|
||||
#define OCR0B_1 1
|
||||
#define OCR0B_2 2
|
||||
#define OCR0B_3 3
|
||||
#define OCR0B_4 4
|
||||
#define OCR0B_5 5
|
||||
#define OCR0B_6 6
|
||||
#define OCR0B_7 7
|
||||
|
||||
#define GPIOR1 _SFR_IO8(0x2A)
|
||||
#define GPIOR10 0
|
||||
#define GPIOR11 1
|
||||
#define GPIOR12 2
|
||||
#define GPIOR13 3
|
||||
#define GPIOR14 4
|
||||
#define GPIOR15 5
|
||||
#define GPIOR16 6
|
||||
#define GPIOR17 7
|
||||
|
||||
#define GPIOR2 _SFR_IO8(0x2B)
|
||||
#define GPIOR20 0
|
||||
#define GPIOR21 1
|
||||
#define GPIOR22 2
|
||||
#define GPIOR23 3
|
||||
#define GPIOR24 4
|
||||
#define GPIOR25 5
|
||||
#define GPIOR26 6
|
||||
#define GPIOR27 7
|
||||
|
||||
#define SPCR _SFR_IO8(0x2C)
|
||||
#define SPR0 0
|
||||
#define SPR1 1
|
||||
#define CPHA 2
|
||||
#define CPOL 3
|
||||
#define MSTR 4
|
||||
#define DORD 5
|
||||
#define SPE 6
|
||||
#define SPIE 7
|
||||
|
||||
#define SPSR _SFR_IO8(0x2D)
|
||||
#define SPI2X 0
|
||||
#define WCOL 6
|
||||
#define SPIF 7
|
||||
|
||||
#define SPDR _SFR_IO8(0x2E)
|
||||
#define SPDR0 0
|
||||
#define SPDR1 1
|
||||
#define SPDR2 2
|
||||
#define SPDR3 3
|
||||
#define SPDR4 4
|
||||
#define SPDR5 5
|
||||
#define SPDR6 6
|
||||
#define SPDR7 7
|
||||
|
||||
#define ACSR _SFR_IO8(0x30)
|
||||
#define ACIS0 0
|
||||
#define ACIS1 1
|
||||
#define ACIC 2
|
||||
#define ACIE 3
|
||||
#define ACI 4
|
||||
#define ACO 5
|
||||
#define ACBG 6
|
||||
#define ACD 7
|
||||
|
||||
#define SMCR _SFR_IO8(0x33)
|
||||
#define SE 0
|
||||
#define SM0 1
|
||||
#define SM1 2
|
||||
#define SM2 3
|
||||
|
||||
#define MCUSR _SFR_IO8(0x34)
|
||||
#define PORF 0
|
||||
#define EXTRF 1
|
||||
#define BORF 2
|
||||
#define WDRF 3
|
||||
|
||||
#define MCUCR _SFR_IO8(0x35)
|
||||
#define IVCE 0
|
||||
#define IVSEL 1
|
||||
#define PUD 4
|
||||
#define BODSE 5
|
||||
#define BODS 6
|
||||
|
||||
#define SPMCSR _SFR_IO8(0x37)
|
||||
#define SELFPRGEN 0
|
||||
#define PGERS 1
|
||||
#define PGWRT 2
|
||||
#define BLBSET 3
|
||||
#define RWWSRE 4
|
||||
#define RWWSB 6
|
||||
#define SPMIE 7
|
||||
|
||||
#define WDTCSR _SFR_MEM8(0x60)
|
||||
#define WDP0 0
|
||||
#define WDP1 1
|
||||
#define WDP2 2
|
||||
#define WDE 3
|
||||
#define WDCE 4
|
||||
#define WDP3 5
|
||||
#define WDIE 6
|
||||
#define WDIF 7
|
||||
|
||||
#define CLKPR _SFR_MEM8(0x61)
|
||||
#define CLKPS0 0
|
||||
#define CLKPS1 1
|
||||
#define CLKPS2 2
|
||||
#define CLKPS3 3
|
||||
#define CLKPCE 7
|
||||
|
||||
#define PRR _SFR_MEM8(0x64)
|
||||
#define PRADC 0
|
||||
#define PRUSART0 1
|
||||
#define PRSPI 2
|
||||
#define PRTIM1 3
|
||||
#define PRTIM0 5
|
||||
#define PRTIM2 6
|
||||
#define PRTWI 7
|
||||
|
||||
#define OSCCAL _SFR_MEM8(0x66)
|
||||
#define CAL0 0
|
||||
#define CAL1 1
|
||||
#define CAL2 2
|
||||
#define CAL3 3
|
||||
#define CAL4 4
|
||||
#define CAL5 5
|
||||
#define CAL6 6
|
||||
#define CAL7 7
|
||||
|
||||
#define PCICR _SFR_MEM8(0x68)
|
||||
#define PCIE0 0
|
||||
#define PCIE1 1
|
||||
#define PCIE2 2
|
||||
|
||||
#define EICRA _SFR_MEM8(0x69)
|
||||
#define ISC00 0
|
||||
#define ISC01 1
|
||||
#define ISC10 2
|
||||
#define ISC11 3
|
||||
|
||||
#define PCMSK0 _SFR_MEM8(0x6B)
|
||||
#define PCINT0 0
|
||||
#define PCINT1 1
|
||||
#define PCINT2 2
|
||||
#define PCINT3 3
|
||||
#define PCINT4 4
|
||||
#define PCINT5 5
|
||||
#define PCINT6 6
|
||||
#define PCINT7 7
|
||||
|
||||
#define PCMSK1 _SFR_MEM8(0x6C)
|
||||
#define PCINT8 0
|
||||
#define PCINT9 1
|
||||
#define PCINT10 2
|
||||
#define PCINT11 3
|
||||
#define PCINT12 4
|
||||
#define PCINT13 5
|
||||
#define PCINT14 6
|
||||
|
||||
#define PCMSK2 _SFR_MEM8(0x6D)
|
||||
#define PCINT16 0
|
||||
#define PCINT17 1
|
||||
#define PCINT18 2
|
||||
#define PCINT19 3
|
||||
#define PCINT20 4
|
||||
#define PCINT21 5
|
||||
#define PCINT22 6
|
||||
#define PCINT23 7
|
||||
|
||||
#define TIMSK0 _SFR_MEM8(0x6E)
|
||||
#define TOIE0 0
|
||||
#define OCIE0A 1
|
||||
#define OCIE0B 2
|
||||
|
||||
#define TIMSK1 _SFR_MEM8(0x6F)
|
||||
#define TOIE1 0
|
||||
#define OCIE1A 1
|
||||
#define OCIE1B 2
|
||||
#define ICIE1 5
|
||||
|
||||
#define TIMSK2 _SFR_MEM8(0x70)
|
||||
#define TOIE2 0
|
||||
#define OCIE2A 1
|
||||
#define OCIE2B 2
|
||||
|
||||
#ifndef __ASSEMBLER__
|
||||
#define ADC _SFR_MEM16(0x78)
|
||||
#endif
|
||||
#define ADCW _SFR_MEM16(0x78)
|
||||
|
||||
#define ADCL _SFR_MEM8(0x78)
|
||||
#define ADCL0 0
|
||||
#define ADCL1 1
|
||||
#define ADCL2 2
|
||||
#define ADCL3 3
|
||||
#define ADCL4 4
|
||||
#define ADCL5 5
|
||||
#define ADCL6 6
|
||||
#define ADCL7 7
|
||||
|
||||
#define ADCH _SFR_MEM8(0x79)
|
||||
#define ADCH0 0
|
||||
#define ADCH1 1
|
||||
#define ADCH2 2
|
||||
#define ADCH3 3
|
||||
#define ADCH4 4
|
||||
#define ADCH5 5
|
||||
#define ADCH6 6
|
||||
#define ADCH7 7
|
||||
|
||||
#define ADCSRA _SFR_MEM8(0x7A)
|
||||
#define ADPS0 0
|
||||
#define ADPS1 1
|
||||
#define ADPS2 2
|
||||
#define ADIE 3
|
||||
#define ADIF 4
|
||||
#define ADATE 5
|
||||
#define ADSC 6
|
||||
#define ADEN 7
|
||||
|
||||
#define ADCSRB _SFR_MEM8(0x7B)
|
||||
#define ADTS0 0
|
||||
#define ADTS1 1
|
||||
#define ADTS2 2
|
||||
#define ACME 6
|
||||
|
||||
#define ADMUX _SFR_MEM8(0x7C)
|
||||
#define MUX0 0
|
||||
#define MUX1 1
|
||||
#define MUX2 2
|
||||
#define MUX3 3
|
||||
#define ADLAR 5
|
||||
#define REFS0 6
|
||||
#define REFS1 7
|
||||
|
||||
#define DIDR0 _SFR_MEM8(0x7E)
|
||||
#define ADC0D 0
|
||||
#define ADC1D 1
|
||||
#define ADC2D 2
|
||||
#define ADC3D 3
|
||||
#define ADC4D 4
|
||||
#define ADC5D 5
|
||||
|
||||
#define DIDR1 _SFR_MEM8(0x7F)
|
||||
#define AIN0D 0
|
||||
#define AIN1D 1
|
||||
|
||||
#define TCCR1A _SFR_MEM8(0x80)
|
||||
#define WGM10 0
|
||||
#define WGM11 1
|
||||
#define COM1B0 4
|
||||
#define COM1B1 5
|
||||
#define COM1A0 6
|
||||
#define COM1A1 7
|
||||
|
||||
#define TCCR1B _SFR_MEM8(0x81)
|
||||
#define CS10 0
|
||||
#define CS11 1
|
||||
#define CS12 2
|
||||
#define WGM12 3
|
||||
#define WGM13 4
|
||||
#define ICES1 6
|
||||
#define ICNC1 7
|
||||
|
||||
#define TCCR1C _SFR_MEM8(0x82)
|
||||
#define FOC1B 6
|
||||
#define FOC1A 7
|
||||
|
||||
#define TCNT1 _SFR_MEM16(0x84)
|
||||
|
||||
#define TCNT1L _SFR_MEM8(0x84)
|
||||
#define TCNT1L0 0
|
||||
#define TCNT1L1 1
|
||||
#define TCNT1L2 2
|
||||
#define TCNT1L3 3
|
||||
#define TCNT1L4 4
|
||||
#define TCNT1L5 5
|
||||
#define TCNT1L6 6
|
||||
#define TCNT1L7 7
|
||||
|
||||
#define TCNT1H _SFR_MEM8(0x85)
|
||||
#define TCNT1H0 0
|
||||
#define TCNT1H1 1
|
||||
#define TCNT1H2 2
|
||||
#define TCNT1H3 3
|
||||
#define TCNT1H4 4
|
||||
#define TCNT1H5 5
|
||||
#define TCNT1H6 6
|
||||
#define TCNT1H7 7
|
||||
|
||||
#define ICR1 _SFR_MEM16(0x86)
|
||||
|
||||
#define ICR1L _SFR_MEM8(0x86)
|
||||
#define ICR1L0 0
|
||||
#define ICR1L1 1
|
||||
#define ICR1L2 2
|
||||
#define ICR1L3 3
|
||||
#define ICR1L4 4
|
||||
#define ICR1L5 5
|
||||
#define ICR1L6 6
|
||||
#define ICR1L7 7
|
||||
|
||||
#define ICR1H _SFR_MEM8(0x87)
|
||||
#define ICR1H0 0
|
||||
#define ICR1H1 1
|
||||
#define ICR1H2 2
|
||||
#define ICR1H3 3
|
||||
#define ICR1H4 4
|
||||
#define ICR1H5 5
|
||||
#define ICR1H6 6
|
||||
#define ICR1H7 7
|
||||
|
||||
#define OCR1A _SFR_MEM16(0x88)
|
||||
|
||||
#define OCR1AL _SFR_MEM8(0x88)
|
||||
#define OCR1AL0 0
|
||||
#define OCR1AL1 1
|
||||
#define OCR1AL2 2
|
||||
#define OCR1AL3 3
|
||||
#define OCR1AL4 4
|
||||
#define OCR1AL5 5
|
||||
#define OCR1AL6 6
|
||||
#define OCR1AL7 7
|
||||
|
||||
#define OCR1AH _SFR_MEM8(0x89)
|
||||
#define OCR1AH0 0
|
||||
#define OCR1AH1 1
|
||||
#define OCR1AH2 2
|
||||
#define OCR1AH3 3
|
||||
#define OCR1AH4 4
|
||||
#define OCR1AH5 5
|
||||
#define OCR1AH6 6
|
||||
#define OCR1AH7 7
|
||||
|
||||
#define OCR1B _SFR_MEM16(0x8A)
|
||||
|
||||
#define OCR1BL _SFR_MEM8(0x8A)
|
||||
#define OCR1BL0 0
|
||||
#define OCR1BL1 1
|
||||
#define OCR1BL2 2
|
||||
#define OCR1BL3 3
|
||||
#define OCR1BL4 4
|
||||
#define OCR1BL5 5
|
||||
#define OCR1BL6 6
|
||||
#define OCR1BL7 7
|
||||
|
||||
#define OCR1BH _SFR_MEM8(0x8B)
|
||||
#define OCR1BH0 0
|
||||
#define OCR1BH1 1
|
||||
#define OCR1BH2 2
|
||||
#define OCR1BH3 3
|
||||
#define OCR1BH4 4
|
||||
#define OCR1BH5 5
|
||||
#define OCR1BH6 6
|
||||
#define OCR1BH7 7
|
||||
|
||||
#define TCCR2A _SFR_MEM8(0xB0)
|
||||
#define WGM20 0
|
||||
#define WGM21 1
|
||||
#define COM2B0 4
|
||||
#define COM2B1 5
|
||||
#define COM2A0 6
|
||||
#define COM2A1 7
|
||||
|
||||
#define TCCR2B _SFR_MEM8(0xB1)
|
||||
#define CS20 0
|
||||
#define CS21 1
|
||||
#define CS22 2
|
||||
#define WGM22 3
|
||||
#define FOC2B 6
|
||||
#define FOC2A 7
|
||||
|
||||
#define TCNT2 _SFR_MEM8(0xB2)
|
||||
#define TCNT2_0 0
|
||||
#define TCNT2_1 1
|
||||
#define TCNT2_2 2
|
||||
#define TCNT2_3 3
|
||||
#define TCNT2_4 4
|
||||
#define TCNT2_5 5
|
||||
#define TCNT2_6 6
|
||||
#define TCNT2_7 7
|
||||
|
||||
#define OCR2A _SFR_MEM8(0xB3)
|
||||
#define OCR2_0 0
|
||||
#define OCR2_1 1
|
||||
#define OCR2_2 2
|
||||
#define OCR2_3 3
|
||||
#define OCR2_4 4
|
||||
#define OCR2_5 5
|
||||
#define OCR2_6 6
|
||||
#define OCR2_7 7
|
||||
|
||||
#define OCR2B _SFR_MEM8(0xB4)
|
||||
#define OCR2_0 0
|
||||
#define OCR2_1 1
|
||||
#define OCR2_2 2
|
||||
#define OCR2_3 3
|
||||
#define OCR2_4 4
|
||||
#define OCR2_5 5
|
||||
#define OCR2_6 6
|
||||
#define OCR2_7 7
|
||||
|
||||
#define ASSR _SFR_MEM8(0xB6)
|
||||
#define TCR2BUB 0
|
||||
#define TCR2AUB 1
|
||||
#define OCR2BUB 2
|
||||
#define OCR2AUB 3
|
||||
#define TCN2UB 4
|
||||
#define AS2 5
|
||||
#define EXCLK 6
|
||||
|
||||
#define TWBR _SFR_MEM8(0xB8)
|
||||
#define TWBR0 0
|
||||
#define TWBR1 1
|
||||
#define TWBR2 2
|
||||
#define TWBR3 3
|
||||
#define TWBR4 4
|
||||
#define TWBR5 5
|
||||
#define TWBR6 6
|
||||
#define TWBR7 7
|
||||
|
||||
#define TWSR _SFR_MEM8(0xB9)
|
||||
#define TWPS0 0
|
||||
#define TWPS1 1
|
||||
#define TWS3 3
|
||||
#define TWS4 4
|
||||
#define TWS5 5
|
||||
#define TWS6 6
|
||||
#define TWS7 7
|
||||
|
||||
#define TWAR _SFR_MEM8(0xBA)
|
||||
#define TWGCE 0
|
||||
#define TWA0 1
|
||||
#define TWA1 2
|
||||
#define TWA2 3
|
||||
#define TWA3 4
|
||||
#define TWA4 5
|
||||
#define TWA5 6
|
||||
#define TWA6 7
|
||||
|
||||
#define TWDR _SFR_MEM8(0xBB)
|
||||
#define TWD0 0
|
||||
#define TWD1 1
|
||||
#define TWD2 2
|
||||
#define TWD3 3
|
||||
#define TWD4 4
|
||||
#define TWD5 5
|
||||
#define TWD6 6
|
||||
#define TWD7 7
|
||||
|
||||
#define TWCR _SFR_MEM8(0xBC)
|
||||
#define TWIE 0
|
||||
#define TWEN 2
|
||||
#define TWWC 3
|
||||
#define TWSTO 4
|
||||
#define TWSTA 5
|
||||
#define TWEA 6
|
||||
#define TWINT 7
|
||||
|
||||
#define TWAMR _SFR_MEM8(0xBD)
|
||||
#define TWAM0 0
|
||||
#define TWAM1 1
|
||||
#define TWAM2 2
|
||||
#define TWAM3 3
|
||||
#define TWAM4 4
|
||||
#define TWAM5 5
|
||||
#define TWAM6 6
|
||||
|
||||
#define UCSR0A _SFR_MEM8(0xC0)
|
||||
#define MPCM0 0
|
||||
#define U2X0 1
|
||||
#define UPE0 2
|
||||
#define DOR0 3
|
||||
#define FE0 4
|
||||
#define UDRE0 5
|
||||
#define TXC0 6
|
||||
#define RXC0 7
|
||||
|
||||
#define UCSR0B _SFR_MEM8(0xC1)
|
||||
#define TXB80 0
|
||||
#define RXB80 1
|
||||
#define UCSZ02 2
|
||||
#define TXEN0 3
|
||||
#define RXEN0 4
|
||||
#define UDRIE0 5
|
||||
#define TXCIE0 6
|
||||
#define RXCIE0 7
|
||||
|
||||
#define UCSR0C _SFR_MEM8(0xC2)
|
||||
#define UCPOL0 0
|
||||
#define UCSZ00 1
|
||||
#define UCPHA0 1
|
||||
#define UCSZ01 2
|
||||
#define UDORD0 2
|
||||
#define USBS0 3
|
||||
#define UPM00 4
|
||||
#define UPM01 5
|
||||
#define UMSEL00 6
|
||||
#define UMSEL01 7
|
||||
|
||||
#define UBRR0 _SFR_MEM16(0xC4)
|
||||
|
||||
#define UBRR0L _SFR_MEM8(0xC4)
|
||||
#define UBRR0_0 0
|
||||
#define UBRR0_1 1
|
||||
#define UBRR0_2 2
|
||||
#define UBRR0_3 3
|
||||
#define UBRR0_4 4
|
||||
#define UBRR0_5 5
|
||||
#define UBRR0_6 6
|
||||
#define UBRR0_7 7
|
||||
|
||||
#define UBRR0H _SFR_MEM8(0xC5)
|
||||
#define UBRR0_8 0
|
||||
#define UBRR0_9 1
|
||||
#define UBRR0_10 2
|
||||
#define UBRR0_11 3
|
||||
|
||||
#define UDR0 _SFR_MEM8(0xC6)
|
||||
#define UDR0_0 0
|
||||
#define UDR0_1 1
|
||||
#define UDR0_2 2
|
||||
#define UDR0_3 3
|
||||
#define UDR0_4 4
|
||||
#define UDR0_5 5
|
||||
#define UDR0_6 6
|
||||
#define UDR0_7 7
|
||||
|
||||
|
||||
|
||||
/* Interrupt Vectors */
|
||||
/* Interrupt Vector 0 is the reset vector. */
|
||||
#define INT0_vect _VECTOR(1) /* External Interrupt Request 0 */
|
||||
#define INT1_vect _VECTOR(2) /* External Interrupt Request 1 */
|
||||
#define PCINT0_vect _VECTOR(3) /* Pin Change Interrupt Request 0 */
|
||||
#define PCINT1_vect _VECTOR(4) /* Pin Change Interrupt Request 0 */
|
||||
#define PCINT2_vect _VECTOR(5) /* Pin Change Interrupt Request 1 */
|
||||
#define WDT_vect _VECTOR(6) /* Watchdog Time-out Interrupt */
|
||||
#define TIMER2_COMPA_vect _VECTOR(7) /* Timer/Counter2 Compare Match A */
|
||||
#define TIMER2_COMPB_vect _VECTOR(8) /* Timer/Counter2 Compare Match A */
|
||||
#define TIMER2_OVF_vect _VECTOR(9) /* Timer/Counter2 Overflow */
|
||||
#define TIMER1_CAPT_vect _VECTOR(10) /* Timer/Counter1 Capture Event */
|
||||
#define TIMER1_COMPA_vect _VECTOR(11) /* Timer/Counter1 Compare Match A */
|
||||
#define TIMER1_COMPB_vect _VECTOR(12) /* Timer/Counter1 Compare Match B */
|
||||
#define TIMER1_OVF_vect _VECTOR(13) /* Timer/Counter1 Overflow */
|
||||
#define TIMER0_COMPA_vect _VECTOR(14) /* TimerCounter0 Compare Match A */
|
||||
#define TIMER0_COMPB_vect _VECTOR(15) /* TimerCounter0 Compare Match B */
|
||||
#define TIMER0_OVF_vect _VECTOR(16) /* Timer/Couner0 Overflow */
|
||||
#define SPI_STC_vect _VECTOR(17) /* SPI Serial Transfer Complete */
|
||||
#define USART_RX_vect _VECTOR(18) /* USART Rx Complete */
|
||||
#define USART_UDRE_vect _VECTOR(19) /* USART, Data Register Empty */
|
||||
#define USART_TX_vect _VECTOR(20) /* USART Tx Complete */
|
||||
#define ADC_vect _VECTOR(21) /* ADC Conversion Complete */
|
||||
#define EE_READY_vect _VECTOR(22) /* EEPROM Ready */
|
||||
#define ANALOG_COMP_vect _VECTOR(23) /* Analog Comparator */
|
||||
#define TWI_vect _VECTOR(24) /* Two-wire Serial Interface */
|
||||
#define SPM_READY_vect _VECTOR(25) /* Store Program Memory Read */
|
||||
|
||||
#define _VECTORS_SIZE (26 * 2)
|
||||
|
||||
|
||||
|
||||
/* Constants */
|
||||
#define SPM_PAGESIZE 64
|
||||
#define RAMEND 0x4FF /* Last On-Chip SRAM Location */
|
||||
#define XRAMSIZE 0
|
||||
#define XRAMEND (RAMEND + XRAMSIZE)
|
||||
#define E2END 0x1FF
|
||||
#define E2PAGESIZE 4
|
||||
#define FLASHEND 0x1FFF
|
||||
|
||||
|
||||
|
||||
/* Fuses */
|
||||
#define FUSE_MEMORY_SIZE 3
|
||||
|
||||
/* Low Fuse Byte */
|
||||
#define FUSE_CKSEL0 (unsigned char)~_BV(0) /* Select Clock Source */
|
||||
#define FUSE_CKSEL1 (unsigned char)~_BV(1) /* Select Clock Source */
|
||||
#define FUSE_CKSEL2 (unsigned char)~_BV(2) /* Select Clock Source */
|
||||
#define FUSE_CKSEL3 (unsigned char)~_BV(3) /* Select Clock Source */
|
||||
#define FUSE_SUT0 (unsigned char)~_BV(4) /* Select start-up time */
|
||||
#define FUSE_SUT1 (unsigned char)~_BV(5) /* Select start-up time */
|
||||
#define FUSE_CKOUT (unsigned char)~_BV(6) /* Clock output */
|
||||
#define FUSE_CKDIV8 (unsigned char)~_BV(7) /* Divide clock by 8 */
|
||||
#define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8)
|
||||
|
||||
/* High Fuse Byte */
|
||||
#define FUSE_BODLEVEL0 (unsigned char)~_BV(0) /* Brown-out Detector trigger level */
|
||||
#define FUSE_BODLEVEL1 (unsigned char)~_BV(1) /* Brown-out Detector trigger level */
|
||||
#define FUSE_BODLEVEL2 (unsigned char)~_BV(2) /* Brown-out Detector trigger level */
|
||||
#define FUSE_EESAVE (unsigned char)~_BV(3) /* EEPROM memory is preserved through chip erase */
|
||||
#define FUSE_WDTON (unsigned char)~_BV(4) /* Watchdog Timer Always On */
|
||||
#define FUSE_SPIEN (unsigned char)~_BV(5) /* Enable Serial programming and Data Downloading */
|
||||
#define FUSE_DWEN (unsigned char)~_BV(6) /* debugWIRE Enable */
|
||||
#define FUSE_RSTDISBL (unsigned char)~_BV(7) /* External reset disable */
|
||||
#define HFUSE_DEFAULT (FUSE_SPIEN)
|
||||
|
||||
/* Extended Fuse Byte */
|
||||
#define FUSE_BOOTRST (unsigned char)~_BV(0)
|
||||
#define FUSE_BOOTSZ0 (unsigned char)~_BV(1)
|
||||
#define FUSE_BOOTSZ1 (unsigned char)~_BV(2)
|
||||
#define EFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1)
|
||||
|
||||
|
||||
|
||||
/* Lock Bits */
|
||||
#define __LOCK_BITS_EXIST
|
||||
#define __BOOT_LOCK_BITS_0_EXIST
|
||||
#define __BOOT_LOCK_BITS_1_EXIST
|
||||
|
||||
|
||||
/* Signature */
|
||||
#define SIGNATURE_0 0x1E
|
||||
#define SIGNATURE_1 0x93
|
||||
#define SIGNATURE_2 0x0F
|
||||
|
||||
|
||||
#endif /* _AVR_IOM88P_H_ */
|
Some files were not shown because too many files have changed in this diff Show more
Reference in a new issue