Make build output quieter.

Use make V=1e make V=1 or set BUILD_VERBOSE in your environment to increase build verbosity.

This should fix issue #117
This commit is contained in:
Dave Hylands 2014-01-08 10:15:39 -08:00
parent 6c73ca1e75
commit 4646801181
5 changed files with 91 additions and 36 deletions

View File

@ -1,3 +1,28 @@
##########
# The following should eventually go into a more central location
# when a reorg is done.
#
# Turn on increased build verbosity by defining BUILD_VERBOSE in your main
# Makefile or in your environment. You can also use V=1 on the make command
# line.
ifeq ("$(origin V)", "command line")
BUILD_VERBOSE=$(V)
endif
ifndef BUILD_VERBOSE
BUILD_VERBOSE = 0
endif
ifeq ($(BUILD_VERBOSE),0)
Q = @
else
Q =
endif
# Since this is a new feature, advertise it
ifeq ($(BUILD_VERBOSE),0)
$(info Use make V=1 or set BUILD_VERBOSE in your environment to increase build verbosity.)
endif
#
#########
# default settings; can be overriden in main Makefile # default settings; can be overriden in main Makefile
ifndef PY_SRC ifndef PY_SRC
@ -11,7 +36,7 @@ endif
# to create the build directory # to create the build directory
$(BUILD): $(BUILD):
mkdir -p $@ $(Q)mkdir -p $@
# where py object files go (they have a name prefix to prevent filename clashes) # where py object files go (they have a name prefix to prevent filename clashes)
@ -80,24 +105,30 @@ PY_O_BASENAME = \
PY_O = $(addprefix $(PY_BUILD), $(PY_O_BASENAME)) PY_O = $(addprefix $(PY_BUILD), $(PY_O_BASENAME))
$(PY_BUILD)emitnx64.o: $(PY_SRC)/emitnative.c $(PY_SRC)/emit.h mpconfigport.h $(PY_BUILD)emitnx64.o: $(PY_SRC)/emitnative.c $(PY_SRC)/emit.h mpconfigport.h
$(CC) $(CFLAGS) -DN_X64 -c -o $@ $< $(ECHO) "CC $<"
$(Q)$(CC) $(CFLAGS) -DN_X64 -c -o $@ $<
$(PY_BUILD)emitnthumb.o: $(PY_SRC)/emitnative.c $(PY_SRC)/emit.h mpconfigport.h $(PY_BUILD)emitnthumb.o: $(PY_SRC)/emitnative.c $(PY_SRC)/emit.h mpconfigport.h
$(CC) $(CFLAGS) -DN_THUMB -c -o $@ $< $(ECHO) "CC $<"
$(Q)$(CC) $(CFLAGS) -DN_THUMB -c -o $@ $<
$(PY_BUILD)%.o: $(PY_SRC)/%.S $(PY_BUILD)%.o: $(PY_SRC)/%.S
$(CC) $(CFLAGS) -c -o $@ $< $(ECHO) "CC $<"
$(Q)$(CC) $(CFLAGS) -c -o $@ $<
$(PY_BUILD)%.o: $(PY_SRC)/%.c mpconfigport.h $(PY_BUILD)%.o: $(PY_SRC)/%.c mpconfigport.h
$(CC) $(CFLAGS) -c -o $@ $< $(ECHO) "CC $<"
$(Q)$(CC) $(CFLAGS) -c -o $@ $<
# optimising gc for speed; 5ms down to 4ms on pybv2 # optimising gc for speed; 5ms down to 4ms on pybv2
$(PY_BUILD)gc.o: $(PY_SRC)/gc.c $(PY_BUILD)gc.o: $(PY_SRC)/gc.c
$(CC) $(CFLAGS) -O3 -c -o $@ $< $(ECHO) "CC $<"
$(Q)$(CC) $(CFLAGS) -O3 -c -o $@ $<
# optimising vm for speed, adds only a small amount to code size but makes a huge difference to speed (20% faster) # optimising vm for speed, adds only a small amount to code size but makes a huge difference to speed (20% faster)
$(PY_BUILD)vm.o: $(PY_SRC)/vm.c $(PY_BUILD)vm.o: $(PY_SRC)/vm.c
$(CC) $(CFLAGS) -O3 -c -o $@ $< $(ECHO) "CC $<"
$(Q)$(CC) $(CFLAGS) -O3 -c -o $@ $<
# header dependencies # header dependencies

View File

@ -6,6 +6,7 @@ include ../py/py.mk
# program for deletion # program for deletion
RM = /bin/rm RM = /bin/rm
ECHO = @echo
STMSRC=lib STMSRC=lib
#STMOTGSRC=lib-otg #STMOTGSRC=lib-otg
@ -115,35 +116,43 @@ OBJ = $(addprefix $(BUILD)/, $(SRC_C:.c=.o) $(SRC_S:.s=.o) $(SRC_FATFS:.c=.o) $(
all2: $(BUILD) $(BUILD)/flash.dfu all2: $(BUILD) $(BUILD)/flash.dfu
$(BUILD)/flash.dfu: $(BUILD)/flash0.bin $(BUILD)/flash1.bin $(BUILD)/flash.dfu: $(BUILD)/flash0.bin $(BUILD)/flash1.bin
python $(DFU) -b 0x08000000:$(BUILD)/flash0.bin -b 0x08020000:$(BUILD)/flash1.bin $@ $(ECHO) "Create $@"
$(Q)python $(DFU) -b 0x08000000:$(BUILD)/flash0.bin -b 0x08020000:$(BUILD)/flash1.bin $@
$(BUILD)/flash0.bin: $(BUILD)/flash.elf $(BUILD)/flash0.bin: $(BUILD)/flash.elf
$(OBJCOPY) -O binary -j .isr_vector $^ $@ $(Q)$(OBJCOPY) -O binary -j .isr_vector $^ $@
$(BUILD)/flash1.bin: $(BUILD)/flash.elf $(BUILD)/flash1.bin: $(BUILD)/flash.elf
$(OBJCOPY) -O binary -j .text -j .data $^ $@ $(Q)$(OBJCOPY) -O binary -j .text -j .data $^ $@
$(BUILD)/flash.elf: $(OBJ) $(BUILD)/flash.elf: $(OBJ)
$(LD) $(LDFLAGS) -o $@ $(OBJ) $(ECHO) "LINK $@"
$(SIZE) $@ $(Q)$(LD) $(LDFLAGS) -o $@ $(OBJ)
$(Q)$(SIZE) $@
$(BUILD)/%.o: %.s $(BUILD)/%.o: %.s
$(AS) -o $@ $< $(ECHO) "AS $<"
$(Q)$(AS) -o $@ $<
$(BUILD)/%.o: %.c $(BUILD)/%.o: %.c
$(CC) $(CFLAGS) -c -o $@ $< $(ECHO) "CC $<"
$(Q)$(CC) $(CFLAGS) -c -o $@ $<
$(BUILD)/%.o: $(FATFSSRC)/%.c $(BUILD)/%.o: $(FATFSSRC)/%.c
$(CC) $(CFLAGS) -c -o $@ $< $(ECHO) "CC $<"
$(Q)$(CC) $(CFLAGS) -c -o $@ $<
$(BUILD)/%.o: $(STMSRC)/%.c $(BUILD)/%.o: $(STMSRC)/%.c
$(CC) $(CFLAGS) -c -o $@ $< $(ECHO) "CC $<"
$(Q)$(CC) $(CFLAGS) -c -o $@ $<
#$(BUILD)/%.o: $(STMOTGSRC)/%.c #$(BUILD)/%.o: $(STMOTGSRC)/%.c
# $(CC) $(CFLAGS) -c -o $@ $< # $(ECHO) "CC $<"
# $(Q)$(CC) $(CFLAGS) -c -o $@ $<
$(BUILD)/%.o: $(CC3KSRC)/%.c $(BUILD)/%.o: $(CC3KSRC)/%.c
$(CC) $(CFLAGS) -c -o $@ $< $(ECHO) "CC $<"
$(Q)$(CC) $(CFLAGS) -c -o $@ $<
clean: clean:
$(RM) -rf $(BUILD) $(RM) -rf $(BUILD)

View File

@ -6,6 +6,7 @@ include ../py/py.mk
# program for deletion # program for deletion
RM = /bin/rm RM = /bin/rm
ECHO = @echo
ifeq ($(ARDUINO),) ifeq ($(ARDUINO),)
$(error Please define ARDUINO (where TeensyDuino is installed)) $(error Please define ARDUINO (where TeensyDuino is installed))
@ -62,35 +63,43 @@ all2: $(BUILD) hex
hex: $(BUILD)/flash.hex hex: $(BUILD)/flash.hex
post_compile: $(BUILD)/flash.hex post_compile: $(BUILD)/flash.hex
$(TOOLS_PATH)/teensy_post_compile -file="$(basename $<)" -path="$(BUILD)" -tools="$(TOOLS_PATH)" $(ECHO) "Preparing $@ for upload"
$(Q)$(TOOLS_PATH)/teensy_post_compile -file="$(basename $(<F))" -path="$(<D)" -tools="$(TOOLS_PATH)"
reboot: reboot:
-$(TOOLS_PATH)/teensy_reboot $(ECHO) "REBOOT"
-$(Q)$(TOOLS_PATH)/teensy_reboot
upload: post_compile reboot upload: post_compile reboot
$(BUILD)/flash.elf: $(OBJ) $(BUILD)/flash.elf: $(OBJ)
$(CC) $(LDFLAGS) -o "$@" -Wl,-Map,$(@:.elf=.map) $(OBJ) $(LIBS) $(ECHO) "LINK $<"
$(SIZE) $@ $(Q)$(CC) $(LDFLAGS) -o "$@" -Wl,-Map,$(@:.elf=.map) $(OBJ) $(LIBS)
$(Q)$(SIZE) $@
$(BUILD)/%.hex: $(BUILD)/%.elf $(BUILD)/%.hex: $(BUILD)/%.elf
$(OBJCOPY) -O ihex -R .eeprom "$<" "$@" $(ECHO) "HEX $<"
$(Q)$(OBJCOPY) -O ihex -R .eeprom "$<" "$@"
$(BUILD)/%.o: %.c $(BUILD)/%.o: %.c
$(CC) $(CFLAGS) -c -o $@ $< $(ECHO) "CC $<"
$(Q)$(CC) $(CFLAGS) -c -o $@ $<
$(BUILD)/%.o: ../stm/%.s $(BUILD)/%.o: ../stm/%.s
$(AS) -o $@ $< $(ECHO) "AS $<"
$(Q)$(AS) -o $@ $<
$(BUILD)/%.o: ../stm/%.c $(BUILD)/%.o: ../stm/%.c
$(CC) $(CFLAGS) -c -o $@ $< $(ECHO) "CC $<"
$(Q)$(CC) $(CFLAGS) -c -o $@ $<
$(BUILD)/%.o: $(CORE_PATH)/%.c $(BUILD)/%.o: $(CORE_PATH)/%.c
$(CC) $(CFLAGS) -c -o $@ $< $(ECHO) "CC $<"
$(Q)$(CC) $(CFLAGS) -c -o $@ $<
$(BUILD)/main.o: mpconfigport.h $(BUILD)/main.o: mpconfigport.h
clean: clean:
/bin/rm -rf $(BUILD) $(RM) -rf $(BUILD)
.PHONY: all all2 clean .PHONY: all all2 clean

View File

@ -7,6 +7,7 @@ include ../py/py.mk
# program for deletion # program for deletion
RM = /bin/rm RM = /bin/rm
ECHO = @echo
# compiler settings # compiler settings
CC = gcc CC = gcc
@ -21,12 +22,14 @@ OBJ = $(addprefix $(BUILD)/, $(SRC_C:.c=.o)) $(PY_O)
LIB = LIB =
$(PROG): $(BUILD) $(OBJ) $(PROG): $(BUILD) $(OBJ)
$(CC) -o $@ $(OBJ) $(LIB) $(LDFLAGS) $(ECHO) "LINK $<"
strip $(PROG) $(Q)$(CC) -o $@ $(OBJ) $(LIB) $(LDFLAGS)
size $(PROG) $(Q)strip $(PROG)
$(Q)size $(PROG)
$(BUILD)/%.o: %.c $(BUILD)/%.o: %.c
$(CC) $(CFLAGS) -c -o $@ $< $(ECHO) "CC $<"
$(Q)$(CC) $(CFLAGS) -c -o $@ $<
$(BUILD)/main.o: mpconfigport.h $(BUILD)/main.o: mpconfigport.h

View File

@ -7,6 +7,7 @@ include ../py/py.mk
# program for deletion # program for deletion
RM = /bin/rm RM = /bin/rm
ECHO = @echo
# compiler settings # compiler settings
CC = gcc CC = gcc
@ -24,12 +25,14 @@ LIB = -lreadline
#LIB += -ltermcap #LIB += -ltermcap
$(PROG): $(BUILD) $(OBJ) $(PROG): $(BUILD) $(OBJ)
$(CC) -o $@ $(OBJ) $(LIB) $(LDFLAGS) $(ECHO) "LINK $<"
strip $(PROG) $(Q)$(CC) -o $@ $(OBJ) $(LIB) $(LDFLAGS)
size $(PROG) $(Q)strip $(PROG)
$(Q)size $(PROG)
$(BUILD)/%.o: %.c $(BUILD)/%.o: %.c
$(CC) $(CFLAGS) -c -o $@ $< $(ECHO) "CC $<"
$(Q)$(CC) $(CFLAGS) -c -o $@ $<
$(BUILD)/main.o: mpconfigport.h $(BUILD)/main.o: mpconfigport.h