Commit | Line | Data |
---|---|---|
d8474a9b | 1 | # Makefile for GNU binary-file utilities |
d8e89b6b | 2 | # Copyright (C) 1989-1992 Free Software Foundation, Inc. |
d8474a9b PB |
3 | |
4 | # This file is part of GNU binutils. | |
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 2 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, write to the Free Software | |
18 | # Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. | |
99a42820 RP |
19 | |
20 | #$Id$ | |
21 | ||
a10d26a1 | 22 | srcdir = . |
84396dcf | 23 | |
d8e89b6b RP |
24 | prefix = /usr/local |
25 | ||
26 | program_prefix = | |
27 | exec_prefix = $(prefix) | |
28 | bindir = $(exec_prefix)/bin | |
29 | libdir = $(exec_prefix)/lib | |
30 | tooldir = $(libdir) | |
31 | ||
32 | datadir = $(prefix)/lib | |
33 | mandir = $(prefix)/man | |
34 | man1dir = $(mandir)/man1 | |
35 | man2dir = $(mandir)/man2 | |
36 | man3dir = $(mandir)/man3 | |
37 | man4dir = $(mandir)/man4 | |
38 | man5dir = $(mandir)/man5 | |
39 | man6dir = $(mandir)/man6 | |
40 | man7dir = $(mandir)/man7 | |
41 | man8dir = $(mandir)/man8 | |
42 | man9dir = $(mandir)/man9 | |
43 | infodir = $(prefix)/info | |
44 | includedir = $(prefix)/include | |
45 | docdir = $(datadir)/doc | |
84396dcf RP |
46 | |
47 | SHELL = /bin/sh | |
d8e89b6b RP |
48 | |
49 | INSTALL = install -c | |
50 | INSTALL_PROGRAM = $(INSTALL) | |
51 | INSTALL_DATA = $(INSTALL) | |
52 | ||
53 | AR = ar | |
54 | AR_FLAGS = qv | |
55 | CFLAGS = -g | |
56 | BISON = bison -y | |
57 | FLEX = flex | |
58 | MAKEINFO = makeinfo | |
59 | RANLIB = ranlib | |
60 | BISONFLAGS = -tvd | |
c83497f5 | 61 | TEXI2ROFF=texi2roff |
b5132a6b | 62 | |
8539db10 | 63 | # Distribution version |
d8e89b6b | 64 | VERSION=1.96 |
8539db10 | 65 | # Distribution name |
d8e89b6b | 66 | DIST_NAME=binutils-${VERSION} |
8539db10 | 67 | |
d8e89b6b | 68 | version=`./../gcc/gcc -dumpversion` |
b5132a6b | 69 | |
6b583720 | 70 | # Where to find texinfo.tex to format docn with TeX |
b7a11ec2 RP |
71 | TEXIDIR = $(srcdir)/../texinfo/fsf |
72 | ||
84396dcf RP |
73 | MANPAGES= ar.1 nm.1 objdump.1 ranlib.1 size.1 strip.1 |
74 | ||
a10d26a1 | 75 | #CC=gcc -Wall |
06a97fbd | 76 | # these two are almost the same program |
a10d26a1 RP |
77 | AR_PROG=ar |
78 | RANLIB_PROG=ranlib | |
99a42820 RP |
79 | |
80 | # copy and strip should be the same program | |
a10d26a1 RP |
81 | COPY_PROG=copy |
82 | STRIP_PROG=strip | |
99a42820 RP |
83 | |
84 | # These should all be the same program too. | |
a10d26a1 RP |
85 | SIZE_PROG=size |
86 | NM_PROG=nm | |
87 | OBJDUMP_PROG=objdump | |
99a42820 | 88 | |
d8e89b6b | 89 | PROGS = $(SIZE_PROG) $(OBJDUMP_PROG) $(NM_PROG) $(AR_PROG) $(STRIP_PROG) $(RANLIB_PROG) |
a01bf1fb | 90 | STAGESTUFF = $(PROGS) *.o |
99a42820 | 91 | |
40773f7f | 92 | BASEDIR = $(srcdir)/.. |
d8e89b6b | 93 | LIBDIR = ./../bfd |
a10d26a1 | 94 | |
a10d26a1 RP |
95 | #### host and target dependant Makefile fragments come in here. |
96 | ### | |
97 | ||
9bba7784 | 98 | INCDIR = $(BASEDIR)/include |
99a42820 | 99 | |
d8e89b6b RP |
100 | .c.o: |
101 | $(CC) -c $(CFLAGS) -I. -I$(srcdir) -I$(INCDIR) $(HDEFINES) $(TDEFINES) $< | |
99a42820 | 102 | |
a26878d1 RP |
103 | # When adding .o files, to make VPATH work in Sun Make, you have to |
104 | # also add a foo.o: foo.c line at the bottom of the file. | |
60c80016 | 105 | DISASMS = m68k-pinsn.o i960-pinsn.o i386-pinsn.o sparc-pinsn.o am29k-pinsn.o |
6a3958b2 | 106 | |
99a42820 RP |
107 | #\f |
108 | ## Random definitions | |
109 | # Hopefully all these may be flushed once we get configuration down pat. | |
110 | ||
111 | # alloca only needed for systems which don't have it and when cc != gcc. | |
112 | # ALLOCA = alloca.o | |
113 | ||
114 | # nm tries to malloc enough space for the string table. The old GNU malloc | |
115 | # rounds this up to a power of two (e.g. 5M becomes 8M), and so it might | |
116 | # fail unnecessarily. I've also seen some Unix malloc's fail, even when | |
117 | # there is enough memory. So use the new GNU malloc. | |
118 | # MALLOC = gmalloc.o | |
119 | ||
120 | # Use the GNU getopt unless you have problems with it. | |
121 | # The IRIS version could probably benefit from being assembled with | |
122 | # libmalloc rather than the ordinary malloc. | |
d8e89b6b | 123 | LIBIBERTY = ./../libiberty/libiberty.a |
99a42820 RP |
124 | |
125 | # Code shared by all the binutils. | |
a10d26a1 | 126 | BULIBS = bucomm.o version.o filemode.o |
99a42820 | 127 | |
7a5a3c7b | 128 | ADDL_LIBS = $(MALLOC) $(BULIBS) $(BFD) $(LIBIBERTY) |
99a42820 RP |
129 | |
130 | BFD = $(LIBDIR)/libbfd.a | |
131 | #\f | |
132 | ## The rules | |
133 | ||
c83497f5 RP |
134 | all: $(ADDL_LIBS) $(PROGS) |
135 | ||
d8e89b6b RP |
136 | check: |
137 | ||
138 | info: binutils.info | |
a10d26a1 RP |
139 | |
140 | #$(BFD):$(LIBDIR)/../common/*.c | |
141 | # (cd $(LIBDIR); make) | |
99a42820 | 142 | |
a10d26a1 | 143 | $(SIZE_PROG): $(ADDL_LIBS) size.o $(BFD) |
6a3958b2 | 144 | $(CC) $(LDFLAGS) $(CFLAGS) -o $(SIZE_PROG) size.o $(ADDL_LIBS) $(LOADLIBES) |
99a42820 | 145 | |
d8e89b6b RP |
146 | $(COPY_PROG): $(ADDL_LIBS) copy.o not-strip.o $(BFD) |
147 | $(CC) $(LDFLAGS) $(CFLAGS) -o $(COPY_PROG) copy.o not-strip.o $(ADDL_LIBS) $(LOADLIBES) | |
148 | ||
149 | $(STRIP_PROG): $(ADDL_LIBS) copy.o is-strip.o $(BFD) | |
150 | $(CC) $(LDFLAGS) $(CFLAGS) -o $(STRIP_PROG) copy.o is-strip.o $(ADDL_LIBS) $(LOADLIBES) | |
99a42820 | 151 | |
a10d26a1 | 152 | $(NM_PROG): $(ADDL_LIBS) nm.o $(BFD) |
6a3958b2 | 153 | $(CC) $(LDFLAGS) $(CFLAGS) -o $(NM_PROG) nm.o $(ADDL_LIBS) $(LOADLIBES) |
99a42820 | 154 | |
a10d26a1 | 155 | $(OBJDUMP_PROG): $(ADDL_LIBS) size.o objdump.o $(DISASMS) $(BFD) |
6a3958b2 | 156 | $(CC) $(LDFLAGS) $(CFLAGS) -o $(OBJDUMP_PROG) objdump.o $(DISASMS) $(ADDL_LIBS) $(LOADLIBES) |
99a42820 | 157 | |
d8e89b6b RP |
158 | arparse.c:arparse.y |
159 | $(BISON) $(BISONFLAGS) $(VPATH)/arparse.y | |
160 | mv y.tab.c arparse.c | |
161 | mv y.tab.h arparse.h | |
162 | ||
99a42820 | 163 | |
d8e89b6b RP |
164 | arlex.c:arlex.l |
165 | $(FLEX) -I -Cem -t $(VPATH)/arlex.l >arlex.c | |
166 | ||
167 | $(AR_PROG): $(ADDL_LIBS) ar.o arparse.o arlex.o not-ranlib.o $(BFD) arsup.o | |
168 | $(CC) $(LDFLAGS) $(CFLAGS) -o $(AR_PROG) ar.o arparse.o arlex.o arsup.o not-ranlib.o $(ADDL_LIBS) $(LOADLIBES) | |
169 | ||
170 | $(RANLIB_PROG): $(ADDL_LIBS) ar.o is-ranlib.o arparse.o arlex.o arsup.o $(BFD) | |
171 | $(CC) $(LDFLAGS) $(CFLAGS) -o $(RANLIB_PROG) ar.o arparse.o arlex.o arsup.o is-ranlib.o $(ADDL_LIBS) $(LOADLIBES) | |
06a97fbd PB |
172 | |
173 | # This rule creates a single binary that switches between ar and ranlib | |
174 | # by looking at argv[0]. Use this kludge to save some disk space. | |
175 | # However, you have to install things by hand. | |
176 | # (That is after 'make install', replace the installed ranlib by a link to ar.) | |
177 | ||
178 | # Alternatively, you can install ranlib.sh as ranlib. | |
179 | ||
180 | ar_with_ranlib: $(ADDL_LIBS) ar.o maybe-ranlib.o $(BFD) | |
181 | $(CC) $(LDFLAGS) $(CFLAGS) -o $(AR_PROG) ar.o maybe-ranlib.o $(ADDL_LIBS) $(LOADLIBES) | |
a10d26a1 RP |
182 | -rm -f $(RANLIB_PROG) |
183 | -ln $(AR_PROG) $(RANLIB_PROG) | |
99a42820 | 184 | |
d8e89b6b RP |
185 | # copy and strip in one binary that uses argv[0] to decide its action. |
186 | ||
187 | copy_with_strip: $(ADDL_LIBS) copy.o maybe-strip.o $(BFD) | |
188 | $(CC) $(LDFLAGS) $(CFLAGS) -o $(COPY_PROG) copy.o maybe-strip.o $(ADDL_LIBS) $(LOADLIBES) | |
a10d26a1 RP |
189 | -rm -f $(STRIP_PROG) |
190 | -ln $(COPY_PROG) $(STRIP_PROG) | |
99a42820 | 191 | |
6a3958b2 RP |
192 | stage1: force |
193 | - mkdir stage1 | |
a01bf1fb | 194 | - mv -f $(STAGESTUFF) stage1 |
6a3958b2 RP |
195 | |
196 | stage2: force | |
197 | - mkdir stage2 | |
a01bf1fb | 198 | - mv -f $(STAGESTUFF) stage2 |
6a3958b2 RP |
199 | |
200 | stage3: force | |
201 | - mkdir stage3 | |
a01bf1fb RP |
202 | - mv -f $(STAGESTUFF) stage3 |
203 | ||
204 | against=stage2 | |
205 | ||
206 | comparison: force | |
207 | for i in $(STAGESTUFF) ; do cmp $$i $(against)/$$i ; done | |
6a3958b2 RP |
208 | |
209 | de-stage1: force | |
210 | - (cd stage1 ; mv -f * ..) | |
211 | - rmdir stage1 | |
212 | ||
213 | de-stage2: force | |
214 | - (cd stage2 ; mv -f * ..) | |
215 | - rmdir stage2 | |
216 | ||
217 | de-stage3: force | |
218 | - (cd stage3 ; mv -f * ..) | |
219 | - rmdir stage3 | |
220 | ||
6b583720 RP |
221 | ###################################################################### |
222 | # DOCUMENTATION TARGETS | |
223 | # TeX output | |
2226a090 RP |
224 | binutils.dvi: $(srcdir)/binutils.texi |
225 | TEXINPUTS=${TEXIDIR}:.:$$TEXINPUTS tex $(srcdir)/binutils.texi | |
b7a11ec2 | 226 | texindex binutils.?? |
2226a090 | 227 | TEXINPUTS=${TEXIDIR}:.:$$TEXINPUTS tex $(srcdir)/binutils.texi |
b7a11ec2 | 228 | |
6b583720 | 229 | # info file for online browsing |
2226a090 | 230 | binutils.info: $(srcdir)/binutils.texi |
6141fd50 | 231 | $(MAKEINFO) -o binutils.info $(srcdir)/binutils.texi |
b7a11ec2 | 232 | |
0c10ff03 | 233 | # different targets for -ms, -mm, -me |
c83497f5 RP |
234 | # Try to use a recent texi2roff. v2 was put on prep in jan91. |
235 | # If you want an index, see texi2roff doc for postprocessing | |
236 | # and add -i to texi2roff invocations below. | |
237 | # Workarounds for texi2roff-2 (probably fixed in later texi2roff's, delete | |
238 | # correspondint -e lines when later texi2roff's are current) | |
239 | # + @ifinfo's deleted explicitly due to texi2roff-2 bug w nested constructs. | |
240 | # + @c's deleted explicitly because texi2roff sees texinfo commands in them | |
241 | # + @ (that's at-BLANK) not recognized by texi2roff, turned into blank | |
242 | # + @alphaenumerate is ridiculously new, turned into @enumerate | |
243 | ||
0c10ff03 | 244 | # roff output (-ms) |
2226a090 | 245 | binutils.ms: $(srcdir)/binutils.texi |
6b583720 RP |
246 | sed -e '/\\input texinfo/d' \ |
247 | -e '/@c TEXI2ROFF-KILL/,/@c END TEXI2ROFF-KILL/d' \ | |
c83497f5 RP |
248 | -e '/^@ifinfo/,/^@end ifinfo/d' \ |
249 | -e '/^@c/d' \ | |
2226a090 | 250 | -e 's/{.*,,/{/' \ |
c83497f5 RP |
251 | -e 's/@ / /g' \ |
252 | -e 's/^@alphaenumerate/@enumerate/g' \ | |
253 | -e 's/^@end alphaenumerate/@end enumerate/g' \ | |
2226a090 | 254 | $(srcdir)/binutils.texi | \ |
d8e89b6b | 255 | $(TEXI2ROFF) -ms | \ |
c83497f5 RP |
256 | sed -e 's/---/\\(em/g' \ |
257 | >binutils.ms | |
6b583720 | 258 | |
0c10ff03 | 259 | # roff output (-mm) |
c83497f5 RP |
260 | # '@noindent's removed due to texi2roff-2 mm bug; if yours is newer, |
261 | # try leaving them in | |
2226a090 | 262 | binutils.mm: $(srcdir)/binutils.texi |
0c10ff03 RP |
263 | sed -e '/\\input texinfo/d' \ |
264 | -e '/@c TEXI2ROFF-KILL/,/@c END TEXI2ROFF-KILL/d' \ | |
c83497f5 RP |
265 | -e '/^@ifinfo/,/^@end ifinfo/d' \ |
266 | -e '/^@c/d' \ | |
2226a090 RP |
267 | -e 's/{.*,,/{/' \ |
268 | -e '/@noindent/d' \ | |
c83497f5 RP |
269 | -e 's/@ / /g' \ |
270 | -e 's/^@alphaenumerate/@enumerate/g' \ | |
271 | -e 's/^@end alphaenumerate/@end enumerate/g' \ | |
2226a090 | 272 | $(srcdir)/binutils.texi | \ |
d8e89b6b | 273 | $(TEXI2ROFF) -mm | \ |
2226a090 RP |
274 | sed -e 's/---/\\(em/g' \ |
275 | >binutils.mm | |
0c10ff03 RP |
276 | |
277 | # roff output (-me) | |
2226a090 | 278 | binutils.me: $(srcdir)/binutils.texi |
0c10ff03 RP |
279 | sed -e '/\\input texinfo/d' \ |
280 | -e '/@c TEXI2ROFF-KILL/,/@c END TEXI2ROFF-KILL/d' \ | |
c83497f5 RP |
281 | -e '/^@ifinfo/,/^@end ifinfo/d' \ |
282 | -e '/^@c/d' \ | |
2226a090 | 283 | -e 's/{.*,,/{/' \ |
c83497f5 RP |
284 | -e 's/@ / /g' \ |
285 | -e 's/^@alphaenumerate/@enumerate/g' \ | |
286 | -e 's/^@end alphaenumerate/@end enumerate/g' \ | |
2226a090 | 287 | $(srcdir)/binutils.texi | \ |
d8e89b6b | 288 | $(TEXI2ROFF) -me | \ |
c83497f5 RP |
289 | sed -e 's/---/\\(em/g' \ |
290 | >binutils.me | |
0c10ff03 RP |
291 | |
292 | ||
6b583720 RP |
293 | ###################################################################### |
294 | ||
99a42820 | 295 | clean: |
b7a11ec2 | 296 | -rm -f *.o *~ \#* core $(STAGESTUFF) TAGS binutils.?? binutils.??? |
99a42820 RP |
297 | |
298 | etags tags: TAGS | |
299 | ||
6a3958b2 | 300 | TAGS: force |
99a42820 RP |
301 | etags $(INCDIR)/*.h $(BFDSRC)/*.[hc] *.[hc] |
302 | ||
303 | realclean: clean | |
a01bf1fb | 304 | -rm -f $(STAGESTUFF) TAGS |
99a42820 | 305 | |
c83497f5 | 306 | install: all |
b5132a6b | 307 | for i in $(PROGS) ; do \ |
d8e89b6b | 308 | $(INSTALL_PROGRAM) $$i $(bindir)/$(program_prefix)$$i ; \ |
99a42820 | 309 | done |
84396dcf | 310 | for i in $(MANPAGES) ; do \ |
d8e89b6b | 311 | $(INSTALL_DATA) $(srcdir)/$$i $(man1dir)/$(program_prefix)$$i ; \ |
de53632c | 312 | done |
c83497f5 | 313 | |
d8e89b6b | 314 | install-info: info |
de53632c | 315 | for i in *.info* ; do \ |
d8e89b6b | 316 | $(INSTALL_DATA) $$i $(infodir)/$$i ; \ |
84396dcf | 317 | done |
99a42820 | 318 | |
d8e89b6b RP |
319 | clean-info: |
320 | -rm -rf *.info* | |
321 | ||
8539db10 PB |
322 | dist: $(DIST_NAME).tar.Z |
323 | ||
d8474a9b | 324 | $(DIST_NAME).tar.Z: |
b27d2046 PB |
325 | cd ../..; rm -f $(DIST_NAME); ln -s devo $(DIST_NAME) |
326 | make binutils.mm -f Makefile.in | |
d8474a9b PB |
327 | cd ../ld; make ld.mm -f Makefile.in |
328 | cd ../..; tar chf - $(DIST_NAME) | compress >$(DIST_NAME).tar.Z | |
b27d2046 | 329 | rm -rf ../../$(DIST_NAME) |
8539db10 | 330 | |
d7cce023 JG |
331 | # These get around a bug in Sun Make in SunOS 4.1.1 |
332 | alloca.o:alloca.c | |
a26878d1 | 333 | am29k-pinsn.o: am29k-pinsn.c |
99a42820 | 334 | ar.o: ar.c |
d7cce023 JG |
335 | bucomm.o: bucomm.c |
336 | copy.o: copy.c | |
337 | cplus-dem.o:cplus-dem.c | |
338 | filemode.o:filemode.c | |
a10d26a1 RP |
339 | getopt.o:getopt.c |
340 | getopt1.o:getopt1.c | |
d7cce023 JG |
341 | gmalloc.o:gmalloc.c |
342 | i960-pinsn.o: i960-pinsn.c | |
343 | is-ranlib.o:is-ranlib.c | |
d8e89b6b | 344 | is-strip.o:is-strip.c |
d7cce023 JG |
345 | m68k-pinsn.o: m68k-pinsn.c |
346 | maybe-ranlib.o:maybe-ranlib.c | |
d8e89b6b | 347 | maybe-strip.o:maybe-strip.c |
d7cce023 JG |
348 | nm.o: nm.c |
349 | not-ranlib.o:not-ranlib.c | |
d8e89b6b | 350 | not-strip.o:not-strip.c |
d7cce023 JG |
351 | objdump.o: objdump.c |
352 | size.o: size.c | |
353 | sparc-pinsn.o: sparc-pinsn.c | |
60c80016 | 354 | i386-pinsn.o: i386-pinsn.c |
d7cce023 | 355 | strip.o:strip.c |
d8e89b6b RP |
356 | version.o: $(srcdir)/version.c |
357 | $(CC) $(CFLAGS) -I. -I$(srcdir) -I$(INCDIR) $(HDEFINES) $(TDEFINES) -DVERSION='"$(VERSION)"' -c $(srcdir)/version.c | |
8539db10 | 358 | |
99a42820 RP |
359 | #----------------------------------------------------------------------------- |
360 | # 'STANDARD' GNU/960 TARGETS BELOW THIS POINT | |
361 | # | |
362 | # 'VERSION' file must be present and contain a string of the form "x.y" | |
363 | #----------------------------------------------------------------------------- | |
364 | ||
365 | ver960.c: FORCE | |
366 | rm -f ver960.c | |
367 | echo "char ${TARG}_ver[]= \"${TARG} `cat VERSION`, `date`\";" > ver960.c | |
368 | ||
369 | ||
370 | # Dummy target to force execution of dependent targets. | |
371 | # | |
6a3958b2 | 372 | force: |
99a42820 RP |
373 | |
374 | # Target to uncomment host-specific lines in this makefile. Such lines must | |
375 | # have the following string beginning in column 1: #__<hostname>__# | |
376 | # Original Makefile is backed up as 'Makefile.old'. | |
377 | # | |
378 | # Invoke with: make make HOST=xxx | |
379 | # | |
380 | make: | |
381 | -@if test $(HOST)x = x ; then \ | |
382 | echo '\aSpecify "make make HOST=???"'; \ | |
383 | exit 1; \ | |
384 | fi ; \ | |
385 | grep -s "^#The next line was generated by 'make make'" Makefile; \ | |
386 | if test $$? = 0 ; then \ | |
387 | echo "\aMakefile has already been processed with 'make make'";\ | |
388 | exit 1; \ | |
389 | fi ; \ | |
390 | mv -f Makefile Makefile.old; \ | |
391 | echo "#The next line was generated by 'make make'" >Makefile ; \ | |
392 | echo "HOST=$(HOST)" >>Makefile ; \ | |
393 | echo >>Makefile ; \ | |
394 | sed "s/^#__$(HOST)__#//" < Makefile.old >>Makefile | |
395 | ||
f1eb48b6 | 396 | Makefile: $(srcdir)/Makefile.in $(host_makefile_frag) $(target_makefile_frag) |
a26878d1 | 397 | $(SHELL) ./config.status |
99a42820 RP |
398 | |
399 | ### Local Variables: *** | |
400 | ### mode:fundamental *** | |
401 | ### page-delimiter: "^#\f" *** | |
402 | ### End: *** | |
403 | ### end of file |