mirror of
https://github.com/arduino/Arduino.git
synced 2024-12-03 14:24:15 +01:00
3176 lines
118 KiB
Plaintext
Executable File
3176 lines
118 KiB
Plaintext
Executable File
# $Id: avrdude.conf,v 1.1 2005/05/23 15:57:32 mellis Exp $
|
|
#
|
|
# AVRDUDE Configuration File
|
|
#
|
|
# This file contains configuration data used by AVRDUDE which describes
|
|
# the programming hardware pinouts and also provides part definitions.
|
|
# AVRDUDE's "-C" command line option specifies the location of the
|
|
# configuration file. The "-c" option names the programmer configuration
|
|
# which must match one of the entry's "id" parameter. The "-p" option
|
|
# identifies which part AVRDUDE is going to be programming and must match
|
|
# one of the parts' "id" parameter.
|
|
#
|
|
# Possible entry formats are:
|
|
#
|
|
# programmer
|
|
# id = <id1> [, <id2> [, <id3>] ...] ; # <idN> are quoted strings
|
|
# desc = <description> ; # quoted string
|
|
# type = par | stk500 | avr910; # programmer type
|
|
# baudrate = <num> ; # baudrate for avr910-programmer
|
|
# vcc = <num1> [, <num2> ... ] ; # pin number(s)
|
|
# reset = <num> ; # pin number
|
|
# sck = <num> ; # pin number
|
|
# mosi = <num> ; # pin number
|
|
# miso = <num> ; # pin number
|
|
# errled = <num> ; # pin number
|
|
# rdyled = <num> ; # pin number
|
|
# pgmled = <num> ; # pin number
|
|
# vfyled = <num> ; # pin number
|
|
# ;
|
|
#
|
|
# part
|
|
# id = <id> ; # quoted string
|
|
# desc = <description> ; # quoted string
|
|
# devicecode = <num> ; # deprecated, use stk500_devcode
|
|
# stk500_devcode = <num> ; # numeric
|
|
# avr910_devcode = <num> ; # numeric
|
|
# chip_erase_delay = <num> ; # micro-seconds
|
|
# pagel = <num> ; # pin name in hex, i.e., 0xD7
|
|
# bs2 = <num> ; # pin name in hex, i.e., 0xA0
|
|
# reset = dedicated | io;
|
|
# retry_pulse = reset | sck;
|
|
# pgm_enable = <instruction format> ;
|
|
# chip_erase = <instruction format> ;
|
|
# memory <memtype>
|
|
# paged = <yes/no> ; # yes / no
|
|
# size = <num> ; # bytes
|
|
# page_size = <num> ; # bytes
|
|
# num_pages = <num> ; # numeric
|
|
# min_write_delay = <num> ; # micro-seconds
|
|
# max_write_delay = <num> ; # micro-seconds
|
|
# readback_p1 = <num> ; # byte value
|
|
# readback_p2 = <num> ; # byte value
|
|
# pwroff_after_write = <yes/no> ; # yes / no
|
|
# read = <instruction format> ;
|
|
# write = <instruction format> ;
|
|
# read_lo = <instruction format> ;
|
|
# read_hi = <instruction format> ;
|
|
# write_lo = <instruction format> ;
|
|
# write_hi = <instruction format> ;
|
|
# loadpage_lo = <instruction format> ;
|
|
# loadpage_hi = <instruction format> ;
|
|
# writepage = <instruction format> ;
|
|
# ;
|
|
# ;
|
|
#
|
|
# If any of the above parameters are not specified, the default value
|
|
# of 0 is used for numerics or the empty string ("") for string
|
|
# values. If a required parameter is left empty, AVRDUDE will
|
|
# complain.
|
|
#
|
|
# NOTES:
|
|
# * 'devicecode' is the device code used by the STK500 (see codes
|
|
# listed below)
|
|
# * Not all memory types will implement all instructions.
|
|
# * AVR Fuse bits and Lock bits are implemented as a type of memory.
|
|
# * Example memory types are:
|
|
# "flash", "eeprom", "fuse", "lfuse" (low fuse), "hfuse" (high
|
|
# fuse), "signature", "calibration", "lock"
|
|
# * The memory type specified on the avrdude command line must match
|
|
# one of the memory types defined for the specified chip.
|
|
# * The pwroff_after_write flag causes avrdude to attempt to
|
|
# power the device off and back on after an unsuccessful write to
|
|
# the affected memory area if VCC programmer pins are defined. If
|
|
# VCC pins are not defined for the programmer, a message
|
|
# indicating that the device needs a power-cycle is printed out.
|
|
# This flag was added to work around a problem with the
|
|
# at90s4433/2333's; see the at90s4433 errata at:
|
|
#
|
|
# http://www.atmel.com/atmel/acrobat/doc1280.pdf
|
|
#
|
|
# INSTRUCTION FORMATS
|
|
#
|
|
# Instruction formats are specified as a comma seperated list of
|
|
# string values containing information (bit specifiers) about each
|
|
# of the 32 bits of the instruction. Bit specifiers may be one of
|
|
# the following formats:
|
|
#
|
|
# '1' = the bit is always set on input as well as output
|
|
#
|
|
# '0' = the bit is always clear on input as well as output
|
|
#
|
|
# 'x' = the bit is ignored on input and output
|
|
#
|
|
# 'a' = the bit is an address bit, the bit-number matches this bit
|
|
# specifier's position within the current instruction byte
|
|
#
|
|
# 'aN' = the bit is the Nth address bit, bit-number = N, i.e., a12
|
|
# is address bit 12 on input, a0 is address bit 0.
|
|
#
|
|
# 'i' = the bit is an input data bit
|
|
#
|
|
# 'o' = the bit is an output data bit
|
|
#
|
|
# Each instruction must be composed of 32 bit specifiers. The
|
|
# instruction specification closely follows the instruction data
|
|
# provided in Atmel's data sheets for their parts.
|
|
#
|
|
# See below for some examples.
|
|
#
|
|
#
|
|
# The following are STK500 part device codes to use for the
|
|
# "devicecode" field of the part. These came from Atmel's software
|
|
# section avr061.zip which accompanies the application note
|
|
# AVR061 available from:
|
|
#
|
|
# http://www.atmel.com/atmel/acrobat/doc2525.pdf
|
|
#
|
|
|
|
#define ATTINY10 0x10
|
|
#define ATTINY11 0x11
|
|
#define ATTINY12 0x12
|
|
#define ATTINY15 0x13
|
|
#define ATTINY13 0x14
|
|
|
|
#define ATTINY22 0x20
|
|
#define ATTINY26 0x21
|
|
#define ATTINY28 0x22
|
|
#define ATTINY2313 0x23
|
|
|
|
#define AT90S1200 0x33
|
|
|
|
#define AT90S2313 0x40
|
|
#define AT90S2323 0x41
|
|
#define AT90S2333 0x42
|
|
#define AT90S2343 0x43
|
|
|
|
#define AT90S4414 0x50
|
|
#define AT90S4433 0x51
|
|
#define AT90S4434 0x52
|
|
#define ATMEGA48 0x59
|
|
|
|
#define AT90S8515 0x60
|
|
#define AT90S8535 0x61
|
|
#define AT90C8534 0x62
|
|
#define ATMEGA8515 0x63
|
|
#define ATMEGA8535 0x64
|
|
|
|
#define ATMEGA8 0x70
|
|
#define ATMEGA88 0x73
|
|
|
|
#define ATMEGA161 0x80
|
|
#define ATMEGA163 0x81
|
|
#define ATMEGA16 0x82
|
|
#define ATMEGA162 0x83
|
|
#define ATMEGA169 0x84
|
|
|
|
#define ATMEGA323 0x90
|
|
#define ATMEGA32 0x91
|
|
|
|
#define ATMEGA64 0xA0
|
|
|
|
#define ATMEGA103 0xB1
|
|
#define ATMEGA128 0xB2
|
|
#define AT90CAN128 0xB3
|
|
|
|
#define AT86RF401 0xD0
|
|
|
|
#define AT89START 0xE0
|
|
#define AT89S51 0xE0
|
|
#define AT89S52 0xE1
|
|
|
|
|
|
#
|
|
# Overall avrdude defaults
|
|
#
|
|
default_parallel = "lpt1";
|
|
default_serial = "com1";
|
|
|
|
|
|
#
|
|
# PROGRAMMER DEFINITIONS
|
|
#
|
|
|
|
programmer
|
|
id = "bsd";
|
|
desc = "Brian Dean's Programmer, http://www.bsdhome.com/avrdude/";
|
|
type = par;
|
|
vcc = 2, 3, 4, 5;
|
|
reset = 7;
|
|
sck = 8;
|
|
mosi = 9;
|
|
miso = 10;
|
|
;
|
|
|
|
programmer
|
|
id = "avrisp";
|
|
desc = "Atmel AVR ISP";
|
|
type = stk500;
|
|
;
|
|
|
|
programmer
|
|
id = "stk500";
|
|
desc = "Atmel STK500";
|
|
type = stk500;
|
|
;
|
|
|
|
programmer
|
|
id = "stk500@9600";
|
|
desc = "Atmel STK500";
|
|
type = stk500;
|
|
baudrate = 9600;
|
|
;
|
|
|
|
programmer
|
|
id = "avr910";
|
|
desc = "Atmel Low Cost Serial Programmer";
|
|
type = avr910;
|
|
;
|
|
|
|
programmer
|
|
id = "butterfly";
|
|
desc = "Atmel Butterfly Development Board";
|
|
type = butterfly;
|
|
;
|
|
|
|
programmer
|
|
id = "pavr";
|
|
desc = "Jason Kyle's pAVR Serial Programmer";
|
|
type = avr910;
|
|
;
|
|
|
|
programmer
|
|
id = "stk200";
|
|
desc = "STK200";
|
|
type = par;
|
|
buff = 4, 5;
|
|
sck = 6;
|
|
mosi = 7;
|
|
reset = 9;
|
|
miso = 10;
|
|
;
|
|
|
|
# The programming dongle used by the popular Ponyprog
|
|
# utility. It is almost similar to the STK200 one,
|
|
# except that there is a LED indicating that the
|
|
# programming is currently in progress.
|
|
|
|
programmer
|
|
id = "pony-stk200";
|
|
desc = "Pony Prog STK200";
|
|
type = par;
|
|
buff = 4, 5;
|
|
sck = 6;
|
|
mosi = 7;
|
|
reset = 9;
|
|
miso = 10;
|
|
pgmled = 8;
|
|
;
|
|
|
|
programmer
|
|
id = "dt006";
|
|
desc = "Dontronics DT006";
|
|
type = par;
|
|
reset = 4;
|
|
sck = 5;
|
|
mosi = 2;
|
|
miso = 11;
|
|
;
|
|
|
|
programmer
|
|
id = "bascom";
|
|
desc = "Bascom SAMPLE programming cable";
|
|
type = par;
|
|
reset = 4;
|
|
sck = 5;
|
|
mosi = 2;
|
|
miso = 11;
|
|
;
|
|
|
|
programmer
|
|
id = "alf";
|
|
desc = "Nightshade ALF-PgmAVR, http://nightshade.homeip.net/";
|
|
type = par;
|
|
vcc = 2, 3, 4, 5;
|
|
buff = 6;
|
|
reset = 7;
|
|
sck = 8;
|
|
mosi = 9;
|
|
miso = 10;
|
|
errled = 1;
|
|
rdyled = 14;
|
|
pgmled = 16;
|
|
vfyled = 17;
|
|
;
|
|
|
|
programmer
|
|
id = "sp12";
|
|
desc = "Steve Bolt's Programmer";
|
|
type = par;
|
|
vcc = 4,5,6,7,8;
|
|
reset = 3;
|
|
sck = 2;
|
|
mosi = 9;
|
|
miso = 11;
|
|
;
|
|
|
|
programmer
|
|
id = "picoweb";
|
|
desc = "Picoweb Programming Cable, http://www.picoweb.net/";
|
|
type = par;
|
|
reset = 2;
|
|
sck = 3;
|
|
mosi = 4;
|
|
miso = 13;
|
|
;
|
|
|
|
programmer
|
|
id = "abcmini";
|
|
desc = "ABCmini Board, aka Dick Smith HOTCHIP";
|
|
type = par;
|
|
reset = 4;
|
|
sck = 3;
|
|
mosi = 2;
|
|
miso = 10;
|
|
;
|
|
|
|
programmer
|
|
id = "futurlec";
|
|
desc = "Futurlec.com programming cable.";
|
|
type = par;
|
|
reset = 3;
|
|
sck = 2;
|
|
mosi = 1;
|
|
miso = 10;
|
|
;
|
|
|
|
#
|
|
# PART DEFINITIONS
|
|
#
|
|
|
|
#------------------------------------------------------------
|
|
# ATtiny12
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "t12";
|
|
desc = "ATtiny12";
|
|
stk500_devcode = 0x12;
|
|
avr910_devcode = 0x55;
|
|
chip_erase_delay = 20000;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 x x x x x",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
size = 64;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read = "1 0 1 0 0 0 0 0 x x x x x x x x",
|
|
"x x a5 a4 a3 a2 a1 a0 o o o o o o o o";
|
|
|
|
write = "1 1 0 0 0 0 0 0 x x x x x x x x",
|
|
"x x a5 a4 a3 a2 a1 a0 i i i i i i i i";
|
|
;
|
|
|
|
memory "flash"
|
|
size = 1024;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 20000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" x x x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" x x x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write_lo = " 0 1 0 0 0 0 0 0",
|
|
" x x x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
write_hi = " 0 1 0 0 1 0 0 0",
|
|
" x x x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"0 0 0 0 0 0 a1 a0 o o o o o o o o";
|
|
;
|
|
|
|
memory "lock"
|
|
size = 1;
|
|
read = "0 1 0 1 1 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x x x x x x o o x";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 1 1 i i 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
;
|
|
|
|
memory "calibration"
|
|
size = 1;
|
|
read = "0 0 1 1 1 0 0 0 x x x x x x x x",
|
|
"0 0 0 0 0 0 0 0 o o o o o o o o";
|
|
;
|
|
|
|
memory "fuse"
|
|
size = 1;
|
|
read = "0 1 0 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 x x x x x",
|
|
"x x x x x x x x i i i i i i i i";
|
|
;
|
|
;
|
|
|
|
#------------------------------------------------------------
|
|
# ATtiny13
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "t13";
|
|
desc = "ATtiny13";
|
|
stk500_devcode = 0x14;
|
|
chip_erase_delay = 4000;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 x x x x x",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
size = 64;
|
|
min_write_delay = 4000;
|
|
max_write_delay = 4000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read = "1 0 1 0 0 0 0 0 0 0 0 x x x x x",
|
|
"x x a5 a4 a3 a2 a1 a0 o o o o o o o o";
|
|
|
|
write = "1 1 0 0 0 0 0 0 0 0 0 x x x x x",
|
|
"x x a5 a4 a3 a2 a1 a0 i i i i i i i i";
|
|
;
|
|
|
|
memory "flash"
|
|
paged = yes;
|
|
size = 1024;
|
|
page_size = 32;
|
|
num_pages = 32;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" 0 0 0 0 0 0 0 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" 0 0 0 0 0 0 0 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
loadpage_lo = " 0 1 0 0 0 0 0 0",
|
|
" 0 0 0 x x x x x",
|
|
" x x x x a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
loadpage_hi = " 0 1 0 0 1 0 0 0",
|
|
" 0 0 0 x x x x x",
|
|
" x x x x a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
writepage = " 0 1 0 0 1 1 0 0",
|
|
" 0 0 0 0 0 0 0 a8",
|
|
" a7 a6 a5 a4 x x x x",
|
|
" x x x x x x x x";
|
|
;
|
|
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 0 0 0 x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
|
|
memory "lock"
|
|
size = 1;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 x x x x x",
|
|
"x x x x x x x x 1 1 i i i i i i";
|
|
;
|
|
|
|
memory "calibration"
|
|
size = 1;
|
|
read = "0 0 1 1 1 0 0 0 0 0 0 x x x x x",
|
|
"0 0 0 0 0 0 0 0 o o o o o o o o";
|
|
;
|
|
|
|
memory "lfuse"
|
|
size = 1;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
;
|
|
|
|
memory "hfuse"
|
|
size = 1;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 1 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
;
|
|
|
|
;
|
|
|
|
|
|
#------------------------------------------------------------
|
|
# ATtiny15
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "t15";
|
|
desc = "ATtiny15";
|
|
stk500_devcode = 0x13;
|
|
avr910_devcode = 0x56;
|
|
chip_erase_delay = 8200;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 x x x x x",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
size = 64;
|
|
min_write_delay = 8200;
|
|
max_write_delay = 8200;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read = "1 0 1 0 0 0 0 0 x x x x x x x x",
|
|
"x x a5 a4 a3 a2 a1 a0 o o o o o o o o";
|
|
|
|
write = "1 1 0 0 0 0 0 0 x x x x x x x x",
|
|
"x x a5 a4 a3 a2 a1 a0 i i i i i i i i";
|
|
;
|
|
|
|
memory "flash"
|
|
size = 1024;
|
|
min_write_delay = 4100;
|
|
max_write_delay = 4100;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" x x x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" x x x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write_lo = " 0 1 0 0 0 0 0 0",
|
|
" x x x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
write_hi = " 0 1 0 0 1 0 0 0",
|
|
" x x x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"0 0 0 0 0 0 a1 a0 o o o o o o o o";
|
|
;
|
|
|
|
memory "lock"
|
|
size = 1;
|
|
read = "0 1 0 1 1 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x x x x x x o o x";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 1 1 i i 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
;
|
|
|
|
memory "calibration"
|
|
size = 1;
|
|
read = "0 0 1 1 1 0 0 0 x x x x x x x x",
|
|
"0 0 0 0 0 0 0 0 o o o o o o o o";
|
|
;
|
|
|
|
memory "fuse"
|
|
size = 1;
|
|
read = "0 1 0 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x o o o o x x o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 x x x x x",
|
|
"x x x x x x x x i i i i 1 1 i i";
|
|
;
|
|
;
|
|
|
|
|
|
#------------------------------------------------------------
|
|
# AT90s1200
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "1200";
|
|
desc = "AT90S1200";
|
|
stk500_devcode = 0x33;
|
|
avr910_devcode = 0x13;
|
|
pagel = 0xd7;
|
|
bs2 = 0xa0;
|
|
chip_erase_delay = 20000;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
size = 64;
|
|
min_write_delay = 4000;
|
|
max_write_delay = 9000;
|
|
readback_p1 = 0x00;
|
|
readback_p2 = 0xff;
|
|
read = "1 0 1 0 0 0 0 0 x x x x x x x x",
|
|
"x x a5 a4 a3 a2 a1 a0 o o o o o o o o";
|
|
|
|
write = "1 1 0 0 0 0 0 0 x x x x x x x x",
|
|
"x x a5 a4 a3 a2 a1 a0 i i i i i i i i";
|
|
;
|
|
memory "flash"
|
|
size = 1024;
|
|
min_write_delay = 4000;
|
|
max_write_delay = 9000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" x x x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" x x x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write_lo = " 0 1 0 0 0 0 0 0",
|
|
" x x x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
write_hi = " 0 1 0 0 1 0 0 0",
|
|
" x x x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
memory "fuse"
|
|
size = 1;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
read = "0 1 0 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x x x o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 i i i i i",
|
|
"x x x x x x x x x x x x x x x x";
|
|
;
|
|
memory "lock"
|
|
size = 1;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
read = "0 1 0 1 1 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x x x x x x o o x";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 1 1 i i 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
;
|
|
;
|
|
|
|
#------------------------------------------------------------
|
|
# AT90s4414
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "4414";
|
|
desc = "AT90S4414";
|
|
stk500_devcode = 0x50;
|
|
avr910_devcode = 0x28;
|
|
chip_erase_delay = 20000;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
size = 256;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
readback_p1 = 0x80;
|
|
readback_p2 = 0x7f;
|
|
read = " 1 0 1 0 0 0 0 0 x x x x x x x a8",
|
|
"a7 a6 a5 a4 a3 a2 a1 a0 o o o o o o o o";
|
|
|
|
write = " 1 1 0 0 0 0 0 0 x x x x x x x a8",
|
|
"a7 a6 a5 a4 a3 a2 a1 a0 i i i i i i i i";
|
|
;
|
|
memory "flash"
|
|
size = 4096;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
readback_p1 = 0x7f;
|
|
readback_p2 = 0x7f;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" x x x x a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" x x x x a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write_lo = " 0 1 0 0 0 0 0 0",
|
|
" x x x x a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
write_hi = " 0 1 0 0 1 0 0 0",
|
|
" x x x x a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
;
|
|
|
|
#------------------------------------------------------------
|
|
# AT90s2313
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "2313";
|
|
desc = "AT90S2313";
|
|
stk500_devcode = 0x40;
|
|
avr910_devcode = 0x20;
|
|
chip_erase_delay = 20000;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
size = 128;
|
|
min_write_delay = 4000;
|
|
max_write_delay = 9000;
|
|
readback_p1 = 0x80;
|
|
readback_p2 = 0x7f;
|
|
read = "1 0 1 0 0 0 0 0 x x x x x x x x",
|
|
"x a6 a5 a4 a3 a2 a1 a0 o o o o o o o o";
|
|
|
|
write = "1 1 0 0 0 0 0 0 x x x x x x x x",
|
|
"x a6 a5 a4 a3 a2 a1 a0 i i i i i i i i";
|
|
;
|
|
memory "flash"
|
|
size = 2048;
|
|
min_write_delay = 4000;
|
|
max_write_delay = 9000;
|
|
readback_p1 = 0x7f;
|
|
readback_p2 = 0x7f;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" x x x x x x a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" x x x x x x a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write_lo = " 0 1 0 0 0 0 0 0",
|
|
" x x x x x x a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
write_hi = " 0 1 0 0 1 0 0 0",
|
|
" x x x x x x a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
memory "lock"
|
|
size = 1;
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 x x i i x",
|
|
"x x x x x x x x x x x x x x x x";
|
|
;
|
|
;
|
|
|
|
#------------------------------------------------------------
|
|
# AT90s2333
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "2333";
|
|
desc = "AT90S2333";
|
|
stk500_devcode = 0x42;
|
|
avr910_devcode = 0x34;
|
|
chip_erase_delay = 20000;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
size = 128;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
readback_p1 = 0x00;
|
|
readback_p2 = 0xff;
|
|
read = "1 0 1 0 0 0 0 0 x x x x x x x x",
|
|
"x a6 a5 a4 a3 a2 a1 a0 o o o o o o o o";
|
|
|
|
write = "1 1 0 0 0 0 0 0 x x x x x x x x",
|
|
"x a6 a5 a4 a3 a2 a1 a0 i i i i i i i i";
|
|
;
|
|
memory "flash"
|
|
size = 2048;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" x x x x x x a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" x x x x x x a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write_lo = " 0 1 0 0 0 0 0 0",
|
|
" x x x x x x a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
write_hi = " 0 1 0 0 1 0 0 0",
|
|
" x x x x x x a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
memory "fuse"
|
|
size = 1;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
pwroff_after_write = yes;
|
|
read = "0 1 0 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x x x o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 i i i i i",
|
|
"x x x x x x x x x x x x x x x x";
|
|
;
|
|
memory "lock"
|
|
size = 1;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
read = "0 1 0 1 1 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x x x x x x o o x";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 1 1 i i 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
;
|
|
;
|
|
|
|
|
|
#------------------------------------------------------------
|
|
# AT90s2343
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "2343";
|
|
desc = "AT90S2343";
|
|
stk500_devcode = 0x43;
|
|
avr910_devcode = 0x4c;
|
|
chip_erase_delay = 18000;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 x x x x x",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
size = 128;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
readback_p1 = 0x00;
|
|
readback_p2 = 0xff;
|
|
read = "1 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x a6 a5 a4 a3 a2 a1 a0 o o o o o o o o";
|
|
|
|
write = "1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x a6 a5 a4 a3 a2 a1 a0 i i i i i i i i";
|
|
;
|
|
memory "flash"
|
|
size = 2048;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" x x x x x x a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" x x x x x x a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write_lo = " 0 1 0 0 0 0 0 0",
|
|
" x x x x x x a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
write_hi = " 0 1 0 0 1 0 0 0",
|
|
" x x x x x x a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
memory "fuse"
|
|
size = 1;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
read = "0 1 0 1 1 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x o o o x x x x o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 1 1 1 1 i",
|
|
"x x x x x x x x x x x x x x x x";
|
|
;
|
|
memory "lock"
|
|
size = 1;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
read = "0 1 0 1 1 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x o o o x x x x o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 1 1 i i 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
;
|
|
;
|
|
|
|
|
|
#------------------------------------------------------------
|
|
# AT90s4433
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "4433";
|
|
desc = "AT90S4433";
|
|
stk500_devcode = 0x51;
|
|
avr910_devcode = 0x30;
|
|
chip_erase_delay = 20000;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
size = 256;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
readback_p1 = 0x00;
|
|
readback_p2 = 0xff;
|
|
read = " 1 0 1 0 0 0 0 0 x x x x x x x x",
|
|
"a7 a6 a5 a4 a3 a2 a1 a0 o o o o o o o o";
|
|
|
|
write = " 1 1 0 0 0 0 0 0 x x x x x x x x",
|
|
"a7 a6 a5 a4 a3 a2 a1 a0 i i i i i i i i";
|
|
;
|
|
memory "flash"
|
|
size = 4096;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" x x x x x a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" x x x x x a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write_lo = " 0 1 0 0 0 0 0 0",
|
|
" x x x x x a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
write_hi = " 0 1 0 0 1 0 0 0",
|
|
" x x x x x a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
memory "fuse"
|
|
size = 1;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
pwroff_after_write = yes;
|
|
read = "0 1 0 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x x x o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 i i i i i",
|
|
"x x x x x x x x x x x x x x x x";
|
|
;
|
|
memory "lock"
|
|
size = 1;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
read = "0 1 0 1 1 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x x x x x x o o x";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 1 1 i i 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
;
|
|
;
|
|
|
|
#------------------------------------------------------------
|
|
# AT90s4434
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "4434";
|
|
desc = "AT90S4434";
|
|
stk500_devcode = 0x52;
|
|
avr910_devcode = 0x6c;
|
|
chip_erase_delay = 20000;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
size = 256;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
readback_p1 = 0x00;
|
|
readback_p2 = 0xff;
|
|
read = " 1 0 1 0 0 0 0 0 x x x x x x x x",
|
|
"a7 a6 a5 a4 a3 a2 a1 a0 o o o o o o o o";
|
|
|
|
write = " 1 1 0 0 0 0 0 0 x x x x x x x x",
|
|
"a7 a6 a5 a4 a3 a2 a1 a0 i i i i i i i i";
|
|
;
|
|
memory "flash"
|
|
size = 4096;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" x x x x x a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" x x x x x a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write_lo = " 0 1 0 0 0 0 0 0",
|
|
" x x x x x a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
write_hi = " 0 1 0 0 1 0 0 0",
|
|
" x x x x x a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
memory "fuse"
|
|
size = 1;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
read = "0 1 0 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x x x o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 i i i i i",
|
|
"x x x x x x x x x x x x x x x x";
|
|
;
|
|
memory "lock"
|
|
size = 1;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
read = "0 1 0 1 1 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x x x x x x o o x";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 1 1 i i 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
;
|
|
;
|
|
|
|
#------------------------------------------------------------
|
|
# AT90s8515
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "8515";
|
|
desc = "AT90S8515";
|
|
stk500_devcode = 0x60;
|
|
avr910_devcode = 0x38;
|
|
chip_erase_delay = 20000;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 x x x x x",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
size = 512;
|
|
min_write_delay = 4000;
|
|
max_write_delay = 9000;
|
|
readback_p1 = 0x80;
|
|
readback_p2 = 0x7f;
|
|
read = " 1 0 1 0 0 0 0 0 x x x x x x x a8",
|
|
"a7 a6 a5 a4 a3 a2 a1 a0 o o o o o o o o";
|
|
|
|
write = " 1 1 0 0 0 0 0 0 x x x x x x x a8",
|
|
"a7 a6 a5 a4 a3 a2 a1 a0 i i i i i i i i";
|
|
;
|
|
memory "flash"
|
|
size = 8192;
|
|
min_write_delay = 4000;
|
|
max_write_delay = 9000;
|
|
readback_p1 = 0x7f;
|
|
readback_p2 = 0x7f;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" x x x x a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" x x x x a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write_lo = " 0 1 0 0 0 0 0 0",
|
|
" x x x x a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
write_hi = " 0 1 0 0 1 0 0 0",
|
|
" x x x x a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
memory "fuse"
|
|
size = 1;
|
|
read = "0 1 0 1 1 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x x x x x x x x o";
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 1 1 1 1 i",
|
|
"x x x x x x x x x x x x x x x x";
|
|
;
|
|
memory "lock"
|
|
size = 1;
|
|
read = "0 1 0 1 1 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x o o x x x x x x";
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 1 1 i i 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
;
|
|
;
|
|
|
|
#------------------------------------------------------------
|
|
# AT90s8535
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "8535";
|
|
desc = "AT90S8535";
|
|
stk500_devcode = 0x61;
|
|
avr910_devcode = 0x68;
|
|
chip_erase_delay = 20000;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
size = 512;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
readback_p1 = 0x00;
|
|
readback_p2 = 0xff;
|
|
read = " 1 0 1 0 0 0 0 0 x x x x x x x a8",
|
|
"a7 a6 a5 a4 a3 a2 a1 a0 o o o o o o o o";
|
|
|
|
write = " 1 1 0 0 0 0 0 0 x x x x x x x a8",
|
|
"a7 a6 a5 a4 a3 a2 a1 a0 i i i i i i i i";
|
|
;
|
|
memory "flash"
|
|
size = 8192;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 20000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" x x x x a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" x x x x a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write_lo = " 0 1 0 0 0 0 0 0",
|
|
" x x x x a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
write_hi = " 0 1 0 0 1 0 0 0",
|
|
" x x x x a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
memory "fuse"
|
|
size = 1;
|
|
read = "0 1 0 1 1 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x x x x x x x x o";
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 1 1 1 1 i",
|
|
"x x x x x x x x x x x x x x x x";
|
|
;
|
|
memory "lock"
|
|
size = 1;
|
|
read = "0 1 0 1 1 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x o o x x x x x x";
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 1 1 i i 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
;
|
|
;
|
|
|
|
#------------------------------------------------------------
|
|
# ATmega103
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "m103";
|
|
desc = "ATMEGA103";
|
|
stk500_devcode = 0xB1;
|
|
avr910_devcode = 0x41;
|
|
chip_erase_delay = 112000;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
size = 4096;
|
|
min_write_delay = 4000;
|
|
max_write_delay = 9000;
|
|
readback_p1 = 0x00;
|
|
readback_p2 = 0xff;
|
|
read = " 1 0 1 0 0 0 0 0",
|
|
" x x x x a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write = " 1 1 0 0 0 0 0 0",
|
|
" x x x x a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
|
|
memory "flash"
|
|
paged = yes;
|
|
size = 131072;
|
|
page_size = 256;
|
|
num_pages = 512;
|
|
min_write_delay = 22000;
|
|
max_write_delay = 56000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
"a15 a14 a13 a12 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
"a15 a14 a13 a12 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
loadpage_lo = " 0 1 0 0 0 0 0 0",
|
|
" x x x x x x x x",
|
|
" x a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
loadpage_hi = " 0 1 0 0 1 0 0 0",
|
|
" x x x x x x x x",
|
|
" x a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
writepage = " 0 1 0 0 1 1 0 0",
|
|
"a15 a14 a13 a12 a11 a10 a9 a8",
|
|
" a7 x x x x x x x",
|
|
" x x x x x x x x";
|
|
;
|
|
|
|
memory "fuse"
|
|
size = 1;
|
|
read = "0 1 0 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x x x o x o 1 o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 1 i 1 i i",
|
|
"x x x x x x x x x x x x x x x x";
|
|
;
|
|
|
|
memory "lock"
|
|
size = 1;
|
|
read = "0 1 0 1 1 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x x x x x x o o x";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 1 1 i i 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
;
|
|
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
;
|
|
|
|
|
|
#------------------------------------------------------------
|
|
# ATmega64
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "m64";
|
|
desc = "ATMEGA64";
|
|
stk500_devcode = 0xA0;
|
|
chip_erase_delay = 9000;
|
|
pagel = 0xD7;
|
|
bs2 = 0xA0;
|
|
reset = dedicated;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
paged = no; /* leave this "no" */
|
|
page_size = 8; /* for parallel programming */
|
|
size = 2048;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 9000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read = " 1 0 1 0 0 0 0 0",
|
|
" x x x x a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write = " 1 1 0 0 0 0 0 0",
|
|
" x x x x a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
|
|
memory "flash"
|
|
paged = yes;
|
|
size = 65536;
|
|
page_size = 256;
|
|
num_pages = 256;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" x a14 a13 a12 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" x a14 a13 a12 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
loadpage_lo = " 0 1 0 0 0 0 0 0",
|
|
" x x x x x x x x",
|
|
" x a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
loadpage_hi = " 0 1 0 0 1 0 0 0",
|
|
" x x x x x x x x",
|
|
" x a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
writepage = " 0 1 0 0 1 1 0 0",
|
|
" x a14 a13 a12 a11 a10 a9 a8",
|
|
" a7 x x x x x x x",
|
|
" x x x x x x x x";
|
|
;
|
|
|
|
memory "lfuse"
|
|
size = 1;
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
;
|
|
|
|
memory "hfuse"
|
|
size = 1;
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 1 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
;
|
|
|
|
memory "efuse"
|
|
size = 1;
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 1 0 0",
|
|
"x x x x x x x x x x x x x x i i";
|
|
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
;
|
|
|
|
memory "lock"
|
|
size = 1;
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 x x x x x",
|
|
"x x x x x x x x 1 1 i i i i i i";
|
|
;
|
|
|
|
memory "calibration"
|
|
size = 1;
|
|
read = "0 0 1 1 1 0 0 0 x x x x x x x x",
|
|
"0 0 0 0 0 0 0 0 o o o o o o o o";
|
|
;
|
|
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
;
|
|
|
|
|
|
|
|
|
|
#------------------------------------------------------------
|
|
# ATmega128
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "m128";
|
|
desc = "ATMEGA128";
|
|
stk500_devcode = 0xB2;
|
|
avr910_devcode = 0x43;
|
|
chip_erase_delay = 9000;
|
|
pagel = 0xD7;
|
|
bs2 = 0xA0;
|
|
reset = dedicated;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
paged = no; /* leave this "no" */
|
|
page_size = 8; /* for parallel programming */
|
|
size = 4096;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 9000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read = " 1 0 1 0 0 0 0 0",
|
|
" x x x x a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write = " 1 1 0 0 0 0 0 0",
|
|
" x x x x a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
|
|
memory "flash"
|
|
paged = yes;
|
|
size = 131072;
|
|
page_size = 256;
|
|
num_pages = 512;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
"a15 a14 a13 a12 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
"a15 a14 a13 a12 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
loadpage_lo = " 0 1 0 0 0 0 0 0",
|
|
" x x x x x x x x",
|
|
" x a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
loadpage_hi = " 0 1 0 0 1 0 0 0",
|
|
" x x x x x x x x",
|
|
" x a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
writepage = " 0 1 0 0 1 1 0 0",
|
|
"a15 a14 a13 a12 a11 a10 a9 a8",
|
|
" a7 x x x x x x x",
|
|
" x x x x x x x x";
|
|
;
|
|
|
|
memory "lfuse"
|
|
size = 1;
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
;
|
|
|
|
memory "hfuse"
|
|
size = 1;
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 1 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
;
|
|
|
|
memory "efuse"
|
|
size = 1;
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 1 0 0",
|
|
"x x x x x x x x x x x x x x i i";
|
|
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
;
|
|
|
|
memory "lock"
|
|
size = 1;
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 x x x x x",
|
|
"x x x x x x x x 1 1 i i i i i i";
|
|
;
|
|
|
|
memory "calibration"
|
|
size = 1;
|
|
read = "0 0 1 1 1 0 0 0 x x x x x x x x",
|
|
"0 0 0 0 0 0 0 0 o o o o o o o o";
|
|
;
|
|
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
;
|
|
|
|
#------------------------------------------------------------
|
|
# ATmega16
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "m16";
|
|
desc = "ATMEGA16";
|
|
stk500_devcode = 0x82;
|
|
avr910_devcode = 0x74;
|
|
pagel = 0xd7;
|
|
bs2 = 0xa0;
|
|
chip_erase_delay = 9000;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 x x x x x",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
size = 512;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 9000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read = " 1 0 1 0 0 0 0 0",
|
|
" 0 0 x x x x a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write = " 1 1 0 0 0 0 0 0",
|
|
" 0 0 x x x x a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
|
|
memory "flash"
|
|
paged = yes;
|
|
size = 16384;
|
|
page_size = 128;
|
|
num_pages = 128;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" 0 0 a13 a12 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" 0 0 a13 a12 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
loadpage_lo = " 0 1 0 0 0 0 0 0",
|
|
" 0 0 x x x x x x",
|
|
" x x a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
loadpage_hi = " 0 1 0 0 1 0 0 0",
|
|
" 0 0 x x x x x x",
|
|
" x x a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
writepage = " 0 1 0 0 1 1 0 0",
|
|
" 0 0 a13 a12 a11 a10 a9 a8",
|
|
" a7 a6 x x x x x x",
|
|
" x x x x x x x x";
|
|
;
|
|
|
|
memory "lock"
|
|
size = 1;
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 x x x x x",
|
|
"x x x x x x x x 1 1 i i i i i i";
|
|
;
|
|
|
|
memory "lfuse"
|
|
size = 1;
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
;
|
|
|
|
memory "hfuse"
|
|
size = 1;
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 1 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
;
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
;
|
|
|
|
|
|
#------------------------------------------------------------
|
|
# ATmega162
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "m162";
|
|
desc = "ATMEGA162";
|
|
stk500_devcode = 0x83;
|
|
chip_erase_delay = 9000;
|
|
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 x x x x x",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "flash"
|
|
paged = yes;
|
|
size = 16384;
|
|
page_size = 128;
|
|
num_pages = 128;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" 0 0 a13 a12 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" 0 0 a13 a12 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
loadpage_lo = " 0 1 0 0 0 0 0 0",
|
|
" 0 0 x x x x x x",
|
|
" x x a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
loadpage_hi = " 0 1 0 0 1 0 0 0",
|
|
" 0 0 x x x x x x",
|
|
" x x a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
writepage = " 0 1 0 0 1 1 0 0",
|
|
" 0 0 a13 a12 a11 a10 a9 a8",
|
|
" a7 a6 x x x x x x",
|
|
" x x x x x x x x";
|
|
;
|
|
|
|
memory "eeprom"
|
|
size = 512;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 9000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
|
|
read = " 1 0 1 0 0 0 0 0",
|
|
" 0 0 x x x x a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write = " 1 1 0 0 0 0 0 0",
|
|
" 0 0 x x x x a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
|
|
memory "lfuse"
|
|
size = 1;
|
|
min_write_delay = 16000;
|
|
max_write_delay = 16000;
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
;
|
|
|
|
memory "hfuse"
|
|
size = 1;
|
|
min_write_delay = 16000;
|
|
max_write_delay = 16000;
|
|
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 1 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
;
|
|
|
|
memory "efuse"
|
|
size = 1;
|
|
min_write_delay = 16000;
|
|
max_write_delay = 16000;
|
|
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 1 0 0",
|
|
"x x x x x x x x 1 1 1 i i i i 1";
|
|
;
|
|
|
|
memory "lock"
|
|
size = 1;
|
|
min_write_delay = 16000;
|
|
max_write_delay = 16000;
|
|
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 x x x x x",
|
|
"x x x x x x x x 1 1 i i i i i i";
|
|
;
|
|
|
|
memory "signature"
|
|
size = 3;
|
|
|
|
read = "0 0 1 1 0 0 0 0 0 0 x x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
|
|
memory "calibration"
|
|
size = 1;
|
|
|
|
read = "0 0 1 1 1 0 0 0 0 0 x x x x x x",
|
|
"0 0 0 0 0 0 0 0 o o o o o o o o";
|
|
;
|
|
;
|
|
|
|
|
|
|
|
#------------------------------------------------------------
|
|
# ATmega163
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "m163";
|
|
desc = "ATMEGA163";
|
|
stk500_devcode = 0x81;
|
|
avr910_devcode = 0x64;
|
|
chip_erase_delay = 32000;
|
|
pagel = 0xd7;
|
|
bs2 = 0xa0;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x x x x x x x";
|
|
memory "eeprom"
|
|
size = 512;
|
|
min_write_delay = 4000;
|
|
max_write_delay = 4000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read = " 1 0 1 0 0 0 0 0",
|
|
" x x x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write = " 1 1 0 0 0 0 0 0",
|
|
" x x x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
|
|
memory "flash"
|
|
paged = yes;
|
|
size = 16384;
|
|
page_size = 128;
|
|
num_pages = 128;
|
|
min_write_delay = 16000;
|
|
max_write_delay = 16000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" x x x a12 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" x x x a12 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
loadpage_lo = " 0 1 0 0 0 0 0 0",
|
|
" x x x x x x x x",
|
|
" x x a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
loadpage_hi = " 0 1 0 0 1 0 0 0",
|
|
" x x x x x x x x",
|
|
" x x a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
writepage = " 0 1 0 0 1 1 0 0",
|
|
" x x x a12 a11 a10 a9 a8",
|
|
" a7 a6 x x x x x x",
|
|
" x x x x x x x x";
|
|
;
|
|
|
|
memory "lfuse"
|
|
size = 1;
|
|
min_write_delay = 2000;
|
|
max_write_delay = 2000;
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x o o x x o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 0 0 0",
|
|
"x x x x x x x x i i 1 1 i i i i";
|
|
;
|
|
|
|
memory "hfuse"
|
|
size = 1;
|
|
min_write_delay = 2000;
|
|
max_write_delay = 2000;
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x x x x x 1 o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 1 0 0 0",
|
|
"x x x x x x x x 1 1 1 1 1 i i i";
|
|
;
|
|
|
|
memory "lock"
|
|
size = 1;
|
|
min_write_delay = 2000;
|
|
max_write_delay = 2000;
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x 0 x x x x x o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 x x x x x",
|
|
"x x x x x x x x 1 1 i i i i i i";
|
|
;
|
|
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
|
|
memory "calibration"
|
|
size = 1;
|
|
read = "0 0 1 1 1 0 0 0 x x x x x x x x",
|
|
"0 0 0 0 0 0 0 0 o o o o o o o o";
|
|
;
|
|
;
|
|
|
|
#------------------------------------------------------------
|
|
# ATmega169
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "m169";
|
|
desc = "ATMEGA169";
|
|
stk500_devcode = 0x85;
|
|
avr910_devcode = 0x75;
|
|
chip_erase_delay = 9000;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x x x x x x x";
|
|
memory "eeprom"
|
|
size = 512;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 9000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read = " 1 0 1 0 0 0 0 0",
|
|
" x x x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write = " 1 1 0 0 0 0 0 0",
|
|
" x x x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
|
|
memory "flash"
|
|
paged = yes;
|
|
size = 16384;
|
|
page_size = 128;
|
|
num_pages = 128;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" x x x a12 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" x x x a12 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
loadpage_lo = " 0 1 0 0 0 0 0 0",
|
|
" x x x x x x x x",
|
|
" x x a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
loadpage_hi = " 0 1 0 0 1 0 0 0",
|
|
" x x x x x x x x",
|
|
" x x a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
writepage = " 0 1 0 0 1 1 0 0",
|
|
" x x x a12 a11 a10 a9 a8",
|
|
" a7 a6 x x x x x x",
|
|
" x x x x x x x x";
|
|
;
|
|
|
|
memory "lfuse"
|
|
size = 1;
|
|
min_write_delay = 2000;
|
|
max_write_delay = 2000;
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
;
|
|
|
|
memory "hfuse"
|
|
size = 1;
|
|
min_write_delay = 2000;
|
|
max_write_delay = 2000;
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 1 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
;
|
|
|
|
memory "efuse"
|
|
size = 1;
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 1 0 0",
|
|
"x x x x x x x x x x x x i i i x";
|
|
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
;
|
|
|
|
memory "lock"
|
|
size = 1;
|
|
min_write_delay = 2000;
|
|
max_write_delay = 2000;
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 x x x x x",
|
|
"x x x x x x x x 1 1 i i i i i i";
|
|
;
|
|
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 0 0 0 x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
|
|
memory "calibration"
|
|
size = 1;
|
|
read = "0 0 1 1 1 0 0 0 0 0 0 x x x x x",
|
|
"0 0 0 0 0 0 0 0 o o o o o o o o";
|
|
;
|
|
;
|
|
|
|
#------------------------------------------------------------
|
|
# ATmega32
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "m32";
|
|
desc = "ATMEGA32";
|
|
stk500_devcode = 0x91;
|
|
avr910_devcode = 0x72;
|
|
chip_erase_delay = 9000;
|
|
pagel = 0xd7;
|
|
bs2 = 0xa0;
|
|
reset = dedicated;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x x x x x x x";
|
|
memory "eeprom"
|
|
paged = no; /* leave this "no" */
|
|
page_size = 4; /* for parallel programming */
|
|
size = 1024;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 9000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read = " 1 0 1 0 0 0 0 0",
|
|
" 0 0 x x x x a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write = " 1 1 0 0 0 0 0 0",
|
|
" 0 0 x x x x a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
|
|
memory "flash"
|
|
paged = yes;
|
|
size = 32768;
|
|
page_size = 128;
|
|
num_pages = 256;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" 0 0 a13 a12 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" 0 0 a13 a12 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
loadpage_lo = " 0 1 0 0 0 0 0 0",
|
|
" 0 0 x x x x x x",
|
|
" x x a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
loadpage_hi = " 0 1 0 0 1 0 0 0",
|
|
" 0 0 x x x x x x",
|
|
" x x a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
writepage = " 0 1 0 0 1 1 0 0",
|
|
" 0 0 a13 a12 a11 a10 a9 a8",
|
|
" a7 a6 x x x x x x",
|
|
" x x x x x x x x";
|
|
;
|
|
|
|
memory "lfuse"
|
|
size = 1;
|
|
min_write_delay = 2000;
|
|
max_write_delay = 2000;
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
;
|
|
|
|
memory "hfuse"
|
|
size = 1;
|
|
min_write_delay = 2000;
|
|
max_write_delay = 2000;
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 1 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
;
|
|
|
|
memory "lock"
|
|
size = 1;
|
|
min_write_delay = 2000;
|
|
max_write_delay = 2000;
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 x x x x x",
|
|
"x x x x x x x x 1 1 i i i i i i";
|
|
;
|
|
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
|
|
memory "calibration"
|
|
size = 1;
|
|
read = "0 0 1 1 1 0 0 0 0 0 x x x x x x",
|
|
"0 0 0 0 0 0 0 0 o o o o o o o o";
|
|
;
|
|
;
|
|
|
|
#------------------------------------------------------------
|
|
# ATmega161
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "m161";
|
|
desc = "ATMEGA161";
|
|
stk500_devcode = 0x80;
|
|
avr910_devcode = 0x60;
|
|
chip_erase_delay = 28000;
|
|
pagel = 0xd7;
|
|
bs2 = 0xa0;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x x x x x x x";
|
|
memory "eeprom"
|
|
size = 512;
|
|
min_write_delay = 3400;
|
|
max_write_delay = 3400;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read = " 1 0 1 0 0 0 0 0",
|
|
" x x x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write = " 1 1 0 0 0 0 0 0",
|
|
" x x x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
|
|
memory "flash"
|
|
paged = yes;
|
|
size = 16384;
|
|
page_size = 128;
|
|
num_pages = 128;
|
|
min_write_delay = 14000;
|
|
max_write_delay = 14000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" x x x a12 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" x x x a12 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
loadpage_lo = " 0 1 0 0 0 0 0 0",
|
|
" x x x x x x x x",
|
|
" x x a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
loadpage_hi = " 0 1 0 0 1 0 0 0",
|
|
" x x x x x x x x",
|
|
" x x a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
writepage = " 0 1 0 0 1 1 0 0",
|
|
" x x x a12 a11 a10 a9 a8",
|
|
" a7 a6 x x x x x x",
|
|
" x x x x x x x x";
|
|
;
|
|
|
|
memory "fuse"
|
|
size = 1;
|
|
min_write_delay = 2000;
|
|
max_write_delay = 2000;
|
|
read = "0 1 0 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x x o x o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 x x x x x",
|
|
"x x x x x x x x 1 i 1 i i i i i";
|
|
;
|
|
|
|
memory "lock"
|
|
size = 1;
|
|
min_write_delay = 2000;
|
|
max_write_delay = 2000;
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 x x x x x",
|
|
"x x x x x x x x 1 1 i i i i i i";
|
|
;
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
;
|
|
|
|
|
|
#------------------------------------------------------------
|
|
# ATmega8
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "m8";
|
|
desc = "ATMEGA8";
|
|
stk500_devcode = 0x70;
|
|
avr910_devcode = 0x76;
|
|
pagel = 0xd7;
|
|
bs2 = 0xc2;
|
|
chip_erase_delay = 9000;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 x x x x x",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
size = 512;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 9000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read = " 1 0 1 0 0 0 0 0",
|
|
" 0 0 x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write = " 1 1 0 0 0 0 0 0",
|
|
" 0 0 x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
memory "flash"
|
|
paged = yes;
|
|
size = 8192;
|
|
page_size = 64;
|
|
num_pages = 128;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" 0 0 0 0 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" 0 0 0 0 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
loadpage_lo = " 0 1 0 0 0 0 0 0",
|
|
" 0 0 0 0 x x x x",
|
|
" x x x a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
loadpage_hi = " 0 1 0 0 1 0 0 0",
|
|
" 0 0 0 0 x x x x",
|
|
" x x x a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
writepage = " 0 1 0 0 1 1 0 0",
|
|
" 0 0 0 0 a11 a10 a9 a8",
|
|
" a7 a6 a5 x x x x x",
|
|
" x x x x x x x x";
|
|
;
|
|
|
|
memory "lfuse"
|
|
size = 1;
|
|
min_write_delay = 2000;
|
|
max_write_delay = 2000;
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
;
|
|
|
|
memory "hfuse"
|
|
size = 1;
|
|
min_write_delay = 2000;
|
|
max_write_delay = 2000;
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 1 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
;
|
|
|
|
memory "lock"
|
|
size = 1;
|
|
min_write_delay = 2000;
|
|
max_write_delay = 2000;
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 x x x x x",
|
|
"x x x x x x x x 1 1 i i i i i i";
|
|
;
|
|
|
|
memory "calibration"
|
|
size = 4;
|
|
read = "0 0 1 1 1 0 0 0 0 0 x x x x x x",
|
|
"0 0 0 0 0 0 a1 a0 o o o o o o o o";
|
|
;
|
|
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
;
|
|
|
|
|
|
|
|
#------------------------------------------------------------
|
|
# ATmega8515
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "m8515";
|
|
desc = "ATMEGA8515";
|
|
stk500_devcode = 0x63;
|
|
avr910_devcode = 0x3A;
|
|
chip_erase_delay = 9000;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 x x x x x",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
size = 512;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 9000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read = " 1 0 1 0 0 0 0 0",
|
|
" 0 0 x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write = " 1 1 0 0 0 0 0 0",
|
|
" 0 0 x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
memory "flash"
|
|
paged = yes;
|
|
size = 8192;
|
|
page_size = 64;
|
|
num_pages = 128;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" 0 0 0 0 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" 0 0 0 0 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
loadpage_lo = " 0 1 0 0 0 0 0 0",
|
|
" 0 0 0 0 x x x x",
|
|
" x x x a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
loadpage_hi = " 0 1 0 0 1 0 0 0",
|
|
" 0 0 0 0 x x x x",
|
|
" x x x a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
writepage = " 0 1 0 0 1 1 0 0",
|
|
" 0 0 0 0 a11 a10 a9 a8",
|
|
" a7 a6 a5 x x x x x",
|
|
" x x x x x x x x";
|
|
;
|
|
|
|
memory "lfuse"
|
|
size = 1;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
;
|
|
|
|
memory "hfuse"
|
|
size = 1;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 1 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
;
|
|
|
|
memory "lock"
|
|
size = 1;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 x x x x x",
|
|
"x x x x x x x x 1 1 i i i i i i";
|
|
;
|
|
|
|
memory "calibration"
|
|
size = 1;
|
|
read = "0 0 1 1 1 0 0 0 0 0 x x x x x x",
|
|
"0 0 0 0 0 0 0 0 o o o o o o o o";
|
|
;
|
|
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
;
|
|
|
|
|
|
|
|
|
|
#------------------------------------------------------------
|
|
# ATmega8535
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "m8535";
|
|
desc = "ATMEGA8535";
|
|
stk500_devcode = 0x64;
|
|
pagel = 0xd7;
|
|
bs2 = 0xa0;
|
|
chip_erase_delay = 9000;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 x x x x x",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
size = 512;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 9000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read = " 1 0 1 0 0 0 0 0",
|
|
" 0 0 x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write = " 1 1 0 0 0 0 0 0",
|
|
" 0 0 x x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
memory "flash"
|
|
paged = yes;
|
|
size = 8192;
|
|
page_size = 64;
|
|
num_pages = 128;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" 0 0 0 0 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" 0 0 0 0 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
loadpage_lo = " 0 1 0 0 0 0 0 0",
|
|
" 0 0 0 0 x x x x",
|
|
" x x x a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
loadpage_hi = " 0 1 0 0 1 0 0 0",
|
|
" 0 0 0 0 x x x x",
|
|
" x x x a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
writepage = " 0 1 0 0 1 1 0 0",
|
|
" 0 0 0 0 a11 a10 a9 a8",
|
|
" a7 a6 a5 x x x x x",
|
|
" x x x x x x x x";
|
|
;
|
|
|
|
memory "lfuse"
|
|
size = 1;
|
|
min_write_delay = 2000;
|
|
max_write_delay = 2000;
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
;
|
|
|
|
memory "hfuse"
|
|
size = 1;
|
|
min_write_delay = 2000;
|
|
max_write_delay = 2000;
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 1 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
;
|
|
|
|
memory "lock"
|
|
size = 1;
|
|
min_write_delay = 2000;
|
|
max_write_delay = 2000;
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 x x x x x",
|
|
"x x x x x x x x 1 1 i i i i i i";
|
|
;
|
|
|
|
memory "calibration"
|
|
size = 1;
|
|
read = "0 0 1 1 1 0 0 0 0 0 x x x x x x",
|
|
"0 0 0 0 0 0 0 0 o o o o o o o o";
|
|
;
|
|
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
;
|
|
|
|
|
|
#------------------------------------------------------------
|
|
# ATtiny26
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "t26";
|
|
desc = "ATTINY26";
|
|
stk500_devcode = 0x21;
|
|
avr910_devcode = 0x5e;
|
|
pagel = 0xb3;
|
|
bs2 = 0xb2;
|
|
chip_erase_delay = 9000;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 x x x x x",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
size = 128;
|
|
min_write_delay = 9000;
|
|
max_write_delay = 9000;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read = "1 0 1 0 0 0 0 0 x x x x x x x x",
|
|
"x a6 a5 a4 a3 a2 a1 a0 o o o o o o o o";
|
|
|
|
write = "1 1 0 0 0 0 0 0 x x x x x x x x",
|
|
"x a6 a5 a4 a3 a2 a1 a0 i i i i i i i i";
|
|
;
|
|
|
|
memory "flash"
|
|
paged = yes;
|
|
size = 2048;
|
|
page_size = 32;
|
|
num_pages = 64;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" x x x x x x a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" x x x x x x a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
loadpage_lo = " 0 1 0 0 0 0 0 0",
|
|
" x x x x x x x x",
|
|
" x x x x a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
loadpage_hi = " 0 1 0 0 1 0 0 0",
|
|
" x x x x x x x x",
|
|
" x x x x a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
writepage = " 0 1 0 0 1 1 0 0",
|
|
" x x x x x x a9 a8",
|
|
" a7 a6 a5 a4 x x x x",
|
|
" x x x x x x x x";
|
|
;
|
|
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 x x x x x x x x",
|
|
"0 0 0 0 0 0 a1 a0 o o o o o o o o";
|
|
;
|
|
|
|
memory "lock"
|
|
size = 1;
|
|
read = "0 1 0 1 1 0 0 0 x x x x x x x x",
|
|
"x x x x x x x x x x x x x x o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 1 1 1 i i",
|
|
"x x x x x x x x x x x x x x x x";
|
|
;
|
|
|
|
memory "lfuse"
|
|
size = 1;
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
;
|
|
|
|
memory "hfuse"
|
|
size = 1;
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 1 0 0 0",
|
|
"x x x x x x x x x x x i i i i i";
|
|
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x x x x o o o o o";
|
|
;
|
|
|
|
memory "calibration"
|
|
size = 4;
|
|
read = "0 0 1 1 1 0 0 0 x x x x x x x x",
|
|
"0 0 0 0 0 0 a1 a0 o o o o o o o o";
|
|
;
|
|
|
|
;
|
|
|
|
|
|
#------------------------------------------------------------
|
|
# ATmega48
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "m48";
|
|
desc = "ATMEGA48";
|
|
stk500_devcode = 0x59;
|
|
# avr910_devcode = 0x;
|
|
pagel = 0xd7;
|
|
bs2 = 0xc2;
|
|
chip_erase_delay = 9000;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 x x x x x",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
size = 256;
|
|
min_write_delay = 3600;
|
|
max_write_delay = 3600;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read = " 1 0 1 0 0 0 0 0",
|
|
" 0 0 0 x x x x x",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write = " 1 1 0 0 0 0 0 0",
|
|
" 0 0 0 x x x x x",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
memory "flash"
|
|
paged = yes;
|
|
size = 4096;
|
|
page_size = 64;
|
|
num_pages = 64;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" 0 0 0 0 0 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" 0 0 0 0 0 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
loadpage_lo = " 0 1 0 0 0 0 0 0",
|
|
" 0 0 0 x x x x x",
|
|
" x x x a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
loadpage_hi = " 0 1 0 0 1 0 0 0",
|
|
" 0 0 0 x x x x x",
|
|
" x x x a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
writepage = " 0 1 0 0 1 1 0 0",
|
|
" 0 0 0 0 0 a10 a9 a8",
|
|
" a7 a6 a5 x x x x x",
|
|
" x x x x x x x x";
|
|
;
|
|
|
|
memory "lfuse"
|
|
size = 1;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
;
|
|
|
|
memory "hfuse"
|
|
size = 1;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 1 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
;
|
|
|
|
memory "efuse"
|
|
size = 1;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 1 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
;
|
|
|
|
memory "calibration"
|
|
size = 1;
|
|
read = "0 0 1 1 1 0 0 0 0 0 0 x x x x x",
|
|
"0 0 0 0 0 0 0 0 o o o o o o o o";
|
|
;
|
|
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 0 0 0 x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
;
|
|
|
|
|
|
#------------------------------------------------------------
|
|
# ATmega88
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "m88";
|
|
desc = "ATMEGA88";
|
|
stk500_devcode = 0x73;
|
|
# avr910_devcode = 0x;
|
|
pagel = 0xd7;
|
|
bs2 = 0xc2;
|
|
chip_erase_delay = 9000;
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 x x x x x",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
size = 512;
|
|
min_write_delay = 3600;
|
|
max_write_delay = 3600;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read = " 1 0 1 0 0 0 0 0",
|
|
" 0 0 0 x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
write = " 1 1 0 0 0 0 0 0",
|
|
" 0 0 0 x x x x a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
;
|
|
memory "flash"
|
|
paged = yes;
|
|
size = 8192;
|
|
page_size = 64;
|
|
num_pages = 128;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" 0 0 0 0 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" 0 0 0 0 a11 a10 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
loadpage_lo = " 0 1 0 0 0 0 0 0",
|
|
" 0 0 0 x x x x x",
|
|
" x x x a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
loadpage_hi = " 0 1 0 0 1 0 0 0",
|
|
" 0 0 0 x x x x x",
|
|
" x x x a4 a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
writepage = " 0 1 0 0 1 1 0 0",
|
|
" 0 0 0 0 a11 a10 a9 a8",
|
|
" a7 a6 a5 x x x x x",
|
|
" x x x x x x x x";
|
|
;
|
|
|
|
memory "lfuse"
|
|
size = 1;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
;
|
|
|
|
memory "hfuse"
|
|
size = 1;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 1 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
;
|
|
|
|
memory "efuse"
|
|
size = 1;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 1 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
;
|
|
|
|
memory "lock"
|
|
size = 1;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x x x o o o o o o";
|
|
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 x x x x x",
|
|
"x x x x x x x x 1 1 i i i i i i";
|
|
;
|
|
|
|
memory "calibration"
|
|
size = 1;
|
|
read = "0 0 1 1 1 0 0 0 0 0 0 x x x x x",
|
|
"0 0 0 0 0 0 0 0 o o o o o o o o";
|
|
;
|
|
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 0 0 0 x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
;
|
|
|
|
|
|
#------------------------------------------------------------
|
|
# ATtiny2313
|
|
#------------------------------------------------------------
|
|
|
|
part
|
|
id = "t2313";
|
|
desc = "ATtiny2313";
|
|
stk500_devcode = 0x23;
|
|
## avr910_devcode = ?;
|
|
## Try the AT90S2313 devcode:
|
|
avr910_devcode = 0x20;
|
|
pagel = 0xD4;
|
|
bs2 = 0xD6;
|
|
reset = io;
|
|
chip_erase_delay = 9000;
|
|
|
|
pgm_enable = "1 0 1 0 1 1 0 0 0 1 0 1 0 0 1 1",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
chip_erase = "1 0 1 0 1 1 0 0 1 0 0 x x x x x",
|
|
"x x x x x x x x x x x x x x x x";
|
|
|
|
memory "eeprom"
|
|
size = 128;
|
|
min_write_delay = 4000;
|
|
max_write_delay = 4500;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read = "1 0 1 0 0 0 0 0 0 0 0 x x x x x",
|
|
"x a6 a5 a4 a3 a2 a1 a0 o o o o o o o o";
|
|
|
|
write = "1 1 0 0 0 0 0 0 0 0 0 x x x x x",
|
|
"x a6 a5 a4 a3 a2 a1 a0 i i i i i i i i";
|
|
;
|
|
memory "flash"
|
|
paged = yes;
|
|
size = 2048;
|
|
page_size = 32;
|
|
num_pages = 64;
|
|
min_write_delay = 4500;
|
|
max_write_delay = 4500;
|
|
readback_p1 = 0xff;
|
|
readback_p2 = 0xff;
|
|
read_lo = " 0 0 1 0 0 0 0 0",
|
|
" 0 0 0 0 0 0 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
read_hi = " 0 0 1 0 1 0 0 0",
|
|
" 0 0 0 0 0 0 a9 a8",
|
|
" a7 a6 a5 a4 a3 a2 a1 a0",
|
|
" o o o o o o o o";
|
|
|
|
# The information in the data sheet of April/2004 is wrong, this works:
|
|
loadpage_lo = " 0 1 0 0 0 0 0 0",
|
|
" 0 0 0 x x x x x",
|
|
" x x x x a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
# The information in the data sheet of April/2004 is wrong, this works:
|
|
loadpage_hi = " 0 1 0 0 1 0 0 0",
|
|
" 0 0 0 x x x x x",
|
|
" x x x x a3 a2 a1 a0",
|
|
" i i i i i i i i";
|
|
|
|
# The information in the data sheet of April/2004 is wrong, this works:
|
|
writepage = " 0 1 0 0 1 1 0 0",
|
|
" 0 0 0 0 0 0 a9 a8",
|
|
" a7 a6 a5 a4 x x x x",
|
|
" x x x x x x x x";
|
|
;
|
|
# ATtiny2313 has Signature Bytes: 0x1E 0x91 0x0A.
|
|
memory "signature"
|
|
size = 3;
|
|
read = "0 0 1 1 0 0 0 0 0 0 0 x x x x x",
|
|
"x x x x x x a1 a0 o o o o o o o o";
|
|
;
|
|
memory "lock"
|
|
size = 1;
|
|
write = "1 0 1 0 1 1 0 0 1 1 1 x x x x x",
|
|
"x x x x x x x x 1 1 i i i i i i";
|
|
;
|
|
|
|
memory "lfuse"
|
|
size = 1;
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
;
|
|
|
|
memory "hfuse"
|
|
size = 1;
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 1 0 0 0",
|
|
"x x x x x x x x i i i i i i i i";
|
|
|
|
read = "0 1 0 1 1 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
;
|
|
|
|
memory "efuse"
|
|
size = 1;
|
|
write = "1 0 1 0 1 1 0 0 1 0 1 0 0 1 0 0",
|
|
"x x x x x x x x x x x x x x x i";
|
|
|
|
read = "0 1 0 1 0 0 0 0 0 0 0 0 1 0 0 0",
|
|
"x x x x x x x x o o o o o o o o";
|
|
;
|
|
# The Tiny2313 has calibration data for both 4 MHz and 8 MHz.
|
|
# The information in the data sheet of April/2004 is wrong, this works:
|
|
|
|
memory "calibration"
|
|
size = 2;
|
|
read = "0 0 1 1 1 0 0 0 0 0 0 x x x x x",
|
|
"0 0 0 0 0 0 0 a0 o o o o o o o o";
|
|
;
|
|
;
|