Makefile 7.77 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
# Select the board to build for: if not given on the command line,
# then default to PYBV10.
BOARD ?= PYBV10
ifeq ($(wildcard boards/$(BOARD)/.),)
$(error Invalid BOARD specified)
endif

# If the build directory is not given, make it reflect the board name.
BUILD ?= build-$(BOARD)

Dave Hylands's avatar
Dave Hylands committed
11
include ../py/mkenv.mk
12
-include mpconfigport.mk
13
include boards/$(BOARD)/mpconfigboard.mk
Dave Hylands's avatar
Dave Hylands committed
14
15

# qstr definitions (must come before including py.mk)
16
QSTR_DEFS = qstrdefsport.h $(BUILD)/pins_qstr.h
Dave Hylands's avatar
Dave Hylands committed
17
18
19
20
21
22

# include py core make definitions
include ../py/py.mk

CMSIS_DIR=cmsis
HAL_DIR=hal
23
24
USBDEV_DIR=usbdev
#USBHOST_DIR=usbhost
25
FATFS_DIR=lib/fatfs
Dave Hylands's avatar
Dave Hylands committed
26
DFU=../tools/dfu.py
27
# may need to prefix dfu-util with sudo
28
29
USE_PYDFU ?= 0
PYDFU = ../tools/pydfu.py
30
DFU_UTIL ?= dfu-util
31
DEVICE=0483:df11
Dave Hylands's avatar
Dave Hylands committed
32
33
34
35

CROSS_COMPILE = arm-none-eabi-

INC =  -I.
36
INC += -I..
37
INC += -I$(BUILD)
Dave Hylands's avatar
Dave Hylands committed
38
39
40
INC += -I$(CMSIS_DIR)/inc
INC += -I$(CMSIS_DIR)/devinc
INC += -I$(HAL_DIR)/inc
41
INC += -I$(USBDEV_DIR)/core/inc -I$(USBDEV_DIR)/class/inc
42
#INC += -I$(USBHOST_DIR)
43
INC += -I../lib/mp-readline
44
INC += -I../lib/netutils
Dave Hylands's avatar
Dave Hylands committed
45
46

CFLAGS_CORTEX_M4 = -mthumb -mtune=cortex-m4 -mabi=aapcs-linux -mcpu=cortex-m4 -mfpu=fpv4-sp-d16 -mfloat-abi=hard -fsingle-precision-constant -Wdouble-promotion
47
CFLAGS = $(INC) -Wall -Wpointer-arith -Werror -ansi -std=gnu99 -nostdlib $(CFLAGS_MOD) $(CFLAGS_CORTEX_M4) $(COPT)
Dave Hylands's avatar
Dave Hylands committed
48
49
CFLAGS += -Iboards/$(BOARD)

50
LDFLAGS = -nostdlib -T $(LD_FILE) -Map=$(@:.elf=.map) --cref
51
52
53
LIBS =

# Debugging/Optimization
Dave Hylands's avatar
Dave Hylands committed
54
55
56
57
ifeq ($(DEBUG), 1)
CFLAGS += -g -DPENDSV_DEBUG
COPT = -O0
else
58
CFLAGS += -fdata-sections -ffunction-sections
Dave Hylands's avatar
Dave Hylands committed
59
COPT += -Os -DNDEBUG
60
LDFLAGS += --gc-sections
Dave Hylands's avatar
Dave Hylands committed
61
62
63
64
65
endif

# uncomment this if you want libgcc
#LIBS += $(shell $(CC) -print-libgcc-file-name)

66
SRC_LIB = $(addprefix lib/,\
67
	libc/string0.c \
68
	libm/math.c \
69
	libm/asinfacosf.c \
70
71
	libm/atanf.c \
	libm/atan2f.c \
72
	libm/fmodf.c \
73
	libm/roundf.c \
74
75
76
77
78
79
80
81
82
	libm/log1pf.c \
	libm/acoshf.c \
	libm/asinhf.c \
	libm/atanhf.c \
	libm/kf_rem_pio2.c \
	libm/kf_sin.c \
	libm/kf_cos.c \
	libm/kf_tan.c \
	libm/ef_rem_pio2.c \
83
	libm/erf_lgamma.c \
84
85
86
	libm/sf_sin.c \
	libm/sf_cos.c \
	libm/sf_tan.c \
87
88
	libm/sf_frexp.c \
	libm/sf_modf.c \
89
90
91
92
	libm/sf_ldexp.c \
	libm/sf_erf.c \
	libm/wf_lgamma.c \
	libm/wf_tgamma.c \
93
94
	fatfs/ff.c \
	fatfs/option/ccsbcs.c \
95
	mp-readline/readline.c \
96
	netutils/netutils.c \
97
98
	)

Dave Hylands's avatar
Dave Hylands committed
99
100
101
SRC_C = \
	main.c \
	system_stm32f4xx.c \
102
	stm32f4xx_it.c \
103
	usbd_conf.c \
104
	usbd_desc.c \
105
	usbd_cdc_interface.c \
106
	usbd_msc_storage.c \
107
	mphal.c \
Dave Hylands's avatar
Dave Hylands committed
108
	irq.c \
109
	pendsv.c \
110
	systick.c  \
111
	timer.c \
112
113
	led.c \
	pin.c \
114
	pin_defs_stmhal.c \
115
	pin_named_pins.c \
Damien George's avatar
Damien George committed
116
117
118
119
	bufhelper.c \
	i2c.c \
	spi.c \
	uart.c \
120
	can.c \
121
	usb.c \
122
123
	printf.c \
	gccollect.c \
124
	pybstdio.c \
125
	pyexec.c \
Damien George's avatar
Damien George committed
126
	help.c \
127
	input.c \
128
129
	modpyb.c \
	modstm.c \
130
131
132
	moduos.c \
	modutime.c \
	moduselect.c \
133
134
	modusocket.c \
	modnetwork.c \
135
136
	import.c \
	lexerfatfs.c \
137
	extint.c \
138
	usrsw.c \
139
	rng.c \
Damien George's avatar
Damien George committed
140
	rtc.c \
141
142
	flash.c \
	storage.c \
143
	file.c \
Damien George's avatar
Damien George committed
144
	sdcard.c \
145
	fsusermount.c \
146
	diskio.c \
147
	ffconf.c \
148
	lcd.c \
149
	accel.c \
Damien George's avatar
Damien George committed
150
	servo.c \
Damien George's avatar
Damien George committed
151
	dac.c \
Dave Hylands's avatar
Dave Hylands committed
152
	adc.c \
Dave Hylands's avatar
Dave Hylands committed
153
154
155

SRC_S = \
	startup_stm32f40xx.s \
156
	gchelper.s \
Dave Hylands's avatar
Dave Hylands committed
157
158
159

SRC_HAL = $(addprefix $(HAL_DIR)/src/,\
	stm32f4xx_hal.c \
Dave Hylands's avatar
Dave Hylands committed
160
161
	stm32f4xx_hal_adc.c \
	stm32f4xx_hal_adc_ex.c \
162
	stm32f4xx_hal_can.c \
Dave Hylands's avatar
Dave Hylands committed
163
	stm32f4xx_hal_cortex.c \
Damien George's avatar
Damien George committed
164
165
	stm32f4xx_hal_dac.c \
	stm32f4xx_hal_dac_ex.c \
166
	stm32f4xx_hal_dma.c \
167
168
	stm32f4xx_hal_flash.c \
	stm32f4xx_hal_flash_ex.c \
169
	stm32f4xx_hal_gpio.c \
170
	stm32f4xx_hal_i2c.c \
171
	stm32f4xx_hal_pcd.c \
172
	stm32f4xx_hal_pcd_ex.c \
173
	stm32f4xx_hal_pwr.c \
174
	stm32f4xx_hal_pwr_ex.c \
175
	stm32f4xx_hal_rcc.c \
Damien George's avatar
Damien George committed
176
	stm32f4xx_hal_rcc_ex.c \
177
	stm32f4xx_hal_rng.c \
Damien George's avatar
Damien George committed
178
179
	stm32f4xx_hal_rtc.c \
	stm32f4xx_hal_rtc_ex.c \
Damien George's avatar
Damien George committed
180
	stm32f4xx_hal_sd.c \
Damien George's avatar
Damien George committed
181
	stm32f4xx_hal_spi.c \
182
183
	stm32f4xx_hal_tim.c \
	stm32f4xx_hal_tim_ex.c \
184
	stm32f4xx_hal_uart.c \
Damien George's avatar
Damien George committed
185
	stm32f4xx_ll_sdmmc.c \
186
	stm32f4xx_ll_usb.c \
Dave Hylands's avatar
Dave Hylands committed
187
188
	)

189
190
191
192
SRC_USBDEV = $(addprefix $(USBDEV_DIR)/,\
	core/src/usbd_core.c \
	core/src/usbd_ctlreq.c \
	core/src/usbd_ioreq.c \
193
194
195
196
	class/src/usbd_cdc_msc_hid.c \
	class/src/usbd_msc_bot.c \
	class/src/usbd_msc_scsi.c \
	class/src/usbd_msc_data.c \
Dave Hylands's avatar
Dave Hylands committed
197
198
	)

199
200
201
202
ifeq ($(MICROPY_PY_WIZNET5K),1)
WIZNET5K_DIR=drivers/wiznet5k
INC += -I$(TOP)/$(WIZNET5K_DIR)
CFLAGS_MOD += -DMICROPY_PY_WIZNET5K=1
203
SRC_MOD += modnwwiznet5k.c
204
205
206
207
208
209
210
211
SRC_MOD += $(addprefix $(WIZNET5K_DIR)/,\
	ethernet/w5200/w5200.c \
	ethernet/wizchip_conf.c \
	ethernet/socket.c \
	internet/dns/dns.c \
	)
endif

212
213
214
215
216
# for CC3000 module
ifeq ($(MICROPY_PY_CC3K),1)
CC3000_DIR=drivers/cc3000
INC += -I$(TOP)/$(CC3000_DIR)/inc
CFLAGS_MOD += -DMICROPY_PY_CC3K=1
217
SRC_MOD += modnwcc3k.c
218
219
220
221
222
223
224
225
226
227
228
229
SRC_MOD += $(addprefix $(CC3000_DIR)/src/,\
	cc3000_common.c \
	evnt_handler.c \
	hci.c \
	netapp.c \
	nvmem.c \
	security.c \
	socket.c \
	wlan.c \
	ccspi.c \
	inet_ntop.c \
	inet_pton.c \
230
231
	patch.c \
	patch_prog.c \
232
233
234
	)
endif

Dave Hylands's avatar
Dave Hylands committed
235
OBJ =
236
OBJ += $(PY_O)
237
OBJ += $(addprefix $(BUILD)/, $(SRC_LIB:.c=.o))
Dave Hylands's avatar
Dave Hylands committed
238
239
240
OBJ += $(addprefix $(BUILD)/, $(SRC_C:.c=.o))
OBJ += $(addprefix $(BUILD)/, $(SRC_S:.s=.o))
OBJ += $(addprefix $(BUILD)/, $(SRC_HAL:.c=.o))
241
OBJ += $(addprefix $(BUILD)/, $(SRC_USBDEV:.c=.o))
242
OBJ += $(addprefix $(BUILD)/, $(SRC_MOD:.c=.o))
243
OBJ += $(BUILD)/pins_$(BOARD).o
Dave Hylands's avatar
Dave Hylands committed
244

245
246
247
248
# We put ff.o and stm32f4xx_hal_sd.o into the first 16K section with the ISRs.
# If we compile these using -O0 then it won't fit. So if you really want these
# to be compiled with -O0, then edit stm32f405.ld (in the .isr_vector section)
# and comment out the following 2 lines.
249
$(BUILD)/$(FATFS_DIR)/ff.o: COPT += -Os
250
251
$(BUILD)/$(HAL_DIR)/src/stm32f4xx_hal_sd.o: COPT += -Os

Windel Bouwman's avatar
Windel Bouwman committed
252
all: $(BUILD)/firmware.dfu $(BUILD)/firmware.hex
Dave Hylands's avatar
Dave Hylands committed
253

254
.PHONY: deploy
255

256
deploy: $(BUILD)/firmware.dfu
257
	$(ECHO) "Writing $< to the board"
258
259
260
ifeq ($(USE_PYDFU),1)
	$(Q)$(PYTHON) $(PYDFU) -u $<
else
261
	$(Q)$(DFU_UTIL) -a 0 -d $(DEVICE) -D $<
262
endif
263

264
$(BUILD)/firmware.dfu: $(BUILD)/firmware.elf
Dave Hylands's avatar
Dave Hylands committed
265
	$(ECHO) "Create $@"
266
267
268
	$(Q)$(OBJCOPY) -O binary -j .isr_vector $^ $(BUILD)/firmware0.bin
	$(Q)$(OBJCOPY) -O binary -j .text -j .data $^ $(BUILD)/firmware1.bin
	$(Q)$(PYTHON) $(DFU) -b 0x08000000:$(BUILD)/firmware0.bin -b 0x08020000:$(BUILD)/firmware1.bin $@
Dave Hylands's avatar
Dave Hylands committed
269

Windel Bouwman's avatar
Windel Bouwman committed
270
271
272
273
$(BUILD)/firmware.hex: $(BUILD)/firmware.elf
	$(ECHO) "Create $@"
	$(Q)$(OBJCOPY) -O ihex $< $@

274
$(BUILD)/firmware.elf: $(OBJ)
Dave Hylands's avatar
Dave Hylands committed
275
276
277
278
279
280
	$(ECHO) "LINK $@"
	$(Q)$(LD) $(LDFLAGS) -o $@ $(OBJ) $(LIBS)
	$(Q)$(SIZE) $@

MAKE_PINS = boards/make-pins.py
BOARD_PINS = boards/$(BOARD)/pins.csv
281
PREFIX_FILE = boards/stm32f4xx_prefix.c
Dave Hylands's avatar
Dave Hylands committed
282
GEN_PINS_SRC = $(BUILD)/pins_$(BOARD).c
283
GEN_PINS_HDR = $(HEADER_BUILD)/pins.h
284
GEN_PINS_QSTR = $(BUILD)/pins_qstr.h
285
GEN_PINS_AF_CONST = $(HEADER_BUILD)/pins_af_const.h
286
GEN_PINS_AF_PY = $(BUILD)/pins_af.py
Dave Hylands's avatar
Dave Hylands committed
287

288
289
290
INSERT_USB_IDS = ../tools/insert-usb-ids.py
FILE2H = ../tools/file2h.py

291
USB_IDS_FILE = usbd_desc.c
292
CDCINF_TEMPLATE = pybcdc.inf_template
293
294
GEN_CDCINF_FILE = $(HEADER_BUILD)/pybcdc.inf
GEN_CDCINF_HEADER = $(HEADER_BUILD)/pybcdc_inf.h
295

Dave Hylands's avatar
Dave Hylands committed
296
297
298
299
300
# Making OBJ use an order-only depenedency on the generated pins.h file
# has the side effect of making the pins.h file before we actually compile
# any of the objects. The normal dependency generation will deal with the
# case when pins.h is modified. But when it doesn't exist, we don't know
# which source files might need it.
301
$(OBJ): | $(HEADER_BUILD)/pins.h
302

303
304
$(BUILD)/main.o: $(GEN_CDCINF_HEADER)

Dave Hylands's avatar
Dave Hylands committed
305
306
# Use a pattern rule here so that make will only call make-pins.py once to make
# both pins_$(BOARD).c and pins.h
307
$(BUILD)/%_$(BOARD).c $(HEADER_BUILD)/%.h $(HEADER_BUILD)/%_af_const.h $(BUILD)/%_qstr.h: boards/$(BOARD)/%.csv $(MAKE_PINS) $(AF_FILE) $(PREFIX_FILE) | $(HEADER_BUILD)
Dave Hylands's avatar
Dave Hylands committed
308
	$(ECHO) "Create $@"
309
	$(Q)$(PYTHON) $(MAKE_PINS) --board $(BOARD_PINS) --af $(AF_FILE) --prefix $(PREFIX_FILE) --hdr $(GEN_PINS_HDR) --qstr $(GEN_PINS_QSTR) --af-const $(GEN_PINS_AF_CONST) --af-py $(GEN_PINS_AF_PY) > $(GEN_PINS_SRC)
Dave Hylands's avatar
Dave Hylands committed
310
311
312
313

$(BUILD)/pins_$(BOARD).o: $(BUILD)/pins_$(BOARD).c
	$(call compile_c)

314
315
316
317
318
319
320
321
$(GEN_CDCINF_HEADER): $(GEN_CDCINF_FILE) $(FILE2H)
	$(ECHO) "Create $@"
	$(Q)$(PYTHON) $(FILE2H) $< > $@

$(GEN_CDCINF_FILE): $(CDCINF_TEMPLATE) $(INSERT_USB_IDS) $(USB_IDS_FILE)
	$(ECHO) "Create $@"
	$(Q)$(PYTHON) $(INSERT_USB_IDS) $(USB_IDS_FILE) $< > $@

Dave Hylands's avatar
Dave Hylands committed
322
include ../py/mkrules.mk