* cgen-asm.in (insert_normal): Use CGEN_BOOL_ATTR.
[platform/upstream/binutils.git] / opcodes / Makefile.am
1 ## Process this file with automake to generate Makefile.in
2
3 AUTOMAKE_OPTIONS = cygnus
4
5 SUBDIRS = po
6
7 INCDIR = $(srcdir)/../include
8 BFDDIR = $(srcdir)/../bfd
9 DEP = mkdep
10
11 lib_LTLIBRARIES = libopcodes.la
12
13 # This is where bfd.h lives.
14 BFD_H = ../bfd/bfd.h
15
16 # Header files.
17 HFILES = \
18         arm-opc.h \
19         h8500-opc.h \
20         sh-opc.h \
21         sysdep.h \
22         w65-opc.h \
23         z8k-opc.h
24
25 # C source files that correspond to .o's.
26 CFILES = \
27         a29k-dis.c \
28         alpha-dis.c \
29         alpha-opc.c \
30         arm-dis.c \
31         cgen-asm.c \
32         cgen-dis.c \
33         cgen-opc.c \
34         d10v-dis.c \
35         d10v-opc.c \
36         d30v-dis.c \
37         d30v-opc.c \
38         dis-buf.c \
39         disassemble.c \
40         $(start-sanitize-fr30) \
41         fr30-asm.c \
42         fr30-dis.c \
43         fr30-opc.c \
44         $(end-sanitize-fr30) \
45         h8300-dis.c \
46         h8500-dis.c \
47         hppa-dis.c \
48         i386-dis.c \
49         i960-dis.c \
50         m32r-asm.c \
51         m32r-dis.c \
52         m32r-opc.c \
53         m68k-dis.c \
54         m68k-opc.c \
55         m88k-dis.c \
56         mips-dis.c \
57         mips-opc.c \
58         mips16-opc.c \
59         m10200-dis.c \
60         m10200-opc.c \
61         m10300-dis.c \
62         m10300-opc.c \
63         ns32k-dis.c \
64         ppc-dis.c \
65         ppc-opc.c \
66         sh-dis.c \
67         sparc-dis.c \
68         sparc-opc.c \
69         tic30-dis.c \
70         vax-dis.c \
71         w65-dis.c \
72         z8k-dis.c \
73         z8kgen.c
74
75 ALL_MACHINES = \
76         a29k-dis.lo \
77         alpha-dis.lo \
78         alpha-opc.lo \
79         arc-dis.lo \
80         arc-opc.lo \
81         arm-dis.lo \
82         cgen-asm.lo \
83         cgen-dis.lo \
84         cgen-opc.lo \
85         d10v-dis.lo \
86         d10v-opc.lo \
87         d30v-dis.lo \
88         d30v-opc.lo \
89         $(end-sanitize-fr30) \
90         fr30-asm.lo \
91         fr30-dis.lo \
92         fr30-opc.lo \
93         $(end-sanitize-fr30) \
94         h8300-dis.lo \
95         h8500-dis.lo \
96         hppa-dis.lo \
97         i386-dis.lo \
98         i960-dis.lo \
99         m32r-asm.lo \
100         m32r-dis.lo \
101         m32r-opc.lo \
102         m68k-dis.lo \
103         m68k-opc.lo \
104         m88k-dis.lo \
105         m10200-dis.lo \
106         m10200-opc.lo \
107         m10300-dis.lo \
108         m10300-opc.lo \
109         mips-dis.lo \
110         mips-opc.lo \
111         mips16-opc.lo \
112         ppc-dis.lo \
113         ppc-opc.lo \
114         ns32k-dis.lo \
115         sh-dis.lo \
116         sparc-dis.lo \
117         sparc-opc.lo \
118         tic30-dis.lo \
119         $(start-sanitize-tic80) \
120         tic80-dis.lo \
121         tic80-opc.lo \
122         $(end-sanitize-tic80) \
123         $(start-sanitize-sky) \
124         dvp-dis.lo \
125         dvp-opc.lo \
126         $(end-sanitize-sky) \
127         v850-dis.lo \
128         v850-opc.lo \
129         vax-dis.lo \
130         w65-dis.lo \
131         z8k-dis.lo
132
133 OFILES = @BFD_MACHINES@
134
135 INCLUDES = -D_GNU_SOURCE -I. -I$(srcdir) -I../bfd -I$(INCDIR) -I$(BFDDIR) @HDEFINES@ -I$(srcdir)/../intl -I../intl
136
137 disassemble.lo: disassemble.c $(INCDIR)/dis-asm.h
138         $(LIBTOOL) --mode=compile $(COMPILE) -c @archdefs@ $(srcdir)/disassemble.c
139
140 libopcodes_la_SOURCES =  dis-buf.c disassemble.c
141 libopcodes_la_DEPENDENCIES = $(OFILES)
142 libopcodes_la_LIBADD = $(OFILES) @WIN32LIBADD@
143 libopcodes_la_LDFLAGS = -release $(VERSION) @WIN32LDFLAGS@
144
145 # libtool will build .libs/libopcodes.a.  We create libopcodes.a in
146 # the build directory so that we don't have to convert all the
147 # programs that use libopcodes.a simultaneously.  This is a hack which
148 # should be removed if everything else starts using libtool.  FIXME.
149
150 noinst_LIBRARIES = libopcodes.a
151
152 stamp-lib: libopcodes.la
153         if [ -f .libs/libopcodes.a ]; then \
154           cp .libs/libopcodes.a libopcodes.tmp; \
155           $(SHELL) $(srcdir)/../move-if-change libopcodes.tmp libopcodes.a; \
156         else true; fi
157         touch stamp-lib
158
159 libopcodes.a: stamp-lib ; @true
160
161 POTFILES = $(HFILES) $(CFILES)
162 po/POTFILES.in: @MAINT@ Makefile
163         for file in $(POTFILES); do echo $$file; done | sort > tmp \
164           && mv tmp $(srcdir)/po/POTFILES.in
165
166 # We should reconfigure whenever bfd/configure.in changes, because
167 # that's where the version number comes from.
168 config.status: $(srcdir)/configure $(srcdir)/../bfd/configure.in
169         $(SHELL) ./config.status --recheck
170
171 CLEANFILES = libopcodes.a stamp-lib dep.sed .dep .dep1
172 # start-sanitize-cygnus
173 CLEANFILES = libopcodes.a stamp-lib dep.sed .dep .dep1 stamp-m32r
174 # end-sanitize-cygnus
175 # start-sanitize-fr30
176 CLEANFILES = libopcodes.a stamp-lib dep.sed .dep .dep1 stamp-m32r stamp-fr30
177 # end-sanitize-fr30
178
179 # start-sanitize-cygnus
180 # CGEN support is sanitized out of FSF releases for now.
181 # Sanitization must be split between assignments and rules because
182 # automake splits them that way.
183
184 CGENDIR = @cgendir@
185 CGEN = @cgen@
186 CGENFLAGS = -v
187
188 CGENFILES = $(CGENDIR)/cos.scm $(CGENDIR)/utils.scm \
189         $(CGENDIR)/attr.scm $(CGENDIR)/enum.scm $(CGENDIR)/types.scm \
190         $(CGENDIR)/utils-cgen.scm $(CGENDIR)/cpu.scm \
191         $(CGENDIR)/mode.scm $(CGENDIR)/mach.scm \
192         $(CGENDIR)/model.scm $(CGENDIR)/hardware.scm \
193         $(CGENDIR)/ifield.scm $(CGENDIR)/iformat.scm \
194         $(CGENDIR)/operand.scm $(CGENDIR)/insn.scm $(CGENDIR)/minsn.scm \
195         $(CGENDIR)/opcodes.scm $(CGENDIR)/rtl.scm \
196         $(CGENDIR)/cgen-opc.scm cgen-opc.in cgen-asm.in cgen-dis.in
197 # The CGEN_MAINT conditional is put here so it ends up in Makefile.in
198 # properly sanitized.
199 if CGEN_MAINT
200 M32R_DEPS = stamp-m32r
201 FR30_DEPS = stamp-fr30
202 else
203 M32R_DEPS =
204 FR30_DEPS =
205 endif
206 # The end marker is written this way to pass through automake unscathed.
207 ENDSAN = end-sanitize-cygnus
208
209 # start-sanitize-cygnus
210 run-cgen:
211         $(SHELL) $(srcdir)/cgen.sh opcodes $(srcdir) $(CGEN) $(CGENDIR) $(CGENFLAGS) $(arch) $(prefix)
212         touch stamp-${prefix}
213 .PHONY: run-cgen
214
215 # For now, require developers to configure with --enable-cgen-maint.
216 m32r-opc.h m32r-opc.c m32r-asm.c m32r-dis.c: $(M32R_DEPS)
217         @true
218 stamp-m32r: $(CGENFILES) $(CGENDIR)/m32r.cpu $(CGENDIR)/m32r.opc
219         $(MAKE) run-cgen arch=m32r prefix=m32r
220 # end-sanitize-cygnus
221 # start-sanitize-fr30
222 fr30-opc.h fr30-opc.c fr30-asm.c fr30-dis.c: $(FR30_DEPS)
223         @true
224 stamp-fr30: $(CGENFILES) $(CGENDIR)/fr30.cpu $(CGENDIR)/fr30.opc
225         $(MAKE) run-cgen arch=fr30 prefix=fr30
226 # end-sanitize-fr30
227
228 # start-sanitize-tic80
229 tic80-dis.lo: tic80-dis.c $(INCDIR)/dis-asm.h ../bfd/bfd.h \
230         $(INCDIR)/opcode/tic80.h
231 tic80-opc.lo: tic80-opc.c $(INCDIR)/opcode/tic80.h
232 # end-sanitize-tic80
233
234 # start-sanitize-sky
235 dvp-dis.lo: dvp-dis.c $(INCDIR)/dis-asm.h ../bfd/bfd.h \
236         $(INCDIR)/opcode/dvp.h
237 dvp-opc.lo: dvp-opc.c $(INCDIR)/opcode/dvp.h
238
239 mips-dis.lo: mips-dis.c
240         $(LIBTOOL) --mode=compile $(COMPILE) -c @archdefs@ $(srcdir)/mips-dis.c
241 # end-sanitize-sky
242
243 # start-sanitize-fr30
244 fr30-asm.lo: fr30-asm.c sysdep.h config.h $(BFD_H) \
245   $(INCDIR)/symcat.h fr30-opc.h $(INCDIR)/opcode/cgen.h \
246   opintl.h
247 fr30-dis.lo: fr30-dis.c sysdep.h config.h $(INCDIR)/dis-asm.h \
248   $(BFD_H) $(INCDIR)/symcat.h fr30-opc.h $(INCDIR)/opcode/cgen.h \
249   opintl.h
250 fr30-opc.lo: fr30-opc.c sysdep.h config.h $(INCDIR)/libiberty.h \
251   $(BFD_H) $(INCDIR)/symcat.h fr30-opc.h $(INCDIR)/opcode/cgen.h \
252   opintl.h
253 # end-sanitize-fr30
254
255 # This dependency stuff is copied from BFD.
256
257 .dep: dep.sed $(CFILES) $(HFILES) config.h
258         rm -f .dep1
259         $(MAKE) DEP=$(DEP) .dep1
260         sed -f dep.sed < .dep1 > .dep
261
262 .dep1: $(CFILES)
263         rm -f .dep2 .dep2a
264         echo '# DO NOT DELETE THIS LINE -- mkdep uses it.' > .dep2
265         echo > .dep2a
266         $(DEP) -f .dep2a $(INCLUDES) $(CFLAGS) $?
267         sed -e '/DO NOT DELETE/d' -e '/^$$/d' < .dep2a >> .dep2
268         rm -f .dep2a
269         $(srcdir)/../move-if-change .dep2 .dep1
270
271 dep.sed: dep-in.sed config.status
272         sed <$(srcdir)/dep-in.sed >dep.sed      \
273                 -e 's!@BFD_H@!$(BFD_H)!'        \
274                 -e 's!@INCDIR@!$(INCDIR)!'      \
275                 -e 's!@BFDDIR@!$(BFDDIR)!'      \
276                 -e 's!@SRCDIR@!$(srcdir)!'
277
278 dep: .dep
279         sed -e '/^..DO NOT DELETE THIS LINE/,$$d' < Makefile > tmp-Makefile
280         cat .dep >> tmp-Makefile
281         $(srcdir)/../move-if-change tmp-Makefile Makefile
282
283 dep-in: .dep
284         sed -e '/^..DO NOT DELETE THIS LINE/,$$d' < $(srcdir)/Makefile.in > tmp-Makefile.in
285         cat .dep >> tmp-Makefile.in
286         $(srcdir)/../move-if-change tmp-Makefile.in $(srcdir)/Makefile.in
287
288 dep-am: .dep
289         sed -e '/^..DO NOT DELETE THIS LINE/,$$d' < $(srcdir)/Makefile.am > tmp-Makefile.am
290         cat .dep >> tmp-Makefile.am
291         $(srcdir)/../move-if-change tmp-Makefile.am $(srcdir)/Makefile.am
292
293 .PHONY: dep dep-in dep-am
294
295 # What appears below is generated by a hacked mkdep using gcc -MM.
296
297 # DO NOT DELETE THIS LINE -- mkdep uses it.
298 # DO NOT PUT ANYTHING AFTER THIS LINE, IT WILL GO AWAY.
299 a29k-dis.lo: a29k-dis.c $(INCDIR)/dis-asm.h $(BFD_H) \
300   $(INCDIR)/ansidecl.h $(INCDIR)/opcode/a29k.h
301 alpha-dis.lo: alpha-dis.c $(INCDIR)/ansidecl.h sysdep.h \
302   config.h $(INCDIR)/dis-asm.h $(BFD_H) $(INCDIR)/opcode/alpha.h
303 alpha-opc.lo: alpha-opc.c $(INCDIR)/ansidecl.h $(INCDIR)/opcode/alpha.h \
304   $(BFD_H) opintl.h
305 arm-dis.lo: arm-dis.c $(INCDIR)/dis-asm.h $(BFD_H) \
306   $(INCDIR)/ansidecl.h arm-opc.h $(INCDIR)/coff/internal.h \
307   $(BFDDIR)/libcoff.h $(INCDIR)/bfdlink.h opintl.h $(BFDDIR)/elf-bfd.h \
308   $(INCDIR)/elf/common.h $(INCDIR)/elf/internal.h $(INCDIR)/elf/external.h
309 cgen-asm.lo: cgen-asm.c sysdep.h config.h $(INCDIR)/libiberty.h \
310   $(BFD_H) $(INCDIR)/symcat.h $(INCDIR)/opcode/cgen.h \
311   opintl.h
312 cgen-dis.lo: cgen-dis.c sysdep.h config.h $(INCDIR)/libiberty.h \
313   $(BFD_H) $(INCDIR)/symcat.h $(INCDIR)/opcode/cgen.h
314 cgen-opc.lo: cgen-opc.c sysdep.h config.h $(INCDIR)/libiberty.h \
315   $(BFD_H) $(INCDIR)/symcat.h $(INCDIR)/opcode/cgen.h
316 d10v-dis.lo: d10v-dis.c $(INCDIR)/ansidecl.h $(INCDIR)/opcode/d10v.h \
317   $(INCDIR)/dis-asm.h $(BFD_H)
318 d10v-opc.lo: d10v-opc.c $(INCDIR)/ansidecl.h $(INCDIR)/opcode/d10v.h
319 d30v-dis.lo: d30v-dis.c $(INCDIR)/opcode/d30v.h $(INCDIR)/dis-asm.h \
320   $(BFD_H) $(INCDIR)/ansidecl.h opintl.h
321 d30v-opc.lo: d30v-opc.c $(INCDIR)/ansidecl.h $(INCDIR)/opcode/d30v.h
322 dis-buf.lo: dis-buf.c sysdep.h config.h $(INCDIR)/dis-asm.h \
323   $(BFD_H) opintl.h
324 disassemble.lo: disassemble.c $(INCDIR)/ansidecl.h \
325   $(INCDIR)/dis-asm.h $(BFD_H)
326 h8300-dis.lo: h8300-dis.c $(INCDIR)/opcode/h8300.h \
327   $(INCDIR)/dis-asm.h $(BFD_H) $(INCDIR)/ansidecl.h opintl.h
328 h8500-dis.lo: h8500-dis.c h8500-opc.h $(INCDIR)/dis-asm.h \
329   $(BFD_H) $(INCDIR)/ansidecl.h opintl.h
330 hppa-dis.lo: hppa-dis.c sysdep.h config.h $(INCDIR)/dis-asm.h \
331   $(BFD_H) $(BFDDIR)/libhppa.h $(INCDIR)/opcode/hppa.h
332 i386-dis.lo: i386-dis.c $(INCDIR)/dis-asm.h $(BFD_H) \
333   $(INCDIR)/ansidecl.h sysdep.h config.h opintl.h
334 i960-dis.lo: i960-dis.c $(INCDIR)/dis-asm.h $(BFD_H) \
335   $(INCDIR)/ansidecl.h
336 m32r-asm.lo: m32r-asm.c sysdep.h config.h $(BFD_H) \
337   $(INCDIR)/symcat.h m32r-opc.h $(INCDIR)/opcode/cgen.h \
338   opintl.h
339 m32r-dis.lo: m32r-dis.c sysdep.h config.h $(INCDIR)/dis-asm.h \
340   $(BFD_H) $(INCDIR)/symcat.h m32r-opc.h $(INCDIR)/opcode/cgen.h \
341   opintl.h
342 m32r-opc.lo: m32r-opc.c sysdep.h config.h $(INCDIR)/libiberty.h \
343   $(BFD_H) $(INCDIR)/symcat.h m32r-opc.h $(INCDIR)/opcode/cgen.h \
344   opintl.h
345 m68k-dis.lo: m68k-dis.c $(INCDIR)/dis-asm.h $(BFD_H) \
346   $(INCDIR)/ansidecl.h $(INCDIR)/floatformat.h opintl.h \
347   $(INCDIR)/opcode/m68k.h
348 m68k-opc.lo: m68k-opc.c $(INCDIR)/ansidecl.h $(INCDIR)/opcode/m68k.h
349 m88k-dis.lo: m88k-dis.c $(INCDIR)/dis-asm.h $(BFD_H) \
350   $(INCDIR)/ansidecl.h $(INCDIR)/opcode/m88k.h opintl.h
351 mips-dis.lo: mips-dis.c sysdep.h config.h $(INCDIR)/dis-asm.h \
352   $(BFD_H) $(INCDIR)/opcode/mips.h opintl.h $(BFDDIR)/elf-bfd.h \
353   $(INCDIR)/elf/common.h $(INCDIR)/elf/internal.h $(INCDIR)/elf/external.h \
354   $(INCDIR)/bfdlink.h $(INCDIR)/elf/mips.h $(INCDIR)/elf/reloc-macros.h
355 mips-opc.lo: mips-opc.c $(INCDIR)/ansidecl.h $(INCDIR)/opcode/mips.h
356 mips16-opc.lo: mips16-opc.c $(INCDIR)/ansidecl.h $(INCDIR)/opcode/mips.h
357 m10200-dis.lo: m10200-dis.c $(INCDIR)/ansidecl.h $(INCDIR)/opcode/mn10200.h \
358   $(INCDIR)/dis-asm.h $(BFD_H) opintl.h
359 m10200-opc.lo: m10200-opc.c $(INCDIR)/ansidecl.h $(INCDIR)/opcode/mn10200.h
360 m10300-dis.lo: m10300-dis.c $(INCDIR)/ansidecl.h $(INCDIR)/opcode/mn10300.h \
361   $(INCDIR)/dis-asm.h $(BFD_H) opintl.h
362 m10300-opc.lo: m10300-opc.c $(INCDIR)/ansidecl.h $(INCDIR)/opcode/mn10300.h
363 ns32k-dis.lo: ns32k-dis.c $(BFD_H) $(INCDIR)/ansidecl.h \
364   sysdep.h config.h $(INCDIR)/dis-asm.h $(INCDIR)/opcode/ns32k.h \
365   opintl.h
366 ppc-dis.lo: ppc-dis.c $(INCDIR)/ansidecl.h sysdep.h \
367   config.h $(INCDIR)/dis-asm.h $(BFD_H) $(INCDIR)/opcode/ppc.h
368 ppc-opc.lo: ppc-opc.c $(INCDIR)/ansidecl.h $(INCDIR)/opcode/ppc.h \
369   opintl.h
370 sh-dis.lo: sh-dis.c sh-opc.h $(INCDIR)/dis-asm.h $(BFD_H) \
371   $(INCDIR)/ansidecl.h
372 sparc-dis.lo: sparc-dis.c $(INCDIR)/ansidecl.h sysdep.h \
373   config.h $(INCDIR)/opcode/sparc.h $(INCDIR)/dis-asm.h \
374   $(BFD_H) $(INCDIR)/libiberty.h opintl.h
375 sparc-opc.lo: sparc-opc.c $(INCDIR)/ansidecl.h $(INCDIR)/opcode/sparc.h
376 tic30-dis.lo: tic30-dis.c $(INCDIR)/dis-asm.h $(BFD_H) \
377   $(INCDIR)/ansidecl.h $(INCDIR)/opcode/tic30.h
378 vax-dis.lo: vax-dis.c $(INCDIR)/opcode/vax.h $(INCDIR)/dis-asm.h \
379   $(BFD_H) $(INCDIR)/ansidecl.h
380 w65-dis.lo: w65-dis.c w65-opc.h $(INCDIR)/dis-asm.h \
381   $(BFD_H) $(INCDIR)/ansidecl.h
382 z8k-dis.lo: z8k-dis.c sysdep.h config.h $(INCDIR)/dis-asm.h \
383   $(BFD_H) z8k-opc.h
384 z8kgen.lo: z8kgen.c sysdep.h config.h
385 # IF YOU PUT ANYTHING HERE IT WILL GO AWAY