2 # Copyright 2008-2012 Michel Pollet <buserror@gmail.com>
4 # This file is part of simavr.
6 # simavr is free software: you can redistribute it and/or modify
7 # it under the terms of the GNU General Public License as published by
8 # the Free Software Foundation, either version 3 of the License, or
9 # (at your option) any later version.
11 # simavr is distributed in the hope that it will be useful,
12 # but WITHOUT ANY WARRANTY; without even the implied warranty of
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 # GNU General Public License for more details.
16 # You should have received a copy of the GNU General Public License
17 # along with simavr. If not, see <http://www.gnu.org/licenses/>.
19 SIMAVR_VERSION = ${shell git tag |tail -1}
25 # tracing id useful especialy if you develop simavr core.
26 # it otherwise eat quite a bit of few cycles, even disabled
27 #CFLAGS += -DCONFIG_SIMAVR_TRACE=1
29 all: obj config libsimavr ${target}
31 include ../Makefile.common
33 cores = ${wildcard cores/*.c}
34 sim = ${wildcard sim/sim_*.c} ${wildcard sim/avr_*.c}
35 sim_o = ${patsubst sim/%.c, ${OBJ}/%.o, ${sim}}
48 ${OBJ}/libsimavr.a : ${sim_o}
50 $(AR) cru $@ $^ && $(RANLIB) $@
53 @$(AR) cru $@ $^ && $(RANLIB) $@
57 # Shared library (Linux)
59 ${OBJ}/libsimavr.so.1 : ${sim_o}
61 $(CC) -shared -Wl,-soname,libsimavr.so.1 -o $@ $^
64 @$(CC) -shared -Wl,-soname,libsimavr.so.1 -o $@ $^
67 ${OBJ}/libsimavr.so : ${OBJ}/libsimavr.so.1
68 ln -sf libsimavr.so.1 $@
70 libsimavr : config ${OBJ}/libsimavr.a
71 # shared library won't work that easily on non-linux
72 ifeq (${shell uname}, Linux)
73 libsimavr : ${OBJ}/libsimavr.so
76 ${OBJ}/${target}.elf : ${OBJ}/${target}.o
78 ${target} : ${OBJ}/${target}.elf
82 rm -rf ${target} *.a *.so
87 $(MKDIR) $(DESTDIR)/include/simavr/avr
88 $(INSTALL) sim/*.h $(DESTDIR)/include/simavr/
89 $(INSTALL) sim_core_*.h $(DESTDIR)/include/simavr/
90 $(INSTALL) ../include/*.h $(DESTDIR)/include/simavr/avr/
91 $(MKDIR) $(DESTDIR)/lib
92 $(INSTALL) ${OBJ}/libsimavr.a $(DESTDIR)/lib/
93 $(MKDIR) $(DESTDIR)/lib/pkgconfig/
94 sed -e "s|PREFIX|${DESTDIR}|g" -e "s|VERSION|${SIMAVR_VERSION}|g" \
95 simavr.pc >$(DESTDIR)/lib/pkgconfig/simavr.pc
96 ifeq (${shell uname}, Linux)
97 $(INSTALL) ${OBJ}/libsimavr.so.1 $(DESTDIR)/lib/
98 ln -sf libsimavr.so.1 $(DESTDIR)/lib/libsimavr.so
100 $(MKDIR) $(DESTDIR)/bin
101 $(INSTALL) ${OBJ}/${target}.elf $(DESTDIR)/bin/simavr
103 config: ${OBJ}/cores.deps sim_core_config.h sim_core_decl.h
106 # this tries to preprocess all the cores and decide
107 # which ones have a chance of compiling at all. Some platform
108 # ship with old version of avr-gcc and associated and needs
112 DEBUGLOG=/tmp/simavr_conf.log
116 sim_core_config.h ${OBJ}/cores.deps: $(cores) Makefile
118 @conf=""; decl=""; array=""; \
119 mkdir -p ${OBJ} ; echo >${OBJ}/cores.deps ; echo >$(DEBUGLOG) ;\
120 for core in cores/*.c ; do \
121 file=$$core; global=$${core/cores\/sim_}; global=$${global/.c}; \
122 upper=$$(echo $$global|tr '[a-z]' '[A-Z]'); \
123 if $(CC) -E $(CFLAGS) ${AVR_CPPFLAGS} $$file \
124 >>$(DEBUGLOG) 2>&1 ; then \
125 conf+="#define CONFIG_$$upper 1\n"; \
126 obj=$${file/.c/.o} ; obj=$${obj/cores\/}; \
127 printf "\$${OBJ}/libsimavr.a: \$${OBJ}/$$obj\n">>${OBJ}/cores.deps ; \
128 printf "\$${OBJ}/libsimavr.so.1: \$${OBJ}/$$obj\n">>${OBJ}/cores.deps ; \
130 echo WARNING $$file did not compile, check your avr-gcc toolchain; \
133 ( printf "// Autogenerated do not edit\n"; \
134 printf "#ifndef __SIM_CORE_CONFIG_H__\n#define __SIM_CORE_CONFIG_H__\n\n"; \
140 # This take the config file that was generated, and create the static
141 # table of all available cores for name lookups, as well as a C
144 sim_core_decl.h: sim_core_config.h $(cores) Makefile
146 @decl=""; array=""; \
147 for core in $$(grep -r avr_kind_t cores/|awk -F '[ :]' '{print $$1 "=" $$3;}') ; do \
148 file=$${core/=*}; global=$${core/*=}; \
149 upper=$${file/cores\/sim_}; upper=$${upper/.c}; \
150 upper=$$(echo $$upper|tr '[a-z]' '[A-Z]'); \
151 decl+="#if CONFIG_$$upper\nextern avr_kind_t $$global;\n#endif\n"; \
152 array+="#if CONFIG_$$upper\n\t&$$global,\n#endif\n"; \
154 ( printf "// Autogenerated do not edit\n"; \
155 printf "#ifndef __SIM_CORE_DECL_H__\n#define __SIM_CORE_DECL_H__\n\n"; \
156 printf "#include \"sim_core_config.h\"\n";\
157 printf "$$decl\n" ; \
158 printf "extern avr_kind_t * avr_kind[];\n"; \
159 printf "#ifdef AVR_KIND_DECL\navr_kind_t * avr_kind[] = {\n$$array\tNULL\n};\n#endif\n"; \
163 -include ${OBJ}/cores.deps