2014-01-24 13:05:30 +04:00
|
|
|
include ../py/mkenv.mk
|
2014-01-08 21:09:47 +04:00
|
|
|
|
|
|
|
# include py core make definitions
|
|
|
|
include ../py/py.mk
|
|
|
|
|
2014-01-06 12:20:11 +04:00
|
|
|
ifeq ($(ARDUINO),)
|
|
|
|
$(error Please define ARDUINO (where TeensyDuino is installed))
|
|
|
|
endif
|
|
|
|
TOOLS_PATH = $(ARDUINO)/hardware/tools
|
|
|
|
COMPILER_PATH = $(TOOLS_PATH)/arm-none-eabi/bin
|
|
|
|
CORE_PATH = $(ARDUINO)/hardware/teensy/cores/teensy3
|
|
|
|
|
2014-01-24 13:05:30 +04:00
|
|
|
CROSS_COMPILE = $(COMPILER_PATH)/arm-none-eabi-
|
2014-01-06 12:20:11 +04:00
|
|
|
|
2014-01-08 21:09:47 +04:00
|
|
|
CFLAGS_TEENSY = -DF_CPU=96000000 -DUSB_SERIAL -D__MK20DX256__
|
2014-01-06 12:20:11 +04:00
|
|
|
CFLAGS_CORTEX_M4 = -mthumb -mtune=cortex-m4 -mcpu=cortex-m4 -fsingle-precision-constant -Wdouble-promotion $(CFLAGS_TEENSY)
|
2014-01-24 13:05:30 +04:00
|
|
|
CFLAGS = -I. -I$(PY_SRC) -I$(CORE_PATH) -Wall -ansi -std=gnu99 $(CFLAGS_CORTEX_M4)
|
2014-01-06 12:20:11 +04:00
|
|
|
LDFLAGS = -nostdlib -T mk20dx256.ld
|
|
|
|
LIBS = -L $(COMPILER_PATH)/../lib/gcc/arm-none-eabi/4.7.2/thumb2 -lgcc
|
|
|
|
|
2014-01-13 17:25:10 +04:00
|
|
|
#Debugging/Optimization
|
|
|
|
ifdef DEBUG
|
|
|
|
CFLAGS += -Og -ggdb
|
|
|
|
else
|
|
|
|
CFLAGS += -Os #-DNDEBUG
|
|
|
|
endif
|
|
|
|
|
2014-01-06 12:20:11 +04:00
|
|
|
SRC_C = \
|
|
|
|
main.c \
|
2014-01-07 21:49:42 +04:00
|
|
|
lcd.c \
|
2014-01-06 12:20:11 +04:00
|
|
|
led.c \
|
2014-01-07 21:49:42 +04:00
|
|
|
lexerfatfs.c \
|
2014-01-08 13:00:22 +04:00
|
|
|
lexermemzip.c \
|
|
|
|
memzip.c \
|
2014-01-07 21:49:42 +04:00
|
|
|
usb.c \
|
|
|
|
|
2014-01-24 13:05:30 +04:00
|
|
|
STM_SRC_C = $(addprefix stm/,\
|
2014-01-06 12:20:11 +04:00
|
|
|
malloc0.c \
|
|
|
|
printf.c \
|
|
|
|
string0.c \
|
2014-01-24 13:05:30 +04:00
|
|
|
)
|
2014-01-06 12:20:11 +04:00
|
|
|
|
2014-01-24 13:05:30 +04:00
|
|
|
STM_SRC_S = $(addprefix stm/,\
|
2014-01-06 12:20:11 +04:00
|
|
|
gchelper.s \
|
2014-01-24 13:05:30 +04:00
|
|
|
)
|
2014-01-06 12:20:11 +04:00
|
|
|
|
|
|
|
SRC_TEENSY = \
|
|
|
|
mk20dx128.c \
|
|
|
|
pins_teensy.c \
|
|
|
|
analog.c \
|
|
|
|
usb_desc.c \
|
|
|
|
usb_dev.c \
|
|
|
|
usb_mem.c \
|
|
|
|
usb_serial.c \
|
|
|
|
yield.c \
|
|
|
|
|
2014-01-08 21:09:47 +04:00
|
|
|
OBJ = $(addprefix $(BUILD)/, $(SRC_C:.c=.o) $(STM_SRC_C:.c=.o) $(STM_SRC_S:.s=.o) $(SRC_TEENSY:.c=.o)) $(PY_O)
|
2014-01-06 12:20:11 +04:00
|
|
|
#LIB = -lreadline
|
|
|
|
# the following is needed for BSD
|
|
|
|
#LIB += -ltermcap
|
|
|
|
|
2014-01-24 13:05:30 +04:00
|
|
|
all: hex
|
2014-01-08 13:00:22 +04:00
|
|
|
hex: $(BUILD)/micropython-mz.hex
|
2014-01-06 12:20:11 +04:00
|
|
|
|
2014-01-08 13:00:22 +04:00
|
|
|
post_compile: $(BUILD)/micropython-mz.hex
|
2014-01-08 22:15:39 +04:00
|
|
|
$(ECHO) "Preparing $@ for upload"
|
|
|
|
$(Q)$(TOOLS_PATH)/teensy_post_compile -file="$(basename $(<F))" -path="$(<D)" -tools="$(TOOLS_PATH)"
|
2014-01-06 12:20:11 +04:00
|
|
|
|
|
|
|
reboot:
|
2014-01-08 22:15:39 +04:00
|
|
|
$(ECHO) "REBOOT"
|
|
|
|
-$(Q)$(TOOLS_PATH)/teensy_reboot
|
2014-01-06 12:20:11 +04:00
|
|
|
|
|
|
|
upload: post_compile reboot
|
|
|
|
|
2014-01-08 13:00:22 +04:00
|
|
|
$(BUILD)/micropython.elf: $(OBJ)
|
2014-01-08 22:15:39 +04:00
|
|
|
$(ECHO) "LINK $<"
|
|
|
|
$(Q)$(CC) $(LDFLAGS) -o "$@" -Wl,-Map,$(@:.elf=.map) $(OBJ) $(LIBS)
|
|
|
|
$(Q)$(SIZE) $@
|
2014-01-06 12:20:11 +04:00
|
|
|
|
2014-01-08 13:00:22 +04:00
|
|
|
ifeq ($(MEMZIP_DIR),)
|
|
|
|
MEMZIP_DIR = memzip_files
|
|
|
|
endif
|
|
|
|
|
|
|
|
$(BUILD)/micropython-mz.hex: $(BUILD)/micropython.hex $(shell find ${MEMZIP_DIR} -type f)
|
|
|
|
@$(ECHO) "Creating $@"
|
|
|
|
$(Q)./add-memzip.sh $< $@ ${MEMZIP_DIR}
|
|
|
|
|
2014-01-08 21:09:47 +04:00
|
|
|
$(BUILD)/%.hex: $(BUILD)/%.elf
|
2014-01-08 22:15:39 +04:00
|
|
|
$(ECHO) "HEX $<"
|
|
|
|
$(Q)$(OBJCOPY) -O ihex -R .eeprom "$<" "$@"
|
2014-01-06 12:20:11 +04:00
|
|
|
|
|
|
|
$(BUILD)/%.o: $(CORE_PATH)/%.c
|
2014-01-24 13:05:30 +04:00
|
|
|
$(call compile_c)
|
2014-01-06 12:20:11 +04:00
|
|
|
|
2014-01-24 13:05:30 +04:00
|
|
|
include ../py/mkrules.mk
|