mirror of
https://github.com/UpsilonNumworks/Upsilon.git
synced 2026-01-19 00:37:25 +01:00
106 lines
4.3 KiB
Makefile
106 lines
4.3 KiB
Makefile
include scripts/targets.device.$(MODEL).mak
|
|
|
|
executables += flasher.light flasher.verbose bench.RAM bench.flash
|
|
extensions = dfu hex bin
|
|
|
|
$(foreach extension,$(extensions),$(foreach executable,$(executables),$(eval $(call rules_for_targets,$(executable),$(extension)))))
|
|
|
|
$(BUILD_DIR)/%.dfu: $(BUILD_DIR)/%.$(EXE)
|
|
@echo "DFUSE $@"
|
|
$(Q) $(PYTHON) scripts/device/elf2dfu.py $< $@
|
|
|
|
$(BUILD_DIR)/%.hex: $(BUILD_DIR)/%.$(EXE)
|
|
@echo "OBJCOPY $@"
|
|
$(Q) $(OBJCOPY) -O ihex $< $@
|
|
|
|
$(BUILD_DIR)/%.bin: $(BUILD_DIR)/%.$(EXE)
|
|
@echo "OBJCOPY $@"
|
|
$(Q) $(OBJCOPY) -O binary $< $@
|
|
# We pad the device binary files because there was a bug in an older version of
|
|
# the dfu code, and it did not upload properly a binary of length non-multiple
|
|
# of 32 bits.
|
|
#TODO: We over-pad here, pad with the the needed amount of bytes only.
|
|
@echo "Padding $@"
|
|
$(Q) printf "\xFF\xFF\xFF\xFF" >> $@
|
|
|
|
.PHONY: %_size
|
|
%_size: %.$(EXE)
|
|
@echo "========= BUILD OUTPUT ========"
|
|
@echo "File: $<"
|
|
@$(SIZE) $< | tail -n 1 | awk '{print "Code: " $$1 " bytes";print "Data: " $$2 " bytes"; print "Total: " int(($$1+$$2)/1024) " kB (" $$1 + $$2 " bytes)";}'
|
|
@echo "==============================="
|
|
|
|
.PHONY: %_run
|
|
%_run: %.$(EXE)
|
|
$(GDB) -x scripts/$(PLATFORM)/gdb_script.gdb $<
|
|
|
|
%.map: %.elf
|
|
@echo "LDMAP $@"
|
|
$(Q) $(LD) $^ $(LDFLAGS) -Wl,-M -Wl,-Map=$@ -o /dev/null
|
|
|
|
.PHONY: %_memory_map
|
|
%_memory_map: %.map
|
|
@echo "========== MEMORY MAP ========="
|
|
$(Q) awk -f scripts/device/memory_map.awk < $<
|
|
@echo "==============================="
|
|
|
|
.PHONY: %_flash
|
|
%_flash: %.bin
|
|
@echo "DFU $@"
|
|
@echo "INFO About to flash your device. Please plug your device to your computer"
|
|
@echo " using an USB cable and press the RESET button the back of your device."
|
|
@until dfu-util -l | grep "Flash" > /dev/null 2>&1; do sleep 1;done
|
|
@echo "DFU $@"
|
|
$(Q) dfu-util -i 0 -a 0 -s 0x08000000:leave -D $<
|
|
|
|
.PHONY: openocd
|
|
openocd:
|
|
openocd -f scripts/$(PLATFORM)/openocd.$(MODEL).cfg
|
|
|
|
# The flasher target is defined here because otherwise $(src) has not been
|
|
# fully filled
|
|
$(BUILD_DIR)/flasher.%.$(EXE): LDFLAGS += -Lion/src/$(PLATFORM)/flasher
|
|
$(BUILD_DIR)/flasher.%.$(EXE): LDSCRIPT = ion/src/$(PLATFORM)/shared/ram.ld
|
|
flasher_objs = $(call object_for,$(src) $(flasher_src) $(ion_device_dfu_xip_src))
|
|
$(BUILD_DIR)/flasher.light.$(EXE): $(BUILD_DIR)/ion/src/$(PLATFORM)/flasher/display_light.o $(flasher_objs)
|
|
$(BUILD_DIR)/flasher.verbose.$(EXE): $(BUILD_DIR)/ion/src/$(PLATFORM)/flasher/display_verbose.o $(flasher_objs)
|
|
|
|
#TODO Do not build all apps... Put elsewhere?
|
|
$(BUILD_DIR)/bench.ram.$(EXE): LDFLAGS += -Lion/src/$(PLATFORM)/bench
|
|
$(BUILD_DIR)/bench.ram.$(EXE): LDSCRIPT = ion/src/$(PLATFORM)/shared/ram.ld
|
|
$(BUILD_DIR)/bench.flash.$(EXE): LDSCRIPT = ion/src/$(PLATFORM)/$(MODEL)/internal_flash.ld
|
|
$(BUILD_DIR)/bench.%.$(EXE): $(call object_for,$(src) $(bench_src) $(ion_device_dfu_xip_src))
|
|
|
|
ifeq ($(EPSILON_ONBOARDING_APP)$(EPSILON_BOOT_PROMPT),1update)
|
|
.PHONY: %_two_binaries
|
|
%_two_binaries: %.elf
|
|
@echo "Building an internal and an external binary for $<"
|
|
$(Q) $(OBJCOPY) -O binary -j .text.external -j .rodata.external $< $(basename $<).external.bin
|
|
$(Q) $(OBJCOPY) -O binary -R .text.external -R .rodata.external $< $(basename $<).internal.bin
|
|
@echo "Padding $(basename $<).external.bin and $(basename $<).internal.bin"
|
|
$(Q) printf "\xFF\xFF\xFF\xFF" >> $(basename $<).external.bin
|
|
$(Q) printf "\xFF\xFF\xFF\xFF" >> $(basename $<).internal.bin
|
|
else
|
|
%_two_binaries:
|
|
@echo "Error: two_binaries requires EPSILON_ONBOARDING_APP=1 EPSILON_BOOT_PROMPT=update"
|
|
endif
|
|
|
|
.PHONY: binpack
|
|
binpack:
|
|
rm -rf build/binpack
|
|
mkdir -p build/binpack
|
|
make clean
|
|
make -j8 $(BUILD_DIR)/flasher.light.bin
|
|
cp $(BUILD_DIR)/flasher.light.bin build/binpack
|
|
make clean
|
|
make -j8 $(BUILD_DIR)/bench.flash.bin
|
|
make -j8 $(BUILD_DIR)/bench.ram.bin
|
|
cp $(BUILD_DIR)/bench.ram.bin $(BUILD_DIR)/bench.flash.bin build/binpack
|
|
make clean
|
|
make -j8 EPSILON_ONBOARDING_APP=1 EPSILON_BOOT_PROMPT=update $(BUILD_DIR)/epsilon_two_binaries
|
|
cp $(BUILD_DIR)/epsilon.internal.bin $(BUILD_DIR)/epsilon.external.bin build/binpack
|
|
make clean
|
|
cd build && for binary in flasher.light.bin bench.flash.bin bench.ram.bin epsilon.internal.bin epsilon.external.bin; do shasum -a 256 -b binpack/$${binary} > binpack/$${binary}.sha256;done
|
|
cd build && tar cvfz binpack-`git rev-parse HEAD | head -c 7`.tgz binpack
|
|
rm -rf build/binpack
|