Fork from bluejay at github and modified for my custom ESC. I need to modify it because some mistake design on my ESC hardware.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 

134 lines
4.0 KiB

# Current version
VERSION ?= v0.8
# 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
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:
# Make sure the list of obj files is expanded twice
.SECONDEXPANSION:
OBJS =
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)
@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($$@) "\
"$(AX51_FLAGS)" > $(_LOG) 2>&1 || (grep "\*\*\* ERROR" Bluejay.LST; mv ./Bluejay.LST $(OUTPUT_DIR)/; exit 1)
@mv ./Bluejay.LST $(OUTPUT_DIR)/
endef
SINGLE_TARGET_HEX = $(HEX_DIR)/$(LAYOUT)_$(MCU)_$(DEADTIME)_$(PWM)_$(VERSION).hex
single_target : $(SINGLE_TARGET_HEX)
HEX_TARGETS = $(OBJS:%.OBJ=$(HEX_DIR)/%.hex)
all : $$(HEX_TARGETS)
@echo "\nbuild finished. built $(shell ls -Aq $(HEX_DIR) | wc -l) hex targets\n"
# 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)))))))
$(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