# Current version VERSION ?= v0.9 # Target parameters LAYOUTS = A B C D E F G H I J K L M N O P Q R S T U V W MCUS = H L DEADTIMES = 0 5 10 15 20 25 30 40 50 70 90 PWM_FREQS = 24 48 96 # Example single target LAYOUT ?= A MCU ?= H DEADTIME ?= 5 PWM ?= 24 # Directory configuration OUTPUT_DIR ?= build HEX_DIR ?= $(OUTPUT_DIR)/hex LOG_DIR ?= $(OUTPUT_DIR)/logs # Path to the keil binaries KEIL_PATH ?= ~/Downloads/keil_8051/9.60/BIN WINE_BIN ?= /usr/local/bin/wine # Assembler and linker binaries AX51_BIN = $(KEIL_PATH)/AX51.exe LX51_BIN = $(KEIL_PATH)/LX51.exe OX51_BIN = $(KEIL_PATH)/Ohx51.exe AX51 = $(WINE_BIN) $(AX51_BIN) LX51 = $(WINE_BIN) $(LX51_BIN) OX51 = $(WINE_BIN) $(OX51_BIN) # Set up flags #AX51_FLAGS = DEBUG NOMOD51 AX51_FLAGS = NOMOD51 NOLIST NOSYMBOLS LX51_FLAGS = # Source files ASM_SRC = Bluejay.asm ASM_INC = $(LAYOUTS:%=targets/%.inc) Common.inc BLHeliBootLoad.inc Silabs/SI_EFM8BB1_Defs.inc Silabs/SI_EFM8BB2_Defs.inc # Check that wine/simplicity studio is available EXECUTABLES = $(WINE_BIN) $(AX51_BIN) $(LX51_BIN) $(OX51_BIN) DUMMYVAR := $(foreach exec, $(EXECUTABLES), \ $(if $(wildcard $(exec)),found, \ $(error "Could not find $(exec). Make sure to set the correct paths to the simplicity install location"))) # Set up efm8load EFM8_LOAD_BIN ?= efm8load.py EFM8_LOAD_PORT ?= /dev/ttyUSB0 EFM8_LOAD_BAUD ?= 57600 # Delete object files on error and warnings .DELETE_ON_ERROR: # AX51 mixes up input defines when run in parallel. Maybe because you cannot change the TMP directory per invocation. .NOTPARALLEL: define MAKE_OBJ OBJS += $(1)_$(2)_$(3)_$(4)_$(VERSION).OBJ $(OUTPUT_DIR)/$(1)_$(2)_$(3)_$(4)_$(VERSION).OBJ : $(ASM_SRC) $(ASM_INC) $(eval _ESC := $(1)) $(eval _ESC_INT := $(shell printf "%d" "'${_ESC}")) $(eval _ESCNO := $(shell echo $$(( $(_ESC_INT) - 65 + 1)))) $(eval _MCU_48MHZ := $(subst L,0,$(subst H,1,$(2)))) $(eval _DEADTIME := $(3)) $(eval _PWM_FREQ := $(subst 24,0,$(subst 48,1,$(subst 96,2,$(4))))) $(eval _LOG := $(LOG_DIR)/$(1)_$(2)_$(3)_$(4)_$(VERSION).log) $$(eval _LST := $$(patsubst %.OBJ,%.LST,$$@)) @mkdir -p $(OUTPUT_DIR) @mkdir -p $(LOG_DIR) @echo "AX51 : $$@" @$(AX51) $(ASM_SRC) \ "DEFINE(ESCNO=$(_ESCNO)) " \ "DEFINE(MCU_48MHZ=$(_MCU_48MHZ)) "\ "DEFINE(FETON_DELAY=$(_DEADTIME)) "\ "DEFINE(PWM_FREQ=$(_PWM_FREQ)) "\ "OBJECT($$@) "\ "PRINT($$(_LST)) "\ "$(AX51_FLAGS)" > $(_LOG) 2>&1 || (grep -B 3 -E "\*\*\* (ERROR|WARNING)" $$(_LST); exit 1) endef SINGLE_TARGET_HEX = $(HEX_DIR)/$(LAYOUT)_$(MCU)_$(DEADTIME)_$(PWM)_$(VERSION).hex single_target : $(SINGLE_TARGET_HEX) # Create all obj targets using macro expansion $(foreach _t,$(LAYOUTS), \ $(foreach _m, $(MCUS), \ $(foreach _f, $(DEADTIMES), \ $(foreach _p, $(filter-out $(subst L,96,$(_m)), $(PWM_FREQS)), \ $(eval $(call MAKE_OBJ,$(_t),$(_m),$(_f),$(_p))))))) HEX_TARGETS = $(OBJS:%.OBJ=$(HEX_DIR)/%.hex) all : $(HEX_TARGETS) @echo "\nbuild finished. built $(shell ls -Aq $(HEX_DIR) | wc -l) hex targets\n" $(OUTPUT_DIR)/%.OMF : $(OUTPUT_DIR)/%.OBJ $(eval LOG := $(LOG_DIR)/$(basename $(notdir $@)).log) @echo "LX51 : linking $< to $@" # Linking should produce exactly 1 warning @$(LX51) "$<" TO "$@" "$(LX51_FLAGS)" >> $(LOG) 2>&1; test $$? -lt 2 && grep -q "1 WARNING" $(LOG) || (tail $(LOG); exit 1) $(HEX_DIR)/%.hex : $(OUTPUT_DIR)/%.OMF $(eval LOG := $(LOG_DIR)/$(basename $(notdir $@)).log) @mkdir -p $(HEX_DIR) @echo "OHX : generating hex file $@" @$(OX51) "$<" "HEXFILE ($@)" >> $(LOG) 2>&1 || (tail $(LOG); exit 1) changelog: @npx -q commitlint --config .github/workflows/commitlint.config.js --from v0.1.0 @npx -q mathiasvr/generate-changelog --exclude build,chore,ci,docs,refactor,style,other help: @echo "" @echo "Usage examples" @echo "================================================================" @echo "make all # Build all targets" @echo "make LAYOUT=A MCU=H DEADTIME=5 PWM=24 # Build a single target" @echo clean: @rm -f $(OUTPUT_DIR)/*.{OBJ,MAP,OMF,LST} @rm -f $(LOG_DIR)/*.log efm8load: single_target $(EFM8_LOAD_BIN) -p $(EFM8_LOAD_PORT) -b $(EFM8_LOAD_BAUD) -w $(SINGLE_TARGET_HEX) .PHONY: single_target all changelog help clean efm8load