Target refactoring and cube update (#161)
* Lib: move cube to libs. Firmware: prepare for code base refactoring, detach from cube, port to cmsis_os2. * Firmware, target f2: regenerate project with latest cube package, tim17 for os ticks. * Firmware: unified codebase. * Core: do not include semaphore on old targets. Firmware: dfu uplaod target. * CI: submodules, add firmware build. * CI: proper submodule config. * refactor build system * CI: update chain to use new targets. Documentation: update to match current structure. * CI: clean before rebuild. * Add local test docker-compose exec dev make -C firmware TARGET=local TEST=1 run * Makefile: target specific build directory. CI: updated artifacts path. * Makefile: init git submodules if they don't exists. * Makefile: debug rule now doesn't reset MCU, prevent SIGINT propagation to st-util. * Makefile: proper rebuild sequence in zz and zzz * Makefile: timestamp tracking for flash and upload commands. * Apps: modular build. Input: fix flipper hal inline. * Wiki: proper bootloader link. * Applications: fix broken build for local targets. * add st-flash to docker * fix build * force rebuild app * move app force to firmware part * fix build deps * qrcode build ok * fix example display * add testing routine * update build instruction Co-authored-by: Aleksandr Kutuzov <aku@plooks.com> Co-authored-by: aanper <mail@s3f.ru>
This commit is contained in:
4
make/base.mk
Normal file
4
make/base.mk
Normal file
@@ -0,0 +1,4 @@
|
||||
OBJ_DIR = .obj
|
||||
ASM_SOURCES =
|
||||
C_SOURCES =
|
||||
CPP_SOURCES =
|
79
make/rules.mk
Normal file
79
make/rules.mk
Normal file
@@ -0,0 +1,79 @@
|
||||
OBJ_DIR := $(OBJ_DIR)/$(TARGET)
|
||||
|
||||
# Include source folder paths to virtual paths
|
||||
VPATH = $(sort $(dir $(C_SOURCES)) $(dir $(ASM_SOURCES)) $(dir $(CPP_SOURCES)))
|
||||
|
||||
# Gather object
|
||||
OBJECTS = $(addprefix $(OBJ_DIR)/, $(notdir $(C_SOURCES:.c=.o)))
|
||||
OBJECTS += $(addprefix $(OBJ_DIR)/, $(notdir $(ASM_SOURCES:.s=.o)))
|
||||
OBJECTS += $(addprefix $(OBJ_DIR)/, $(notdir $(CPP_SOURCES:.cpp=.o)))
|
||||
|
||||
# Generate dependencies
|
||||
DEPS = $(OBJECTS:.o=.d)
|
||||
|
||||
$(shell mkdir -p $(OBJ_DIR))
|
||||
|
||||
all: $(OBJ_DIR)/$(PROJECT).elf $(OBJ_DIR)/$(PROJECT).hex $(OBJ_DIR)/$(PROJECT).bin
|
||||
|
||||
$(OBJ_DIR)/$(PROJECT).elf: $(OBJECTS)
|
||||
@echo "\tLD\t" $@
|
||||
@$(CC) $(LDFLAGS) $(OBJECTS) -o $@
|
||||
@$(SZ) $@
|
||||
|
||||
$(OBJ_DIR)/$(PROJECT).hex: $(OBJ_DIR)/$(PROJECT).elf
|
||||
@echo "\tHEX\t" $@
|
||||
@$(HEX) $< $@
|
||||
|
||||
$(OBJ_DIR)/$(PROJECT).bin: $(OBJ_DIR)/$(PROJECT).elf
|
||||
@echo "\tBIN\t" $@
|
||||
@$(BIN) $< $@
|
||||
|
||||
$(OBJ_DIR)/%.o: %.c
|
||||
@echo "\tCC\t" $@
|
||||
@$(CC) $(CFLAGS) -c $< -o $@
|
||||
|
||||
$(OBJ_DIR)/%.o: %.s
|
||||
@echo "\tASM\t" $@
|
||||
@$(AS) $(CFLAGS) -c $< -o $@
|
||||
|
||||
$(OBJ_DIR)/%.o: %.cpp
|
||||
@echo "\tCPP\t" $@
|
||||
@$(CPP) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
|
||||
|
||||
$(OBJ_DIR)/flash: $(OBJ_DIR)/$(PROJECT).bin
|
||||
st-flash --reset write $(OBJ_DIR)/$(PROJECT).bin $(FLASH_ADDRESS)
|
||||
touch $@
|
||||
|
||||
$(OBJ_DIR)/upload: $(OBJ_DIR)/$(PROJECT).bin
|
||||
dfu-util -D $(OBJ_DIR)/$(PROJECT).bin -a 0 -s $(FLASH_ADDRESS)
|
||||
touch $@
|
||||
|
||||
flash: $(OBJ_DIR)/flash
|
||||
|
||||
upload: $(OBJ_DIR)/upload
|
||||
|
||||
debug: flash
|
||||
set -m; st-util -n --semihosting & echo $$! > st-util.PID
|
||||
arm-none-eabi-gdb -ex "target extended-remote 127.0.0.1:4242" $(OBJ_DIR)/$(PROJECT).elf; kill `cat st-util.PID`; rm st-util.PID
|
||||
|
||||
clean:
|
||||
@echo "\tCLEAN\t"
|
||||
@$(RM) $(OBJ_DIR)/*
|
||||
|
||||
.PHONY: check-and-reinit-submodules
|
||||
check-and-reinit-submodules:
|
||||
@if git submodule status | egrep -q '^[-]|^[+]' ; then \
|
||||
echo "INFO: Need to reinitialize git submodules"; \
|
||||
git submodule update --init; \
|
||||
fi
|
||||
|
||||
z: clean
|
||||
$(MAKE) all
|
||||
|
||||
zz: clean
|
||||
$(MAKE) flash
|
||||
|
||||
zzz: clean
|
||||
$(MAKE) debug
|
||||
|
||||
-include $(DEPS)
|
26
make/toolchain.mk
Normal file
26
make/toolchain.mk
Normal file
@@ -0,0 +1,26 @@
|
||||
# Compiller
|
||||
ifeq ($(TOOLCHAIN), arm)
|
||||
PREFIX = arm-none-eabi-
|
||||
ifdef GCC_PATH
|
||||
PREFIX = $(GCC_PATH)/$(PREFIX)
|
||||
endif
|
||||
endif
|
||||
|
||||
CC = $(PREFIX)gcc
|
||||
CPP = $(PREFIX)g++
|
||||
AS = $(PREFIX)gcc -x assembler-with-cpp
|
||||
CP = $(PREFIX)objcopy
|
||||
SZ = $(PREFIX)size
|
||||
HEX = $(CP) -O ihex
|
||||
BIN = $(CP) -O binary -S
|
||||
|
||||
DEBUG ?= 1
|
||||
ifeq ($(DEBUG), 1)
|
||||
CFLAGS += -DDEBUG -g
|
||||
else
|
||||
CFLAGS += -DNDEBUG -Os
|
||||
endif
|
||||
|
||||
CFLAGS += -MMD -MP -MF"$(@:%.o=%.d)"
|
||||
CPPFLAGS = -fno-threadsafe-statics
|
||||
LDFLAGS += -Wl,-Map=$(OBJ_DIR)/$(PROJECT).map,--cref -Wl,--gc-sections
|
Reference in New Issue
Block a user