1 # Makefile for Lattice Mico32 simulator.
2 # Contributed by Jon Beniston <jon@beniston.com>
4 ## COMMON_PRE_CONFIG_FRAG
6 # List of object files, less common parts.
8 $(SIM_NEW_COMMON_OBJS
) \
9 cgen-utils.o cgen-trace.o cgen-scache.o \
12 cpu.o decode.o sem.o model.o mloop.o \
15 # List of extra dependencies.
16 # Generally this consists of simulator specific files included by sim-main.h.
17 SIM_EXTRA_DEPS
= $(CGEN_INCLUDE_DEPS
) $(srcdir)/..
/..
/opcodes
/lm32-desc.h
19 # List of flags to always pass to $(CC).
22 SIM_EXTRA_CLEAN
= lm32-clean
24 # This selects the lm32 newlib/libgloss syscall definitions.
25 NL_TARGET
= -DNL_TARGET_lm32
27 ## COMMON_POST_CONFIG_FRAG
31 arch.o
: arch.c
$(SIM_MAIN_DEPS
)
33 traps.o
: traps.c targ-vals.h
$(SIM_MAIN_DEPS
)
35 sim-if.o
: sim-if.c
$(SIM_MAIN_DEPS
) $(srcdir)/..
/common
/sim-core.h
37 LM32BF_INCLUDE_DEPS
= \
38 $(CGEN_MAIN_CPU_DEPS
) \
41 lm32.o
: lm32.c
$(LM32BF_INCLUDE_DEPS
)
43 # FIXME: Use of `mono' is wip.
44 mloop.c eng.h
: stamp-mloop
45 stamp-mloop
: $(srcdir)/..
/common
/genmloop.sh mloop.in Makefile
46 $(SHELL
) $(srccom
)/genmloop.sh \
47 -mono
-fast
-pbb
-switch sem-switch.c \
48 -cpu lm32bf
-infile
$(srcdir)/mloop.in
49 $(SHELL
) $(srcroot
)/move-if-change eng.hin eng.h
50 $(SHELL
) $(srcroot
)/move-if-change mloop.cin mloop.c
52 mloop.o
: mloop.c sem-switch.c
54 cpu.o
: cpu.c
$(LM32BF_INCLUDE_DEPS
)
55 decode.o
: decode.c
$(LM32BF_INCLUDE_DEPS
)
56 sem.o
: sem.c
$(LM32BF_INCLUDE_DEPS
)
57 model.o
: model.c
$(LM32BF_INCLUDE_DEPS
)
60 rm -f mloop.c eng.h stamp-mloop
61 rm -f stamp-arch stamp-cpu
64 # cgen support, enable with --enable-cgen-maint
66 # The following line is commented in or out depending upon --enable-cgen-maint.
67 @CGEN_MAINT@CGEN_MAINT
=
69 stamp-arch
: $(CGEN_READ_SCM
) $(CGEN_ARCH_SCM
) $(CPU_DIR
)/lm32.cpu
70 $(MAKE
) cgen-arch
$(CGEN_FLAGS_TO_PASS
) mach
=all \
71 archfile
=$(CPU_DIR
)/lm32.cpu \
72 FLAGS
="with-scache with-profile=fn"
74 arch.h arch.c cpuall.h
: $(CGEN_MAINT
) stamp-arch
76 stamp-cpu
: $(CGEN_READ_SCM
) $(CGEN_CPU_SCM
) $(CGEN_DECODE_SCM
) $(CPU_DIR
)/lm32.cpu
77 $(MAKE
) cgen-cpu-decode
$(CGEN_FLAGS_TO_PASS
) \
78 cpu
=lm32bf mach
=lm32 SUFFIX
= \
79 archfile
=$(CPU_DIR
)/lm32.cpu \
80 FLAGS
="with-scache with-profile=fn" \
81 EXTRAFILES
="$(CGEN_CPU_SEM) $(CGEN_CPU_SEMSW)"
83 cpu.h sem.c sem-switch.c model.c decode.c decode.h
: $(CGEN_MAINT
) stamp-cpu