[04a62dce] | 1 | /* Copyright (c) 2004,2005, Anatoly Sokolov <aesok@pautinka.net> |
---|
| 2 | All rights reserved. |
---|
| 3 | |
---|
| 4 | Redistribution and use in source and binary forms, with or without |
---|
| 5 | modification, are permitted provided that the following conditions are met: |
---|
| 6 | |
---|
| 7 | * Redistributions of source code must retain the above copyright |
---|
| 8 | notice, this list of conditions and the following disclaimer. |
---|
| 9 | |
---|
| 10 | * Redistributions in binary form must reproduce the above copyright |
---|
| 11 | notice, this list of conditions and the following disclaimer in |
---|
| 12 | the documentation and/or other materials provided with the |
---|
| 13 | distribution. |
---|
| 14 | |
---|
| 15 | * Neither the name of the copyright holders nor the names of |
---|
| 16 | contributors may be used to endorse or promote products derived |
---|
| 17 | from this software without specific prior written permission. |
---|
| 18 | |
---|
| 19 | THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" |
---|
| 20 | AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
---|
| 21 | IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
---|
| 22 | ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE |
---|
| 23 | LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR |
---|
| 24 | CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
---|
| 25 | SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
---|
| 26 | INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN |
---|
| 27 | CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) |
---|
| 28 | ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
---|
| 29 | POSSIBILITY OF SUCH DAMAGE. */ |
---|
| 30 | |
---|
| 31 | /* $Id$ */ |
---|
| 32 | |
---|
| 33 | /* iocan64.h - definitions for CAN64 */ |
---|
| 34 | |
---|
| 35 | #ifndef _AVR_IOCAN64_H_ |
---|
| 36 | #define _AVR_IOCAN64_H_ 1 |
---|
| 37 | |
---|
| 38 | #include <avr/iocanxx.h> |
---|
| 39 | |
---|
| 40 | /* Constants */ |
---|
| 41 | #define SPM_PAGESIZE 256 |
---|
| 42 | #define RAMEND 0x10FF /* Last On-Chip SRAM Location */ |
---|
| 43 | #define XRAMEND 0xFFFF |
---|
| 44 | #define E2END 0x07FF |
---|
| 45 | #define E2PAGESIZE 8 |
---|
| 46 | #define FLASHEND 0xFFFF |
---|
| 47 | |
---|
| 48 | |
---|
| 49 | /* Fuses */ |
---|
| 50 | |
---|
| 51 | #define FUSE_MEMORY_SIZE 3 |
---|
| 52 | |
---|
| 53 | /* Low Fuse Byte */ |
---|
| 54 | #define FUSE_CKSEL0 (unsigned char)~_BV(0) |
---|
| 55 | #define FUSE_CKSEL1 (unsigned char)~_BV(1) |
---|
| 56 | #define FUSE_CKSEL2 (unsigned char)~_BV(2) |
---|
| 57 | #define FUSE_CKSEL3 (unsigned char)~_BV(3) |
---|
| 58 | #define FUSE_SUT0 (unsigned char)~_BV(4) |
---|
| 59 | #define FUSE_SUT1 (unsigned char)~_BV(5) |
---|
| 60 | #define FUSE_CKOUT (unsigned char)~_BV(6) |
---|
| 61 | #define FUSE_CKDIV8 (unsigned char)~_BV(7) |
---|
| 62 | #define LFUSE_DEFAULT (FUSE_CKSEL0 & FUSE_CKSEL2 & FUSE_CKSEL3 & FUSE_SUT0 & FUSE_CKDIV8) |
---|
| 63 | |
---|
| 64 | /* High Fuse Byte */ |
---|
| 65 | #define FUSE_BOOTRST (unsigned char)~_BV(0) |
---|
| 66 | #define FUSE_BOOTSZ0 (unsigned char)~_BV(1) |
---|
| 67 | #define FUSE_BOOTSZ1 (unsigned char)~_BV(2) |
---|
| 68 | #define FUSE_EESAVE (unsigned char)~_BV(3) |
---|
| 69 | #define FUSE_WDTON (unsigned char)~_BV(4) |
---|
| 70 | #define FUSE_SPIEN (unsigned char)~_BV(5) |
---|
| 71 | #define FUSE_JTAGEN (unsigned char)~_BV(6) |
---|
| 72 | #define FUSE_OCDEN (unsigned char)~_BV(7) |
---|
| 73 | #define HFUSE_DEFAULT (FUSE_BOOTSZ0 & FUSE_BOOTSZ1 & FUSE_SPIEN & FUSE_JTAGEN) |
---|
| 74 | |
---|
| 75 | /* Extended Fuse Byte */ |
---|
| 76 | #define FUSE_BODLEVEL0 (unsigned char)~_BV(1) |
---|
| 77 | #define FUSE_BODLEVEL1 (unsigned char)~_BV(2) |
---|
| 78 | #define FUSE_BODLEVEL2 (unsigned char)~_BV(3) |
---|
| 79 | #define EFUSE_DEFAULT (0xFF) |
---|
| 80 | |
---|
| 81 | |
---|
| 82 | /* Lock Bits */ |
---|
| 83 | #define __LOCK_BITS_EXIST |
---|
| 84 | #define __BOOT_LOCK_BITS_0_EXIST |
---|
| 85 | #define __BOOT_LOCK_BITS_1_EXIST |
---|
| 86 | |
---|
| 87 | |
---|
| 88 | /* Signature */ |
---|
| 89 | #define SIGNATURE_0 0x1E |
---|
| 90 | #define SIGNATURE_1 0x96 |
---|
| 91 | #define SIGNATURE_2 0x81 |
---|
| 92 | |
---|
| 93 | |
---|
| 94 | #endif /* _AVR_IOCAN64_H_ */ |
---|