]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blame - opcodes/Makefile.am
* msp430: New Directory.
[thirdparty/binutils-gdb.git] / opcodes / Makefile.am
CommitLineData
252b5132 1## Process this file with automake to generate Makefile.in
5bf135a7
NC
2#
3# Copyright 2012 Free Software Foundation
4#
5# This file is free software; you can redistribute it and/or modify
6# it under the terms of the GNU General Public License as published by
7# the Free Software Foundation; either version 3 of the License, or
8# (at your option) any later version.
9#
10# This program is distributed in the hope that it will be useful,
11# but WITHOUT ANY WARRANTY; without even the implied warranty of
12# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13# GNU General Public License for more details.
14#
15# You should have received a copy of the GNU General Public License
16# along with this program; see the file COPYING3. If not see
17# <http://www.gnu.org/licenses/>.
18#
252b5132 19
758227f0 20AUTOMAKE_OPTIONS = 1.11 foreign no-dist
79887925 21ACLOCAL_AMFLAGS = -I .. -I ../config -I ../bfd
252b5132 22
ff13a42d
RW
23# Build '.' first so all generated files exist.
24SUBDIRS = . po
252b5132
RH
25
26INCDIR = $(srcdir)/../include
27BFDDIR = $(srcdir)/../bfd
252b5132 28
a2d91340 29WARN_CFLAGS = @WARN_CFLAGS@
9e9b66a9 30NO_WERROR = @NO_WERROR@
35d0a169 31NO_WMISSING_FIELD_INITIALIZERS = @NO_WMISSING_FIELD_INITIALIZERS@
a2d91340
AC
32AM_CFLAGS = $(WARN_CFLAGS)
33
ff13a42d 34COMPILE_FOR_BUILD = $(CC_FOR_BUILD) $(INCLUDES) $(AM_CPPFLAGS) \
791f3971
L
35 $(CFLAGS_FOR_BUILD)
36LINK_FOR_BUILD = $(CC_FOR_BUILD) $(CFLAGS_FOR_BUILD) \
37 $(LDFLAGS_FOR_BUILD) -o $@
ff13a42d 38
14ec8efd
RW
39libopcodes_la_LDFLAGS =
40if INSTALL_LIBBFD
573e8a1c
RW
41bfdlibdir = @bfdlibdir@
42bfdincludedir = @bfdincludedir@
81172ff2 43bfdlib_LTLIBRARIES = libopcodes.la
14ec8efd
RW
44bfdinclude_DATA = $(INCDIR)/dis-asm.h
45else
573e8a1c
RW
46# Empty these so that the respective installation directories will not be created.
47bfdlibdir =
48bfdincludedir =
49rpath_bfdlibdir = @bfdlibdir@
14ec8efd 50noinst_LTLIBRARIES = libopcodes.la
573e8a1c 51libopcodes_la_LDFLAGS += -rpath $(rpath_bfdlibdir)
14ec8efd 52endif
252b5132
RH
53
54# This is where bfd.h lives.
55BFD_H = ../bfd/bfd.h
56
2eee5593
AM
57BUILD_LIBS = @BUILD_LIBS@
58BUILD_LIB_DEPS = @BUILD_LIB_DEPS@
6c298591 59
252b5132
RH
60# Header files.
61HFILES = \
a06ea964 62 aarch64-asm.h aarch64-dis.h aarch64-opc.h aarch64-tbl.h \
cfb8c092 63 epiphany-desc.h epiphany-opc.h \
252b5132 64 fr30-desc.h fr30-opc.h \
fd3c93d5 65 frv-desc.h frv-opc.h \
252b5132 66 h8500-opc.h \
40fb9820 67 i386-init.h \
40b8e679
L
68 i386-opc.h \
69 i386-tbl.h \
43079f18
NC
70 ia64-asmtab.h \
71 ia64-opc.h \
a40cbfa3 72 ip2k-desc.h ip2k-opc.h \
47b1a55a 73 iq2000-desc.h iq2000-opc.h \
500b1f44
AM
74 lm32-desc.h \
75 lm32-opc.h \
49f58d10 76 m32c-desc.h m32c-opc.h \
252b5132
RH
77 m32r-desc.h m32r-opc.h \
78 mcore-opc.h \
bd2f2e55 79 mep-desc.h mep-opc.h \
7ba29e2a 80 microblaze-opc.h \
d031aafb 81 mt-desc.h mt-opc.h \
87e6d782 82 openrisc-desc.h openrisc-opc.h \
1c0d3aa6 83 score-opc.h \
252b5132 84 sh-opc.h \
43079f18 85 sh64-opc.h \
252b5132
RH
86 sysdep.h \
87 w65-opc.h \
d70c5fc7 88 xc16x-desc.h xc16x-opc.h \
93fbbb04 89 xstormy16-desc.h xstormy16-opc.h \
252b5132
RH
90 z8k-opc.h
91
6f01793d
RW
92# C source files that correspond to .o's ending up in libopcodes
93# for all machines.
94TARGET_LIBOPCODES_CFILES = \
a06ea964
NC
95 aarch64-asm.c \
96 aarch64-asm-2.c \
97 aarch64-dis.c \
98 aarch64-dis-2.c \
99 aarch64-opc.c \
100 aarch64-opc-2.c \
252b5132
RH
101 alpha-dis.c \
102 alpha-opc.c \
71f22174 103 arc-dis.c \
0d2bcfaf 104 arc-ext.c \
6f01793d 105 arc-opc.c \
252b5132 106 arm-dis.c \
832ddf62 107 avr-dis.c \
4b7f6baa 108 bfin-dis.c \
252b5132 109 cgen-asm.c \
3609e0fe 110 cgen-bitset.c \
252b5132
RH
111 cgen-dis.c \
112 cgen-opc.c \
3d3d428f
NC
113 cr16-dis.c \
114 cr16-opc.c \
6c95a37f
HPN
115 cris-dis.c \
116 cris-opc.c \
1fe1f39c
NC
117 crx-dis.c \
118 crx-opc.c \
252b5132
RH
119 d10v-dis.c \
120 d10v-opc.c \
121 d30v-dis.c \
122 d30v-opc.c \
d172d4ba 123 dlx-dis.c \
cfb8c092
NC
124 epiphany-asm.c \
125 epiphany-desc.c \
126 epiphany-dis.c \
127 epiphany-ibld.c \
128 epiphany-opc.c \
252b5132
RH
129 fr30-asm.c \
130 fr30-desc.c \
131 fr30-dis.c \
132 fr30-ibld.c \
133 fr30-opc.c \
fd3c93d5
DB
134 frv-asm.c \
135 frv-desc.c \
136 frv-dis.c \
137 frv-ibld.c \
138 frv-opc.c \
252b5132
RH
139 h8300-dis.c \
140 h8500-dis.c \
141 hppa-dis.c \
5b93d8bb
AM
142 i370-dis.c \
143 i370-opc.c \
252b5132 144 i386-dis.c \
0b1cf022 145 i386-opc.c \
915ef37f 146 i860-dis.c \
252b5132 147 i960-dis.c \
800eeca4 148 ia64-dis.c \
800eeca4 149 ia64-opc.c \
a40cbfa3
NC
150 ip2k-asm.c \
151 ip2k-desc.c \
152 ip2k-dis.c \
153 ip2k-ibld.c \
154 ip2k-opc.c \
47b1a55a
SC
155 iq2000-asm.c \
156 iq2000-desc.c \
157 iq2000-dis.c \
158 iq2000-ibld.c \
159 iq2000-opc.c \
828c0124
JK
160 lm32-asm.c \
161 lm32-desc.c \
828c0124
JK
162 lm32-dis.c \
163 lm32-ibld.c \
164 lm32-opc.c \
828c0124 165 lm32-opinst.c \
6f01793d
RW
166 m10200-dis.c \
167 m10200-opc.c \
168 m10300-dis.c \
169 m10300-opc.c \
49f58d10
JB
170 m32c-asm.c \
171 m32c-desc.c \
172 m32c-dis.c \
173 m32c-ibld.c \
174 m32c-opc.c \
252b5132
RH
175 m32r-asm.c \
176 m32r-desc.c \
177 m32r-dis.c \
178 m32r-ibld.c \
179 m32r-opc.c \
180 m32r-opinst.c \
60bcf0fa
NC
181 m68hc11-dis.c \
182 m68hc11-opc.c \
252b5132
RH
183 m68k-dis.c \
184 m68k-opc.c \
185 m88k-dis.c \
186 mcore-dis.c \
bd2f2e55
DB
187 mep-asm.c \
188 mep-desc.c \
189 mep-dis.c \
190 mep-ibld.c \
191 mep-opc.c \
a3c62988 192 metag-dis.c \
7ba29e2a 193 microblaze-dis.c \
df58fc94 194 micromips-opc.c \
6f01793d 195 mips-dis.c \
252b5132
RH
196 mips-opc.c \
197 mips16-opc.c \
3c3bdf30
NC
198 mmix-dis.c \
199 mmix-opc.c \
6f01793d
RW
200 moxie-dis.c \
201 moxie-opc.c \
202 msp430-dis.c \
d031aafb
NS
203 mt-asm.c \
204 mt-desc.c \
205 mt-dis.c \
206 mt-ibld.c \
207 mt-opc.c \
36591ba1
SL
208 nios2-dis.c \
209 nios2-opc.c \
252b5132 210 ns32k-dis.c \
87e6d782
NC
211 openrisc-asm.c \
212 openrisc-desc.c \
213 openrisc-dis.c \
214 openrisc-ibld.c \
215 openrisc-opc.c \
3b16e843
NC
216 or32-dis.c \
217 or32-opc.c \
e135f41b
NC
218 pdp11-dis.c \
219 pdp11-opc.c \
1e608f98
ILT
220 pj-dis.c \
221 pj-opc.c \
252b5132
RH
222 ppc-dis.c \
223 ppc-opc.c \
99c513f6
DD
224 rl78-decode.c \
225 rl78-dis.c \
c7927a3c
NC
226 rx-decode.c \
227 rx-dis.c \
a85d7ed0 228 s390-dis.c \
6f01793d 229 s390-opc.c \
1c0d3aa6 230 score-dis.c \
c3b7224a 231 score7-dis.c \
252b5132 232 sh-dis.c \
43079f18
NC
233 sh64-dis.c \
234 sh64-opc.c \
252b5132
RH
235 sparc-dis.c \
236 sparc-opc.c \
e9f53129
AM
237 spu-dis.c \
238 spu-opc.c \
252b5132 239 tic30-dis.c \
026df7c5 240 tic4x-dis.c \
5c84d377
TW
241 tic54x-dis.c \
242 tic54x-opc.c \
40b36596 243 tic6x-dis.c \
252b5132
RH
244 tic80-dis.c \
245 tic80-opc.c \
aa137e4d
NC
246 tilegx-dis.c \
247 tilegx-opc.c \
248 tilepro-dis.c \
249 tilepro-opc.c \
71f22174
AS
250 v850-dis.c \
251 v850-opc.c \
252b5132
RH
252 vax-dis.c \
253 w65-dis.c \
d70c5fc7
NC
254 xc16x-asm.c \
255 xc16x-desc.c \
256 xc16x-dis.c \
257 xc16x-ibld.c \
258 xc16x-opc.c \
93fbbb04
GK
259 xstormy16-asm.c \
260 xstormy16-desc.c \
261 xstormy16-dis.c \
262 xstormy16-ibld.c \
263 xstormy16-opc.c \
e0001a05 264 xtensa-dis.c \
f6c1a2d5 265 xgate-dis.c \
5bf135a7 266 xgate-opc.c \
3c9b82ba 267 z80-dis.c \
6f01793d
RW
268 z8k-dis.c
269
270# C source files that correspond to .o's ending up in libopcodes.
271LIBOPCODES_CFILES = \
272 $(TARGET_LIBOPCODES_CFILES) \
273 dis-buf.c \
274 dis-init.c \
275 disassemble.c
276
277# C source files that correspond to .o's.
278CFILES = \
279 $(LIBOPCODES_CFILES) \
a06ea964 280 aarch64-gen.c \
6f01793d
RW
281 i386-gen.c \
282 ia64-asmtab.c \
283 ia64-gen.c \
284 ia64-opc-a.c \
285 ia64-opc-b.c \
286 ia64-opc-f.c \
287 ia64-opc-i.c \
288 ia64-opc-m.c \
289 ia64-opc-d.c \
290 s390-mkopc.c \
252b5132
RH
291 z8kgen.c
292
6f01793d 293ALL_MACHINES = $(TARGET_LIBOPCODES_CFILES:.c=.lo)
252b5132
RH
294
295OFILES = @BFD_MACHINES@
296
3f85e526
L
297# We should reconfigure whenever bfd/configure.in changes, because
298# that's where the version number in Makefile comes from.
299CONFIG_STATUS_DEPENDENCIES = $(BFDDIR)/configure.in
300
14ec8efd 301AM_CPPFLAGS = -I. -I$(srcdir) -I../bfd -I$(INCDIR) -I$(BFDDIR) @HDEFINES@ @INCINTL@
252b5132 302
758227f0
RW
303disassemble.lo: disassemble.c
304if am__fastdepCC
305 $(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ @archdefs@ $(srcdir)/disassemble.c
306 mv -f $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo
307else
308if AMDEP
309 source='disassemble.c' object='$@' libtool=yes @AMDEPBACKSLASH@
310 DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
311endif
312 $(LTCOMPILE) -c -o $@ @archdefs@ $(srcdir)/disassemble.c
313endif
252b5132 314
92c2346c 315libopcodes_la_SOURCES = dis-buf.c disassemble.c dis-init.c
3ba7a1aa
DJ
316# It's desirable to list ../bfd/libbfd.la in DEPENDENCIES and LIBADD.
317# Unfortunately this causes libtool to add -L$(libdir), referring to the
318# planned install directory of libbfd. This can cause us to pick up an
319# old version of libbfd, or to pick up libbfd for the wrong architecture
45d42143
NC
320# if host != build. So for building with shared libraries we use a
321# hardcoded path to libbfd.so instead of relying on the entries in libbfd.la.
322libopcodes_la_DEPENDENCIES = $(OFILES) @SHARED_DEPENDENCIES@
323libopcodes_la_LIBADD = $(OFILES) @SHARED_LIBADD@
14ec8efd 324libopcodes_la_LDFLAGS += -release `cat ../bfd/libtool-soversion` @SHARED_LDFLAGS@
758227f0 325# Allow dependency tracking to work on all the source files.
6f01793d 326EXTRA_libopcodes_la_SOURCES = $(LIBOPCODES_CFILES)
252b5132
RH
327
328# libtool will build .libs/libopcodes.a. We create libopcodes.a in
329# the build directory so that we don't have to convert all the
330# programs that use libopcodes.a simultaneously. This is a hack which
331# should be removed if everything else starts using libtool. FIXME.
332
333noinst_LIBRARIES = libopcodes.a
d92fa646 334libopcodes_a_SOURCES =
252b5132
RH
335
336stamp-lib: libopcodes.la
e56f75e9
ILT
337 libtooldir=`$(LIBTOOL) --config | sed -n -e 's/^objdir=//p'`; \
338 if [ -f $$libtooldir/libopcodes.a ]; then \
339 cp $$libtooldir/libopcodes.a libopcodes.tmp; \
847ee773 340 $(RANLIB) libopcodes.tmp; \
252b5132
RH
341 $(SHELL) $(srcdir)/../move-if-change libopcodes.tmp libopcodes.a; \
342 else true; fi
343 touch stamp-lib
344
345libopcodes.a: stamp-lib ; @true
346
347POTFILES = $(HFILES) $(CFILES)
348po/POTFILES.in: @MAINT@ Makefile
323ee3f4 349 for f in $(POTFILES); do echo $$f; done | LC_ALL=C sort > tmp \
252b5132
RH
350 && mv tmp $(srcdir)/po/POTFILES.in
351
252b5132 352CLEANFILES = \
cfb8c092 353 stamp-epiphany stamp-fr30 stamp-frv stamp-ip2k stamp-iq2000 stamp-lm32 \
a43817df
AM
354 stamp-m32c stamp-m32r stamp-mep stamp-mt \
355 stamp-openrisc stamp-xc16x stamp-xstormy16 \
356 libopcodes.a stamp-lib
252b5132
RH
357
358
6e31aea3 359CGENDIR = @cgendir@
dc15e575 360CPUDIR = $(srcdir)/../cpu
0a40490e 361CGEN = "`if test -f ../guile/libguile/guile ; then echo ../guile/libguile/guile; else echo guile ; fi` -l ${cgendir}/guile.scm -s"
6e31aea3
BE
362CGENFLAGS = -v
363
bc98a631 364CGENDEPS = \
6e31aea3
BE
365 $(CGENDIR)/desc.scm $(CGENDIR)/desc-cpu.scm \
366 $(CGENDIR)/opcodes.scm $(CGENDIR)/opc-asmdis.scm \
367 $(CGENDIR)/opc-ibld.scm $(CGENDIR)/opc-itab.scm \
368 $(CGENDIR)/opc-opinst.scm \
369 cgen-asm.in cgen-dis.in cgen-ibld.in
370
cfb8c092 371CGEN_CPUS = epiphany fr30 frv ip2k iq2000 lm32 m32c m32r mep mt openrisc xc16x xstormy16
4714fbc0 372
6e31aea3 373if CGEN_MAINT
cfb8c092 374EPIPHANY_DEPS = stamp-epiphany
d1119f7a
DE
375FR30_DEPS = stamp-fr30
376FRV_DEPS = stamp-frv
a40cbfa3 377IP2K_DEPS = stamp-ip2k
d1119f7a 378IQ2000_DEPS = stamp-iq2000
84e94c90 379LM32_DEPS = stamp-lm32
49f58d10 380M32C_DEPS = stamp-m32c
6e31aea3 381M32R_DEPS = stamp-m32r
bd2f2e55 382MEP_DEPS = stamp-mep
4970f871 383MT_DEPS = stamp-mt
87e6d782 384OPENRISC_DEPS = stamp-openrisc
d70c5fc7 385XC16X_DEPS = stamp-xc16x
93fbbb04 386XSTORMY16_DEPS = stamp-xstormy16
6e31aea3 387else
cfb8c092 388EPIPHANY_DEPS =
d1119f7a
DE
389FR30_DEPS =
390FRV_DEPS =
a40cbfa3 391IP2K_DEPS =
d1119f7a 392IQ2000_DEPS =
84e94c90 393LM32_DEPS =
49f58d10 394M32C_DEPS =
6e31aea3 395M32R_DEPS =
bd2f2e55 396MEP_DEPS =
4970f871 397MT_DEPS =
87e6d782 398OPENRISC_DEPS =
d70c5fc7 399XC16X_DEPS =
93fbbb04 400XSTORMY16_DEPS =
6e31aea3
BE
401endif
402
403run-cgen:
404 $(SHELL) $(srcdir)/cgen.sh opcodes $(srcdir) $(CGEN) \
9c2de729
DB
405 $(CGENDIR) "$(CGENFLAGS)" $(arch) $(prefix) $(archfile) $(opcfile) \
406 "$(options)" "$(extrafiles)"
6e31aea3
BE
407 touch stamp-${prefix}
408.PHONY: run-cgen
409
4714fbc0
DE
410# Maintainer utility rule to regenerate all cgen files.
411run-cgen-all:
412 for c in $(CGEN_CPUS) ; \
413 do \
414 $(MAKE) stamp-$$c || exit 1 ; \
415 done
416.PHONY: run-cgen-all
417
6e31aea3 418# For now, require developers to configure with --enable-cgen-maint.
d1119f7a 419
cfb8c092
NC
420$(srcdir)/epiphany-desc.h $(srcdir)/epiphany-desc.c $(srcdir)/epiphany-opc.h \
421 $(srcdir)/epiphany-opc.c $(srcdir)/epiphany-ibld.c \
422 $(srcdir)/epiphany-opinst.c $(srcdir)/epiphany-asm.c \
423 $(srcdir)/epiphany-dis.c: $(EPIPHANY_DEPS)
424 @true
425
426stamp-epiphany: $(CGENDEPS) $(CPUDIR)/epiphany.cpu $(CPUDIR)/epiphany.opc
427 $(MAKE) run-cgen arch=epiphany prefix=epiphany options= \
428 archfile=$(CPUDIR)/epiphany.cpu opcfile=$(CPUDIR)/epiphany.opc extrafiles=
429
d1119f7a
DE
430$(srcdir)/fr30-desc.h $(srcdir)/fr30-desc.c $(srcdir)/fr30-opc.h $(srcdir)/fr30-opc.c $(srcdir)/fr30-ibld.c $(srcdir)/fr30-asm.c $(srcdir)/fr30-dis.c: $(FR30_DEPS)
431 @true
432stamp-fr30: $(CGENDEPS) $(CPUDIR)/fr30.cpu $(CPUDIR)/fr30.opc
433 $(MAKE) run-cgen arch=fr30 prefix=fr30 options= \
434 archfile=$(CPUDIR)/fr30.cpu opcfile=$(CPUDIR)/fr30.opc extrafiles=
435
436$(srcdir)/frv-desc.h $(srcdir)/frv-desc.c $(srcdir)/frv-opc.h $(srcdir)/frv-opc.c $(srcdir)/frv-ibld.c $(srcdir)/frv-asm.c $(srcdir)/frv-dis.c: $(FRV_DEPS)
437 @true
dc15e575 438stamp-frv: $(CGENDEPS) $(CPUDIR)/frv.cpu $(CPUDIR)/frv.opc
d1119f7a 439 $(MAKE) run-cgen arch=frv prefix=frv options= \
dc15e575 440 archfile=$(CPUDIR)/frv.cpu opcfile=$(CPUDIR)/frv.opc extrafiles=
d1119f7a 441
a40cbfa3
NC
442$(srcdir)/ip2k-desc.h $(srcdir)/ip2k-desc.c $(srcdir)/ip2k-opc.h $(srcdir)/ip2k-opc.c $(srcdir)/ip2k-ibld.c $(srcdir)/ip2k-asm.c $(srcdir)/ip2k-dis.c: $(IP2K_DEPS)
443 @true
444stamp-ip2k: $(CGENDEPS) $(CPUDIR)/ip2k.cpu $(CPUDIR)/ip2k.opc
9c2de729
DB
445 $(MAKE) run-cgen arch=ip2k prefix=ip2k options= \
446 archfile=$(CPUDIR)/ip2k.cpu opcfile=$(CPUDIR)/ip2k.opc extrafiles=
a40cbfa3 447
d1119f7a
DE
448$(srcdir)/iq2000-desc.h $(srcdir)/iq2000-desc.c $(srcdir)/iq2000-opc.h $(srcdir)/iq2000-opc.c $(srcdir)/iq2000-ibld.c $(srcdir)/iq2000-asm.c $(srcdir)/iq2000-dis.c: $(IQ2000_DEPS)
449 @true
dc15e575
NC
450stamp-iq2000: $(CGENDEPS) $(CPUDIR)/iq2000.cpu \
451 $(CPUDIR)/iq2000.opc $(CPUDIR)/iq2000m.cpu \
452 $(CPUDIR)/iq10.cpu
d1119f7a 453 $(MAKE) run-cgen arch=iq2000 prefix=iq2000 options= \
dc15e575
NC
454 archfile=$(CPUDIR)/iq2000.cpu \
455 opcfile=$(CPUDIR)/iq2000.opc extrafiles=
d1119f7a 456
84e94c90
NC
457$(srcdir)lm32-desc.h $(srcdir)/lm32-desc.c $(srcdir)/lm32-opc.h $(srcdir)/lm32-opc.c $(srcdir)/lm32-ibld.c $(srcdir)/lm32-opinst.c $(srcdir)/lm32-asm.c $(srcdir)/lm32-dis.c: $(LM32_DEPS)
458 @true
dc15e575 459stamp-lm32: $(CGENDEPS) $(CPUDIR)/lm32.cpu $(CPUDIR)/lm32.opc
84e94c90 460 $(MAKE) run-cgen arch=lm32 prefix=lm32 options=opinst \
dc15e575
NC
461 archfile=$(CPUDIR)/lm32.cpu \
462 opcfile=$(CPUDIR)/lm32.opc \
84e94c90
NC
463 extrafiles=opinst
464
49f58d10
JB
465$(srcdir)/m32c-desc.h $(srcdir)/m32c-desc.c $(srcdir)/m32c-opc.h $(srcdir)/m32c-opc.c $(srcdir)/m32c-ibld.c $(srcdir)/m32c-asm.c $(srcdir)/m32c-dis.c: $(M32C_DEPS)
466# @true
dc15e575 467stamp-m32c: $(CGENDEPS) $(CPUDIR)/m32c.cpu $(CPUDIR)/m32c.opc
49f58d10 468 $(MAKE) run-cgen arch=m32c prefix=m32c options= \
dc15e575
NC
469 archfile=$(CPUDIR)/m32c.cpu \
470 opcfile=$(CPUDIR)/m32c.opc extrafiles=
49f58d10 471
6e31aea3 472$(srcdir)/m32r-desc.h $(srcdir)/m32r-desc.c $(srcdir)/m32r-opc.h $(srcdir)/m32r-opc.c $(srcdir)/m32r-ibld.c $(srcdir)/m32r-opinst.c $(srcdir)/m32r-asm.c $(srcdir)/m32r-dis.c: $(M32R_DEPS)
dc62a253 473 @true
dc15e575 474stamp-m32r: $(CGENDEPS) $(CPUDIR)/m32r.cpu $(CPUDIR)/m32r.opc
9c2de729 475 $(MAKE) run-cgen arch=m32r prefix=m32r options=opinst \
dc15e575
NC
476 archfile=$(CPUDIR)/m32r.cpu \
477 opcfile=$(CPUDIR)/m32r.opc extrafiles=opinst
6e31aea3 478
bd2f2e55
DB
479$(srcdir)/mep-desc.h $(srcdir)/mep-desc.c $(srcdir)/mep-opc.h $(srcdir)/mep-opc.c $(srcdir)/mep-ibld.c $(srcdir)/mep-asm.c $(srcdir)/mep-dis.c: $(MEP_DEPS)
480 @true
481stamp-mep: $(CGENDEPS) $(CPUDIR)/mep.cpu $(CPUDIR)/mep-default.cpu $(CPUDIR)/mep-core.cpu $(CPUDIR)/mep-h1.cpu $(CPUDIR)/mep-ext-cop.cpu $(CPUDIR)/mep-sample-ucidsp.cpu $(CPUDIR)/mep-rhcop.cpu $(CPUDIR)/mep-fmax.cpu $(CPUDIR)/mep.opc
482 $(MAKE) run-cgen arch=mep prefix=mep options= \
483 archfile=$(CPUDIR)/mep.cpu opcfile=$(CPUDIR)/mep.opc extrafiles=
484
d031aafb 485$(srcdir)/mt-desc.h $(srcdir)/mt-desc.c $(srcdir)/mt-opc.h $(srcdir)/mt-opc.c $(srcdir)/mt-ibld.c $(srcdir)/mt-asm.c $(srcdir)/mt-dis.c: $(MT_DEPS)
ac188222 486 @true
dc15e575 487stamp-mt: $(CGENDEPS) $(CPUDIR)/mt.cpu $(CPUDIR)/mt.opc
d031aafb 488 $(MAKE) run-cgen arch=mt prefix=mt options= \
dc15e575
NC
489 archfile=$(CPUDIR)/mt.cpu \
490 opcfile=$(CPUDIR)/mt.opc extrafiles=
ac188222 491
87e6d782
NC
492$(srcdir)/openrisc-desc.h $(srcdir)/openrisc-desc.c $(srcdir)/openrisc-opc.h $(srcdir)/openrisc-opc.c $(srcdir)/openrisc-ibld.c $(srcdir)/openrisc-asm.c $(srcdir)/openrisc-dis.c: $(OPENRISC_DEPS)
493 @true
4a3264e6 494stamp-openrisc: $(CGENDEPS) $(CPUDIR)/openrisc.cpu $(CPUDIR)/openrisc.opc
9c2de729
DB
495 $(MAKE) run-cgen arch=openrisc prefix=openrisc options= \
496 archfile=$(CPUDIR)/openrisc.cpu opcfile=$(CPUDIR)/openrisc.opc extrafiles=
87e6d782 497
d1119f7a 498$(srcdir)/xc16x-desc.h $(srcdir)/xc16x-desc.c $(srcdir)/xc16x-opc.h $(srcdir)/xc16x-opc.c $(srcdir)/xc16x-ibld.c $(srcdir)/xc16x-asm.c $(srcdir)/xc16x-dis.c: $(XC16X_DEPS)
47b1a55a 499 @true
dc15e575 500stamp-xc16x: $(CGENDEPS) $(CPUDIR)/xc16x.cpu $(CPUDIR)/xc16x.opc
d1119f7a 501 $(MAKE) run-cgen arch=xc16x prefix=xc16x options= \
dc15e575
NC
502 archfile=$(CPUDIR)/xc16x.cpu \
503 opcfile=$(CPUDIR)/xc16x.opc \
c7e770a0 504 extrafiles=
47b1a55a 505
93fbbb04
GK
506$(srcdir)/xstormy16-desc.h $(srcdir)/xstormy16-desc.c $(srcdir)/xstormy16-opc.h $(srcdir)/xstormy16-opc.c $(srcdir)/xstormy16-ibld.c $(srcdir)/xstormy16-asm.c $(srcdir)/xstormy16-dis.c: $(XSTORMY16_DEPS)
507 @true
508stamp-xstormy16: $(CGENDEPS) $(CPUDIR)/xstormy16.cpu $(CPUDIR)/xstormy16.opc
9c2de729
DB
509 $(MAKE) run-cgen arch=xstormy16 prefix=xstormy16 options= \
510 archfile=$(CPUDIR)/xstormy16.cpu opcfile=$(CPUDIR)/xstormy16.opc extrafiles=
93fbbb04 511
a06ea964
NC
512MOSTLYCLEANFILES = aarch64-gen$(EXEEXT_FOR_BUILD) i386-gen$(EXEEXT_FOR_BUILD) \
513 ia64-gen$(EXEEXT_FOR_BUILD) s390-mkopc$(EXEEXT_FOR_BUILD) s390-opc.tab \
514 z8kgen$(EXEEXT_FOR_BUILD) opc2c$(EXEEXT_FOR_BUILD)
ff13a42d 515
a06ea964
NC
516MAINTAINERCLEANFILES = $(srcdir)/aarch64-asm-2.c $(srcdir)/aarch64-dis-2.c \
517 $(srcdir)/aarch64-opc-2.c $(srcdir)/i386-tbl.h $(srcdir)/i386-init.h \
56300268 518 $(srcdir)/ia64-asmtab.c $(srcdir)/z8k-opc.h \
99c513f6 519 $(srcdir)/rl78-decode.c \
49293ef7 520 $(srcdir)/rx-decode.c
ff13a42d 521
a06ea964
NC
522aarch64-gen$(EXEEXT_FOR_BUILD): aarch64-gen.o $(BUILD_LIB_DEPS)
523 $(LINK_FOR_BUILD) aarch64-gen.o $(BUILD_LIBS)
524
525aarch64-gen.o: aarch64-gen.c $(BFD_H) $(INCDIR)/getopt.h $(INCDIR)/libiberty.h\
526 $(INCDIR)/opcode/aarch64.h config.h aarch64-opc.h aarch64-tbl.h
527 $(COMPILE_FOR_BUILD) -c $(srcdir)/aarch64-gen.c
528
529$(srcdir)/aarch64-asm-2.c: @MAINT@ aarch64-gen$(exeext_for_build)
530 ./aarch64-gen$(exeext_for_build) --gen-asm > $@
531$(srcdir)/aarch64-dis-2.c: @MAINT@ aarch64-gen$(exeext_for_build)
532 ./aarch64-gen$(exeext_for_build) --gen-dis > $@
533$(srcdir)/aarch64-opc-2.c: @MAINT@ aarch64-gen$(exeext_for_build)
534 ./aarch64-gen$(exeext_for_build) --gen-opc > $@
535
2eee5593
AM
536i386-gen$(EXEEXT_FOR_BUILD): i386-gen.o $(BUILD_LIB_DEPS)
537 $(LINK_FOR_BUILD) i386-gen.o $(BUILD_LIBS)
ff13a42d
RW
538
539i386-gen.o: i386-gen.c i386-opc.h $(srcdir)/../include/opcode/i386.h \
540 $(INCDIR)/ansidecl.h $(INCDIR)/getopt.h $(INCDIR)/hashtab.h \
541 $(INCDIR)/libiberty.h $(INCDIR)/opcode/i386.h $(INCDIR)/safe-ctype.h \
542 config.h i386-opc.h sysdep.h
543 $(COMPILE_FOR_BUILD) -c $(srcdir)/i386-gen.c
40b8e679 544
40fb9820
L
545$(srcdir)/i386-tbl.h: $(srcdir)/i386-init.h
546 @echo $@
547
ff13a42d
RW
548$(srcdir)/i386-init.h: @MAINT@ i386-gen$(EXEEXT_FOR_BUILD) i386-opc.tbl i386-reg.tbl
549 ./i386-gen$(EXEEXT_FOR_BUILD) --srcdir $(srcdir)
550
551i386-opc.lo: $(srcdir)/i386-tbl.h
552
2eee5593
AM
553ia64-gen$(EXEEXT_FOR_BUILD): ia64-gen.o $(BUILD_LIB_DEPS)
554 $(LINK_FOR_BUILD) ia64-gen.o $(BUILD_LIBS)
40b8e679 555
ff13a42d
RW
556ia64-gen.o: ia64-gen.c $(BFD_H) $(INCDIR)/ansidecl.h $(INCDIR)/getopt.h \
557 $(INCDIR)/libiberty.h $(INCDIR)/opcode/ia64.h $(INCDIR)/safe-ctype.h \
558 $(INCDIR)/symcat.h config.h ia64-opc-a.c ia64-opc-b.c \
559 ia64-opc-d.c ia64-opc-f.c ia64-opc-i.c ia64-opc-m.c \
560 ia64-opc-x.c ia64-opc.h sysdep.h
561 $(COMPILE_FOR_BUILD) -c $(srcdir)/ia64-gen.c
800eeca4 562
ff13a42d
RW
563# Use a helper variable for the dependencies to avoid 'make' issues
564# with continuations in comments, as @MAINT@ can be expanded to '#'.
565ia64_asmtab_deps = ia64-gen$(EXEEXT_FOR_BUILD) ia64-ic.tbl \
566 ia64-raw.tbl ia64-waw.tbl ia64-war.tbl
567$(srcdir)/ia64-asmtab.c: @MAINT@ $(ia64_asmtab_deps)
568 ./ia64-gen$(EXEEXT_FOR_BUILD) --srcdir $(srcdir) > $@
252b5132 569
ff13a42d 570ia64-opc.lo: $(srcdir)/ia64-asmtab.c
b6849f55 571
99c513f6
DD
572$(srcdir)/rl78-decode.c: @MAINT@ $(srcdir)/rl78-decode.opc opc2c$(EXEEXT_FOR_BUILD)
573 ./opc2c$(EXEEXT_FOR_BUILD) $(srcdir)/rl78-decode.opc > $(srcdir)/rl78-decode.c
574
35d0a169 575micromips-opc.lo: micromips-opc.c
de40ceb6
AM
576if am__fastdepCC
577 $(LTCOMPILE) $(NO_WMISSING_FIELD_INITIALIZERS) \
578 -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ @archdefs@ $<
579 mv -f $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo
580else
581if AMDEP
582 source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@
583 DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
584endif
585 $(LTCOMPILE) $(NO_WMISSING_FIELD_INITIALIZERS) -c -o $@ @archdefs@ $<
586endif
35d0a169
MR
587
588mips-opc.lo: mips-opc.c
de40ceb6
AM
589if am__fastdepCC
590 $(LTCOMPILE) $(NO_WMISSING_FIELD_INITIALIZERS) \
591 -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ @archdefs@ $<
592 mv -f $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo
593else
594if AMDEP
595 source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@
596 DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
597endif
598 $(LTCOMPILE) $(NO_WMISSING_FIELD_INITIALIZERS) -c -o $@ @archdefs@ $<
599endif
35d0a169
MR
600
601mips16-opc.lo: mips16-opc.c
de40ceb6
AM
602if am__fastdepCC
603 $(LTCOMPILE) $(NO_WMISSING_FIELD_INITIALIZERS) \
604 -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ @archdefs@ $<
605 mv -f $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo
606else
607if AMDEP
608 source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@
609 DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
610endif
611 $(LTCOMPILE) $(NO_WMISSING_FIELD_INITIALIZERS) -c -o $@ @archdefs@ $<
612endif
35d0a169 613
49293ef7
NC
614$(srcdir)/rx-decode.c: @MAINT@ $(srcdir)/rx-decode.opc opc2c$(EXEEXT_FOR_BUILD)
615 ./opc2c$(EXEEXT_FOR_BUILD) $(srcdir)/rx-decode.opc > $(srcdir)/rx-decode.c
616
617opc2c$(EXEEXT_FOR_BUILD): opc2c.o $(BUILD_LIBS_DEPS)
618 $(LINK_FOR_BUILD) opc2c.o $(BUILD_LIBS)
619
620opc2c.o: opc2c.c $(INCDIR)/libiberty.h
621 $(COMPILE_FOR_BUILD) -c $(srcdir)/opc2c.c
622
ff13a42d
RW
623s390-mkopc$(EXEEXT_FOR_BUILD): s390-mkopc.c
624 $(COMPILE_FOR_BUILD) -o s390-mkopc $(srcdir)/s390-mkopc.c
625
626s390-opc.tab: s390-mkopc$(EXEEXT_FOR_BUILD) s390-opc.txt
627 ./s390-mkopc$(EXEEXT_FOR_BUILD) < $(srcdir)/s390-opc.txt > s390-opc.tab
b6849f55 628
758227f0 629s390-opc.lo: s390-opc.tab
252b5132 630
2eee5593
AM
631z8kgen$(EXEEXT_FOR_BUILD): z8kgen.o $(BUILD_LIB_DEPS)
632 $(LINK_FOR_BUILD) z8kgen.o $(BUILD_LIBS)
ff13a42d
RW
633
634z8kgen.o: z8kgen.c
635 $(COMPILE_FOR_BUILD) -c $(srcdir)/z8kgen.c
636
637$(srcdir)/z8k-opc.h: @MAINT@ z8kgen$(EXEEXT_FOR_BUILD)
638 ./z8kgen$(EXEEXT_FOR_BUILD) -a > $@
639
640z8k-dis.lo: $(srcdir)/z8k-opc.h
641
758227f0
RW
642sh-dis.lo: sh-dis.c
643if am__fastdepCC
644 $(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ @archdefs@ $(srcdir)/sh-dis.c
645 mv -f $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo
646else
647if AMDEP
648 source='sh-dis.c' object='$@' libtool=yes @AMDEPBACKSLASH@
649 DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
650endif
651 $(LTCOMPILE) -c -o $@ @archdefs@ $(srcdir)/sh-dis.c
652endif