1 ### Makefile for GNU binary-file utilities
8 version
=`$(srcdir)/../gcc$(subdir)/gcc -dumpversion`
10 bindir = $(prefix)/bin
11 libdir = $(prefix)/lib
12 libsubdir
= $(libdir)/gcc
/$(target
)/$(version
)
15 INSTALL_PROGRAM
= $(INSTALL
)
16 INSTALL_FILE
= $(INSTALL
)
18 ## Configuration options
19 # These should be all you need set before compiling
22 # these two should be the same program
26 # copy and strip should be the same program
30 # These should all be the same program too.
35 PROGS
= $(SIZE_PROG
) $(COPY_PROG
) $(OBJDUMP_PROG
) $(NM_PROG
) $(AR_PROG
) $(STRIP_PROG
) $(RANLIB_PROG
)
37 BASEDIR
= $(srcdir)/..
38 LIBDIR
= $(srcdir)/..
/bfd
$(subdir
)
40 #### host and target dependant Makefile fragments come in here.
43 INCDIR
= $(BASEDIR
)/include
45 CFLAGS
= -g
-I
$(srcdir)/..
/include -I
$(INCDIR
) $(HDEFINES
) $(TDEFINES
)
47 DISASMS
= m68k-pinsn.o i960-pinsn.o sparc-pinsn.o
51 # Hopefully all these may be flushed once we get configuration down pat.
53 # alloca only needed for systems which don't have it and when cc != gcc.
56 # nm tries to malloc enough space for the string table. The old GNU malloc
57 # rounds this up to a power of two (e.g. 5M becomes 8M), and so it might
58 # fail unnecessarily. I've also seen some Unix malloc's fail, even when
59 # there is enough memory. So use the new GNU malloc.
62 # Use the GNU getopt unless you have problems with it.
63 # The IRIS version could probably benefit from being assembled with
64 # libmalloc rather than the ordinary malloc.
65 #GNU_GETOPT = $(srcdir)/../getopt$(subdir)/libgetopt.a
66 GNU_GETOPT_LONG
= $(srcdir)/..
/getopt
$(subdir
)/libgetopt.a
68 # Code shared by all the binutils.
69 BULIBS
= bucomm.o version.o filemode.o
71 ADDL_LIBS
= $(GNU_GETOPT_LONG
) $(MALLOC
) $(BULIBS
) $(BFD
)
73 BFD
= $(LIBDIR
)/libbfd.a
77 all: $(ADDL_LIBS
) $(PROGS
)
80 #$(BFD):$(LIBDIR)/../common/*.c
81 # (cd $(LIBDIR); make)
83 $(SIZE_PROG
): $(ADDL_LIBS
) size.o
$(BFD
)
84 $(CC
) $(LDFLAGS
) $(CFLAGS
) -o
$(SIZE_PROG
) size.o
$(ADDL_LIBS
) $(LOADLIBES
)
86 $(COPY_PROG
): $(ADDL_LIBS
) copy.o
$(BFD
)
87 $(CC
) $(LDFLAGS
) $(CFLAGS
) -o
$(COPY_PROG
) copy.o
$(ADDL_LIBS
) $(LOADLIBES
)
89 $(NM_PROG
): $(ADDL_LIBS
) nm.o
$(BFD
)
90 $(CC
) $(LDFLAGS
) $(CFLAGS
) -o
$(NM_PROG
) nm.o
$(ADDL_LIBS
) $(LOADLIBES
)
92 $(OBJDUMP_PROG
): $(ADDL_LIBS
) size.o objdump.o
$(DISASMS
) $(BFD
)
93 $(CC
) $(LDFLAGS
) $(CFLAGS
) -o
$(OBJDUMP_PROG
) objdump.o
$(DISASMS
) $(ADDL_LIBS
) $(LOADLIBES
)
95 $(AR_PROG
): $(ADDL_LIBS
) ar.o
$(BFD
)
96 $(CC
) $(LDFLAGS
) $(CFLAGS
) -o
$(AR_PROG
) ar.o
$(ADDL_LIBS
) $(LOADLIBES
)
98 $(RANLIB_PROG
): $(AR_PROG
)
100 -ln
$(AR_PROG
) $(RANLIB_PROG
)
102 $(STRIP_PROG
): $(COPY_PROG
)
104 -ln
$(COPY_PROG
) $(STRIP_PROG
)
108 - mv
-f
*.o
$(PROGS
) stage1
112 - mv
-f
*.o
$(PROGS
) stage2
116 - mv
-f
*.o
$(PROGS
) stage3
119 - (cd stage1
; mv
-f
* ..
)
123 - (cd stage2
; mv
-f
* ..
)
127 - (cd stage3
; mv
-f
* ..
)
131 -rm -f
*.o
*~ \
#* core $(PROGS) TAGS
136 etags
$(INCDIR
)/*.h
$(BFDSRC
)/*.
[hc
] *.
[hc
]
142 for i in
$(PROGS
) ; do \
143 $(INSTALL_PROGRAM
) $$i $(destdir
)/bin
/$$i ; \
151 m68k-pinsn.o
: m68k-pinsn.c
152 m68k-pinsn.o
: .
/m68k-opcode.h
153 i960-pinsn.o
: i960-pinsn.c
154 sparc-pinsn.o
: sparc-pinsn.c
155 sparc-pinsn.o
: .
/sparc-opcode.h
160 filemode.o
:filemode.c
161 #-----------------------------------------------------------------------------
162 # 'STANDARD' GNU/960 TARGETS BELOW THIS POINT
164 # 'VERSION' file must be present and contain a string of the form "x.y"
165 #-----------------------------------------------------------------------------
169 echo
"char ${TARG}_ver[]= \"${TARG} `cat VERSION`, `date`\";" > ver960.c
172 # Dummy target to force execution of dependent targets.
176 # Target to uncomment host-specific lines in this makefile. Such lines must
177 # have the following string beginning in column 1: #__<hostname>__#
178 # Original Makefile is backed up as 'Makefile.old'.
180 # Invoke with: make make HOST=xxx
183 -@if
test $(HOST
)x
= x
; then \
184 echo
'\aSpecify "make make HOST=???"'; \
187 grep
-s
"^#The next line was generated by 'make make'" Makefile
; \
188 if
test $$?
= 0 ; then \
189 echo
"\aMakefile has already been processed with 'make make'";\
192 mv
-f Makefile Makefile.old
; \
193 echo
"#The next line was generated by 'make make'" >Makefile
; \
194 echo
"HOST=$(HOST)" >>Makefile
; \
196 sed
"s/^#__$(HOST)__#//" < Makefile.old
>>Makefile
200 Makefile
: $(srcdir)/Makefile.in
$(srcdir)/configure
202 .
/configure
+norecurse \
203 +destdir
=$(destdir
) \
204 `if [ "$(srcdir)" != "." ] ; then echo +f; fi` \
205 $(host
) +target
=$(target
))
207 ### Local Variables: ***
208 ### mode:fundamental ***
209 ### page-delimiter: "^#\f" ***