# it otherwise eat quite a bit of few cycles, even disabled
#CFLAGS += -DCONFIG_SIMAVR_TRACE=1
-all: obj config ${target}
+all: obj config libsimavr ${target}
include ../Makefile.common
# Static library
#
${OBJ}/libsimavr.a : ${sim_o}
+ifeq ($(V),1)
+ $(AR) cru $@ $^ && $(RANLIB) $@
+else
@echo AR $@
@$(AR) cru $@ $^ && $(RANLIB) $@
+endif
#
# Shared library (Linux)
#
${OBJ}/libsimavr.so.1 : ${sim_o}
+ifeq ($(V),1)
+ $(CC) -shared -Wl,-soname,libsimavr.so.1 -o $@ $^
+else
@echo SHARED $@
@$(CC) -shared -Wl,-soname,libsimavr.so.1 -o $@ $^
+endif
${OBJ}/libsimavr.so : ${OBJ}/libsimavr.so.1
ln -sf libsimavr.so.1 $@
libsimavr : ${OBJ}/libsimavr.so
endif
-${OBJ}/${target}.o : libsimavr
${OBJ}/${target}.elf : ${OBJ}/${target}.o
${target} : ${OBJ}/${target}.elf
# ship with old version of avr-gcc and associated and needs
# to be verified
#
+ifeq ($(V), 1)
+DEBUGLOG=/tmp/simavr_conf.log
+else
+DEBUGLOG=/dev/null
+endif
sim_core_config.h ${OBJ}/cores.deps: $(cores) Makefile
@echo CONF $@
@conf=""; decl=""; array=""; \
- mkdir -p ${OBJ} ; echo >${OBJ}/cores.deps ; \
+ mkdir -p ${OBJ} ; echo >${OBJ}/cores.deps ; echo >$(DEBUGLOG) ;\
for core in cores/*.c ; do \
file=$$core; global=$${core/cores\/sim_}; global=$${global/.c}; \
upper=$$(echo $$global|tr '[a-z]' '[A-Z]'); \
if $(CC) -E $(CFLAGS) ${AVR_CPPFLAGS} $$file \
- >/dev/null 2>&1 ; then \
+ >>$(DEBUGLOG) 2>&1 ; then \
conf+="#define CONFIG_$$upper 1\n"; \
obj=$${file/.c/.o} ; obj=$${obj/cores\/}; \
printf "\$${OBJ}/libsimavr.a: \$${OBJ}/$$obj\n">>${OBJ}/cores.deps ; \