X-Git-Url: http://git.linex4red.de/pub/USBaspLoader.git/blobdiff_plain/eca26b3881806aea40726f234df80718581a03ce..56a4cf84a03639f2a2753eef01bb407697a5ea53:/Makefile.inc diff --git a/Makefile.inc b/Makefile.inc index e531a69..9575920 100644 --- a/Makefile.inc +++ b/Makefile.inc @@ -8,10 +8,6 @@ F_CPU = 16000000 DEVICE = atmega8 -# BOOTLOADER_ADDRESS is 1800 for 8k devices, 3800 for 16k and 7800 for 32k. -BOOTLOADER_ADDRESS = 0x1800 -NEW_BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS) - # where the updating firmware should be located (starting address) FLASHADDRESS = 0x0000 @@ -22,88 +18,128 @@ PROGRAMMER = -c usbasp # since USBaspLoader supports HAVE_BLB11_SOFTW_LOCKBIT... LOCKOPT = -U lock:w:0x3f:m -FUSEOPT = $(FUSEOPT_8) # standard atmega8 needs BODLEVEL to be programed, since it is a 5V device # you may also want to UNprogram SUT1 to get a SLOWER bootup (lfuse then would be 0x3f) -FUSEOPT_8 = -U hfuse:w:0xc0:m -U lfuse:w:0x1f:m - -FUSEOPT_88 = -U hfuse:w:0xd6:m -U lfuse:w:0xdf:m -U efuse:w:0x00:m -FUSEOPT_168 = -U hfuse:w:0xd6:m -U lfuse:w:0xdf:m -U efuse:w:0x00:m -FUSEOPT_328 = -U lfuse:w:0xf7:m -U hfuse:w:0xda:m -U efuse:w:0x03:m -# You may have to change the order of these -U commands. - -#--------------------------------------------------------------------- -# ATMega8 -#--------------------------------------------------------------------- -# Fuse high byte: -# 0xc0 = 1 1 0 0 0 0 0 0 <-- BOOTRST (boot reset vector at 0x1800) -# ^ ^ ^ ^ ^ ^ ^------ BOOTSZ0 -# | | | | | +-------- BOOTSZ1 -# | | | | + --------- EESAVE (preserve EEPROM over chip erase) -# | | | +-------------- CKOPT (full output swing) -# | | +---------------- SPIEN (allow serial programming) -# | +------------------ WDTON (WDT not always on) -# +-------------------- RSTDISBL (reset pin is enabled) -# Fuse low byte: -# 0x9f = 1 0 0 1 1 1 1 1 -# ^ ^ \ / \--+--/ -# | | | +------- CKSEL 3..0 (external >8M crystal) -# | | +--------------- SUT 1..0 (crystal osc, BOD enabled) -# | +------------------ BODEN (BrownOut Detector enabled) -# +-------------------- BODLEVEL (2.7V) -#--------------------------------------------------------------------- -# ATMega88, ATMega168 -#--------------------------------------------------------------------- -# Fuse extended byte: -# 0x00 = 0 0 0 0 0 0 0 0 <-- BOOTRST (boot reset vector at 0x1800) -# \+/ -# +------- BOOTSZ (00 = 2k bytes) -# Fuse high byte: -# 0xd6 = 1 1 0 1 0 1 1 0 -# ^ ^ ^ ^ ^ \-+-/ -# | | | | | +------ BODLEVEL 0..2 (110 = 1.8 V) -# | | | | + --------- EESAVE (preserve EEPROM over chip erase) -# | | | +-------------- WDTON (if 0: watchdog always on) -# | | +---------------- SPIEN (allow serial programming) -# | +------------------ DWEN (debug wire enable) -# +-------------------- RSTDISBL (reset pin is enabled) -# Fuse low byte: -# 0xdf = 1 1 0 1 1 1 1 1 -# ^ ^ \ / \--+--/ -# | | | +------- CKSEL 3..0 (external >8M crystal) -# | | +--------------- SUT 1..0 (crystal osc, BOD enabled) -# | +------------------ CKOUT (if 0: Clock output enabled) -# +-------------------- CKDIV8 (if 0: divide by 8) -#--------------------------------------------------------------------- -# ATMega328P -#--------------------------------------------------------------------- -# Fuse extended byte: -# 0x03 = - - - - - 0 1 1 -# \-+-/ -# +------ BODLEVEL 0..2 (011 = 4.3V) -# Fuse high byte: -# 0xda = 1 1 0 1 1 0 1 0 <-- BOOTRST (0 = jump to bootloader at start) -# ^ ^ ^ ^ ^ \+/ -# | | | | | +------- BOOTSZ 0..1 (01 = 2KB starting at 0x7800) -# | | | | + --------- EESAVE (don't preserve EEPROM over chip erase) -# | | | +-------------- WDTON (1 = watchdog disabled at start) -# | | +---------------- SPIEN (0 = allow serial programming) -# | +------------------ DWEN (1 = debug wire disable) -# +-------------------- RSTDISBL (1 = reset pin is enabled) -# Fuse low byte: -# 0xf7 = 1 1 1 1 0 1 1 1 -# ^ ^ \ / \--+--/ -# | | | +------- CKSEL 3..0 (0111 = external full-swing crystal) -# | | +--------------- SUT 1..0 (11 = startup time 16K CK/14K + 65ms) -# | +------------------ CKOUT (1 = clock output disabled) -# +-------------------- CKDIV8 (1 = do not divide clock by 8) - - -############################################################################### +FUSEOPT_8 = -U hfuse:w:0xc0:m -U lfuse:w:0x1f:m +BOOTLOADER_ADDRESS_8 = 0x1800 + + +#untested (WARNING: may destroy ISP ability!) +#device always should select maximum bootloader-section size +#please mail tests-reports to matrixstorm@gmx.de: +FUSEOPT_32 = unknown +BOOTLOADER_ADDRESS_32 = 0x7000 + +FUSEOPT_88 = -U hfuse:w:0xd6:m -U lfuse:w:0xdf:m -U efuse:w:0x00:m +BOOTLOADER_ADDRESS_88 = 0x1800 + +FUSEOPT_164 = unknown +BOOTLOADER_ADDRESS_164 = 0x3800 + +FUSEOPT_168 = -U hfuse:w:0xd6:m -U lfuse:w:0xdf:m -U efuse:w:0x00:m +BOOTLOADER_ADDRESS_168 = 0x3800 + +FUSEOPT_324 = unknown +BOOTLOADER_ADDRESS_324 = 0x7000 + +FUSEOPT_328 = -U lfuse:w:0xf7:m -U hfuse:w:0xda:m -U efuse:w:0x03:m +BOOTLOADER_ADDRESS_328 = 0x7000 + +FUSEOPT_644 = unknown +BOOTLOADER_ADDRESS_644 = 0xE000 + +FUSEOPT_128 = unknown +BOOTLOADER_ADDRESS_128 = 0x1E000 + +FUSEOPT_1284 = unknown +BOOTLOADER_ADDRESS_1284 = 0x1E000 + + +#autoselect logic +ifeq ($(DEVICE), atmega8) + FUSEOPT = $(FUSEOPT_8) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_8) +else ifeq ($(DEVICE), atmega32) + FUSEOPT = $(FUSEOPT_32) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_32) +else ifeq ($(DEVICE), atmega88) + FUSEOPT = $(FUSEOPT_88) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_88) +else ifeq ($(DEVICE), atmega88a) + FUSEOPT = $(FUSEOPT_88) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_88) +else ifeq ($(DEVICE), atmega88p) + FUSEOPT = $(FUSEOPT_88) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_88) +else ifeq ($(DEVICE), atmega88pa) + FUSEOPT = $(FUSEOPT_88) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_88) +else ifeq ($(DEVICE), atmega164a) + FUSEOPT = $(FUSEOPT_164) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_164) +else ifeq ($(DEVICE), atmega164p) + FUSEOPT = $(FUSEOPT_164) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_164) +else ifeq ($(DEVICE), atmega164pa) + FUSEOPT = $(FUSEOPT_164) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_164) +else ifeq ($(DEVICE), atmega168) + FUSEOPT = $(FUSEOPT_168) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_168) +else ifeq ($(DEVICE), atmega168a) + FUSEOPT = $(FUSEOPT_168) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_168) +else ifeq ($(DEVICE), atmega168p) + FUSEOPT = $(FUSEOPT_168) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_168) +else ifeq ($(DEVICE), atmega168pa) + FUSEOPT = $(FUSEOPT_168) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_168) +else ifeq ($(DEVICE), atmega324a) + FUSEOPT = $(FUSEOPT_324) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_324) +else ifeq ($(DEVICE), atmega324p) + FUSEOPT = $(FUSEOPT_324) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_324) +else ifeq ($(DEVICE), atmega324pa) + FUSEOPT = $(FUSEOPT_324) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_324) +else ifeq ($(DEVICE), atmega328) + FUSEOPT = $(FUSEOPT_328) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_328) +else ifeq ($(DEVICE), atmega328p) + FUSEOPT = $(FUSEOPT_328) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_328) +else ifeq ($(DEVICE), atmega644) + FUSEOPT = $(FUSEOPT_644) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_644) +else ifeq ($(DEVICE), atmega644a) + FUSEOPT = $(FUSEOPT_644) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_644) +else ifeq ($(DEVICE), atmega644p) + FUSEOPT = $(FUSEOPT_644) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_644) +else ifeq ($(DEVICE), atmega644pa) + FUSEOPT = $(FUSEOPT_644) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_644) +else ifeq ($(DEVICE), atmega128) + FUSEOPT = $(FUSEOPT_128) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_128) +else ifeq ($(DEVICE), atmega1284) + FUSEOPT = $(FUSEOPT_1284) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_1284) +else ifeq ($(DEVICE), atmega1284p) + FUSEOPT = $(FUSEOPT_1284) + BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS_1284) +else + FUSEOPT = unknown +endif + +NEW_BOOTLOADER_ADDRESS = $(BOOTLOADER_ADDRESS) # Tools: -AVRPATH = +AVRPATH = $(AVR8TOOLCHAINBINDIR) AVRDUDE = @echo avrdude $(PROGRAMMER) -p $(DEVICE) ECHO=@echo