xref: /netbsd-src/external/gpl3/gdb/dist/sim/d10v/local.mk (revision 22ebeae4b2252475e0ebe332f69734639cb946ea)
1## See sim/Makefile.am
2##
3## Copyright (C) 1996-2024 Free Software Foundation, Inc.
4## Written by Cygnus Support.
5##
6## This program 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.
10##
11## This program 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.
15##
16## You should have received a copy of the GNU General Public License
17## along with this program.  If not, see <http://www.gnu.org/licenses/>.
18
19nodist_%C%_libsim_a_SOURCES = \
20	%D%/modules.c
21%C%_libsim_a_SOURCES = \
22	$(common_libcommon_a_SOURCES)
23%C%_libsim_a_LIBADD = \
24	%D%/interp.o \
25	$(patsubst %,%D%/%,$(SIM_NEW_COMMON_OBJS)) \
26	$(patsubst %,%D%/dv-%.o,$(SIM_HW_DEVICES)) \
27	%D%/endian.o \
28	%D%/sim-resume.o \
29	%D%/simops.o \
30	%D%/table.o
31$(%C%_libsim_a_OBJECTS) $(%C%_libsim_a_LIBADD): %D%/hw-config.h
32
33noinst_LIBRARIES += %D%/libsim.a
34
35## Override wildcards that trigger common/modules.c to be (incorrectly) used.
36%D%/modules.o: %D%/modules.c
37
38%D%/%.o: common/%.c ; $(SIM_COMPILE)
39-@am__include@ %D%/$(DEPDIR)/*.Po
40
41%C%_run_SOURCES =
42%C%_run_LDADD = \
43	%D%/nrun.o \
44	%D%/libsim.a \
45	$(SIM_COMMON_LIBS)
46
47noinst_PROGRAMS += %D%/run
48
49## List all generated headers to help Automake dependency tracking.
50BUILT_SOURCES += %D%/simops.h
51%C%_BUILD_OUTPUTS = \
52	%D%/gencode$(EXEEXT) \
53	%D%/table.c
54
55## Generating modules.c requires all sources to scan.
56%D%/modules.c: | $(%C%_BUILD_OUTPUTS)
57
58%C%_gencode_SOURCES = %D%/gencode.c
59%C%_gencode_LDADD = %D%/d10v-opc.o
60
61# These rules are copied from automake, but tweaked to use FOR_BUILD variables.
62%D%/gencode$(EXEEXT): $(%C%_gencode_OBJECTS) $(%C%_gencode_DEPENDENCIES) %D%/$(am__dirstamp)
63	$(AM_V_CCLD)$(LINK_FOR_BUILD) $(%C%_gencode_OBJECTS) $(%C%_gencode_LDADD)
64
65# gencode is a build-time only tool.  Override the default rules for it.
66%D%/gencode.o: %D%/gencode.c
67	$(AM_V_CC)$(COMPILE_FOR_BUILD) -c $< -o $@
68%D%/d10v-opc.o: ../opcodes/d10v-opc.c
69	$(AM_V_CC)$(COMPILE_FOR_BUILD) -c $< -o $@
70
71%D%/simops.h: %D%/gencode$(EXEEXT)
72	$(AM_V_GEN)$< -h >$@
73
74%D%/table.c: %D%/gencode$(EXEEXT)
75	$(AM_V_GEN)$< >$@
76
77EXTRA_PROGRAMS += %D%/gencode
78CLEANFILES += %D%/simops.h
79MOSTLYCLEANFILES += $(%C%_BUILD_OUTPUTS)
80