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
) \
13 cgen-utils.o cgen-trace.o cgen-scache.o \
14 cgen-run.o sim-reason.o sim-stop.o \
16 cpu.o decode.o sem.o model.o mloop.o \
19 # List of extra dependencies.
20 # Generally this consists of simulator specific files included by sim-main.h.
21 SIM_EXTRA_DEPS
= $(CGEN_INCLUDE_DEPS
) $(srcdir)/..
/..
/opcodes
/lm32-desc.h
23 # List of flags to always pass to $(CC).
26 SIM_EXTRA_CLEAN
= lm32-clean
28 # This selects the lm32 newlib/libgloss syscall definitions.
29 NL_TARGET
= -DNL_TARGET_lm32
31 ## COMMON_POST_CONFIG_FRAG
35 arch.o
: arch.c
$(SIM_MAIN_DEPS
)
37 traps.o
: traps.c targ-vals.h
$(SIM_MAIN_DEPS
)
39 sim-if.o
: sim-if.c
$(SIM_MAIN_DEPS
) $(srcdir)/..
/common
/sim-core.h
41 LM32BF_INCLUDE_DEPS
= \
42 $(CGEN_MAIN_CPU_DEPS
) \
45 lm32.o
: lm32.c
$(LM32BF_INCLUDE_DEPS
)
47 # FIXME: Use of `mono' is wip.
48 mloop.c eng.h
: stamp-mloop
49 stamp-mloop
: $(srcdir)/..
/common
/genmloop.sh mloop.in Makefile
50 $(SHELL
) $(srccom
)/genmloop.sh \
51 -mono
-fast
-pbb
-switch sem-switch.c \
52 -cpu lm32bf
-infile
$(srcdir)/mloop.in
53 $(SHELL
) $(srcroot
)/move-if-change eng.hin eng.h
54 $(SHELL
) $(srcroot
)/move-if-change mloop.cin mloop.c
56 mloop.o
: mloop.c sem-switch.c
58 cpu.o
: cpu.c
$(LM32BF_INCLUDE_DEPS
)
59 decode.o
: decode.c
$(LM32BF_INCLUDE_DEPS
)
60 sem.o
: sem.c
$(LM32BF_INCLUDE_DEPS
)
61 model.o
: model.c
$(LM32BF_INCLUDE_DEPS
)
64 rm -f mloop.c eng.h stamp-mloop
65 rm -f stamp-arch stamp-cpu
68 # cgen support, enable with --enable-cgen-maint
70 # The following line is commented in or out depending upon --enable-cgen-maint.
71 @CGEN_MAINT@CGEN_MAINT
=
73 stamp-arch
: $(CGEN_READ_SCM
) $(CGEN_ARCH_SCM
) $(CPU_DIR
)/lm32.cpu
74 $(MAKE
) cgen-arch
$(CGEN_FLAGS_TO_PASS
) mach
=all \
75 archfile
=$(CPU_DIR
)/lm32.cpu \
76 FLAGS
="with-scache with-profile=fn"
78 arch.h arch.c cpuall.h
: $(CGEN_MAINT
) stamp-arch
80 stamp-cpu
: $(CGEN_READ_SCM
) $(CGEN_CPU_SCM
) $(CGEN_DECODE_SCM
) $(CPU_DIR
)/lm32.cpu
81 $(MAKE
) cgen-cpu-decode
$(CGEN_FLAGS_TO_PASS
) \
82 cpu
=lm32bf mach
=lm32 SUFFIX
= \
83 archfile
=$(CPU_DIR
)/lm32.cpu \
84 FLAGS
="with-scache with-profile=fn" \
85 EXTRAFILES
="$(CGEN_CPU_SEM) $(CGEN_CPU_SEMSW)"
87 cpu.h sem.c sem-switch.c model.c decode.c decode.h
: $(CGEN_MAINT
) stamp-cpu