2 # Makefile for ld version 2
11 version
=`$(unsubdir)/../gcc$(subdir)/gcc -dumpversion`
13 bindir = $(prefix)/bin
14 libdir = $(prefix)/lib
15 libsubdir
= $(libdir)/gcc
/$(target
)/$(version
)
18 INSTALL_PROGRAM
= $(INSTALL
)
19 INSTALL_FILE
= $(INSTALL
)
22 INCLUDE
= $(srcdir)/..
/include
23 INCLUDES
= -I.
-I
$(srcdir) -I
$(INCLUDE
)
29 SCRIPTS
= ldgld68k.sc ldgld.sc \
30 ldlnk960.sc ldlnk960r.sc ldgld960.sc \
31 ldm88k.sc ldglda29k.sc news.sc h8300hds.sc
33 #### target and host dependent Makefile fragments come in here.
36 CFLAGS
= $(INCLUDES
) $(DEBUG
) $(HDEFINES
) $(TDEFINES
) $(CDEFINES
)
37 LINTFLAGS
= $(INCLUDES
) $(EXTRA_DEF
)
39 .SUFFIXES
: .y .x .xr .xu .sc .scu .scr
$(SUFFIXES
)
41 # go directly to ld.new in case this ld isn't capable of
42 # linking native object on this host. It can be renamed on
46 # A .sc script file is needed for each emulation mode.
47 # sed is used to transform this script into two variant forms:
48 # A .scr script is for linking without relocation (-r flag).
49 # A .scu script is like .scr, but *do* create constructors.
51 # A sed pattern to translate .sc to .scu:
52 SED_MAKE_RELOC_WITH_CONSTRUCTORS
=\
53 -e
"/If relocating/,/End if relocating/d" \
54 -e
"/=/s/[_a-z.]* *= .*//g" \
55 -e
'/>/s/} *> *[a-z]*/}/' \
56 -e
"/text/s/[.]text .*:/.text :/" \
57 -e
"/data/s/[.]data .*:/.data :/"
58 # A sed pattern to translate .scu to .scr:
59 SED_REMOVE_CONSTRUCTORS
= -e
/CONSTRUCTORS
/d
62 sed
$(SED_MAKE_RELOC_WITH_CONSTRUCTORS
) $< >$*.scu
64 sed
$(SED_REMOVE_CONSTRUCTORS
) < $< >$*.scr
66 # Each .sc .scr or .scu script is filtered by mkscript
67 # into a string literal that can be included in a .c program.
71 .
/mkscript
< $< >$*.xu
73 .
/mkscript
< $< >$*.xr
75 sed
$(SED_MAKE_RELOC_WITH_CONSTRUCTORS
) < $< | .
/mkscript
>$*.xu
77 sed
$(SED_MAKE_RELOC_WITH_CONSTRUCTORS
) $(SED_REMOVE_CONSTRUCTORS
) \
78 < $< | .
/mkscript
>$*.xr
81 BFDLIB
=$(unsubdir
)/..
/bfd
$(subdir
)/libbfd.a
82 LIBIBERTY
=$(unsubdir
)/..
/libiberty
$(subdir
)/libiberty.a
84 OFILES
= ldgram.o ldlex.o ldlang.o ldmain.o ldwarn.o ldwrite.o ldexp.o ldlnk960.o ldgld68k.o ldindr.o \
85 ldm88k.o ldglda29k.o news.o h8300hds.o \
86 ldgld.o ldgld960.o ldemul.o ldver.o ldmisc.o ldsym.o ldvanilla.o ldfile.o
88 HEADERS
=config.h ldmain.h ldmain.h ldwarn.h ldmisc.h ldindr.h ldsym.h ldlang.h ldexp.h \
89 ldlex.h ldwrite.h ldver.h ldemul.h ldfile.h ldgram.h
ld.h
93 LDCSOURCES
=ldlang.c ldindr.c ldmain.c ldwrite.c ldwarn.c ldlnk960.c ldgld.c ldgld68k.c \
95 ldgld960.c ldemul.c ldver.c ldmisc.c ldexp.c ldsym.c ldfile.c ldvanilla.c
97 GENERATED_SOURCES
=ldgram.c ldlex.c ldgram.h
98 GENERATED_HEADERS
=ldgram.h
100 LDSOURCES
=$(LDCSOURCES
) ldgram.y ldlex.l ldgram.h
102 BFDSOURCES
=..
/..
/bfd
/common
/*.c
104 SOURCES
= $(LDSOURCES
) $(BFDSOURCES
)
105 LINTSOURCES
= $(LDCSOURCES
) $(BFDSOURCES
) $(GENERATED_SOURCES
)
107 STAGESTUFF
= *.x
*.x
[ru
] *.sc
[ru
] $(GENERATED_SOURCES
) $(GENERATED_HEADERS
) $(OFILES
) $(LD_PROG
) mkscript
109 all: Makefile
$(LD_PROG
)
111 ldgram.h ldgram.c
: ldgram.y
112 $(BISON
) $(BISONFLAGS
) -d
$(VPATH
)/ldgram.y
-o ldgram.c
113 # These are in case BISON is really yacc (which ignores -o).
114 if
[ -f y.tab.c
-a
! -f ldgram.c
]; then mv y.tab.c ldgram.c
; fi
115 if
[ -f y.tab.h
-a
! -f ldgram.h
]; then mv y.tab.h ldgram.h
; fi
118 lex -t
$(VPATH
)/ldlex.l
>ldlex.c
122 sed
-e s
/"<ldtarget>"/ldgld
/g
-e s
/"<arch>"/m68k
/g \
123 -e s
/"<target>"//g
-e s
/"<TARGET>"//g
< ldtemplate
> ldgld.c
125 sed
-e s
/"<ldtarget>"/news
/g
-e s
/"<arch>"/m68k
/g \
126 -e s
/"<target>"/news
/g
-e s
/"<TARGET>"/NEWS
/g
< ldtemplate
> news.c
127 ldgld68k.c
: ldtemplate
128 sed
-e s
/"<ldtarget>"/ldgld68k
/g
-e s
/"<arch>"/m68k
/g \
129 -e s
/"<target>"/68k
/g
-e s
/"<TARGET>"/68K
/g
< ldtemplate
> ldgld68k.c
130 ldglda29k.c
: ldtemplate
131 sed
-e s
/"<ldtarget>"/ldglda29k
/g
-e s
/"<arch>"/a29k
/g \
132 -e s
/"<target>"/29k
/g
-e s
/"<TARGET>"/29K
/g
< ldtemplate
> ldglda29k.c
134 sed
-e s
/"<ldtarget>"/ldm88k
/g
-e s
/"<arch>"/m88k
/g \
135 -e s
/"<target>"/m88kbcs
/g
-e s
/"<TARGET>"/M88KBCS
/g
< ldtemplate
> ldm88k.c
137 # The .c files for these are generated from ldtemplete.
138 ldgld.o
: .
/mkscript ldgld.x ldgld.xr ldgld.xu
139 news.o
: .
/mkscript news.x news.xr news.xu
140 ldgld68k.o
: .
/mkscript ldgld68k.x ldgld68k.xr ldgld68k.xu
141 ldglda29k.o
: .
/mkscript ldglda29k.x ldglda29k.xr ldglda29k.xu
142 ldm88k.o
: .
/mkscript ldm88k.x ldm88k.xr ldm88k.xu
144 # The .c files for these are (for now) specially written (not ldtemplete).
145 ldgld960.o
: .
/mkscript ldgld960.x
146 ldlnk960.o
: .
/mkscript ldlnk960.x ldlnk960.xr
147 h8300hds.o
: .
/mkscript h8300hds.x
150 #$(BFDLIB): $(BFDSOURCES)
153 $(LD_PROG
): $(OFILES
) $(BFDLIB
) $(LIBIBERTY
)
154 $(CC
) $(CFLAGS
) $(LDFLAGS
) -o
$(LD_PROG
) $(OFILES
) $(BFDLIB
) $(LIBIBERTY
) $(LOADLIBES
)
157 # LDEMULATION=gld; export LDEMULATION; GNUTARGET=a.out-sunos-big;./ldok -format a.out-sunos-big -o ld /lib/crt0.o $(OFILES) $(BFDLIB) $(LIBIBERTY) -lc /usr/local/lib/gcc/sparc/1.91/gnulib
158 # gld -o ld /lib/crt0.o $(OFILES) $(BFDLIB) $(LIBIBERTY) -lc /usr/local/lib/gcc/sparc/1.91/gnulib
159 # $(CC) -Bstatic -o ld.new $(OFILES) $(BFDLIB) $(LIBIBERTY)
163 $(HOSTING_EMU
); .
/ld.new
-o ld1
$(HOSTING_CRT0
) $(OFILES
) $(BFDLIB
) $(LIBIBERTY
) $(HOSTING_LIBS
)
166 $(HOSTING_EMU
); .
/ld1
-o ld2
$(HOSTING_CRT0
) $(OFILES
) $(BFDLIB
) $(LIBIBERTY
) $(HOSTING_LIBS
)
169 $(HOSTING_EMU
); .
/ld2
-o ld3
$(HOSTING_CRT0
) $(OFILES
) $(BFDLIB
) $(LIBIBERTY
) $(HOSTING_LIBS
)
174 mkscript
: $(srcdir)/mkscript.c
175 $(CC
) $(CFLAGS
) $(LDFLAGS
) -o mkscript
$(srcdir)/mkscript.c
$(LOADLIBES
)
177 ldlex.c
: ldlex.l ldgram.h
178 ldlex.o
: ldlex.c ldgram.h
182 ldgld68k.x
:ldgld68k.sc
183 ldgld68kUr.x
:ldgld68kUr.sc
184 ldgld68kr.x
:ldgld68kr.sc
185 h8300hds.x
:h8300hds.sc
187 ldgldUr.x
:ldgldUr.sc
189 ldlnk960.x
:ldlnk960.sc
190 ldlnk960r.x
:ldlnk960r.sc
191 ldgld960.x
:ldgld960.sc
192 ldgldm88k.x
:ldgldm88k.sc
193 ldm88kUr.x
:ldm88kUr.sc
195 ldgld68k.x
:ldgld68k.sc
196 ldglda29k.x
:ldglda29k.sc
197 ldglda29kr.x
:ldglda29kr.sc
198 ldglda29kUr.x
:ldglda29kUr.sc
202 - mv
-f
$(STAGESTUFF
) stage1
203 - (cd stage1
; ln
-s
$(LD_PROG
) ld)
207 - mv
-f
$(STAGESTUFF
) stage2
208 - (cd stage2
; ln
-s
$(LD_PROG
) ld)
212 - mv
-f
$(STAGESTUFF
) stage3
213 - (cd stage3
; ln
-s
$(LD_PROG
) ld)
218 for i in
$(STAGESTUFF
) ; do cmp
$$i $(against
)/$$i ; done
221 - (cd stage1
; mv
-f
* ..
)
226 - (cd stage2
; mv
-f
* ..
)
231 - (cd stage3
; mv
-f
* ..
)
236 - rm -f TAGS
$(OFILES
) $(GENERATED_SOURCES
) $(GENERATED_HEADERS
)
237 - rm -f
*.x
*.x
[ru
] *.sc
[ur
]
238 - rm -f
ld ld1 ld2 ld3
ld.new mkscript
*.o y.output
240 lintlog
:$(SOURCES
) Makefile
241 $(LINT
) -abhxzn
$(LINTFLAGS
) $(LINTSOURCES
) \
242 | grep
-v
"pointer casts may be troublesome" \
243 | grep
-v
"possible pointer alignment problem" \
245 | grep
-v
"conversion from long may lose accuracy" \
246 | grep
-v
"warning: constant argument to NOT" \
247 | grep
-v
"enumeration type clash, operator CAST" \
248 | grep
-v
"warning: constant in conditional context"\
249 | grep
-v
"archive\.c"
252 tags TAGS
:$(SOURCES
) $(HEADERS
)
256 (cd
/4/steve
/ld; tar cf
- $(LDSOURCES
) $(HEADERS
) $(MANSOURCES
)) |
tar xf
-
261 $(INSTALL_PROGRAM
) ld.new
$(libsubdir
)/ld
263 #-----------------------------------------------------------------------------
264 # 'STANDARD' GNU/960 TARGETS BELOW THIS POINT
266 # 'VERSION' file must be present and contain a string of the form "x.y"
267 #-----------------------------------------------------------------------------
271 echo
"char ${TARG}_ver[]= \"${TARG} `cat VERSION`, `date`\";" > ver960.c
274 # This target should be invoked before building a new release.
275 # 'VERSION' file must be present and contain a string of the form "x.y"
279 MAJ
=`sed 's/\..*//' VERSION` ; \
280 MIN
=`sed 's/.*\.//' VERSION` ; \
281 V
=$$MAJ.
`expr $$MIN + 1` ; \
283 echo
$$V >VERSION
; \
290 # Dummy target to force execution of dependent targets.
294 # Target to uncomment host-specific lines in this makefile. Such lines must
295 # have the following string beginning in column 1: #__<hostname>__#
296 # Original Makefile is backed up as 'Makefile.old'.
298 # Invoke with: make make HOST=xxx
301 -@if
test $(HOST
)x
= x
; then \
302 echo
'\aSpecify "make make HOST=???"'; \
305 grep
-s
"^#The next line was generated by 'make make'" Makefile
; \
306 if
test $$?
= 0 ; then \
307 echo
"\aMakefile has already been processed with 'make make'";\
310 mv
-f Makefile Makefile.old
; \
311 echo
"#The next line was generated by 'make make'" >Makefile
; \
312 echo
"HOST=$(HOST)" >>Makefile
; \
314 sed
"s/^#__$(HOST)__#//" < Makefile.old
>>Makefile
318 Makefile
: $(srcdir)/Makefile.in
$(host_makefile_frag
) $(target_makefile_frag
)
319 $(SHELL
) .
/config.status
321 ### Local Variables: ***
322 ### mode:fundamental ***
323 ### page-delimiter: "^#\f" ***
328 # IF YOU PUT ANYTHING HERE IT WILL GO AWAY