123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544 |
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- HARDWARE_MOTHERBOARD ?= 11
-
-
-
- ARDUINO_INSTALL_DIR ?= ${HOME}/Arduino
- ARDUINO_VERSION ?= 106
-
-
- AVR_TOOLS_PATH ?=
-
-
- UPLOAD_RATE ?= 57600
- AVRDUDE_PROGRAMMER ?= arduino
-
- UPLOAD_PORT ?= /dev/ttyUSB0
-
-
-
- BUILD_DIR ?= applet
-
-
- LIQUID_TWI2 ?= 0
-
-
- WIRE ?= 0
-
-
-
-
-
-
-
-
-
- ifeq ($(HARDWARE_MOTHERBOARD),10)
- HARDWARE_VARIANT ?= Gen7
- MCU ?= atmega644
- F_CPU ?= 20000000
- else ifeq ($(HARDWARE_MOTHERBOARD),11)
- HARDWARE_VARIANT ?= Gen7
- MCU ?= atmega644p
- F_CPU ?= 20000000
- else ifeq ($(HARDWARE_MOTHERBOARD),12)
- HARDWARE_VARIANT ?= Gen7
- MCU ?= atmega644p
- F_CPU ?= 20000000
- else ifeq ($(HARDWARE_MOTHERBOARD),13)
- HARDWARE_VARIANT ?= Gen7
- MCU ?= atmega1284p
- F_CPU ?= 20000000
-
-
- else ifeq ($(HARDWARE_MOTHERBOARD),3)
- HARDWARE_VARIANT ?= arduino
- MCU ?= atmega2560
- else ifeq ($(HARDWARE_MOTHERBOARD),33)
- HARDWARE_VARIANT ?= arduino
- MCU ?= atmega2560
- else ifeq ($(HARDWARE_MOTHERBOARD),34)
- HARDWARE_VARIANT ?= arduino
- MCU ?= atmega2560
- else ifeq ($(HARDWARE_MOTHERBOARD),35)
- HARDWARE_VARIANT ?= arduino
- MCU ?= atmega2560
- else ifeq ($(HARDWARE_MOTHERBOARD),36)
- HARDWARE_VARIANT ?= arduino
- MCU ?= atmega2560
- else ifeq ($(HARDWARE_MOTHERBOARD),38)
- HARDWARE_VARIANT ?= arduino
- MCU ?= atmega2560
- else ifeq ($(HARDWARE_MOTHERBOARD),43)
- HARDWARE_VARIANT ?= arduino
- MCU ?= atmega2560
- else ifeq ($(HARDWARE_MOTHERBOARD),44)
- HARDWARE_VARIANT ?= arduino
- MCU ?= atmega2560
- else ifeq ($(HARDWARE_MOTHERBOARD),45)
- HARDWARE_VARIANT ?= arduino
- MCU ?= atmega2560
- else ifeq ($(HARDWARE_MOTHERBOARD),46)
- HARDWARE_VARIANT ?= arduino
- MCU ?= atmega2560
- else ifeq ($(HARDWARE_MOTHERBOARD),48)
- HARDWARE_VARIANT ?= arduino
- MCU ?= atmega2560
-
-
- else ifeq ($(HARDWARE_MOTHERBOARD),5)
- HARDWARE_VARIANT ?= Gen6
- MCU ?= atmega644p
- else ifeq ($(HARDWARE_MOTHERBOARD),51)
- HARDWARE_VARIANT ?= Gen6
- MCU ?= atmega644p
-
-
- else ifeq ($(HARDWARE_MOTHERBOARD),6)
- HARDWARE_VARIANT ?= Sanguino
- MCU ?= atmega644p
- else ifeq ($(HARDWARE_MOTHERBOARD),62)
- HARDWARE_VARIANT ?= Sanguino
- MCU ?= atmega644p
- else ifeq ($(HARDWARE_MOTHERBOARD),63)
- HARDWARE_VARIANT ?= Sanguino
- MCU ?= atmega644p
- else ifeq ($(HARDWARE_MOTHERBOARD),65)
- HARDWARE_VARIANT ?= Sanguino
- MCU ?= atmega1284p
- else ifeq ($(HARDWARE_MOTHERBOARD),66)
- HARDWARE_VARIANT ?= Sanguino
- MCU ?= atmega1284p
- else ifeq ($(HARDWARE_MOTHERBOARD),69)
- HARDWARE_VARIANT ?= Sanguino
- MCU ?= atmega1284p
-
-
- else ifeq ($(HARDWARE_MOTHERBOARD),7)
- HARDWARE_VARIANT ?= arduino
- MCU ?= atmega2560
- else ifeq ($(HARDWARE_MOTHERBOARD),71)
- HARDWARE_VARIANT ?= arduino
- MCU ?= atmega1280
-
-
- else ifeq ($(HARDWARE_MOTHERBOARD),8)
- HARDWARE_VARIANT ?= Teensy
- MCU ?= at90usb1286
- else ifeq ($(HARDWARE_MOTHERBOARD),81)
- HARDWARE_VARIANT ?= Teensy
- MCU ?= at90usb1286
- else ifeq ($(HARDWARE_MOTHERBOARD),811)
- HARDWARE_VARIANT ?= Teensy
- MCU ?= at90usb1286
- else ifeq ($(HARDWARE_MOTHERBOARD),82)
- HARDWARE_VARIANT ?= Teensy
- MCU ?= at90usb646
- else ifeq ($(HARDWARE_MOTHERBOARD),83)
- HARDWARE_VARIANT ?= Teensy
- MCU ?= at90usb1286
- else ifeq ($(HARDWARE_MOTHERBOARD),84)
- HARDWARE_VARIANT ?= Teensy
- MCU ?= at90usb1286
-
-
- else ifeq ($(HARDWARE_MOTHERBOARD),9)
- HARDWARE_VARIANT ?= Sanguino
- MCU ?= atmega644p
-
-
- else ifeq ($(HARDWARE_MOTHERBOARD),22)
- HARDWARE_VARIANT ?= Sanguino
- MCU ?= atmega644p
-
-
- else ifeq ($(HARDWARE_MOTHERBOARD),70)
- HARDWARE_VARIANT ?= arduino
- MCU ?= atmega2560
-
-
- else ifeq ($(HARDWARE_MOTHERBOARD),90)
- HARDWARE_VARIANT ?= SanguinoA
- MCU ?= atmega644
-
-
- else ifeq ($(HARDWARE_MOTHERBOARD),91)
- HARDWARE_VARIANT ?= Sanguino
- MCU ?= atmega644p
-
-
- else ifeq ($(HARDWARE_MOTHERBOARD),301)
- HARDWARE_VARIANT ?= arduino
- MCU ?= atmega2560
-
-
- else ifeq ($(HARDWARE_MOTHERBOARD),67)
- HARDWARE_VARIANT ?= arduino
- MCU ?= atmega2560
- else ifeq ($(HARDWARE_MOTHERBOARD),68)
- HARDWARE_VARIANT ?= arduino
- MCU ?= atmega2560
-
- endif
-
-
-
-
- F_CPU ?= 16000000
-
-
-
-
-
- ifeq ($(HARDWARE_VARIANT), $(filter $(HARDWARE_VARIANT),arduino Sanguino))
- HARDWARE_DIR = $(ARDUINO_INSTALL_DIR)/hardware
- else
- ifeq ($(shell [ $(ARDUINO_VERSION) -ge 100 ] && echo true), true)
- HARDWARE_DIR = ../ArduinoAddons/Arduino_1.x.x
- else
- HARDWARE_DIR = ../ArduinoAddons/Arduino_0.xx
- endif
- endif
- HARDWARE_SRC= $(HARDWARE_DIR)/arduino/avr/cores/arduino
-
- TARGET = $(notdir $(CURDIR))
-
-
-
-
-
- VPATH = .
- VPATH += $(BUILD_DIR)
- VPATH += $(HARDWARE_SRC)
- ifeq ($(HARDWARE_VARIANT), $(filter $(HARDWARE_VARIANT),arduino Teensy Sanguino))
- VPATH += $(HARDWARE_DIR)/marlin/avr/libraries/LiquidCrystal/src
- VPATH += $(HARDWARE_DIR)/marlin/avr/libraries/SPI
- VPATH += $(HARDWARE_DIR)/arduino/avr/libraries/SPI
- VPATH += $(HARDWARE_DIR)/arduino/avr/libraries/SPI/src
- VPATH += $(ARDUINO_INSTALL_DIR)/libraries/LiquidCrystal/src
- ifeq ($(LIQUID_TWI2), 1)
- VPATH += $(ARDUINO_INSTALL_DIR)/libraries/Wire
- VPATH += $(ARDUINO_INSTALL_DIR)/libraries/Wire/utility
- VPATH += $(ARDUINO_INSTALL_DIR)/libraries/LiquidTWI2
- endif
- ifeq ($(WIRE), 1)
- VPATH += $(ARDUINO_INSTALL_DIR)/libraries/Wire
- VPATH += $(ARDUINO_INSTALL_DIR)/libraries/Wire/utility
- endif
- else
- VPATH += $(HARDWARE_DIR)/libraries/LiquidCrystal
- VPATH += $(HARDWARE_DIR)/libraries/SPI
- ifeq ($(LIQUID_TWI2), 1)
- VPATH += $(HARDWARE_DIR)/libraries/Wire
- VPATH += $(HARDWARE_DIR)/libraries/Wire/utility
- VPATH += $(HARDWARE_DIR)/libraries/LiquidTWI2
- endif
- ifeq ($(WIRE), 1)
- VPATH += $(HARDWARE_DIR)/libraries/Wire
- VPATH += $(HARDWARE_DIR)/libraries/Wire/utility
- endif
- endif
- ifeq ($(HARDWARE_VARIANT), arduino)
- HARDWARE_SUB_VARIANT ?= mega
- VPATH += $(ARDUINO_INSTALL_DIR)/hardware/arduino/variants/$(HARDWARE_SUB_VARIANT)
- VPATH += $(ARDUINO_INSTALL_DIR)/hardware/arduino/avr/variants/$(HARDWARE_SUB_VARIANT)
- else
- ifeq ($(HARDWARE_VARIANT), Sanguino)
- VPATH += $(HARDWARE_DIR)/marlin/avr/variants/sanguino
- else
- HARDWARE_SUB_VARIANT ?= standard
- VPATH += $(HARDWARE_DIR)/$(HARDWARE_VARIANT)/variants/$(HARDWARE_SUB_VARIANT)
- endif
- endif
- SRC = wiring.c \
- wiring_analog.c wiring_digital.c \
- wiring_pulse.c \
- wiring_shift.c WInterrupts.c hooks.c
- ifeq ($(HARDWARE_VARIANT), Teensy)
- SRC = wiring.c
- VPATH += $(ARDUINO_INSTALL_DIR)/hardware/teensy/cores/teensy
- endif
- CXXSRC = WMath.cpp WString.cpp Print.cpp Marlin_main.cpp \
- MarlinSerial.cpp Sd2Card.cpp SdBaseFile.cpp SdFatUtil.cpp \
- SdFile.cpp SdVolume.cpp planner.cpp stepper.cpp \
- temperature.cpp cardreader.cpp configuration_store.cpp \
- watchdog.cpp SPI.cpp servo.cpp Tone.cpp ultralcd.cpp digipot_mcp4451.cpp \
- dac_mcp4728.cpp vector_3.cpp qr_solve.cpp endstops.cpp stopwatch.cpp utility.cpp
- ifeq ($(LIQUID_TWI2), 0)
- CXXSRC += LiquidCrystal.cpp
- else
- SRC += twi.c
- CXXSRC += Wire.cpp LiquidTWI2.cpp
- endif
-
- ifeq ($(WIRE), 1)
- SRC += twi.c
- CXXSRC += Wire.cpp
- endif
-
-
- ifeq ($(shell [ $(ARDUINO_VERSION) -ge 100 ] && echo true), true)
- CXXSRC += main.cpp
- else
- SRC += pins_arduino.c main.c
- endif
-
- FORMAT = ihex
-
-
- MAKEFILE = Makefile
-
-
-
-
- DEBUG = stabs
-
- OPT = s
-
- DEFINES ?=
-
-
- CC = $(AVR_TOOLS_PATH)avr-gcc
- CXX = $(AVR_TOOLS_PATH)avr-g++
- OBJCOPY = $(AVR_TOOLS_PATH)avr-objcopy
- OBJDUMP = $(AVR_TOOLS_PATH)avr-objdump
- AR = $(AVR_TOOLS_PATH)avr-ar
- SIZE = $(AVR_TOOLS_PATH)avr-size
- NM = $(AVR_TOOLS_PATH)avr-nm
- AVRDUDE = avrdude
- REMOVE = rm -f
- MV = mv -f
-
-
- CDEFS = -DF_CPU=$(F_CPU) ${addprefix -D , $(DEFINES)}
- CXXDEFS = $(CDEFS)
-
- ifeq ($(HARDWARE_VARIANT), Teensy)
- CDEFS += -DUSB_SERIAL
- SRC += usb.c pins_teensy.c
- CXXSRC += usb_api.cpp
- endif
-
-
- CINCS = ${addprefix -I ,${VPATH}}
- CXXINCS = ${addprefix -I ,${VPATH}}
-
-
-
-
-
-
-
- CDEBUG = -g$(DEBUG)
- CWARN = -Wall -Wstrict-prototypes
- CTUNING = -funsigned-char -funsigned-bitfields -fpack-struct \
- -fshort-enums -w -ffunction-sections -fdata-sections \
- -DARDUINO=$(ARDUINO_VERSION)
- ifneq ($(HARDWARE_MOTHERBOARD),)
- CTUNING += -DMOTHERBOARD=${HARDWARE_MOTHERBOARD}
- endif
-
- CEXTRA = -fno-use-cxa-atexit
-
- CFLAGS := $(CDEBUG) $(CDEFS) $(CINCS) -O$(OPT) $(CWARN) $(CEXTRA) $(CTUNING)
- CXXFLAGS := $(CDEFS) $(CINCS) -O$(OPT) -Wall $(CEXTRA) $(CTUNING)
-
- LDFLAGS = -lm
-
-
-
- AVRDUDE_PORT = $(UPLOAD_PORT)
- AVRDUDE_WRITE_FLASH = -Uflash:w:$(BUILD_DIR)/$(TARGET).hex:i
- ifeq ($(shell uname -s), Linux)
- AVRDUDE_CONF = /etc/avrdude/avrdude.conf
- else
- AVRDUDE_CONF = $(ARDUINO_INSTALL_DIR)/hardware/tools/avr/etc/avrdude.conf
- endif
- AVRDUDE_FLAGS = -D -C$(AVRDUDE_CONF) \
- -p$(MCU) -P$(AVRDUDE_PORT) -c$(AVRDUDE_PROGRAMMER) \
- -b$(UPLOAD_RATE)
-
-
- OBJ = ${patsubst %.c, $(BUILD_DIR)/%.o, ${SRC}}
- OBJ += ${patsubst %.cpp, $(BUILD_DIR)/%.o, ${CXXSRC}}
- OBJ += ${patsubst %.S, $(BUILD_DIR)/%.o, ${ASRC}}
-
-
- LST = $(ASRC:.S=.lst) $(CXXSRC:.cpp=.lst) $(SRC:.c=.lst)
-
-
-
- ALL_CFLAGS = -mmcu=$(MCU) -I. $(CFLAGS)
- ALL_CXXFLAGS = -mmcu=$(MCU) $(CXXFLAGS)
- ALL_ASFLAGS = -mmcu=$(MCU) -x assembler-with-cpp $(ASFLAGS)
-
-
- ifneq ($V,1)
- Pecho=@echo
- P=@
- else
- Pecho=@:
- P=
- endif
-
-
- all: sizeafter
-
- build: $(BUILD_DIR) elf hex
-
-
- $(BUILD_DIR):
- $P mkdir -p $(BUILD_DIR)
-
- elf: $(BUILD_DIR)/$(TARGET).elf
- hex: $(BUILD_DIR)/$(TARGET).hex
- eep: $(BUILD_DIR)/$(TARGET).eep
- lss: $(BUILD_DIR)/$(TARGET).lss
- sym: $(BUILD_DIR)/$(TARGET).sym
-
-
-
- upload: $(BUILD_DIR)/$(TARGET).hex
- ifeq (${AVRDUDE_PROGRAMMER}, arduino)
- stty hup < $(UPLOAD_PORT); true
- endif
- $(AVRDUDE) $(AVRDUDE_FLAGS) $(AVRDUDE_WRITE_FLASH)
- ifeq (${AVRDUDE_PROGRAMMER}, arduino)
- stty -hup < $(UPLOAD_PORT); true
- endif
-
-
- HEXSIZE = $(SIZE) --target=$(FORMAT) $(BUILD_DIR)/$(TARGET).hex
- ELFSIZE = $(SIZE) --mcu=$(MCU) -C $(BUILD_DIR)/$(TARGET).elf; \
- $(SIZE) $(BUILD_DIR)/$(TARGET).elf
- sizebefore:
- $P if [ -f $(BUILD_DIR)/$(TARGET).elf ]; then echo; echo $(MSG_SIZE_BEFORE); $(HEXSIZE); echo; fi
-
- sizeafter: build
- $P if [ -f $(BUILD_DIR)/$(TARGET).elf ]; then echo; echo $(MSG_SIZE_AFTER); $(ELFSIZE); echo; fi
-
-
-
- COFFCONVERT=$(OBJCOPY) --debugging \
- --change-section-address .data-0x800000 \
- --change-section-address .bss-0x800000 \
- --change-section-address .noinit-0x800000 \
- --change-section-address .eeprom-0x810000
-
-
- coff: $(BUILD_DIR)/$(TARGET).elf
- $(COFFCONVERT) -O coff-avr $(BUILD_DIR)/$(TARGET).elf $(TARGET).cof
-
-
- extcoff: $(TARGET).elf
- $(COFFCONVERT) -O coff-ext-avr $(BUILD_DIR)/$(TARGET).elf $(TARGET).cof
-
-
- .SUFFIXES: .elf .hex .eep .lss .sym
- .PRECIOUS: .o
-
- .elf.hex:
- $(Pecho) " COPY $@"
- $P $(OBJCOPY) -O $(FORMAT) -R .eeprom $< $@
-
- .elf.eep:
- -$(OBJCOPY) -j .eeprom --set-section-flags=.eeprom="alloc,load" \
- --change-section-lma .eeprom=0 -O $(FORMAT) $< $@
-
-
- .elf.lss:
- $(OBJDUMP) -h -S $< > $@
-
-
- .elf.sym:
- $(NM) -n $< > $@
-
-
- $(BUILD_DIR)/$(TARGET).elf: $(OBJ) Configuration.h
- $(Pecho) " CXX $@"
- $P $(CC) $(ALL_CXXFLAGS) -Wl,--gc-sections -o $@ -L. $(OBJ) $(LDFLAGS)
-
- $(BUILD_DIR)/%.o: %.c Configuration.h Configuration_adv.h $(MAKEFILE)
- $(Pecho) " CC $<"
- $P $(CC) -MMD -c $(ALL_CFLAGS) $< -o $@
-
- $(BUILD_DIR)/%.o: $(BUILD_DIR)/%.cpp Configuration.h Configuration_adv.h $(MAKEFILE)
- $(Pecho) " CXX $<"
- $P $(CXX) -MMD -c $(ALL_CXXFLAGS) $< -o $@
-
- $(BUILD_DIR)/%.o: %.cpp Configuration.h Configuration_adv.h $(MAKEFILE)
- $(Pecho) " CXX $<"
- $P $(CXX) -MMD -c $(ALL_CXXFLAGS) $< -o $@
-
-
-
- clean:
- $(Pecho) " RM $(BUILD_DIR)/*"
- $P $(REMOVE) $(BUILD_DIR)/$(TARGET).hex $(BUILD_DIR)/$(TARGET).eep $(BUILD_DIR)/$(TARGET).cof $(BUILD_DIR)/$(TARGET).elf \
- $(BUILD_DIR)/$(TARGET).map $(BUILD_DIR)/$(TARGET).sym $(BUILD_DIR)/$(TARGET).lss $(BUILD_DIR)/$(TARGET).cpp \
- $(OBJ) $(LST) $(SRC:.c=.s) $(SRC:.c=.d) $(CXXSRC:.cpp=.s) $(CXXSRC:.cpp=.d)
- $(Pecho) " RMDIR $(BUILD_DIR)/"
- $P rm -rf $(BUILD_DIR)
-
-
- .PHONY: all build elf hex eep lss sym program coff extcoff clean depend sizebefore sizeafter
-
-
- -include ${wildcard $(BUILD_DIR)/*.d}
|