|
@@ -15,7 +15,23 @@
|
|
|
# make lilypad_isp
|
|
|
# make ng_isp
|
|
|
# etc...
|
|
|
+#
|
|
|
+# Edit History
|
|
|
+# 201303xx: WestfW: Major Makefile restructuring.
|
|
|
+# Allows options on Make command line "make xx LED=B3"
|
|
|
+# (see also pin_defs.h)
|
|
|
+# Divide into "chip" targets and "board" targets.
|
|
|
+# Most boards are (recursive) board targets with options.
|
|
|
+# Move isp target to separate makefile (fixes m8 EFUSE)
|
|
|
+# Some (many) targets will now be rebuilt when not
|
|
|
+# strictly necessary, so that options will be included.
|
|
|
+# (any "make" with options will always compile.)
|
|
|
+# Set many variables with ?= so they can be overridden
|
|
|
+# Use arduinoISP settings as default for ISP targets
|
|
|
+#
|
|
|
|
|
|
+#----------------------------------------------------------------------
|
|
|
+#
|
|
|
# program name should not be changed...
|
|
|
PROGRAM = optiboot
|
|
|
|
|
@@ -29,22 +45,10 @@ PROGRAM = optiboot
|
|
|
# OS ?= macosx
|
|
|
# OS ?= windows
|
|
|
|
|
|
+# export symbols to recursive makes (for ISP)
|
|
|
+export
|
|
|
|
|
|
-# enter the parameters for the avrdude isp tool -b19200
|
|
|
-#
|
|
|
-# These are the parameters for a usb-based STK500v2 programmer.
|
|
|
-# Exact type unknown. (historical Makefile values.)
|
|
|
-ISPTOOL = stk500v2
|
|
|
-ISPPORT = usb
|
|
|
-ISPSPEED = -b 115200
|
|
|
-#
|
|
|
-#
|
|
|
-# These are parameters for using an Arduino with the ArduinoISP sketch
|
|
|
-# as the programmer. On a mac, for a particular Uno as programmer.
|
|
|
-#ISPTOOL = stk500v1 -C /Applications/arduino/arduino-0022/hardware/tools/avr/etc/avrdude.conf
|
|
|
-#ISPPORT = /dev/tty.usbmodemfd3141
|
|
|
-#ISPSPEED = -b19200
|
|
|
-
|
|
|
+# defaults
|
|
|
MCU_TARGET = atmega168
|
|
|
LDSECTIONS = -Wl,--section-start=.text=0x3e00 -Wl,--section-start=.version=0x3ffe
|
|
|
|
|
@@ -62,7 +66,6 @@ ifeq ($(ENV), arduino)
|
|
|
# of avr-tools are "right up there" in standard places.
|
|
|
TOOLROOT = ../../../tools
|
|
|
GCCROOT = $(TOOLROOT)/avr/bin/
|
|
|
-AVRDUDE_CONF = -C$(TOOLROOT)/avr/etc/avrdude.conf
|
|
|
|
|
|
ifeq ($(OS), windows)
|
|
|
# On windows, SOME of the tool paths will need to have backslashes instead
|
|
@@ -90,32 +93,14 @@ else
|
|
|
GCCROOT =
|
|
|
AVRDUDE_CONF =
|
|
|
endif
|
|
|
-#
|
|
|
-# End of build environment code.
|
|
|
-
|
|
|
-
|
|
|
-# the efuse should really be 0xf8; since, however, only the lower
|
|
|
-# three bits of that byte are used on the atmega168, avrdude gets
|
|
|
-# confused if you specify 1's for the higher bits, see:
|
|
|
-# http://tinker.it/now/2007/02/24/the-tale-of-avrdude-atmega168-and-extended-bits-fuses/
|
|
|
-#
|
|
|
-# similarly, the lock bits should be 0xff instead of 0x3f (to
|
|
|
-# unlock the bootloader section) and 0xcf instead of 0x2f (to
|
|
|
-# lock it), but since the high two bits of the lock byte are
|
|
|
-# unused, avrdude would get confused.
|
|
|
-
|
|
|
-ISPFUSES = $(GCCROOT)avrdude $(AVRDUDE_CONF) -c $(ISPTOOL) \
|
|
|
- -p $(MCU_TARGET) -P $(ISPPORT) $(ISPSPEED) \
|
|
|
- -e -u -U lock:w:0x3f:m -U efuse:w:0x$(EFUSE):m \
|
|
|
- -U hfuse:w:0x$(HFUSE):m -U lfuse:w:0x$(LFUSE):m
|
|
|
-ISPFLASH = $(GCCROOT)avrdude $(AVRDUDE_CONF) -c $(ISPTOOL) \
|
|
|
- -p $(MCU_TARGET) -P $(ISPPORT) $(ISPSPEED) \
|
|
|
- -U flash:w:$(PROGRAM)_$(TARGET).hex -U lock:w:0x2f:m
|
|
|
|
|
|
STK500 = "C:\Program Files\Atmel\AVR Tools\STK500\Stk500.exe"
|
|
|
STK500-1 = $(STK500) -e -d$(MCU_TARGET) -pf -vf -if$(PROGRAM)_$(TARGET).hex \
|
|
|
--lFF -LFF -f$(HFUSE)$(LFUSE) -EF8 -ms -q -cUSB -I200kHz -s -wt
|
|
|
+ -lFF -LFF -f$(HFUSE)$(LFUSE) -EF8 -ms -q -cUSB -I200kHz -s -wt
|
|
|
STK500-2 = $(STK500) -d$(MCU_TARGET) -ms -q -lCF -LCF -cUSB -I200kHz -s -wt
|
|
|
+#
|
|
|
+# End of build environment code.
|
|
|
+
|
|
|
|
|
|
OBJ = $(PROGRAM).o
|
|
|
OPTIMIZE = -Os -fno-inline-small-functions -fno-split-wide-types -mshort-calls
|
|
@@ -135,59 +120,98 @@ OBJDUMP = $(call fixpath,$(GCCROOT)avr-objdump)
|
|
|
|
|
|
SIZE = $(GCCROOT)avr-size
|
|
|
|
|
|
-# Test platforms
|
|
|
-# Virtual boot block test
|
|
|
-virboot328: TARGET = atmega328
|
|
|
-virboot328: MCU_TARGET = atmega328p
|
|
|
-virboot328: CFLAGS += '-DLED_START_FLASHES=3' '-DBAUD_RATE=115200' '-DVIRTUAL_BOOT'
|
|
|
-virboot328: AVR_FREQ = 16000000L
|
|
|
-virboot328: LDSECTIONS = -Wl,--section-start=.text=0x7e00 -Wl,--section-start=.version=0x7ffe
|
|
|
-virboot328: $(PROGRAM)_atmega328.hex
|
|
|
-virboot328: $(PROGRAM)_atmega328.lst
|
|
|
-
|
|
|
-# 20MHz clocked platforms
|
|
|
#
|
|
|
-# These are capable of 230400 baud, or 115200 baud on PC (Arduino Avrdude issue)
|
|
|
+# Make command-line Options.
|
|
|
+# Permit commands like "make atmega328 LED_START_FLASHES=10" to pass the
|
|
|
+# appropriate parameters ("-DLED_START_FLASHES=10") to gcc
|
|
|
#
|
|
|
|
|
|
-pro20: TARGET = pro_20mhz
|
|
|
-pro20: MCU_TARGET = atmega168
|
|
|
-pro20: CFLAGS += '-DLED_START_FLASHES=3' '-DBAUD_RATE=115200'
|
|
|
-pro20: AVR_FREQ = 20000000L
|
|
|
-pro20: $(PROGRAM)_pro_20mhz.hex
|
|
|
-pro20: $(PROGRAM)_pro_20mhz.lst
|
|
|
+ifdef BAUD_RATE
|
|
|
+BAUD_RATE_CMD = -DBAUD_RATE=$(BAUD_RATE)
|
|
|
+dummy = FORCE
|
|
|
+else
|
|
|
+BAUD_RATE_CMD = -DBAUD_RATE=115200
|
|
|
+endif
|
|
|
|
|
|
-pro20_isp: pro20
|
|
|
-pro20_isp: TARGET = pro_20mhz
|
|
|
-# 2.7V brownout
|
|
|
-pro20_isp: HFUSE = DD
|
|
|
-# Full swing xtal (20MHz) 258CK/14CK+4.1ms
|
|
|
-pro20_isp: LFUSE = C6
|
|
|
-# 512 byte boot
|
|
|
-pro20_isp: EFUSE = 04
|
|
|
-pro20_isp: isp
|
|
|
+ifdef LED_START_FLASHES
|
|
|
+LED_START_FLASHES_CMD = -DLED_START_FLASHES=$(LED_START_FLASHES)
|
|
|
+dummy = FORCE
|
|
|
+else
|
|
|
+LED_START_FLASHES_CMD = -DLED_START_FLASHES=3
|
|
|
+endif
|
|
|
|
|
|
-# 16MHz clocked platforms
|
|
|
-#
|
|
|
-# These are capable of 230400 baud, or 115200 baud on PC (Arduino Avrdude issue)
|
|
|
+# BIG_BOOT: Include extra features, up to 1K.
|
|
|
+ifdef BIG_BOOT
|
|
|
+BIG_BOOT_CMD = -DBIG_BOOT
|
|
|
+dummy = FORCE
|
|
|
+endif
|
|
|
+
|
|
|
+ifdef SOFT_UART
|
|
|
+SOFT_UART_CMD = -DSOFT_UART
|
|
|
+dummy = FORCE
|
|
|
+endif
|
|
|
+
|
|
|
+ifdef LED_DATA_FLASH
|
|
|
+LED_DATA_FLASH_CMD = -DLED_DATA_FLASH
|
|
|
+dummy = FORCE
|
|
|
+endif
|
|
|
+
|
|
|
+ifdef LED
|
|
|
+LED_CMD = -DLED=$(LED)
|
|
|
+dummy = FORCE
|
|
|
+endif
|
|
|
+
|
|
|
+COMMON_OPTIONS = $(BAUD_RATE_CMD) $(LED_START_FLASHES_CMD) $(BIG_BOOT_CMD)
|
|
|
+COMMON_OPTIONS += $(SOFT_UART_CMD) $(LED_DATA_FLASH_CMD) $(LED_CMD)
|
|
|
+
|
|
|
+#UART is handled separately and only passed for devices with more than one.
|
|
|
+ifdef UART
|
|
|
+UARTCMD = -DUART=$(UART)
|
|
|
+endif
|
|
|
+
|
|
|
+# Not supported yet
|
|
|
+# ifdef SUPPORT_EEPROM
|
|
|
+# SUPPORT_EEPROM_CMD = -DSUPPORT_EEPROM
|
|
|
+# dummy = FORCE
|
|
|
+# endif
|
|
|
+
|
|
|
+# Not supported yet
|
|
|
+# ifdef TIMEOUT_MS
|
|
|
+# TIMEOUT_MS_CMD = -DTIMEOUT_MS=$(TIMEOUT_MS)
|
|
|
+# dummy = FORCE
|
|
|
+# endif
|
|
|
#
|
|
|
|
|
|
-pro16: TARGET = pro_16MHz
|
|
|
-pro16: MCU_TARGET = atmega168
|
|
|
-pro16: CFLAGS += '-DLED_START_FLASHES=3' '-DBAUD_RATE=115200'
|
|
|
-pro16: AVR_FREQ = 16000000L
|
|
|
-pro16: $(PROGRAM)_pro_16MHz.hex
|
|
|
-pro16: $(PROGRAM)_pro_16MHz.lst
|
|
|
+#---------------------------------------------------------------------------
|
|
|
+# "Chip-level Platform" targets.
|
|
|
+# A "Chip-level Platform" compiles for a particular chip, but probably does
|
|
|
+# not have "standard" values for things like clock speed, LED pin, etc.
|
|
|
+# Makes for chip-level platforms should usually explicitly define their
|
|
|
+# options like: "make atmega1285 AVR_FREQ=16000000L LED=D0"
|
|
|
+#---------------------------------------------------------------------------
|
|
|
+#
|
|
|
+# Note about fuses:
|
|
|
+# the efuse should really be 0xf8; since, however, only the lower
|
|
|
+# three bits of that byte are used on the atmega168, avrdude gets
|
|
|
+# confused if you specify 1's for the higher bits, see:
|
|
|
+# http://tinker.it/now/2007/02/24/the-tale-of-avrdude-atmega168-and-extended-bits-fuses/
|
|
|
+#
|
|
|
+# similarly, the lock bits should be 0xff instead of 0x3f (to
|
|
|
+# unlock the bootloader section) and 0xcf instead of 0x2f (to
|
|
|
+# lock it), but since the high two bits of the lock byte are
|
|
|
+# unused, avrdude would get confused.
|
|
|
+#---------------------------------------------------------------------------
|
|
|
+#
|
|
|
|
|
|
-pro16_isp: pro16
|
|
|
-pro16_isp: TARGET = pro_16MHz
|
|
|
-# 2.7V brownout
|
|
|
-pro16_isp: HFUSE = DD
|
|
|
-# Full swing xtal (20MHz) 258CK/14CK+4.1ms
|
|
|
-pro16_isp: LFUSE = C6
|
|
|
-# 512 byte boot
|
|
|
-pro16_isp: EFUSE = 04
|
|
|
-pro16_isp: isp
|
|
|
+# Test platforms
|
|
|
+# Virtual boot block test
|
|
|
+virboot328: TARGET = atmega328
|
|
|
+virboot328: MCU_TARGET = atmega328p
|
|
|
+virboot328: CFLAGS += $(COMMON_OPTIONS) '-DVIRTUAL_BOOT'
|
|
|
+virboot328: AVR_FREQ ?= 16000000L
|
|
|
+virboot328: LDSECTIONS = -Wl,--section-start=.text=0x7e00 -Wl,--section-start=.version=0x7ffe
|
|
|
+virboot328: $(PROGRAM)_atmega328.hex
|
|
|
+virboot328: $(PROGRAM)_atmega328.lst
|
|
|
|
|
|
# Diecimila, Duemilanove with m168, and NG use identical bootloaders
|
|
|
# Call it "atmega168" for generality and clarity, keep "diecimila" for
|
|
@@ -195,41 +219,24 @@ pro16_isp: isp
|
|
|
#
|
|
|
atmega168: TARGET = atmega168
|
|
|
atmega168: MCU_TARGET = atmega168
|
|
|
-atmega168: CFLAGS += '-DLED_START_FLASHES=3' '-DBAUD_RATE=115200'
|
|
|
-atmega168: AVR_FREQ = 16000000L
|
|
|
+atmega168: CFLAGS += $(COMMON_OPTIONS)
|
|
|
+atmega168: AVR_FREQ ?= 16000000L
|
|
|
atmega168: $(PROGRAM)_atmega168.hex
|
|
|
atmega168: $(PROGRAM)_atmega168.lst
|
|
|
|
|
|
atmega168_isp: atmega168
|
|
|
atmega168_isp: TARGET = atmega168
|
|
|
# 2.7V brownout
|
|
|
-atmega168_isp: HFUSE = DD
|
|
|
+atmega168_isp: HFUSE ?= DD
|
|
|
# Low power xtal (16MHz) 16KCK/14CK+65ms
|
|
|
-atmega168_isp: LFUSE = FF
|
|
|
+atmega168_isp: LFUSE ?= FF
|
|
|
# 512 byte boot
|
|
|
-atmega168_isp: EFUSE = 04
|
|
|
+atmega168_isp: EFUSE ?= 04
|
|
|
atmega168_isp: isp
|
|
|
|
|
|
-diecimila: TARGET = diecimila
|
|
|
-diecimila: MCU_TARGET = atmega168
|
|
|
-diecimila: CFLAGS += '-DLED_START_FLASHES=3' '-DBAUD_RATE=115200'
|
|
|
-diecimila: AVR_FREQ = 16000000L
|
|
|
-diecimila: $(PROGRAM)_diecimila.hex
|
|
|
-diecimila: $(PROGRAM)_diecimila.lst
|
|
|
-
|
|
|
-diecimila_isp: diecimila
|
|
|
-diecimila_isp: TARGET = diecimila
|
|
|
-# 2.7V brownout
|
|
|
-diecimila_isp: HFUSE = DD
|
|
|
-# Low power xtal (16MHz) 16KCK/14CK+65ms
|
|
|
-diecimila_isp: LFUSE = FF
|
|
|
-# 512 byte boot
|
|
|
-diecimila_isp: EFUSE = 04
|
|
|
-diecimila_isp: isp
|
|
|
-
|
|
|
atmega328: TARGET = atmega328
|
|
|
atmega328: MCU_TARGET = atmega328p
|
|
|
-atmega328: CFLAGS += '-DLED_START_FLASHES=3' '-DBAUD_RATE=115200'
|
|
|
+atmega328: CFLAGS += $(COMMON_OPTIONS)
|
|
|
atmega328: AVR_FREQ ?= 16000000L
|
|
|
atmega328: LDSECTIONS = -Wl,--section-start=.text=0x7e00 -Wl,--section-start=.version=0x7ffe
|
|
|
atmega328: $(PROGRAM)_atmega328.hex
|
|
@@ -239,79 +246,59 @@ atmega328_isp: atmega328
|
|
|
atmega328_isp: TARGET = atmega328
|
|
|
atmega328_isp: MCU_TARGET = atmega328p
|
|
|
# 512 byte boot, SPIEN
|
|
|
-atmega328_isp: HFUSE = DE
|
|
|
+atmega328_isp: HFUSE ?= DE
|
|
|
# Low power xtal (16MHz) 16KCK/14CK+65ms
|
|
|
-atmega328_isp: LFUSE = FF
|
|
|
+atmega328_isp: LFUSE ?= FF
|
|
|
# 2.7V brownout
|
|
|
-atmega328_isp: EFUSE = FD
|
|
|
+atmega328_isp: EFUSE ?= FD
|
|
|
atmega328_isp: isp
|
|
|
|
|
|
+atmega644p: TARGET = atmega644p
|
|
|
+atmega644p: MCU_TARGET = atmega644p
|
|
|
+atmega644p: CFLAGS += $(COMMON_OPTIONS) -DBIGBOOT $(LED_CMD)
|
|
|
+atmega644p: AVR_FREQ ?= 16000000L
|
|
|
+atmega644p: LDSECTIONS = -Wl,--section-start=.text=0xfc00 -Wl,--section-start=.version=0xfffe
|
|
|
+atmega644p: CFLAGS += $(UARTCMD)
|
|
|
+atmega644p: $(PROGRAM)_atmega644p.hex
|
|
|
+atmega644p: $(PROGRAM)_atmega644p.lst
|
|
|
+
|
|
|
atmega1284: TARGET = atmega1284p
|
|
|
atmega1284: MCU_TARGET = atmega1284p
|
|
|
-atmega1284: CFLAGS += '-DLED_START_FLASHES=3' '-DBAUD_RATE=115200' '-DBIGBOOT'
|
|
|
-atmega1284: AVR_FREQ = 16000000L
|
|
|
+atmega1284: CFLAGS += $(COMMON_OPTIONS) -DBIGBOOT $(LED_CMD)
|
|
|
+atmega1284: AVR_FREQ ?= 16000000L
|
|
|
atmega1284: LDSECTIONS = -Wl,--section-start=.text=0x1fc00 -Wl,--section-start=.version=0x1fffe
|
|
|
+atmega1284: CFLAGS += $(UARTCMD)
|
|
|
atmega1284: $(PROGRAM)_atmega1284p.hex
|
|
|
atmega1284: $(PROGRAM)_atmega1284p.lst
|
|
|
|
|
|
+atmega1284p: atmega1284
|
|
|
+
|
|
|
atmega1284_isp: atmega1284
|
|
|
atmega1284_isp: TARGET = atmega1284p
|
|
|
atmega1284_isp: MCU_TARGET = atmega1284p
|
|
|
# 1024 byte boot
|
|
|
-atmega1284_isp: HFUSE = DE
|
|
|
+atmega1284_isp: HFUSE ?= DE
|
|
|
# Full Swing xtal (16MHz) 16KCK/14CK+65ms
|
|
|
-atmega1284_isp: LFUSE = F7
|
|
|
+atmega1284_isp: LFUSE ?= F7
|
|
|
# 2.7V brownout
|
|
|
-atmega1284_isp: EFUSE = FD
|
|
|
+atmega1284_isp: EFUSE ?= FD
|
|
|
atmega1284_isp: isp
|
|
|
|
|
|
-# Sanguino has a minimum boot size of 1024 bytes, so enable extra functions
|
|
|
-#
|
|
|
-sanguino: TARGET = atmega644p
|
|
|
-sanguino: MCU_TARGET = atmega644p
|
|
|
-sanguino: CFLAGS += '-DLED_START_FLASHES=3' '-DBAUD_RATE=115200' '-DBIGBOOT'
|
|
|
-sanguino: AVR_FREQ = 16000000L
|
|
|
-sanguino: LDSECTIONS = -Wl,--section-start=.text=0xfc00 -Wl,--section-start=.version=0xfffe
|
|
|
-sanguino: $(PROGRAM)_atmega644p.hex
|
|
|
-sanguino: $(PROGRAM)_atmega644p.lst
|
|
|
-
|
|
|
-sanguino_isp: sanguino
|
|
|
-sanguino_isp: TARGET = atmega644p
|
|
|
-sanguino_isp: MCU_TARGET = atmega644p
|
|
|
-# 1024 byte boot
|
|
|
-sanguino_isp: HFUSE = DE
|
|
|
-# Full swing xtal (16MHz) 16KCK/14CK+65ms
|
|
|
-sanguino_isp: LFUSE = F7
|
|
|
-# 2.7V brownout
|
|
|
-sanguino_isp: EFUSE = FD
|
|
|
-sanguino_isp: isp
|
|
|
-
|
|
|
-# Mega has a minimum boot size of 1024 bytes, so enable extra functions
|
|
|
-#mega: TARGET = atmega1280
|
|
|
-mega1280: MCU_TARGET = atmega1280
|
|
|
-mega1280: CFLAGS += '-DLED_START_FLASHES=3' '-DBAUD_RATE=115200' '-DBIGBOOT'
|
|
|
-mega1280: AVR_FREQ = 16000000L
|
|
|
-mega1280: LDSECTIONS = -Wl,--section-start=.text=0x1fc00 -Wl,--section-start=.version=0x1fffe
|
|
|
-mega1280: $(PROGRAM)_atmega1280.hex
|
|
|
-mega1280: $(PROGRAM)_atmega1280.lst
|
|
|
+#Atmega1280
|
|
|
+atmega1280: MCU_TARGET = atmega1280
|
|
|
+atmega1280: CFLAGS += $(COMMON_OPTIONS) -DBIGBOOT $(UART_CMD)
|
|
|
+atmega1280: AVR_FREQ ?= 16000000L
|
|
|
+atmega1280: LDSECTIONS = -Wl,--section-start=.text=0x1fc00 -Wl,--section-start=.version=0x1fffe
|
|
|
+atmega1280: $(PROGRAM)_atmega1280.hex
|
|
|
+atmega1280: $(PROGRAM)_atmega1280.lst
|
|
|
|
|
|
-mega1280_isp: mega1280
|
|
|
-mega1280_isp: TARGET = atmega1280
|
|
|
-mega1280_isp: MCU_TARGET = atmega1280
|
|
|
-# 1024 byte boot
|
|
|
-mega1280_isp: HFUSE = DE
|
|
|
-# Low power xtal (16MHz) 16KCK/14CK+65ms
|
|
|
-mega1280_isp: LFUSE = FF
|
|
|
-# 2.7V brownout
|
|
|
-mega1280_isp: EFUSE = FD
|
|
|
-mega1280_isp: isp
|
|
|
|
|
|
# ATmega8
|
|
|
#
|
|
|
atmega8: TARGET = atmega8
|
|
|
atmega8: MCU_TARGET = atmega8
|
|
|
-atmega8: CFLAGS += '-DLED_START_FLASHES=3' '-DBAUD_RATE=115200'
|
|
|
-atmega8: AVR_FREQ = 16000000L
|
|
|
+atmega8: CFLAGS += $(COMMON_OPTIONS)
|
|
|
+atmega8: AVR_FREQ ?= 16000000L
|
|
|
atmega8: LDSECTIONS = -Wl,--section-start=.text=0x1e00 -Wl,--section-start=.version=0x1ffe
|
|
|
atmega8: $(PROGRAM)_atmega8.hex
|
|
|
atmega8: $(PROGRAM)_atmega8.lst
|
|
@@ -320,17 +307,17 @@ atmega8_isp: atmega8
|
|
|
atmega8_isp: TARGET = atmega8
|
|
|
atmega8_isp: MCU_TARGET = atmega8
|
|
|
# SPIEN, CKOPT (for full swing xtal), Bootsize=512B
|
|
|
-atmega8_isp: HFUSE = CC
|
|
|
+atmega8_isp: HFUSE ?= CC
|
|
|
# 2.7V brownout, 16MHz Xtal, 16KCK/14CK+65ms
|
|
|
-atmega8_isp: LFUSE = BF
|
|
|
+atmega8_isp: LFUSE ?= BF
|
|
|
atmega8_isp: isp
|
|
|
|
|
|
# ATmega88
|
|
|
#
|
|
|
atmega88: TARGET = atmega88
|
|
|
atmega88: MCU_TARGET = atmega88
|
|
|
-atmega88: CFLAGS += '-DLED_START_FLASHES=3' '-DBAUD_RATE=115200'
|
|
|
-atmega88: AVR_FREQ = 16000000L
|
|
|
+atmega88: CFLAGS += $(COMMON_OPTIONS)
|
|
|
+atmega88: AVR_FREQ ?= 16000000L
|
|
|
atmega88: LDSECTIONS = -Wl,--section-start=.text=0x1e00 -Wl,--section-start=.version=0x1ffe
|
|
|
atmega88: $(PROGRAM)_atmega88.hex
|
|
|
atmega88: $(PROGRAM)_atmega88.lst
|
|
@@ -339,17 +326,17 @@ atmega88_isp: atmega88
|
|
|
atmega88_isp: TARGET = atmega88
|
|
|
atmega88_isp: MCU_TARGET = atmega88
|
|
|
# 2.7V brownout
|
|
|
-atmega88_isp: HFUSE = DD
|
|
|
+atmega88_isp: HFUSE ?= DD
|
|
|
# Low power xtal (16MHz) 16KCK/14CK+65ms
|
|
|
-atemga88_isp: LFUSE = FF
|
|
|
+atemga88_isp: LFUSE ?= FF
|
|
|
# 512 byte boot
|
|
|
-atmega88_isp: EFUSE = 04
|
|
|
+atmega88_isp: EFUSE ?= 04
|
|
|
atmega88_isp: isp
|
|
|
|
|
|
atmega32: TARGET = atmega32
|
|
|
atmega32: MCU_TARGET = atmega32
|
|
|
-atmega32: CFLAGS += '-DLED_START_FLASHES=2' '-DBAUD_RATE=115200' '-DLED_DATA_FLASH'
|
|
|
-atmega32: AVR_FREQ = 11059200L
|
|
|
+atmega32: CFLAGS += $(COMMON_OPTIONS)
|
|
|
+atmega32: AVR_FREQ ?= 11059200L
|
|
|
atmega32: LDSECTIONS = -Wl,--section-start=.text=0x7e00 -Wl,--section-start=.version=0x7ffe
|
|
|
atmega32: $(PROGRAM)_atmega32.hex
|
|
|
atmega32: $(PROGRAM)_atmega32.lst
|
|
@@ -358,84 +345,227 @@ atmega32_isp: atmega32
|
|
|
atmega32_isp: TARGET = atmega32
|
|
|
atmega32_isp: MCU_TARGET = atmega32
|
|
|
# No OCD or JTAG, SPIEN, CKOPT (for full swing xtal), Bootsize=512B
|
|
|
-atmega32_isp: HFUSE = CE
|
|
|
+atmega32_isp: HFUSE ?= CE
|
|
|
# 2.7V brownout, 16MHz Xtal, 16KCK/14CK+65ms
|
|
|
-atemga32_isp: LFUSE = BF
|
|
|
+atemga32_isp: LFUSE ?= BF
|
|
|
atmega32_isp: isp
|
|
|
|
|
|
+
|
|
|
+
|
|
|
+#---------------------------------------------------------------------------
|
|
|
+# "Board-level Platform" targets.
|
|
|
+# A "Board-level Platform" implies a manufactured platform with a particular
|
|
|
+# AVR_FREQ, LED, and so on. Parameters are not particularly changable from
|
|
|
+# the "make" command line.
|
|
|
+# Most of the board-level platform builds should envoke make recursively
|
|
|
+# appropriate specific options
|
|
|
+#---------------------------------------------------------------------------
|
|
|
+# 20MHz clocked platforms
|
|
|
+#
|
|
|
+# These are capable of 230400 baud, or 115200 baud on PC (Arduino Avrdude issue)
|
|
|
+#
|
|
|
+
|
|
|
+pro20: TARGET = pro_20mhz
|
|
|
+pro20: CHIP = atmega168
|
|
|
+pro20:
|
|
|
+ $(MAKE) atmega168 AVR_FREQ=20000000L LED_START_FLASHES=3
|
|
|
+ mv $(PROGRAM)_$(CHIP).hex $(PROGRAM)_$(TARGET).hex
|
|
|
+ mv $(PROGRAM)_$(CHIP).lst $(PROGRAM)_$(TARGET).lst
|
|
|
+
|
|
|
+pro20_isp: pro20
|
|
|
+pro20_isp: TARGET = pro_20mhz
|
|
|
+# 2.7V brownout
|
|
|
+pro20_isp: HFUSE ?= DD
|
|
|
+# Full swing xtal (20MHz) 258CK/14CK+4.1ms
|
|
|
+pro20_isp: LFUSE ?= C6
|
|
|
+# 512 byte boot
|
|
|
+pro20_isp: EFUSE ?= 04
|
|
|
+pro20_isp: isp
|
|
|
+
|
|
|
+# 16MHz clocked platforms
|
|
|
+#
|
|
|
+# These are capable of 230400 baud, or 115200 baud on PC (Arduino Avrdude issue)
|
|
|
+#
|
|
|
+
|
|
|
+pro16: TARGET = pro_16MHz
|
|
|
+pro16: CHIP = atmega168
|
|
|
+pro16:
|
|
|
+ $(MAKE) $(CHIP) AVR_FREQ=16000000L LED_START_FLASHES=3
|
|
|
+ mv $(PROGRAM)_$(CHIP).hex $(PROGRAM)_$(TARGET).hex
|
|
|
+ mv $(PROGRAM)_$(CHIP).lst $(PROGRAM)_$(TARGET).lst
|
|
|
+
|
|
|
+pro16_isp: pro16
|
|
|
+pro16_isp: TARGET = pro_16MHz
|
|
|
+# 2.7V brownout
|
|
|
+pro16_isp: HFUSE ?= DD
|
|
|
+# Full swing xtal (20MHz) 258CK/14CK+4.1ms
|
|
|
+pro16_isp: LFUSE ?= C6
|
|
|
+# 512 byte boot
|
|
|
+pro16_isp: EFUSE ?= 04
|
|
|
+pro16_isp: isp
|
|
|
+
|
|
|
+diecimila: TARGET = diecimila
|
|
|
+diecimila: CHIP = atmega168
|
|
|
+diecimila:
|
|
|
+ $(MAKE) $(CHIP) AVR_FREQ=16000000L LED_START_FLASHES=3
|
|
|
+ mv $(PROGRAM)_$(CHIP).hex $(PROGRAM)_$(TARGET).hex
|
|
|
+ mv $(PROGRAM)_$(CHIP).lst $(PROGRAM)_$(TARGET).lst
|
|
|
+
|
|
|
+diecimila_isp: diecimila
|
|
|
+diecimila_isp: TARGET = diecimila
|
|
|
+# 2.7V brownout
|
|
|
+diecimila_isp: HFUSE ?= DD
|
|
|
+# Low power xtal (16MHz) 16KCK/14CK+65ms
|
|
|
+diecimila_isp: LFUSE ?= FF
|
|
|
+# 512 byte boot
|
|
|
+diecimila_isp: EFUSE ?= 04
|
|
|
+diecimila_isp: isp
|
|
|
+
|
|
|
+# Sanguino has a minimum boot size of 1024 bytes, so enable extra functions
|
|
|
+#
|
|
|
+sanguino: TARGET = $@
|
|
|
+sanguino: CHIP = atmega644p
|
|
|
+sanguino:
|
|
|
+ $(MAKE) $(CHIP) AVR_FREQ=16000000L LED=B0
|
|
|
+ mv $(PROGRAM)_$(CHIP).hex $(PROGRAM)_$(TARGET).hex
|
|
|
+ mv $(PROGRAM)_$(CHIP).lst $(PROGRAM)_$(TARGET).lst
|
|
|
+
|
|
|
+sanguino_isp: sanguino
|
|
|
+sanguino_isp: TARGET = sanguino
|
|
|
+sanguino_isp: MCU_TARGET = atmega644p
|
|
|
+# 1024 byte boot
|
|
|
+sanguino_isp: HFUSE ?= DE
|
|
|
+# Full swing xtal (16MHz) 16KCK/14CK+65ms
|
|
|
+sanguino_isp: LFUSE ?= F7
|
|
|
+# 2.7V brownout
|
|
|
+sanguino_isp: EFUSE ?= FD
|
|
|
+sanguino_isp: isp
|
|
|
+
|
|
|
+mighty1284: TARGET = $@
|
|
|
+mighty1284: CHIP = atmega1284p
|
|
|
+mighty1284:
|
|
|
+ $(MAKE) $(CHIP) AVR_FREQ=16000000L LED=B7
|
|
|
+ mv $(PROGRAM)_$(CHIP).hex $(PROGRAM)_$(TARGET).hex
|
|
|
+ mv $(PROGRAM)_$(CHIP).lst $(PROGRAM)_$(TARGET).lst
|
|
|
+
|
|
|
+mighty1284_isp: mighty1284
|
|
|
+mighty1284_isp: TARGET = mighty1284
|
|
|
+mighty1284_isp: MCU_TARGET = atmega1284p
|
|
|
+# 1024 byte boot
|
|
|
+mighty1284_isp: HFUSE ?= DE
|
|
|
+# Full swing xtal (16MHz) 16KCK/14CK+65ms
|
|
|
+mighty1284_isp: LFUSE ?= F7
|
|
|
+# 2.7V brownout
|
|
|
+mighty1284_isp: EFUSE ?= FD
|
|
|
+mighty1284_isp: isp
|
|
|
+
|
|
|
+bobuino: TARGET = $@
|
|
|
+bobuino: CHIP = atmega1284p
|
|
|
+bobuino:
|
|
|
+ $(MAKE) $(CHIP) AVR_FREQ=16000000L LED=B5
|
|
|
+ mv $(PROGRAM)_$(CHIP).hex $(PROGRAM)_$(TARGET).hex
|
|
|
+ mv $(PROGRAM)_$(CHIP).lst $(PROGRAM)_$(TARGET).lst
|
|
|
+
|
|
|
+bobuino_isp: bobuino
|
|
|
+bobuino_isp: TARGET = bobuino
|
|
|
+bobuino_isp: MCU_TARGET = atmega1284p
|
|
|
+# 1024 byte boot
|
|
|
+bobuino_isp: HFUSE ?= DE
|
|
|
+# Full swing xtal (16MHz) 16KCK/14CK+65ms
|
|
|
+bobuino_isp: LFUSE ?= F7
|
|
|
+# 2.7V brownout
|
|
|
+bobuino_isp: EFUSE ?= FD
|
|
|
+bobuino_isp: isp
|
|
|
+
|
|
|
+# MEGA1280 Board (this is different from the atmega1280 chip platform)
|
|
|
+# Mega has a minimum boot size of 1024 bytes, so enable extra functions
|
|
|
+# Note that optiboot does not (can not) work on the MEGA2560
|
|
|
+#mega: TARGET = atmega1280
|
|
|
+mega1280: atmega1280
|
|
|
+
|
|
|
+
|
|
|
+mega1280_isp: mega1280
|
|
|
+mega1280_isp: TARGET = atmega1280
|
|
|
+mega1280_isp: MCU_TARGET = atmega1280
|
|
|
+# 1024 byte boot
|
|
|
+mega1280_isp: HFUSE ?= DE
|
|
|
+# Low power xtal (16MHz) 16KCK/14CK+65ms
|
|
|
+mega1280_isp: LFUSE ?= FF
|
|
|
+# 2.7V brownout; wants F5 for some reason...
|
|
|
+mega1280_isp: EFUSE ?= F5
|
|
|
+mega1280_isp: isp
|
|
|
+
|
|
|
# 8MHz clocked platforms
|
|
|
#
|
|
|
# These are capable of 115200 baud
|
|
|
+# Note that "new" Arduinos with an AVR as USB/Serial converter will NOT work
|
|
|
+# with an 8MHz target Arduino. The bitrate errors are in opposite directions,
|
|
|
+# and total too large a number.
|
|
|
#
|
|
|
|
|
|
-lilypad: TARGET = lilypad
|
|
|
-lilypad: MCU_TARGET = atmega168
|
|
|
-lilypad: CFLAGS += '-DLED_START_FLASHES=3' '-DBAUD_RATE=115200'
|
|
|
-lilypad: AVR_FREQ = 8000000L
|
|
|
-lilypad: $(PROGRAM)_lilypad.hex
|
|
|
-lilypad: $(PROGRAM)_lilypad.lst
|
|
|
+lilypad: TARGET = $@
|
|
|
+lilypad: CHIP = atmega168
|
|
|
+lilypad:
|
|
|
+ $(MAKE) $(CHIP) AVR_FREQ=8000000L LED_START_FLASHES=3
|
|
|
+ mv $(PROGRAM)_$(CHIP).hex $(PROGRAM)_$(TARGET).hex
|
|
|
+ mv $(PROGRAM)_$(CHIP).lst $(PROGRAM)_$(TARGET).lst
|
|
|
|
|
|
lilypad_isp: lilypad
|
|
|
lilypad_isp: TARGET = lilypad
|
|
|
# 2.7V brownout
|
|
|
-lilypad_isp: HFUSE = DD
|
|
|
+lilypad_isp: HFUSE ?= DD
|
|
|
# Internal 8MHz osc (8MHz) Slow rising power
|
|
|
-lilypad_isp: LFUSE = E2
|
|
|
+lilypad_isp: LFUSE ?= E2
|
|
|
# 512 byte boot
|
|
|
-lilypad_isp: EFUSE = 04
|
|
|
+lilypad_isp: EFUSE ?= 04
|
|
|
lilypad_isp: isp
|
|
|
|
|
|
-lilypad_resonator: TARGET = lilypad_resonator
|
|
|
-lilypad_resonator: MCU_TARGET = atmega168
|
|
|
-lilypad_resonator: CFLAGS += '-DLED_START_FLASHES=3' '-DBAUD_RATE=115200'
|
|
|
-lilypad_resonator: AVR_FREQ = 8000000L
|
|
|
-lilypad_resonator: $(PROGRAM)_lilypad_resonator.hex
|
|
|
-lilypad_resonator: $(PROGRAM)_lilypad_resonator.lst
|
|
|
+# lilypad_resonator is the same as a 8MHz lilypad, except for fuses.
|
|
|
+lilypad_resonator: lilypad
|
|
|
|
|
|
-lilypad_resonator_isp: lilypad_resonator
|
|
|
-lilypad_resonator_isp: TARGET = lilypad_resonator
|
|
|
+lilypad_resonator_isp: lilypad
|
|
|
+lilypad_resonator_isp: TARGET = lilypad
|
|
|
# 2.7V brownout
|
|
|
-lilypad_resonator_isp: HFUSE = DD
|
|
|
+lilypad_resonator_isp: HFUSE ?= DD
|
|
|
# Full swing xtal (20MHz) 258CK/14CK+4.1ms
|
|
|
-lilypad_resonator_isp: LFUSE = C6
|
|
|
+lilypad_resonator_isp: LFUSE ?= C6
|
|
|
# 512 byte boot
|
|
|
-lilypad_resonator_isp: EFUSE = 04
|
|
|
+lilypad_resonator_isp: EFUSE ?= 04
|
|
|
lilypad_resonator_isp: isp
|
|
|
|
|
|
pro8: TARGET = pro_8MHz
|
|
|
-pro8: MCU_TARGET = atmega168
|
|
|
-pro8: CFLAGS += '-DLED_START_FLASHES=3' '-DBAUD_RATE=115200'
|
|
|
-pro8: AVR_FREQ = 8000000L
|
|
|
-pro8: $(PROGRAM)_pro_8MHz.hex
|
|
|
-pro8: $(PROGRAM)_pro_8MHz.lst
|
|
|
+pro8: CHIP = atmega168
|
|
|
+pro8:
|
|
|
+ $(MAKE) $(CHIP) AVR_FREQ=8000000L LED_START_FLASHES=3
|
|
|
+ mv $(PROGRAM)_$(CHIP).hex $(PROGRAM)_$(TARGET).hex
|
|
|
+ mv $(PROGRAM)_$(CHIP).lst $(PROGRAM)_$(TARGET).lst
|
|
|
|
|
|
pro8_isp: pro8
|
|
|
pro8_isp: TARGET = pro_8MHz
|
|
|
# 2.7V brownout
|
|
|
-pro8_isp: HFUSE = DD
|
|
|
+pro8_isp: HFUSE ?= DD
|
|
|
# Full swing xtal (20MHz) 258CK/14CK+4.1ms
|
|
|
-pro8_isp: LFUSE = C6
|
|
|
+pro8_isp: LFUSE ?= C6
|
|
|
# 512 byte boot
|
|
|
-pro8_isp: EFUSE = 04
|
|
|
+pro8_isp: EFUSE ?= 04
|
|
|
pro8_isp: isp
|
|
|
|
|
|
atmega328_pro8: TARGET = atmega328_pro_8MHz
|
|
|
-atmega328_pro8: MCU_TARGET = atmega328p
|
|
|
-atmega328_pro8: CFLAGS += '-DLED_START_FLASHES=3' '-DBAUD_RATE=115200'
|
|
|
-atmega328_pro8: AVR_FREQ = 8000000L
|
|
|
-atmega328_pro8: LDSECTIONS = -Wl,--section-start=.text=0x7e00 -Wl,--section-start=.version=0x7ffe
|
|
|
-atmega328_pro8: $(PROGRAM)_atmega328_pro_8MHz.hex
|
|
|
-atmega328_pro8: $(PROGRAM)_atmega328_pro_8MHz.lst
|
|
|
+atmega328_pro8: CHIP = atmega328
|
|
|
+atmega328_pro8:
|
|
|
+ $(MAKE) $(CHIP) AVR_FREQ=8000000L LED_START_FLASHES=3
|
|
|
+ mv $(PROGRAM)_$(CHIP).hex $(PROGRAM)_$(TARGET).hex
|
|
|
+ mv $(PROGRAM)_$(CHIP).lst $(PROGRAM)_$(TARGET).lst
|
|
|
|
|
|
atmega328_pro8_isp: atmega328_pro8
|
|
|
atmega328_pro8_isp: TARGET = atmega328_pro_8MHz
|
|
|
atmega328_pro8_isp: MCU_TARGET = atmega328p
|
|
|
# 512 byte boot, SPIEN
|
|
|
-atmega328_pro8_isp: HFUSE = DE
|
|
|
+atmega328_pro8_isp: HFUSE ?= DE
|
|
|
# Low power xtal (16MHz) 16KCK/14CK+65ms
|
|
|
-atmega328_pro8_isp: LFUSE = FF
|
|
|
+atmega328_pro8_isp: LFUSE ?= FF
|
|
|
# 2.7V brownout
|
|
|
-atmega328_pro8_isp: EFUSE = DE
|
|
|
+atmega328_pro8_isp: EFUSE ?= DE
|
|
|
atmega328_pro8_isp: isp
|
|
|
|
|
|
# 1MHz clocked platforms
|
|
@@ -445,9 +575,9 @@ atmega328_pro8_isp: isp
|
|
|
|
|
|
luminet: TARGET = luminet
|
|
|
luminet: MCU_TARGET = attiny84
|
|
|
-luminet: CFLAGS += '-DLED_START_FLASHES=3' '-DSOFT_UART' '-DBAUD_RATE=9600'
|
|
|
+luminet: CFLAGS += $(COMMON_OPTIONS) '-DSOFT_UART' '-DBAUD_RATE=9600'
|
|
|
luminet: CFLAGS += '-DVIRTUAL_BOOT_PARTITION'
|
|
|
-luminet: AVR_FREQ = 1000000L
|
|
|
+luminet: AVR_FREQ ?= 1000000L
|
|
|
luminet: LDSECTIONS = -Wl,--section-start=.text=0x1d00 -Wl,--section-start=.version=0x1efe
|
|
|
luminet: $(PROGRAM)_luminet.hex
|
|
|
luminet: $(PROGRAM)_luminet.lst
|
|
@@ -456,28 +586,30 @@ luminet_isp: luminet
|
|
|
luminet_isp: TARGET = luminet
|
|
|
luminet_isp: MCU_TARGET = attiny84
|
|
|
# Brownout disabled
|
|
|
-luminet_isp: HFUSE = DF
|
|
|
+luminet_isp: HFUSE ?= DF
|
|
|
# 1MHz internal oscillator, slowly rising power
|
|
|
-luminet_isp: LFUSE = 62
|
|
|
+luminet_isp: LFUSE ?= 62
|
|
|
# Self-programming enable
|
|
|
-luminet_isp: EFUSE = FE
|
|
|
+luminet_isp: EFUSE ?= FE
|
|
|
luminet_isp: isp
|
|
|
|
|
|
+
|
|
|
+#---------------------------------------------------------------------------
|
|
|
#
|
|
|
# Generic build instructions
|
|
|
#
|
|
|
-#
|
|
|
+
|
|
|
+FORCE:
|
|
|
|
|
|
isp: $(TARGET)
|
|
|
- $(ISPFUSES)
|
|
|
- $(ISPFLASH)
|
|
|
+ $(MAKE) -f Makefile.isp isp TARGET=$(TARGET)
|
|
|
|
|
|
isp-stk500: $(PROGRAM)_$(TARGET).hex
|
|
|
$(STK500-1)
|
|
|
$(STK500-2)
|
|
|
|
|
|
-%.elf: $(OBJ)
|
|
|
- $(CC) $(CFLAGS) $(LDFLAGS) -o $@ $^ $(LIBS)
|
|
|
+%.elf: $(OBJ) $(dummy)
|
|
|
+ $(CC) $(CFLAGS) $(LDFLAGS) -o $@ $< $(LIBS)
|
|
|
$(SIZE) $@
|
|
|
|
|
|
clean:
|