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 | 136 | check: |
dc760829 | 137 | /bin/sh $(srcdir)/sanity.sh . |
d8e89b6b RP |
138 | |
139 | info: binutils.info | |
a10d26a1 RP |
140 | |
141 | #$(BFD):$(LIBDIR)/../common/*.c | |
142 | # (cd $(LIBDIR); make) | |
99a42820 | 143 | |
a10d26a1 | 144 | $(SIZE_PROG): $(ADDL_LIBS) size.o $(BFD) |
6a3958b2 | 145 | $(CC) $(LDFLAGS) $(CFLAGS) -o $(SIZE_PROG) size.o $(ADDL_LIBS) $(LOADLIBES) |
99a42820 | 146 | |
d8e89b6b RP |
147 | $(COPY_PROG): $(ADDL_LIBS) copy.o not-strip.o $(BFD) |
148 | $(CC) $(LDFLAGS) $(CFLAGS) -o $(COPY_PROG) copy.o not-strip.o $(ADDL_LIBS) $(LOADLIBES) | |
149 | ||
150 | $(STRIP_PROG): $(ADDL_LIBS) copy.o is-strip.o $(BFD) | |
151 | $(CC) $(LDFLAGS) $(CFLAGS) -o $(STRIP_PROG) copy.o is-strip.o $(ADDL_LIBS) $(LOADLIBES) | |
99a42820 | 152 | |
a10d26a1 | 153 | $(NM_PROG): $(ADDL_LIBS) nm.o $(BFD) |
6a3958b2 | 154 | $(CC) $(LDFLAGS) $(CFLAGS) -o $(NM_PROG) nm.o $(ADDL_LIBS) $(LOADLIBES) |
99a42820 | 155 | |
a10d26a1 | 156 | $(OBJDUMP_PROG): $(ADDL_LIBS) size.o objdump.o $(DISASMS) $(BFD) |
6a3958b2 | 157 | $(CC) $(LDFLAGS) $(CFLAGS) -o $(OBJDUMP_PROG) objdump.o $(DISASMS) $(ADDL_LIBS) $(LOADLIBES) |
99a42820 | 158 | |
d8e89b6b RP |
159 | arparse.c:arparse.y |
160 | $(BISON) $(BISONFLAGS) $(VPATH)/arparse.y | |
161 | mv y.tab.c arparse.c | |
162 | mv y.tab.h arparse.h | |
163 | ||
99a42820 | 164 | |
d8e89b6b RP |
165 | arlex.c:arlex.l |
166 | $(FLEX) -I -Cem -t $(VPATH)/arlex.l >arlex.c | |
167 | ||
168 | $(AR_PROG): $(ADDL_LIBS) ar.o arparse.o arlex.o not-ranlib.o $(BFD) arsup.o | |
169 | $(CC) $(LDFLAGS) $(CFLAGS) -o $(AR_PROG) ar.o arparse.o arlex.o arsup.o not-ranlib.o $(ADDL_LIBS) $(LOADLIBES) | |
170 | ||
171 | $(RANLIB_PROG): $(ADDL_LIBS) ar.o is-ranlib.o arparse.o arlex.o arsup.o $(BFD) | |
172 | $(CC) $(LDFLAGS) $(CFLAGS) -o $(RANLIB_PROG) ar.o arparse.o arlex.o arsup.o is-ranlib.o $(ADDL_LIBS) $(LOADLIBES) | |
06a97fbd PB |
173 | |
174 | # This rule creates a single binary that switches between ar and ranlib | |
175 | # by looking at argv[0]. Use this kludge to save some disk space. | |
176 | # However, you have to install things by hand. | |
177 | # (That is after 'make install', replace the installed ranlib by a link to ar.) | |
178 | ||
179 | # Alternatively, you can install ranlib.sh as ranlib. | |
180 | ||
181 | ar_with_ranlib: $(ADDL_LIBS) ar.o maybe-ranlib.o $(BFD) | |
182 | $(CC) $(LDFLAGS) $(CFLAGS) -o $(AR_PROG) ar.o maybe-ranlib.o $(ADDL_LIBS) $(LOADLIBES) | |
a10d26a1 RP |
183 | -rm -f $(RANLIB_PROG) |
184 | -ln $(AR_PROG) $(RANLIB_PROG) | |
99a42820 | 185 | |
d8e89b6b RP |
186 | # copy and strip in one binary that uses argv[0] to decide its action. |
187 | ||
188 | copy_with_strip: $(ADDL_LIBS) copy.o maybe-strip.o $(BFD) | |
189 | $(CC) $(LDFLAGS) $(CFLAGS) -o $(COPY_PROG) copy.o maybe-strip.o $(ADDL_LIBS) $(LOADLIBES) | |
a10d26a1 RP |
190 | -rm -f $(STRIP_PROG) |
191 | -ln $(COPY_PROG) $(STRIP_PROG) | |
99a42820 | 192 | |
6a3958b2 RP |
193 | stage1: force |
194 | - mkdir stage1 | |
a01bf1fb | 195 | - mv -f $(STAGESTUFF) stage1 |
6a3958b2 RP |
196 | |
197 | stage2: force | |
198 | - mkdir stage2 | |
a01bf1fb | 199 | - mv -f $(STAGESTUFF) stage2 |
6a3958b2 RP |
200 | |
201 | stage3: force | |
202 | - mkdir stage3 | |
a01bf1fb RP |
203 | - mv -f $(STAGESTUFF) stage3 |
204 | ||
205 | against=stage2 | |
206 | ||
207 | comparison: force | |
208 | for i in $(STAGESTUFF) ; do cmp $$i $(against)/$$i ; done | |
6a3958b2 RP |
209 | |
210 | de-stage1: force | |
211 | - (cd stage1 ; mv -f * ..) | |
212 | - rmdir stage1 | |
213 | ||
214 | de-stage2: force | |
215 | - (cd stage2 ; mv -f * ..) | |
216 | - rmdir stage2 | |
217 | ||
218 | de-stage3: force | |
219 | - (cd stage3 ; mv -f * ..) | |
220 | - rmdir stage3 | |
221 | ||
6b583720 RP |
222 | ###################################################################### |
223 | # DOCUMENTATION TARGETS | |
224 | # TeX output | |
2226a090 RP |
225 | binutils.dvi: $(srcdir)/binutils.texi |
226 | TEXINPUTS=${TEXIDIR}:.:$$TEXINPUTS tex $(srcdir)/binutils.texi | |
b7a11ec2 | 227 | texindex binutils.?? |
2226a090 | 228 | TEXINPUTS=${TEXIDIR}:.:$$TEXINPUTS tex $(srcdir)/binutils.texi |
b7a11ec2 | 229 | |
6b583720 | 230 | # info file for online browsing |
2226a090 | 231 | binutils.info: $(srcdir)/binutils.texi |
6141fd50 | 232 | $(MAKEINFO) -o binutils.info $(srcdir)/binutils.texi |
b7a11ec2 | 233 | |
0c10ff03 | 234 | # different targets for -ms, -mm, -me |
c83497f5 RP |
235 | # Try to use a recent texi2roff. v2 was put on prep in jan91. |
236 | # If you want an index, see texi2roff doc for postprocessing | |
237 | # and add -i to texi2roff invocations below. | |
238 | # Workarounds for texi2roff-2 (probably fixed in later texi2roff's, delete | |
239 | # correspondint -e lines when later texi2roff's are current) | |
240 | # + @ifinfo's deleted explicitly due to texi2roff-2 bug w nested constructs. | |
241 | # + @c's deleted explicitly because texi2roff sees texinfo commands in them | |
242 | # + @ (that's at-BLANK) not recognized by texi2roff, turned into blank | |
243 | # + @alphaenumerate is ridiculously new, turned into @enumerate | |
244 | ||
0c10ff03 | 245 | # roff output (-ms) |
2226a090 | 246 | binutils.ms: $(srcdir)/binutils.texi |
6b583720 RP |
247 | sed -e '/\\input texinfo/d' \ |
248 | -e '/@c TEXI2ROFF-KILL/,/@c END TEXI2ROFF-KILL/d' \ | |
c83497f5 RP |
249 | -e '/^@ifinfo/,/^@end ifinfo/d' \ |
250 | -e '/^@c/d' \ | |
2226a090 | 251 | -e 's/{.*,,/{/' \ |
c83497f5 RP |
252 | -e 's/@ / /g' \ |
253 | -e 's/^@alphaenumerate/@enumerate/g' \ | |
254 | -e 's/^@end alphaenumerate/@end enumerate/g' \ | |
2226a090 | 255 | $(srcdir)/binutils.texi | \ |
d8e89b6b | 256 | $(TEXI2ROFF) -ms | \ |
c83497f5 RP |
257 | sed -e 's/---/\\(em/g' \ |
258 | >binutils.ms | |
6b583720 | 259 | |
0c10ff03 | 260 | # roff output (-mm) |
c83497f5 RP |
261 | # '@noindent's removed due to texi2roff-2 mm bug; if yours is newer, |
262 | # try leaving them in | |
2226a090 | 263 | binutils.mm: $(srcdir)/binutils.texi |
0c10ff03 RP |
264 | sed -e '/\\input texinfo/d' \ |
265 | -e '/@c TEXI2ROFF-KILL/,/@c END TEXI2ROFF-KILL/d' \ | |
c83497f5 RP |
266 | -e '/^@ifinfo/,/^@end ifinfo/d' \ |
267 | -e '/^@c/d' \ | |
2226a090 RP |
268 | -e 's/{.*,,/{/' \ |
269 | -e '/@noindent/d' \ | |
c83497f5 RP |
270 | -e 's/@ / /g' \ |
271 | -e 's/^@alphaenumerate/@enumerate/g' \ | |
272 | -e 's/^@end alphaenumerate/@end enumerate/g' \ | |
2226a090 | 273 | $(srcdir)/binutils.texi | \ |
d8e89b6b | 274 | $(TEXI2ROFF) -mm | \ |
2226a090 RP |
275 | sed -e 's/---/\\(em/g' \ |
276 | >binutils.mm | |
0c10ff03 RP |
277 | |
278 | # roff output (-me) | |
2226a090 | 279 | binutils.me: $(srcdir)/binutils.texi |
0c10ff03 RP |
280 | sed -e '/\\input texinfo/d' \ |
281 | -e '/@c TEXI2ROFF-KILL/,/@c END TEXI2ROFF-KILL/d' \ | |
c83497f5 RP |
282 | -e '/^@ifinfo/,/^@end ifinfo/d' \ |
283 | -e '/^@c/d' \ | |
2226a090 | 284 | -e 's/{.*,,/{/' \ |
c83497f5 RP |
285 | -e 's/@ / /g' \ |
286 | -e 's/^@alphaenumerate/@enumerate/g' \ | |
287 | -e 's/^@end alphaenumerate/@end enumerate/g' \ | |
2226a090 | 288 | $(srcdir)/binutils.texi | \ |
d8e89b6b | 289 | $(TEXI2ROFF) -me | \ |
c83497f5 RP |
290 | sed -e 's/---/\\(em/g' \ |
291 | >binutils.me | |
0c10ff03 RP |
292 | |
293 | ||
6b583720 RP |
294 | ###################################################################### |
295 | ||
99a42820 | 296 | clean: |
b7a11ec2 | 297 | -rm -f *.o *~ \#* core $(STAGESTUFF) TAGS binutils.?? binutils.??? |
99a42820 RP |
298 | |
299 | etags tags: TAGS | |
300 | ||
6a3958b2 | 301 | TAGS: force |
99a42820 RP |
302 | etags $(INCDIR)/*.h $(BFDSRC)/*.[hc] *.[hc] |
303 | ||
304 | realclean: clean | |
a01bf1fb | 305 | -rm -f $(STAGESTUFF) TAGS |
99a42820 | 306 | |
c83497f5 | 307 | install: all |
b5132a6b | 308 | for i in $(PROGS) ; do \ |
d8e89b6b | 309 | $(INSTALL_PROGRAM) $$i $(bindir)/$(program_prefix)$$i ; \ |
99a42820 | 310 | done |
84396dcf | 311 | for i in $(MANPAGES) ; do \ |
d8e89b6b | 312 | $(INSTALL_DATA) $(srcdir)/$$i $(man1dir)/$(program_prefix)$$i ; \ |
de53632c | 313 | done |
c83497f5 | 314 | |
d8e89b6b | 315 | install-info: info |
de53632c | 316 | for i in *.info* ; do \ |
d8e89b6b | 317 | $(INSTALL_DATA) $$i $(infodir)/$$i ; \ |
84396dcf | 318 | done |
99a42820 | 319 | |
d8e89b6b RP |
320 | clean-info: |
321 | -rm -rf *.info* | |
322 | ||
8539db10 PB |
323 | dist: $(DIST_NAME).tar.Z |
324 | ||
d8474a9b | 325 | $(DIST_NAME).tar.Z: |
b27d2046 PB |
326 | cd ../..; rm -f $(DIST_NAME); ln -s devo $(DIST_NAME) |
327 | make binutils.mm -f Makefile.in | |
d8474a9b PB |
328 | cd ../ld; make ld.mm -f Makefile.in |
329 | cd ../..; tar chf - $(DIST_NAME) | compress >$(DIST_NAME).tar.Z | |
b27d2046 | 330 | rm -rf ../../$(DIST_NAME) |
8539db10 | 331 | |
d7cce023 JG |
332 | # These get around a bug in Sun Make in SunOS 4.1.1 |
333 | alloca.o:alloca.c | |
a26878d1 | 334 | am29k-pinsn.o: am29k-pinsn.c |
99a42820 | 335 | ar.o: ar.c |
d7cce023 JG |
336 | bucomm.o: bucomm.c |
337 | copy.o: copy.c | |
338 | cplus-dem.o:cplus-dem.c | |
339 | filemode.o:filemode.c | |
a10d26a1 RP |
340 | getopt.o:getopt.c |
341 | getopt1.o:getopt1.c | |
d7cce023 JG |
342 | gmalloc.o:gmalloc.c |
343 | i960-pinsn.o: i960-pinsn.c | |
344 | is-ranlib.o:is-ranlib.c | |
d8e89b6b | 345 | is-strip.o:is-strip.c |
d7cce023 JG |
346 | m68k-pinsn.o: m68k-pinsn.c |
347 | maybe-ranlib.o:maybe-ranlib.c | |
d8e89b6b | 348 | maybe-strip.o:maybe-strip.c |
d7cce023 JG |
349 | nm.o: nm.c |
350 | not-ranlib.o:not-ranlib.c | |
d8e89b6b | 351 | not-strip.o:not-strip.c |
d7cce023 JG |
352 | objdump.o: objdump.c |
353 | size.o: size.c | |
354 | sparc-pinsn.o: sparc-pinsn.c | |
60c80016 | 355 | i386-pinsn.o: i386-pinsn.c |
d7cce023 | 356 | strip.o:strip.c |
d8e89b6b RP |
357 | version.o: $(srcdir)/version.c |
358 | $(CC) $(CFLAGS) -I. -I$(srcdir) -I$(INCDIR) $(HDEFINES) $(TDEFINES) -DVERSION='"$(VERSION)"' -c $(srcdir)/version.c | |
8539db10 | 359 | |
99a42820 RP |
360 | #----------------------------------------------------------------------------- |
361 | # 'STANDARD' GNU/960 TARGETS BELOW THIS POINT | |
362 | # | |
363 | # 'VERSION' file must be present and contain a string of the form "x.y" | |
364 | #----------------------------------------------------------------------------- | |
365 | ||
366 | ver960.c: FORCE | |
367 | rm -f ver960.c | |
368 | echo "char ${TARG}_ver[]= \"${TARG} `cat VERSION`, `date`\";" > ver960.c | |
369 | ||
370 | ||
371 | # Dummy target to force execution of dependent targets. | |
372 | # | |
6a3958b2 | 373 | force: |
99a42820 RP |
374 | |
375 | # Target to uncomment host-specific lines in this makefile. Such lines must | |
376 | # have the following string beginning in column 1: #__<hostname>__# | |
377 | # Original Makefile is backed up as 'Makefile.old'. | |
378 | # | |
379 | # Invoke with: make make HOST=xxx | |
380 | # | |
381 | make: | |
382 | -@if test $(HOST)x = x ; then \ | |
383 | echo '\aSpecify "make make HOST=???"'; \ | |
384 | exit 1; \ | |
385 | fi ; \ | |
386 | grep -s "^#The next line was generated by 'make make'" Makefile; \ | |
387 | if test $$? = 0 ; then \ | |
388 | echo "\aMakefile has already been processed with 'make make'";\ | |
389 | exit 1; \ | |
390 | fi ; \ | |
391 | mv -f Makefile Makefile.old; \ | |
392 | echo "#The next line was generated by 'make make'" >Makefile ; \ | |
393 | echo "HOST=$(HOST)" >>Makefile ; \ | |
394 | echo >>Makefile ; \ | |
395 | sed "s/^#__$(HOST)__#//" < Makefile.old >>Makefile | |
396 | ||
f1eb48b6 | 397 | Makefile: $(srcdir)/Makefile.in $(host_makefile_frag) $(target_makefile_frag) |
a26878d1 | 398 | $(SHELL) ./config.status |
99a42820 RP |
399 | |
400 | ### Local Variables: *** | |
401 | ### mode:fundamental *** | |
402 | ### page-delimiter: "^#\f" *** | |
403 | ### End: *** | |
404 | ### end of file |