annotate gcc/brig/Make-lang.in @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 1830386684a0
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 # Make-lang.in -- Top level -*- makefile -*- fragment for gcc BRIG (HSAIL)
kono
parents:
diff changeset
2 # frontend.
kono
parents:
diff changeset
3
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 131
diff changeset
4 # Copyright (C) 2015-2020 Free Software Foundation, Inc.
111
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 # This file is part of GCC.
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 # GCC is free software; you can redistribute it and/or modify
kono
parents:
diff changeset
9 # it under the terms of the GNU General Public License as published by
kono
parents:
diff changeset
10 # the Free Software Foundation; either version 3, or (at your option)
kono
parents:
diff changeset
11 # any later version.
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13 # GCC is distributed in the hope that it will be useful,
kono
parents:
diff changeset
14 # but WITHOUT ANY WARRANTY; without even the implied warranty of
kono
parents:
diff changeset
15 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
kono
parents:
diff changeset
16 # GNU General Public License for more details.
kono
parents:
diff changeset
17
kono
parents:
diff changeset
18 # You should have received a copy of the GNU General Public License
kono
parents:
diff changeset
19 # along with GCC; see the file COPYING3. If not see
kono
parents:
diff changeset
20 # <http://www.gnu.org/licenses/>.
kono
parents:
diff changeset
21
kono
parents:
diff changeset
22 # This file provides the language dependent support in the main Makefile.
kono
parents:
diff changeset
23
kono
parents:
diff changeset
24 # Installation name.
kono
parents:
diff changeset
25
kono
parents:
diff changeset
26 GCCBRIG_INSTALL_NAME := $(shell echo gccbrig|sed '$(program_transform_name)')
kono
parents:
diff changeset
27 GCCBRIG_TARGET_INSTALL_NAME := $(target_noncanonical)-$(shell echo gccbrig|sed \
kono
parents:
diff changeset
28 '$(program_transform_name)')
kono
parents:
diff changeset
29
kono
parents:
diff changeset
30 # The name for selecting brig in LANGUAGES.
kono
parents:
diff changeset
31 brig: brig1$(exeext)
kono
parents:
diff changeset
32
kono
parents:
diff changeset
33 .PHONY: brig
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35 CFLAGS-brig/brigspec.o += $(DRIVER_DEFINES)
kono
parents:
diff changeset
36
kono
parents:
diff changeset
37 GCCBRIG_OBJS = $(GCC_OBJS) brig/brigspec.o
kono
parents:
diff changeset
38 gccbrig$(exeext): $(GCCBRIG_OBJS) $(EXTRA_GCC_OBJS) libcommon-target.a \
kono
parents:
diff changeset
39 $(LIBDEPS)
kono
parents:
diff changeset
40 +$(LINKER) $(ALL_LINKERFLAGS) $(LDFLAGS) -o $@ \
kono
parents:
diff changeset
41 $(GCCBRIG_OBJS) $(EXTRA_GCC_OBJS) libcommon-target.a \
kono
parents:
diff changeset
42 $(EXTRA_GCC_LIBS) $(LIBS)
kono
parents:
diff changeset
43
kono
parents:
diff changeset
44 # The cross-compiler version. This is built mainly as a signal to the
kono
parents:
diff changeset
45 # brig.install-common target. If this executable exists, it means that
kono
parents:
diff changeset
46 # brig.all.cross was run.
kono
parents:
diff changeset
47 gccbrig-cross$(exeext): gccbrig$(exeext)
kono
parents:
diff changeset
48 -rm -f gccbrig-cross$(exeext)
kono
parents:
diff changeset
49 cp gccbrig$(exeext) gccbrig-cross$(exeext)
kono
parents:
diff changeset
50
kono
parents:
diff changeset
51 # Use strict warnings.
kono
parents:
diff changeset
52 brig-warn = $(STRICT_WARN)
kono
parents:
diff changeset
53
kono
parents:
diff changeset
54 BRIG_OBJS = \
kono
parents:
diff changeset
55 brig/brig-lang.o \
kono
parents:
diff changeset
56 brig/brig-code-entry-handler.o \
kono
parents:
diff changeset
57 brig/brig-function-handler.o \
kono
parents:
diff changeset
58 brig/brig-variable-handler.o \
kono
parents:
diff changeset
59 brig/brig-fbarrier-handler.o \
kono
parents:
diff changeset
60 brig/brig-label-handler.o \
kono
parents:
diff changeset
61 brig/brig-comment-handler.o \
kono
parents:
diff changeset
62 brig/brig-basic-inst-handler.o \
kono
parents:
diff changeset
63 brig/brig-cvt-inst-handler.o \
kono
parents:
diff changeset
64 brig/brig-seg-inst-handler.o \
kono
parents:
diff changeset
65 brig/brig-lane-inst-handler.o \
kono
parents:
diff changeset
66 brig/brig-queue-inst-handler.o \
kono
parents:
diff changeset
67 brig/brig-copy-move-inst-handler.o \
kono
parents:
diff changeset
68 brig/brig-signal-inst-handler.o \
kono
parents:
diff changeset
69 brig/brig-atomic-inst-handler.o \
kono
parents:
diff changeset
70 brig/brig-arg-block-handler.o \
kono
parents:
diff changeset
71 brig/brig-control-handler.o \
kono
parents:
diff changeset
72 brig/brig-cmp-inst-handler.o \
kono
parents:
diff changeset
73 brig/brig-branch-inst-handler.o \
kono
parents:
diff changeset
74 brig/brig-mem-inst-handler.o \
kono
parents:
diff changeset
75 brig/brig-module-handler.o \
kono
parents:
diff changeset
76 brig/brig-inst-mod-handler.o \
kono
parents:
diff changeset
77 brig/brig-function.o \
kono
parents:
diff changeset
78 brig/brig-to-generic.o \
kono
parents:
diff changeset
79 brig/brig-machine.o \
kono
parents:
diff changeset
80 brig/brig-util.o
kono
parents:
diff changeset
81
kono
parents:
diff changeset
82 brig_OBJS = $(BRIG_OBJS) brig/brigspec.o
kono
parents:
diff changeset
83
kono
parents:
diff changeset
84 # brig1$(exeext): $(BRIG_OBJS) attribs.o $(BACKEND) $(LIBDEPS)
kono
parents:
diff changeset
85 # +$(LLINKER) $(ALL_LINKERFLAGS) $(LDFLAGS) -o $@ \
kono
parents:
diff changeset
86 # $(BRIG_OBJS) attribs.o $(BACKEND) $(LIBS) $(BACKENDLIBS)
kono
parents:
diff changeset
87
kono
parents:
diff changeset
88
kono
parents:
diff changeset
89 brig1$(exeext): $(BRIG_OBJS) attribs.o $(BACKEND) $(LIBDEPS)
kono
parents:
diff changeset
90 +$(LLINKER) $(ALL_LINKERFLAGS) $(LDFLAGS) -o $@ \
kono
parents:
diff changeset
91 $(BRIG_OBJS) attribs.o $(BACKEND) $(LIBS) \
kono
parents:
diff changeset
92 $(BACKENDLIBS)
kono
parents:
diff changeset
93
kono
parents:
diff changeset
94 # Documentation.
kono
parents:
diff changeset
95
kono
parents:
diff changeset
96 BRIG_TEXI_FILES = \
kono
parents:
diff changeset
97 brig/gccbrig.texi \
kono
parents:
diff changeset
98 $(gcc_docdir)/include/fdl.texi \
kono
parents:
diff changeset
99 $(gcc_docdir)/include/gpl_v3.texi \
kono
parents:
diff changeset
100 $(gcc_docdir)/include/gcc-common.texi \
kono
parents:
diff changeset
101 gcc-vers.texi
kono
parents:
diff changeset
102
kono
parents:
diff changeset
103 doc/gccbrig.info: $(BRIG_TEXI_FILES)
kono
parents:
diff changeset
104 if test "x$(BUILD_INFO)" = xinfo; then \
kono
parents:
diff changeset
105 rm -f doc/gccbrig.info*; \
kono
parents:
diff changeset
106 $(MAKEINFO) $(MAKEINFOFLAGS) -I $(gcc_docdir) \
kono
parents:
diff changeset
107 -I $(gcc_docdir)/include -o $@ $<; \
kono
parents:
diff changeset
108 else true; fi
kono
parents:
diff changeset
109
kono
parents:
diff changeset
110 doc/gccbrig.dvi: $(BRIG_TEXI_FILES)
kono
parents:
diff changeset
111 $(TEXI2DVI) -I $(abs_docdir) -I $(abs_docdir)/include -o $@ $<
kono
parents:
diff changeset
112
kono
parents:
diff changeset
113 doc/gccbrig.pdf: $(BRIG_TEXI_FILES)
kono
parents:
diff changeset
114 $(TEXI2PDF) -I $(abs_docdir) -I $(abs_docdir)/include -o $@ $<
kono
parents:
diff changeset
115
kono
parents:
diff changeset
116 $(build_htmldir)/brig/index.html: $(BRIG_TEXI_FILES)
kono
parents:
diff changeset
117 $(mkinstalldirs) $(@D)
kono
parents:
diff changeset
118 rm -f $(@D)/*
kono
parents:
diff changeset
119 $(TEXI2HTML) -I $(gcc_docdir) -I $(gcc_docdir)/include \
kono
parents:
diff changeset
120 -I $(srcdir)/brig -o $(@D) $<
kono
parents:
diff changeset
121
kono
parents:
diff changeset
122 .INTERMEDIATE: gccbrig.pod
kono
parents:
diff changeset
123
kono
parents:
diff changeset
124 gccbrig.pod: brig/gccbrig.texi
kono
parents:
diff changeset
125 -$(TEXI2POD) -D gccbrig < $< > $@
kono
parents:
diff changeset
126
kono
parents:
diff changeset
127 # Build hooks.
kono
parents:
diff changeset
128
kono
parents:
diff changeset
129 brig.all.cross: gccbrig-cross$(exeext)
kono
parents:
diff changeset
130 brig.start.encap: gccbrig$(exeext)
kono
parents:
diff changeset
131 brig.rest.encap:
kono
parents:
diff changeset
132 brig.info: doc/gccbrig.info
kono
parents:
diff changeset
133 brig.dvi: doc/gccbrig.dvi
kono
parents:
diff changeset
134 brig.pdf: doc/gccbrig.pdf
kono
parents:
diff changeset
135 brig.html: $(build_htmldir)/brig/index.html
kono
parents:
diff changeset
136 brig.srcinfo: doc/gccbrig.info
kono
parents:
diff changeset
137 -cp -p $^ $(srcdir)/doc
kono
parents:
diff changeset
138
kono
parents:
diff changeset
139 brig.srcextra:
kono
parents:
diff changeset
140 brig.tags: force
kono
parents:
diff changeset
141 cd $(srcdir)/brig; \
kono
parents:
diff changeset
142 etags -o TAGS.sub *.c *.h; \
kono
parents:
diff changeset
143 etags --include TAGS.sub --include ../TAGS.sub
kono
parents:
diff changeset
144
kono
parents:
diff changeset
145 brig.man: doc/gccbrig.1
kono
parents:
diff changeset
146 brig.srcman: doc/gccbrig.1
kono
parents:
diff changeset
147 -cp -p $^ $(srcdir)/doc
kono
parents:
diff changeset
148
kono
parents:
diff changeset
149 lang_checks += check-brig
kono
parents:
diff changeset
150
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
151 # No brig-specific selftests
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
152 selftest-brig:
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
153
111
kono
parents:
diff changeset
154 # Install hooks.
kono
parents:
diff changeset
155
kono
parents:
diff changeset
156 brig.install-common: installdirs
kono
parents:
diff changeset
157 -rm -f $(DESTDIR)$(bindir)/$(GCCBRIG_INSTALL_NAME)$(exeext)
kono
parents:
diff changeset
158 $(INSTALL_PROGRAM) gccbrig$(exeext) \
kono
parents:
diff changeset
159 $(DESTDIR)$(bindir)/$(GCCBRIG_INSTALL_NAME)$(exeext)
kono
parents:
diff changeset
160 -if test -f brig1$(exeext); then \
kono
parents:
diff changeset
161 if test -f gccbrig-cross$(exeext); then \
kono
parents:
diff changeset
162 :; \
kono
parents:
diff changeset
163 else \
kono
parents:
diff changeset
164 rm -f $(DESTDIR)$(bindir)/$(GCCBRIG_TARGET_INSTALL_NAME)$(exeext); \
kono
parents:
diff changeset
165 ( cd $(DESTDIR)$(bindir) && \
kono
parents:
diff changeset
166 $(LN) $(GCCBRIG_INSTALL_NAME)$(exeext) \
kono
parents:
diff changeset
167 $(GCCBRIG_TARGET_INSTALL_NAME)$(exeext) ); \
kono
parents:
diff changeset
168 fi; \
kono
parents:
diff changeset
169 fi
kono
parents:
diff changeset
170
kono
parents:
diff changeset
171 brig.install-plugin:
kono
parents:
diff changeset
172
kono
parents:
diff changeset
173 brig.install-info: #$(DESTDIR)$(infodir)/gccbrig.info
kono
parents:
diff changeset
174
kono
parents:
diff changeset
175 brig.install-pdf: doc/gccbrig.pdf
kono
parents:
diff changeset
176 @$(NORMAL_INSTALL)
kono
parents:
diff changeset
177 test -z "$(pdfdir)" || $(mkinstalldirs) "$(DESTDIR)$(pdfdir)/gcc"
kono
parents:
diff changeset
178 @for p in doc/gccbrig.pdf; do \
kono
parents:
diff changeset
179 if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \
kono
parents:
diff changeset
180 f=$(pdf__strip_dir) \
kono
parents:
diff changeset
181 echo " $(INSTALL_DATA) '$$d$$p' '$(DESTDIR)$(pdfdir)/gcc/$$f'"; \
kono
parents:
diff changeset
182 $(INSTALL_DATA) "$$d$$p" "$(DESTDIR)$(pdfdir)/gcc/$$f"; \
kono
parents:
diff changeset
183 done
kono
parents:
diff changeset
184
kono
parents:
diff changeset
185 brig.install-html: $(build_htmldir)/brig
kono
parents:
diff changeset
186 @$(NORMAL_INSTALL)
kono
parents:
diff changeset
187 test -z "$(htmldir)" || $(mkinstalldirs) "$(DESTDIR)$(htmldir)"
kono
parents:
diff changeset
188 @for p in $(build_htmldir)/brig; do \
kono
parents:
diff changeset
189 if test -f "$$p" || test -d "$$p"; then d=""; else d="$(srcdir)/"; \
kono
parents:
diff changeset
190 fi; \
kono
parents:
diff changeset
191 f=$(html__strip_dir) \
kono
parents:
diff changeset
192 if test -d "$$d$$p"; then \
kono
parents:
diff changeset
193 echo " $(mkinstalldirs) '$(DESTDIR)$(htmldir)/$$f'"; \
kono
parents:
diff changeset
194 $(mkinstalldirs) "$(DESTDIR)$(htmldir)/$$f" || exit 1; \
kono
parents:
diff changeset
195 echo " $(INSTALL_DATA) '$$d$$p'/* '$(DESTDIR)$(htmldir)/$$f'"; \
kono
parents:
diff changeset
196 $(INSTALL_DATA) "$$d$$p"/* "$(DESTDIR)$(htmldir)/$$f"; \
kono
parents:
diff changeset
197 else \
kono
parents:
diff changeset
198 echo " $(INSTALL_DATA) '$$d$$p' '$(DESTDIR)$(htmldir)/$$f'"; \
kono
parents:
diff changeset
199 $(INSTALL_DATA) "$$d$$p" "$(DESTDIR)$(htmldir)/$$f"; \
kono
parents:
diff changeset
200 fi; \
kono
parents:
diff changeset
201 done
kono
parents:
diff changeset
202
kono
parents:
diff changeset
203 brig.install-man: $(DESTDIR)$(man1dir)/$(GCCBRIG_INSTALL_NAME)$(man1ext)
kono
parents:
diff changeset
204
kono
parents:
diff changeset
205 $(DESTDIR)$(man1dir)/$(GCCBRIG_INSTALL_NAME)$(man1ext): doc/gccbrig.1 \
kono
parents:
diff changeset
206 installdirs
kono
parents:
diff changeset
207 -rm -f $@
kono
parents:
diff changeset
208 -$(INSTALL_DATA) $< $@
kono
parents:
diff changeset
209 -chmod a-x $@
kono
parents:
diff changeset
210
kono
parents:
diff changeset
211 brig.uninstall:
kono
parents:
diff changeset
212 rm -rf $(DESTDIR)$(bindir)/$(GCCBRIG_INSTALL_NAME)$(exeext)
kono
parents:
diff changeset
213 rm -rf $(DESTDIR)$(man1dir)/$(GCCBRIG_INSTALL_NAME)$(man1ext)
kono
parents:
diff changeset
214 rm -rf $(DESTDIR)$(bindir)/$(GCCBRIG_TARGET_INSTALL_NAME)$(exeext)
kono
parents:
diff changeset
215 rm -rf $(DESTDIR)$(infodir)/gccbrig.info*
kono
parents:
diff changeset
216
kono
parents:
diff changeset
217 # Clean hooks.
kono
parents:
diff changeset
218
kono
parents:
diff changeset
219 brig.mostlyclean:
kono
parents:
diff changeset
220 -rm -f brig/*$(objext)
kono
parents:
diff changeset
221 -rm -f brig/*$(coverageexts)
kono
parents:
diff changeset
222 brig.clean:
kono
parents:
diff changeset
223 brig.distclean:
kono
parents:
diff changeset
224 brig.maintainer-clean:
kono
parents:
diff changeset
225 -rm -f $(docobjdir)/gccbrig.1
kono
parents:
diff changeset
226
kono
parents:
diff changeset
227 # Stage hooks.
kono
parents:
diff changeset
228
kono
parents:
diff changeset
229 brig.stage1: stage1-start
kono
parents:
diff changeset
230 -mv brig/*$(objext) stage1/brig
kono
parents:
diff changeset
231 brig.stage2: stage2-start
kono
parents:
diff changeset
232 -mv brig/*$(objext) stage2/brig
kono
parents:
diff changeset
233 brig.stage3: stage3-start
kono
parents:
diff changeset
234 -mv brig/*$(objext) stage3/brig
kono
parents:
diff changeset
235 brig.stage4: stage4-start
kono
parents:
diff changeset
236 -mv brig/*$(objext) stage4/brig
kono
parents:
diff changeset
237 brig.stageprofile: stageprofile-start
kono
parents:
diff changeset
238 -mv brig/*$(objext) stageprofile/brig
kono
parents:
diff changeset
239 brig.stagefeedback: stagefeedback-start
kono
parents:
diff changeset
240 -mv brig/*$(objext) stagefeedback/brig
kono
parents:
diff changeset
241
kono
parents:
diff changeset
242 CFLAGS-brig/brig-lang.o += -DDEFAULT_TARGET_VERSION=\"$(version)\" \
kono
parents:
diff changeset
243 -DDEFAULT_TARGET_MACHINE=\"$(target_noncanonical)\"
kono
parents:
diff changeset
244
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
245 BRIGINCLUDES = -I $(srcdir)/brig -I $(srcdir)/brig/brigfrontend
111
kono
parents:
diff changeset
246
kono
parents:
diff changeset
247 brig/brig-machine.o: brig/brigfrontend/brig-machine.c
kono
parents:
diff changeset
248 $(COMPILE) $(BRIGINCLUDES) $<
kono
parents:
diff changeset
249 $(POSTCOMPILE)
kono
parents:
diff changeset
250
kono
parents:
diff changeset
251 brig/%.o: brig/brigfrontend/%.cc
kono
parents:
diff changeset
252 $(COMPILE) $(BRIGINCLUDES) $<
kono
parents:
diff changeset
253 $(POSTCOMPILE)