forked from forks/qmk_firmware
6169b47e82
* Add target 'build-for-compare' to `build_keyboard.mk` The `build-for-compare` target provides an easy way to check the md5 checksum of the generated binary. You can easily see if there is any change in the generated binaries between the two versions, as in the example below. ``` $ git checkout 0.11.0 M build_keyboard.mk M tmk_core/rules.mk Note: checking out '0.11.0'. HEAD is now atc66df1664
2020 November 28 Breaking Changes Update (#11053) $ make helix:all:build-for-compare | grep ^MD5 MD5 (.build/helix_rev2_default.hex) = 5c3606562c944bb4d18832e601b45d4a MD5 (.build/helix_rev2_edvorakjp.hex) = 9e43d13d389d518ba7e99cd7337e28d6 MD5 (.build/helix_rev2_five_rows.hex) = 8bcb61c2fd5d237c2997f2fa007d4934 MD5 (.build/helix_rev2_five_rows_jis.hex) = b97cd818d52f73ca2d4e78c86d90a791 MD5 (.build/helix_rev2_froggy.hex) = c492172364188f4e2918b10bf0f3a0a6 MD5 (.build/helix_rev2_froggy_106.hex) = b0861fd735a8f81881a8c02730641a2b MD5 (.build/helix_rev2_led_test.hex) = 5c97d982a5da5cfb3dacb28a8934b81d MD5 (.build/helix_rev2_xulkal.hex) = 01f603dc46bcf9094d7e106831d8f5b1 MD5 (.build/helix_rev2_yshrsmz.hex) = 5a008bca2d0c5790a151c02834c529ba $ git checkout 0.11.1 M build_keyboard.mk M tmk_core/rules.mk Previous HEAD position wasc66df1664
2020 November 28 Breaking Changes Update (#11053) HEAD is now atcc08e3082
nix-shell: add milc dependency (#11086) $ make helix:all:build-for-compare | grep ^MD5 MD5 (.build/helix_rev2_default.hex) = 5c3606562c944bb4d18832e601b45d4a MD5 (.build/helix_rev2_edvorakjp.hex) = 9e43d13d389d518ba7e99cd7337e28d6 MD5 (.build/helix_rev2_five_rows.hex) = 8bcb61c2fd5d237c2997f2fa007d4934 MD5 (.build/helix_rev2_five_rows_jis.hex) = b97cd818d52f73ca2d4e78c86d90a791 MD5 (.build/helix_rev2_froggy.hex) = c492172364188f4e2918b10bf0f3a0a6 MD5 (.build/helix_rev2_froggy_106.hex) = b0861fd735a8f81881a8c02730641a2b MD5 (.build/helix_rev2_led_test.hex) = 5c97d982a5da5cfb3dacb28a8934b81d MD5 (.build/helix_rev2_xulkal.hex) = d848383adfd7463b138c6da179cf1436 MD5 (.build/helix_rev2_yshrsmz.hex) = 5a008bca2d0c5790a151c02834c529ba ``` * make builds reproducable by default * update build_keyboard.mk: remove 'build-for-compare' target * GNU make (3.81) on macOS 10.14(Mojave) does not have the 'undefine' directive. * Adopted fauxpark's suggestion. * Update tmk_core/rules.mk Co-authored-by: Ryan <fauxpark@gmail.com> * update tmk_core/rules.mk * fix tmk_core/rules.mk Co-authored-by: Zach White <skullydazed@gmail.com> Co-authored-by: Ryan <fauxpark@gmail.com>
463 lines
15 KiB
Makefile
463 lines
15 KiB
Makefile
# Hey Emacs, this is a -*- makefile -*-
|
|
#----------------------------------------------------------------------------
|
|
# WinAVR Makefile Template written by Eric B. Weddington, Jg Wunsch, et al.
|
|
#
|
|
# Released to the Public Domain
|
|
#
|
|
# Additional material for this makefile was written by:
|
|
# Peter Fleury
|
|
# Tim Henigan
|
|
# Colin O'Flynn
|
|
# Reiner Patommel
|
|
# Markus Pfaff
|
|
# Sander Pool
|
|
# Frederik Rouleau
|
|
# Carlos Lamas
|
|
#
|
|
|
|
# Enable vpath seraching for source files only
|
|
# Without this, output files, could be read from the wrong .build directories
|
|
VPATH_SRC := $(VPATH)
|
|
vpath %.c $(VPATH_SRC)
|
|
vpath %.h $(VPATH_SRC)
|
|
vpath %.cpp $(VPATH_SRC)
|
|
vpath %.cc $(VPATH_SRC)
|
|
vpath %.hpp $(VPATH_SRC)
|
|
vpath %.S $(VPATH_SRC)
|
|
VPATH :=
|
|
|
|
# Convert all SRC to OBJ
|
|
define OBJ_FROM_SRC
|
|
$(patsubst %.c,$1/%.o,$(patsubst %.cpp,$1/%.o,$(patsubst %.cc,$1/%.o,$(patsubst %.S,$1/%.o,$(patsubst %.clib,$1/%.a,$($1_SRC))))))
|
|
endef
|
|
$(foreach OUTPUT,$(OUTPUTS),$(eval $(OUTPUT)_OBJ +=$(call OBJ_FROM_SRC,$(OUTPUT))))
|
|
|
|
# Define a list of all objects
|
|
OBJ := $(foreach OUTPUT,$(OUTPUTS),$($(OUTPUT)_OBJ))
|
|
NO_LTO_OBJ := $(filter %.a,$(OBJ))
|
|
|
|
MASTER_OUTPUT := $(firstword $(OUTPUTS))
|
|
|
|
|
|
|
|
# Output format. (can be srec, ihex, binary)
|
|
FORMAT = ihex
|
|
|
|
# Optimization level, can be [0, 1, 2, 3, s].
|
|
# 0 = turn off optimization. s = optimize for size.
|
|
# (Note: 3 is not always the best optimization level. See avr-libc FAQ.)
|
|
OPT ?= s
|
|
|
|
# Compiler flag to set the C Standard level.
|
|
# c89 = "ANSI" C
|
|
# gnu89 = c89 plus GCC extensions
|
|
# c99 = ISO C99 standard (not yet fully implemented)
|
|
# gnu99 = c99 plus GCC extensions
|
|
CSTANDARD = -std=gnu99
|
|
|
|
|
|
# Place -D or -U options here for C sources
|
|
#CDEFS +=
|
|
|
|
|
|
# Place -D or -U options here for ASM sources
|
|
#ADEFS +=
|
|
|
|
|
|
# Place -D or -U options here for C++ sources
|
|
#CXXDEFS += -D__STDC_LIMIT_MACROS
|
|
#CXXDEFS += -D__STDC_CONSTANT_MACROS
|
|
#CXXDEFS +=
|
|
|
|
|
|
|
|
|
|
#---------------- Compiler Options C ----------------
|
|
# -g*: generate debugging information
|
|
# -O*: optimization level
|
|
# -f...: tuning, see GCC manual and avr-libc documentation
|
|
# -Wall...: warning level
|
|
# -Wa,...: tell GCC to pass this to the assembler.
|
|
# -adhlns...: create assembler listing
|
|
DEBUG_ENABLE ?= yes
|
|
ifeq ($(strip $(SKIP_DEBUG_INFO)),yes)
|
|
DEBUG_ENABLE=no
|
|
endif
|
|
|
|
ifeq ($(strip $(DEBUG_ENABLE)),yes)
|
|
CFLAGS += -g$(DEBUG)
|
|
endif
|
|
CFLAGS += $(CDEFS)
|
|
CFLAGS += -O$(OPT)
|
|
# add color
|
|
ifeq ($(COLOR),true)
|
|
ifeq ("$(shell echo "int main(){}" | $(CC) -fdiagnostics-color -x c - -o /dev/null 2>&1)", "")
|
|
CFLAGS+= -fdiagnostics-color
|
|
endif
|
|
endif
|
|
CFLAGS += -Wall
|
|
CFLAGS += -Wstrict-prototypes
|
|
ifneq ($(strip $(ALLOW_WARNINGS)), yes)
|
|
CFLAGS += -Werror
|
|
endif
|
|
#CFLAGS += -mshort-calls
|
|
#CFLAGS += -fno-unit-at-a-time
|
|
#CFLAGS += -Wundef
|
|
#CFLAGS += -Wunreachable-code
|
|
#CFLAGS += -Wsign-compare
|
|
CFLAGS += -Wa,-adhlns=$(@:%.o=%.lst)
|
|
CFLAGS += $(CSTANDARD)
|
|
|
|
#---------------- Compiler Options C++ ----------------
|
|
# -g*: generate debugging information
|
|
# -O*: optimization level
|
|
# -f...: tuning, see GCC manual and avr-libc documentation
|
|
# -Wall...: warning level
|
|
# -Wa,...: tell GCC to pass this to the assembler.
|
|
# -adhlns...: create assembler listing
|
|
ifeq ($(strip $(DEBUG_ENABLE)),yes)
|
|
CXXFLAGS += -g$(DEBUG)
|
|
endif
|
|
CXXFLAGS += $(CXXDEFS)
|
|
CXXFLAGS += -O$(OPT)
|
|
# to supress "warning: only initialized variables can be placed into program memory area"
|
|
CXXFLAGS += -w
|
|
CXXFLAGS += -Wall
|
|
CXXFLAGS += -Wundef
|
|
ifneq ($(strip $(ALLOW_WARNINGS)), yes)
|
|
CXXFLAGS += -Werror
|
|
endif
|
|
#CXXFLAGS += -mshort-calls
|
|
#CXXFLAGS += -fno-unit-at-a-time
|
|
#CXXFLAGS += -Wstrict-prototypes
|
|
#CXXFLAGS += -Wunreachable-code
|
|
#CXXFLAGS += -Wsign-compare
|
|
CXXFLAGS += -Wa,-adhlns=$(@:%.o=%.lst)
|
|
#CXXFLAGS += $(CSTANDARD)
|
|
|
|
#---------------- Assembler Options ----------------
|
|
# -Wa,...: tell GCC to pass this to the assembler.
|
|
# -adhlns: create listing
|
|
# -gstabs: have the assembler create line number information; note that
|
|
# for use in COFF files, additional information about filenames
|
|
# and function names needs to be present in the assembler source
|
|
# files -- see avr-libc docs [FIXME: not yet described there]
|
|
# -listing-cont-lines: Sets the maximum number of continuation lines of hex
|
|
# dump that will be displayed for a given single line of source input.
|
|
ASFLAGS += $(ADEFS)
|
|
ifeq ($(strip $(DEBUG_ENABLE)),yes)
|
|
ASFLAGS += -Wa,-adhlns=$(@:%.o=%.lst),-gstabs,--listing-cont-lines=100
|
|
else
|
|
ASFLAGS += -Wa,-adhlns=$(@:%.o=%.lst),--listing-cont-lines=100
|
|
endif
|
|
|
|
#---------------- Library Options ----------------
|
|
# Minimalistic printf version
|
|
PRINTF_LIB_MIN = -Wl,-u,vfprintf -lprintf_min
|
|
|
|
# Floating point printf version (requires MATH_LIB = -lm below)
|
|
PRINTF_LIB_FLOAT = -Wl,-u,vfprintf -lprintf_flt
|
|
|
|
# If this is left blank, then it will use the Standard printf version.
|
|
PRINTF_LIB =
|
|
#PRINTF_LIB = $(PRINTF_LIB_MIN)
|
|
#PRINTF_LIB = $(PRINTF_LIB_FLOAT)
|
|
|
|
|
|
# Minimalistic scanf version
|
|
SCANF_LIB_MIN = -Wl,-u,vfscanf -lscanf_min
|
|
|
|
# Floating point + %[ scanf version (requires MATH_LIB = -lm below)
|
|
SCANF_LIB_FLOAT = -Wl,-u,vfscanf -lscanf_flt
|
|
|
|
# If this is left blank, then it will use the Standard scanf version.
|
|
SCANF_LIB =
|
|
#SCANF_LIB = $(SCANF_LIB_MIN)
|
|
#SCANF_LIB = $(SCANF_LIB_FLOAT)
|
|
|
|
|
|
MATH_LIB = -lm
|
|
CREATE_MAP ?= yes
|
|
|
|
|
|
#---------------- Linker Options ----------------
|
|
# -Wl,...: tell GCC to pass this to linker.
|
|
# -Map: create map file
|
|
# --cref: add cross reference to map file
|
|
#
|
|
# Comennt out "--relax" option to avoid a error such:
|
|
# (.vectors+0x30): relocation truncated to fit: R_AVR_13_PCREL against symbol `__vector_12'
|
|
#
|
|
|
|
ifeq ($(CREATE_MAP),yes)
|
|
LDFLAGS += -Wl,-Map=$(BUILD_DIR)/$(TARGET).map,--cref
|
|
endif
|
|
#LDFLAGS += -Wl,--relax
|
|
LDFLAGS += $(EXTMEMOPTS)
|
|
LDFLAGS += $(patsubst %,-L%,$(EXTRALIBDIRS))
|
|
LDFLAGS += $(PRINTF_LIB) $(SCANF_LIB) $(MATH_LIB)
|
|
#LDFLAGS += -T linker_script.x
|
|
# You can give EXTRALDFLAGS at 'make' command line.
|
|
LDFLAGS += $(EXTRALDFLAGS)
|
|
|
|
# Define programs and commands.
|
|
SHELL = sh
|
|
REMOVE = rm -f
|
|
REMOVEDIR = rmdir
|
|
COPY = cp
|
|
WINSHELL = cmd
|
|
SECHO = $(SILENT) || echo
|
|
MD5SUM ?= md5sum
|
|
ifneq ($(filter Darwin FreeBSD,$(shell uname -s)),)
|
|
MD5SUM = md5
|
|
endif
|
|
|
|
# Compiler flags to generate dependency files.
|
|
#GENDEPFLAGS = -MMD -MP -MF .dep/$(@F).d
|
|
GENDEPFLAGS = -MMD -MP -MF $(patsubst %.o,%.td,$@)
|
|
|
|
|
|
# Combine all necessary flags and optional flags.
|
|
# Add target processor to flags.
|
|
# You can give extra flags at 'make' command line like: make EXTRAFLAGS=-DFOO=bar
|
|
ALL_CFLAGS = $(MCUFLAGS) $(CFLAGS) $(EXTRAFLAGS)
|
|
ALL_CXXFLAGS = $(MCUFLAGS) -x c++ $(CXXFLAGS) $(EXTRAFLAGS)
|
|
ALL_ASFLAGS = $(MCUFLAGS) -x assembler-with-cpp $(ASFLAGS) $(EXTRAFLAGS)
|
|
|
|
define NO_LTO
|
|
$(patsubst %.a,%.o,$1): NOLTO_CFLAGS += -fno-lto
|
|
endef
|
|
$(foreach LOBJ, $(NO_LTO_OBJ), $(eval $(call NO_LTO,$(LOBJ))))
|
|
|
|
MOVE_DEP = mv -f $(patsubst %.o,%.td,$@) $(patsubst %.o,%.d,$@)
|
|
|
|
# For a ChibiOS build, ensure that the board files have the hook overrides injected
|
|
define BOARDSRC_INJECT_HOOKS
|
|
$(KEYBOARD_OUTPUT)/$(patsubst %.c,%.o,$(patsubst ./%,%,$1)): INIT_HOOK_CFLAGS += -include $(TOP_DIR)/tmk_core/protocol/chibios/init_hooks.h
|
|
endef
|
|
$(foreach LOBJ, $(BOARDSRC), $(eval $(call BOARDSRC_INJECT_HOOKS,$(LOBJ))))
|
|
|
|
# Add QMK specific flags
|
|
DFU_SUFFIX ?= dfu-suffix
|
|
DFU_SUFFIX_ARGS ?=
|
|
|
|
|
|
elf: $(BUILD_DIR)/$(TARGET).elf
|
|
hex: $(BUILD_DIR)/$(TARGET).hex
|
|
cpfirmware: $(FIRMWARE_FORMAT)
|
|
$(SILENT) || printf "Copying $(TARGET).$(FIRMWARE_FORMAT) to qmk_firmware folder" | $(AWK_CMD)
|
|
$(COPY) $(BUILD_DIR)/$(TARGET).$(FIRMWARE_FORMAT) $(TARGET).$(FIRMWARE_FORMAT) && $(PRINT_OK)
|
|
eep: $(BUILD_DIR)/$(TARGET).eep
|
|
lss: $(BUILD_DIR)/$(TARGET).lss
|
|
sym: $(BUILD_DIR)/$(TARGET).sym
|
|
LIBNAME=lib$(TARGET).a
|
|
lib: $(LIBNAME)
|
|
|
|
# Display size of file.
|
|
HEXSIZE = $(SIZE) --target=$(FORMAT) $(BUILD_DIR)/$(TARGET).hex
|
|
#ELFSIZE = $(SIZE) --mcu=$(MCU) --format=avr $(TARGET).elf
|
|
ELFSIZE = $(SIZE) $(BUILD_DIR)/$(TARGET).elf
|
|
|
|
sizebefore:
|
|
@if test -f $(BUILD_DIR)/$(TARGET).hex; then $(SECHO) $(MSG_SIZE_BEFORE); $(SILENT) || $(HEXSIZE); \
|
|
2>/dev/null; $(SECHO); fi
|
|
|
|
sizeafter: $(BUILD_DIR)/$(TARGET).hex
|
|
@if test -f $(BUILD_DIR)/$(TARGET).hex; then $(SECHO); $(SECHO) $(MSG_SIZE_AFTER); $(SILENT) || $(HEXSIZE); \
|
|
2>/dev/null; $(SECHO); fi
|
|
|
|
# Display compiler version information.
|
|
gccversion :
|
|
@$(SILENT) || $(CC) --version
|
|
|
|
# Create final output files (.hex, .eep) from ELF output file.
|
|
%.hex: %.elf
|
|
@$(SILENT) || printf "$(MSG_FLASH) $@" | $(AWK_CMD)
|
|
$(eval CMD=$(HEX) $< $@)
|
|
@$(BUILD_CMD)
|
|
|
|
%.eep: %.elf
|
|
@$(SILENT) || printf "$(MSG_EEPROM) $@" | $(AWK_CMD)
|
|
$(eval CMD=$(EEP) $< $@ || exit 0)
|
|
@$(BUILD_CMD)
|
|
|
|
# Create extended listing file from ELF output file.
|
|
%.lss: %.elf
|
|
@$(SILENT) || printf "$(MSG_EXTENDED_LISTING) $@" | $(AWK_CMD)
|
|
$(eval CMD=$(OBJDUMP) -h -S -z $< > $@)
|
|
@$(BUILD_CMD)
|
|
|
|
# Create a symbol table from ELF output file.
|
|
%.sym: %.elf
|
|
@$(SILENT) || printf "$(MSG_SYMBOL_TABLE) $@" | $(AWK_CMD)
|
|
$(eval CMD=$(NM) -n $< > $@ )
|
|
@$(BUILD_CMD)
|
|
|
|
%.bin: %.elf
|
|
@$(SILENT) || printf "$(MSG_BIN) $@" | $(AWK_CMD)
|
|
$(eval CMD=$(BIN) $< $@ || exit 0)
|
|
@$(BUILD_CMD)
|
|
if [ ! -z "$(DFU_SUFFIX_ARGS)" ]; then \
|
|
$(DFU_SUFFIX) $(DFU_SUFFIX_ARGS) -a $(BUILD_DIR)/$(TARGET).bin 1>/dev/null ;\
|
|
fi
|
|
$(COPY) $(BUILD_DIR)/$(TARGET).bin $(TARGET).bin;
|
|
|
|
BEGIN = gccversion sizebefore
|
|
|
|
# Link: create ELF output file from object files.
|
|
.SECONDARY : $(BUILD_DIR)/$(TARGET).elf
|
|
.PRECIOUS : $(OBJ)
|
|
# Note the obj.txt depeendency is there to force linking if a source file is deleted
|
|
%.elf: $(OBJ) $(MASTER_OUTPUT)/cflags.txt $(MASTER_OUTPUT)/ldflags.txt $(MASTER_OUTPUT)/obj.txt | $(BEGIN)
|
|
@$(SILENT) || printf "$(MSG_LINKING) $@" | $(AWK_CMD)
|
|
$(eval CMD=$(CC) $(ALL_CFLAGS) $(filter-out %.txt,$^) --output $@ $(LDFLAGS))
|
|
@$(BUILD_CMD)
|
|
|
|
|
|
define GEN_OBJRULE
|
|
$1_INCFLAGS := $$(patsubst %,-I%,$$($1_INC))
|
|
ifdef $1_CONFIG
|
|
$1_CONFIG_FLAGS += $$(patsubst %,-include %,$$($1_CONFIG))
|
|
endif
|
|
$1_CFLAGS = $$(ALL_CFLAGS) $$($1_DEFS) $$($1_INCFLAGS) $$($1_CONFIG_FLAGS) $$(NOLTO_CFLAGS)
|
|
$1_CXXFLAGS = $$(ALL_CXXFLAGS) $$($1_DEFS) $$($1_INCFLAGS) $$($1_CONFIG_FLAGS) $$(NOLTO_CFLAGS)
|
|
$1_ASFLAGS = $$(ALL_ASFLAGS) $$($1_DEFS) $$($1_INCFLAGS) $$($1_CONFIG_FLAGS)
|
|
|
|
# Compile: create object files from C source files.
|
|
$1/%.o : %.c $1/%.d $1/cflags.txt $1/compiler.txt | $(BEGIN)
|
|
@mkdir -p $$(@D)
|
|
@$$(SILENT) || printf "$$(MSG_COMPILING) $$<" | $$(AWK_CMD)
|
|
$$(eval CMD := $$(CC) -c $$($1_CFLAGS) $$(INIT_HOOK_CFLAGS) $$(GENDEPFLAGS) $$< -o $$@ && $$(MOVE_DEP))
|
|
@$$(BUILD_CMD)
|
|
|
|
# Compile: create object files from C++ source files.
|
|
$1/%.o : %.cpp $1/%.d $1/cxxflags.txt $1/compiler.txt | $(BEGIN)
|
|
@mkdir -p $$(@D)
|
|
@$$(SILENT) || printf "$$(MSG_COMPILING_CXX) $$<" | $$(AWK_CMD)
|
|
$$(eval CMD=$$(CC) -c $$($1_CXXFLAGS) $$(INIT_HOOK_CFLAGS) $$(GENDEPFLAGS) $$< -o $$@ && $$(MOVE_DEP))
|
|
@$$(BUILD_CMD)
|
|
|
|
$1/%.o : %.cc $1/%.d $1/cxxflags.txt $1/compiler.txt | $(BEGIN)
|
|
@mkdir -p $$(@D)
|
|
@$$(SILENT) || printf "$$(MSG_COMPILING_CXX) $$<" | $$(AWK_CMD)
|
|
$$(eval CMD=$$(CC) -c $$($1_CXXFLAGS) $$(INIT_HOOK_CFLAGS) $$(GENDEPFLAGS) $$< -o $$@ && $$(MOVE_DEP))
|
|
@$$(BUILD_CMD)
|
|
|
|
# Assemble: create object files from assembler source files.
|
|
$1/%.o : %.S $1/asflags.txt $1/compiler.txt | $(BEGIN)
|
|
@mkdir -p $$(@D)
|
|
@$(SILENT) || printf "$$(MSG_ASSEMBLING) $$<" | $$(AWK_CMD)
|
|
$$(eval CMD=$$(CC) -c $$($1_ASFLAGS) $$< -o $$@)
|
|
@$$(BUILD_CMD)
|
|
|
|
$1/%.a : $1/%.o
|
|
@mkdir -p $$(@D)
|
|
@$(SILENT) || printf "Archiving: $$<" | $$(AWK_CMD)
|
|
$$(eval CMD=$$(AR) rcs $$@ $$<)
|
|
@$$(BUILD_CMD)
|
|
|
|
$1/force:
|
|
|
|
$1/cflags.txt: $1/force
|
|
echo '$$($1_CFLAGS)' | cmp -s - $$@ || echo '$$($1_CFLAGS)' > $$@
|
|
|
|
$1/cxxflags.txt: $1/force
|
|
echo '$$($1_CXXFLAGS)' | cmp -s - $$@ || echo '$$($1_CXXFLAGS)' > $$@
|
|
|
|
$1/asflags.txt: $1/force
|
|
echo '$$($1_ASFLAGS)' | cmp -s - $$@ || echo '$$($1_ASFLAGS)' > $$@
|
|
|
|
$1/compiler.txt: $1/force
|
|
$$(CC) --version | cmp -s - $$@ || $$(CC) --version > $$@
|
|
endef
|
|
|
|
.PRECIOUS: $(MASTER_OUTPUT)/obj.txt
|
|
$(MASTER_OUTPUT)/obj.txt: $(MASTER_OUTPUT)/force
|
|
echo '$(OBJ)' | cmp -s - $@ || echo '$(OBJ)' > $@
|
|
|
|
.PRECIOUS: $(MASTER_OUTPUT)/ldflags.txt
|
|
$(MASTER_OUTPUT)/ldflags.txt: $(MASTER_OUTPUT)/force
|
|
echo '$(LDFLAGS)' | cmp -s - $@ || echo '$(LDFLAGS)' > $@
|
|
|
|
|
|
# We have to use static rules for the .d files for some reason
|
|
DEPS = $(patsubst %.o,%.d,$(patsubst %.a,%.o,$(OBJ)))
|
|
# Keep the .d files
|
|
.PRECIOUS: $(DEPS)
|
|
# Empty rule to force recompilation if the .d file is missing
|
|
$(DEPS):
|
|
|
|
|
|
$(foreach OUTPUT,$(OUTPUTS),$(eval $(call GEN_OBJRULE,$(OUTPUT))))
|
|
|
|
# Create preprocessed source for use in sending a bug report.
|
|
%.i : %.c | $(BEGIN)
|
|
$(CC) -E -mmcu=$(MCU) $(CFLAGS) $< -o $@
|
|
|
|
# Target: clean project.
|
|
clean:
|
|
$(foreach OUTPUT,$(OUTPUTS), $(REMOVE) -r $(OUTPUT) 2>/dev/null)
|
|
$(REMOVE) $(BUILD_DIR)/$(TARGET).*
|
|
|
|
show_path:
|
|
@echo VPATH=$(VPATH)
|
|
@echo SRC=$(SRC)
|
|
@echo OBJ=$(OBJ)
|
|
|
|
dump_vars: ERROR_IF_EMPTY=""
|
|
dump_vars: ERROR_IF_NONBOOL=""
|
|
dump_vars: ERROR_IF_UNSET=""
|
|
dump_vars:
|
|
@$(foreach V,$(sort $(.VARIABLES)),$(if $(filter-out environment% default automatic,$(origin $V)),$(info $V=$($V))))
|
|
|
|
objs-size:
|
|
for i in $(OBJ); do echo $$i; done | sort | xargs $(SIZE)
|
|
|
|
ifeq ($(findstring avr-gcc,$(CC)),avr-gcc)
|
|
SIZE_MARGIN = 1024
|
|
|
|
check-size:
|
|
$(eval MAX_SIZE=$(shell n=`$(CC) -E -mmcu=$(MCU) $(CFLAGS) $(OPT_DEFS) tmk_core/common/avr/bootloader_size.c 2> /dev/null | sed -ne 's/\r//;/^#/n;/^AVR_SIZE:/,$${s/^AVR_SIZE: //;p;}'` && echo $$(($$n)) || echo 0))
|
|
$(eval CURRENT_SIZE=$(shell if [ -f $(BUILD_DIR)/$(TARGET).hex ]; then $(SIZE) --target=$(FORMAT) $(BUILD_DIR)/$(TARGET).hex | $(AWK) 'NR==2 {print $$4}'; else printf 0; fi))
|
|
$(eval FREE_SIZE=$(shell expr $(MAX_SIZE) - $(CURRENT_SIZE)))
|
|
$(eval OVER_SIZE=$(shell expr $(CURRENT_SIZE) - $(MAX_SIZE)))
|
|
$(eval PERCENT_SIZE=$(shell expr $(CURRENT_SIZE) \* 100 / $(MAX_SIZE)))
|
|
if [ $(MAX_SIZE) -gt 0 ] && [ $(CURRENT_SIZE) -gt 0 ]; then \
|
|
$(SILENT) || printf "$(MSG_CHECK_FILESIZE)" | $(AWK_CMD); \
|
|
if [ $(CURRENT_SIZE) -gt $(MAX_SIZE) ]; then \
|
|
printf "\n * $(MSG_FILE_TOO_BIG)"; $(PRINT_ERROR_PLAIN); \
|
|
else \
|
|
if [ $(FREE_SIZE) -lt $(SIZE_MARGIN) ]; then \
|
|
$(PRINT_WARNING_PLAIN); printf " * $(MSG_FILE_NEAR_LIMIT)"; \
|
|
else \
|
|
$(PRINT_OK); $(SILENT) || printf " * $(MSG_FILE_JUST_RIGHT)"; \
|
|
fi \
|
|
fi \
|
|
fi
|
|
else
|
|
check-size:
|
|
$(SILENT) || echo "(Firmware size check does not yet support $(MCU) microprocessors; skipping.)"
|
|
endif
|
|
|
|
check-md5:
|
|
$(MD5SUM) $(BUILD_DIR)/$(TARGET).$(FIRMWARE_FORMAT)
|
|
|
|
# Create build directory
|
|
$(shell mkdir -p $(BUILD_DIR) 2>/dev/null)
|
|
|
|
# Create object files directory
|
|
$(eval $(foreach OUTPUT,$(OUTPUTS),$(shell mkdir -p $(OUTPUT) 2>/dev/null)))
|
|
|
|
# Include the dependency files.
|
|
-include $(patsubst %.o,%.d,$(patsubst %.a,%.o,$(OBJ)))
|
|
|
|
|
|
# Listing of phony targets.
|
|
.PHONY : all dump_vars finish sizebefore sizeafter qmkversion \
|
|
gccversion build elf hex eep lss sym coff extcoff \
|
|
clean clean_list debug gdb-config show_path \
|
|
program teensy dfu dfu-ee dfu-start \
|
|
flash dfu-split-left dfu-split-right \
|
|
avrdude-split-left avrdude-split-right \
|
|
avrdude-loop usbasp
|