2017-09-06 14:09:13 +10:00
|
|
|
include ../../py/mkenv.mk
|
2015-03-28 21:45:40 +00:00
|
|
|
|
|
|
|
# qstr definitions (must come before including py.mk)
|
|
|
|
QSTR_DEFS = qstrdefsport.h
|
|
|
|
|
|
|
|
# include py core make definitions
|
2017-08-11 12:22:19 +10:00
|
|
|
include $(TOP)/py/py.mk
|
2022-06-17 11:11:30 -05:00
|
|
|
include $(TOP)/extmod/extmod.mk
|
2015-03-28 21:45:40 +00:00
|
|
|
|
2021-04-24 17:41:55 +02:00
|
|
|
XCVERSION ?= 1.35
|
|
|
|
XC16 ?= /opt/microchip/xc16/v$(XCVERSION)
|
2019-12-21 14:22:26 -06:00
|
|
|
CROSS_COMPILE ?= $(XC16)/bin/xc16-
|
2015-03-28 21:45:40 +00:00
|
|
|
|
|
|
|
PARTFAMILY = dsPIC33F
|
|
|
|
PART = 33FJ256GP506
|
|
|
|
|
2015-10-19 18:22:16 +03:00
|
|
|
INC += -I.
|
2017-08-11 12:22:19 +10:00
|
|
|
INC += -I$(TOP)
|
2015-03-28 21:45:40 +00:00
|
|
|
INC += -I$(BUILD)
|
|
|
|
INC += -I$(XC16)/include
|
|
|
|
INC += -I$(XC16)/support/$(PARTFAMILY)/h
|
|
|
|
|
|
|
|
CFLAGS_PIC16BIT = -mcpu=$(PART) -mlarge-code
|
2017-03-05 13:28:27 +01:00
|
|
|
CFLAGS = $(INC) -Wall -Werror -std=gnu99 -nostdlib $(CFLAGS_PIC16BIT) $(COPT)
|
2015-03-28 21:45:40 +00:00
|
|
|
|
|
|
|
#Debugging/Optimization
|
|
|
|
ifeq ($(DEBUG), 1)
|
|
|
|
CFLAGS += -O0 -ggdb
|
|
|
|
else
|
|
|
|
CFLAGS += -O1 -DNDEBUG
|
|
|
|
endif
|
|
|
|
|
|
|
|
LDFLAGS = --heap=0 -nostdlib -T $(XC16)/support/$(PARTFAMILY)/gld/p$(PART).gld -Map=$@.map --cref -p$(PART)
|
2019-01-25 16:06:13 +11:00
|
|
|
LIBS = -L$(XC16)/lib -L$(XC16)/lib/$(PARTFAMILY) -lc -lm -lpic30
|
2015-03-28 21:45:40 +00:00
|
|
|
|
|
|
|
SRC_C = \
|
|
|
|
main.c \
|
|
|
|
board.c \
|
|
|
|
pic16bit_mphal.c \
|
|
|
|
modpyb.c \
|
|
|
|
modpybled.c \
|
|
|
|
modpybswitch.c \
|
2021-07-09 14:19:15 +10:00
|
|
|
shared/runtime/pyexec.c \
|
|
|
|
shared/runtime/sys_stdio_mphal.c \
|
|
|
|
shared/readline/readline.c \
|
2015-03-28 21:45:40 +00:00
|
|
|
|
|
|
|
SRC_S = \
|
|
|
|
# gchelper.s \
|
|
|
|
|
|
|
|
OBJ = $(PY_O) $(addprefix $(BUILD)/, $(SRC_C:.c=.o) $(SRC_S:.s=.o))
|
|
|
|
|
py: Add rules for automated extraction of qstrs from sources.
- add template rule that converts a specified source file into a qstring file
- add special rule for generating a central header that contains all
extracted/autogenerated strings - defined by QSTR_DEFS_COLLECTED
variable. Each platform appends a list of sources that may contain
qstrings into a new build variable: SRC_QSTR. Any autogenerated
prerequisities are should be appened to SRC_QSTR_AUTO_DEPS variable.
- remove most qstrings from py/qstrdefs, keep only qstrings that
contain special characters - these cannot be easily detected in the
sources without additional annotations
- remove most manual qstrdefs, use qstrdef autogen for: py, cc3200,
stmhal, teensy, unix, windows, pic16bit:
- remove all micropython generic qstrdefs except for the special strings that contain special characters (e.g. /,+,<,> etc.)
- remove all port specific qstrdefs except for special strings
- append sources for qstr generation in platform makefiles (SRC_QSTR)
2016-03-10 09:22:41 +00:00
|
|
|
# List of sources for qstr extraction
|
|
|
|
SRC_QSTR += $(SRC_C)
|
|
|
|
# Append any auto-generated sources that are needed by sources listed in
|
|
|
|
# SRC_QSTR
|
|
|
|
SRC_QSTR_AUTO_DEPS +=
|
|
|
|
|
2015-03-28 21:45:40 +00:00
|
|
|
all: $(BUILD)/firmware.hex
|
|
|
|
|
|
|
|
$(BUILD)/firmware.hex: $(BUILD)/firmware.elf
|
|
|
|
$(ECHO) "Create $@"
|
|
|
|
$(Q)$(CROSS_COMPILE)bin2hex $<
|
|
|
|
|
|
|
|
$(BUILD)/firmware.elf: $(OBJ)
|
|
|
|
$(ECHO) "LINK $@"
|
2015-10-24 02:26:10 +03:00
|
|
|
$(Q)$(LD) $(LDFLAGS) -o $@ $^ $(LIBS)
|
2015-03-28 21:45:40 +00:00
|
|
|
$(Q)size $@
|
|
|
|
|
|
|
|
$(PY_BUILD)/gc.o: CFLAGS += -O1
|
|
|
|
$(PY_BUILD)/vm.o: CFLAGS += -O1
|
|
|
|
|
2017-08-11 12:22:19 +10:00
|
|
|
include $(TOP)/py/mkrules.mk
|