OSDN Git Service

2008-01-27 Thomas Koenig <tkoenig@gcc.gnu.org>
[pf3gnuchains/gcc-fork.git] / libgfortran / Makefile.am
1 ## Process this file with automake to produce Makefile.in
2
3
4 ACLOCAL_AMFLAGS = -I .. -I ../config
5
6 ## May be used by toolexeclibdir.
7 gcc_version := $(shell cat $(top_srcdir)/../gcc/BASE-VER)
8
9 ## Symbol versioning (copied from libssp).
10 if LIBGFOR_USE_SYMVER
11 version_arg = -Wl,--version-script=$(srcdir)/gfortran.map
12 else
13 version_arg =
14 endif
15
16 toolexeclib_LTLIBRARIES = libgfortran.la
17 libgfortran_la_LINK = $(LINK)
18 libgfortran_la_LDFLAGS = -version-info `grep -v '^\#' $(srcdir)/libtool-version` -lm $(extra_ldflags_libgfortran) $(version_arg)
19
20 myexeclib_LTLIBRARIES = libgfortranbegin.la
21 myexeclibdir = $(libdir)/gcc/$(target_alias)/$(gcc_version)$(MULTISUBDIR)
22 libgfortranbegin_la_SOURCES = fmain.c
23 libgfortranbegin_la_LDFLAGS = -static
24
25 ## io.h conflicts with a system header on some platforms, so
26 ## use -iquote
27 AM_CPPFLAGS = -iquote$(srcdir)/io -I$(srcdir)/$(MULTISRCTOP)../gcc \
28               -I$(srcdir)/$(MULTISRCTOP)../gcc/config \
29               -I$(MULTIBUILDTOP)../../$(host_subdir)/gcc -D_GNU_SOURCE
30
31 gfor_io_src= \
32 io/close.c \
33 io/file_pos.c \
34 io/format.c \
35 io/inquire.c \
36 io/intrinsics.c \
37 io/list_read.c \
38 io/lock.c \
39 io/open.c \
40 io/read.c \
41 io/size_from_kind.c \
42 io/transfer.c \
43 io/unit.c \
44 io/unix.c \
45 io/write.c
46
47 gfor_io_headers= \
48 io/io.h
49
50 gfor_helper_src= \
51 intrinsics/associated.c \
52 intrinsics/abort.c \
53 intrinsics/access.c \
54 intrinsics/args.c \
55 intrinsics/c99_functions.c \
56 intrinsics/chdir.c \
57 intrinsics/chmod.c \
58 intrinsics/clock.c \
59 intrinsics/cpu_time.c \
60 intrinsics/cshift0.c \
61 intrinsics/ctime.c \
62 intrinsics/date_and_time.c \
63 intrinsics/dtime.c \
64 intrinsics/env.c \
65 intrinsics/eoshift0.c \
66 intrinsics/eoshift2.c \
67 intrinsics/etime.c \
68 intrinsics/exit.c \
69 intrinsics/fnum.c \
70 intrinsics/gerror.c \
71 intrinsics/getcwd.c \
72 intrinsics/getlog.c \
73 intrinsics/getXid.c \
74 intrinsics/hostnm.c \
75 intrinsics/ierrno.c \
76 intrinsics/ishftc.c \
77 intrinsics/iso_c_generated_procs.c \
78 intrinsics/iso_c_binding.c \
79 intrinsics/kill.c \
80 intrinsics/link.c \
81 intrinsics/malloc.c \
82 intrinsics/mvbits.c \
83 intrinsics/move_alloc.c \
84 intrinsics/pack_generic.c \
85 intrinsics/perror.c \
86 intrinsics/signal.c \
87 intrinsics/size.c \
88 intrinsics/sleep.c \
89 intrinsics/spread_generic.c \
90 intrinsics/string_intrinsics.c \
91 intrinsics/system.c \
92 intrinsics/rand.c \
93 intrinsics/random.c \
94 intrinsics/rename.c \
95 intrinsics/reshape_generic.c \
96 intrinsics/reshape_packed.c \
97 intrinsics/selected_int_kind.f90 \
98 intrinsics/selected_real_kind.f90 \
99 intrinsics/stat.c \
100 intrinsics/symlnk.c \
101 intrinsics/system_clock.c \
102 intrinsics/time.c \
103 intrinsics/transpose_generic.c \
104 intrinsics/umask.c \
105 intrinsics/unlink.c \
106 intrinsics/unpack_generic.c \
107 runtime/in_pack_generic.c \
108 runtime/in_unpack_generic.c
109
110 gfor_src= \
111 runtime/backtrace.c \
112 runtime/compile_options.c \
113 runtime/environ.c \
114 runtime/error.c \
115 runtime/fpu.c \
116 runtime/main.c \
117 runtime/memory.c \
118 runtime/pause.c \
119 runtime/stop.c \
120 runtime/string.c \
121 runtime/select.c
122
123 i_all_c= \
124 $(srcdir)/generated/all_l1.c \
125 $(srcdir)/generated/all_l2.c \
126 $(srcdir)/generated/all_l4.c \
127 $(srcdir)/generated/all_l8.c \
128 $(srcdir)/generated/all_l16.c
129
130 i_any_c= \
131 $(srcdir)/generated/any_l1.c \
132 $(srcdir)/generated/any_l2.c \
133 $(srcdir)/generated/any_l4.c \
134 $(srcdir)/generated/any_l8.c \
135 $(srcdir)/generated/any_l16.c
136
137 i_count_c= \
138 $(srcdir)/generated/count_1_l.c \
139 $(srcdir)/generated/count_2_l.c \
140 $(srcdir)/generated/count_4_l.c \
141 $(srcdir)/generated/count_8_l.c \
142 $(srcdir)/generated/count_16_l.c
143
144 i_maxloc0_c= \
145 $(srcdir)/generated/maxloc0_4_i1.c \
146 $(srcdir)/generated/maxloc0_8_i1.c \
147 $(srcdir)/generated/maxloc0_16_i1.c \
148 $(srcdir)/generated/maxloc0_4_i2.c \
149 $(srcdir)/generated/maxloc0_8_i2.c \
150 $(srcdir)/generated/maxloc0_16_i2.c \
151 $(srcdir)/generated/maxloc0_4_i4.c \
152 $(srcdir)/generated/maxloc0_8_i4.c \
153 $(srcdir)/generated/maxloc0_16_i4.c \
154 $(srcdir)/generated/maxloc0_4_i8.c \
155 $(srcdir)/generated/maxloc0_8_i8.c \
156 $(srcdir)/generated/maxloc0_16_i8.c \
157 $(srcdir)/generated/maxloc0_4_i16.c \
158 $(srcdir)/generated/maxloc0_8_i16.c \
159 $(srcdir)/generated/maxloc0_16_i16.c \
160 $(srcdir)/generated/maxloc0_4_r4.c \
161 $(srcdir)/generated/maxloc0_8_r4.c \
162 $(srcdir)/generated/maxloc0_16_r4.c \
163 $(srcdir)/generated/maxloc0_4_r8.c \
164 $(srcdir)/generated/maxloc0_8_r8.c \
165 $(srcdir)/generated/maxloc0_16_r8.c \
166 $(srcdir)/generated/maxloc0_4_r10.c \
167 $(srcdir)/generated/maxloc0_8_r10.c \
168 $(srcdir)/generated/maxloc0_16_r10.c \
169 $(srcdir)/generated/maxloc0_4_r16.c \
170 $(srcdir)/generated/maxloc0_8_r16.c \
171 $(srcdir)/generated/maxloc0_16_r16.c
172
173 i_maxloc1_c= \
174 $(srcdir)/generated/maxloc1_4_i1.c \
175 $(srcdir)/generated/maxloc1_8_i1.c \
176 $(srcdir)/generated/maxloc1_16_i1.c \
177 $(srcdir)/generated/maxloc1_4_i2.c \
178 $(srcdir)/generated/maxloc1_8_i2.c \
179 $(srcdir)/generated/maxloc1_16_i2.c \
180 $(srcdir)/generated/maxloc1_4_i4.c \
181 $(srcdir)/generated/maxloc1_8_i4.c \
182 $(srcdir)/generated/maxloc1_16_i4.c \
183 $(srcdir)/generated/maxloc1_4_i8.c \
184 $(srcdir)/generated/maxloc1_8_i8.c \
185 $(srcdir)/generated/maxloc1_16_i8.c \
186 $(srcdir)/generated/maxloc1_4_i16.c \
187 $(srcdir)/generated/maxloc1_8_i16.c \
188 $(srcdir)/generated/maxloc1_16_i16.c \
189 $(srcdir)/generated/maxloc1_4_r4.c \
190 $(srcdir)/generated/maxloc1_8_r4.c \
191 $(srcdir)/generated/maxloc1_16_r4.c \
192 $(srcdir)/generated/maxloc1_4_r8.c \
193 $(srcdir)/generated/maxloc1_8_r8.c \
194 $(srcdir)/generated/maxloc1_16_r8.c \
195 $(srcdir)/generated/maxloc1_4_r10.c \
196 $(srcdir)/generated/maxloc1_8_r10.c \
197 $(srcdir)/generated/maxloc1_16_r10.c \
198 $(srcdir)/generated/maxloc1_4_r16.c \
199 $(srcdir)/generated/maxloc1_8_r16.c \
200 $(srcdir)/generated/maxloc1_16_r16.c
201
202 i_maxval_c= \
203 $(srcdir)/generated/maxval_i1.c \
204 $(srcdir)/generated/maxval_i2.c \
205 $(srcdir)/generated/maxval_i4.c \
206 $(srcdir)/generated/maxval_i8.c \
207 $(srcdir)/generated/maxval_i16.c \
208 $(srcdir)/generated/maxval_r4.c \
209 $(srcdir)/generated/maxval_r8.c \
210 $(srcdir)/generated/maxval_r10.c \
211 $(srcdir)/generated/maxval_r16.c
212
213 i_minloc0_c= \
214 $(srcdir)/generated/minloc0_4_i1.c \
215 $(srcdir)/generated/minloc0_8_i1.c \
216 $(srcdir)/generated/minloc0_16_i1.c \
217 $(srcdir)/generated/minloc0_4_i2.c \
218 $(srcdir)/generated/minloc0_8_i2.c \
219 $(srcdir)/generated/minloc0_16_i2.c \
220 $(srcdir)/generated/minloc0_4_i4.c \
221 $(srcdir)/generated/minloc0_8_i4.c \
222 $(srcdir)/generated/minloc0_16_i4.c \
223 $(srcdir)/generated/minloc0_4_i8.c \
224 $(srcdir)/generated/minloc0_8_i8.c \
225 $(srcdir)/generated/minloc0_16_i8.c \
226 $(srcdir)/generated/minloc0_4_i16.c \
227 $(srcdir)/generated/minloc0_8_i16.c \
228 $(srcdir)/generated/minloc0_16_i16.c \
229 $(srcdir)/generated/minloc0_4_r4.c \
230 $(srcdir)/generated/minloc0_8_r4.c \
231 $(srcdir)/generated/minloc0_16_r4.c \
232 $(srcdir)/generated/minloc0_4_r8.c \
233 $(srcdir)/generated/minloc0_8_r8.c \
234 $(srcdir)/generated/minloc0_16_r8.c \
235 $(srcdir)/generated/minloc0_4_r10.c \
236 $(srcdir)/generated/minloc0_8_r10.c \
237 $(srcdir)/generated/minloc0_16_r10.c \
238 $(srcdir)/generated/minloc0_4_r16.c \
239 $(srcdir)/generated/minloc0_8_r16.c \
240 $(srcdir)/generated/minloc0_16_r16.c
241
242 i_minloc1_c= \
243 $(srcdir)/generated/minloc1_4_i1.c \
244 $(srcdir)/generated/minloc1_8_i1.c \
245 $(srcdir)/generated/minloc1_16_i1.c \
246 $(srcdir)/generated/minloc1_4_i2.c \
247 $(srcdir)/generated/minloc1_8_i2.c \
248 $(srcdir)/generated/minloc1_16_i2.c \
249 $(srcdir)/generated/minloc1_4_i4.c \
250 $(srcdir)/generated/minloc1_8_i4.c \
251 $(srcdir)/generated/minloc1_16_i4.c \
252 $(srcdir)/generated/minloc1_4_i8.c \
253 $(srcdir)/generated/minloc1_8_i8.c \
254 $(srcdir)/generated/minloc1_16_i8.c \
255 $(srcdir)/generated/minloc1_4_i16.c \
256 $(srcdir)/generated/minloc1_8_i16.c \
257 $(srcdir)/generated/minloc1_16_i16.c \
258 $(srcdir)/generated/minloc1_4_r4.c \
259 $(srcdir)/generated/minloc1_8_r4.c \
260 $(srcdir)/generated/minloc1_16_r4.c \
261 $(srcdir)/generated/minloc1_4_r8.c \
262 $(srcdir)/generated/minloc1_8_r8.c \
263 $(srcdir)/generated/minloc1_16_r8.c \
264 $(srcdir)/generated/minloc1_4_r10.c \
265 $(srcdir)/generated/minloc1_8_r10.c \
266 $(srcdir)/generated/minloc1_16_r10.c \
267 $(srcdir)/generated/minloc1_4_r16.c \
268 $(srcdir)/generated/minloc1_8_r16.c \
269 $(srcdir)/generated/minloc1_16_r16.c
270
271 i_minval_c= \
272 $(srcdir)/generated/minval_i1.c \
273 $(srcdir)/generated/minval_i2.c \
274 $(srcdir)/generated/minval_i4.c \
275 $(srcdir)/generated/minval_i8.c \
276 $(srcdir)/generated/minval_i16.c \
277 $(srcdir)/generated/minval_r4.c \
278 $(srcdir)/generated/minval_r8.c \
279 $(srcdir)/generated/minval_r10.c \
280 $(srcdir)/generated/minval_r16.c
281
282 i_sum_c= \
283 $(srcdir)/generated/sum_i1.c \
284 $(srcdir)/generated/sum_i2.c \
285 $(srcdir)/generated/sum_i4.c \
286 $(srcdir)/generated/sum_i8.c \
287 $(srcdir)/generated/sum_i16.c \
288 $(srcdir)/generated/sum_r4.c \
289 $(srcdir)/generated/sum_r8.c \
290 $(srcdir)/generated/sum_r10.c \
291 $(srcdir)/generated/sum_r16.c \
292 $(srcdir)/generated/sum_c4.c \
293 $(srcdir)/generated/sum_c8.c \
294 $(srcdir)/generated/sum_c10.c \
295 $(srcdir)/generated/sum_c16.c
296
297 i_product_c= \
298 $(srcdir)/generated/product_i1.c \
299 $(srcdir)/generated/product_i2.c \
300 $(srcdir)/generated/product_i4.c \
301 $(srcdir)/generated/product_i8.c \
302 $(srcdir)/generated/product_i16.c \
303 $(srcdir)/generated/product_r4.c \
304 $(srcdir)/generated/product_r8.c \
305 $(srcdir)/generated/product_r10.c \
306 $(srcdir)/generated/product_r16.c \
307 $(srcdir)/generated/product_c4.c \
308 $(srcdir)/generated/product_c8.c \
309 $(srcdir)/generated/product_c10.c \
310 $(srcdir)/generated/product_c16.c
311
312 i_matmul_c= \
313 $(srcdir)/generated/matmul_i1.c \
314 $(srcdir)/generated/matmul_i2.c \
315 $(srcdir)/generated/matmul_i4.c \
316 $(srcdir)/generated/matmul_i8.c \
317 $(srcdir)/generated/matmul_i16.c \
318 $(srcdir)/generated/matmul_r4.c \
319 $(srcdir)/generated/matmul_r8.c \
320 $(srcdir)/generated/matmul_r10.c \
321 $(srcdir)/generated/matmul_r16.c \
322 $(srcdir)/generated/matmul_c4.c \
323 $(srcdir)/generated/matmul_c8.c \
324 $(srcdir)/generated/matmul_c10.c \
325 $(srcdir)/generated/matmul_c16.c
326
327 i_matmull_c= \
328 $(srcdir)/generated/matmul_l4.c \
329 $(srcdir)/generated/matmul_l8.c \
330 $(srcdir)/generated/matmul_l16.c
331
332 i_transpose_c= \
333 $(srcdir)/generated/transpose_i4.c \
334 $(srcdir)/generated/transpose_i8.c \
335 $(srcdir)/generated/transpose_i16.c \
336 $(srcdir)/generated/transpose_r4.c \
337 $(srcdir)/generated/transpose_r8.c \
338 $(srcdir)/generated/transpose_r10.c \
339 $(srcdir)/generated/transpose_r16.c \
340 $(srcdir)/generated/transpose_c4.c \
341 $(srcdir)/generated/transpose_c8.c \
342 $(srcdir)/generated/transpose_c10.c \
343 $(srcdir)/generated/transpose_c16.c
344
345 i_shape_c= \
346 $(srcdir)/generated/shape_i4.c \
347 $(srcdir)/generated/shape_i8.c \
348 $(srcdir)/generated/shape_i16.c
349
350 i_reshape_c= \
351 $(srcdir)/generated/reshape_i4.c \
352 $(srcdir)/generated/reshape_i8.c \
353 $(srcdir)/generated/reshape_i16.c \
354 $(srcdir)/generated/reshape_r4.c \
355 $(srcdir)/generated/reshape_r8.c \
356 $(srcdir)/generated/reshape_r10.c \
357 $(srcdir)/generated/reshape_r16.c \
358 $(srcdir)/generated/reshape_c4.c \
359 $(srcdir)/generated/reshape_c8.c \
360 $(srcdir)/generated/reshape_c10.c \
361 $(srcdir)/generated/reshape_c16.c
362
363 i_eoshift1_c= \
364 $(srcdir)/generated/eoshift1_4.c \
365 $(srcdir)/generated/eoshift1_8.c \
366 $(srcdir)/generated/eoshift1_16.c
367
368 i_eoshift3_c= \
369 $(srcdir)/generated/eoshift3_4.c \
370 $(srcdir)/generated/eoshift3_8.c \
371 $(srcdir)/generated/eoshift3_16.c
372
373 i_cshift1_c= \
374 $(srcdir)/generated/cshift1_4.c \
375 $(srcdir)/generated/cshift1_8.c \
376 $(srcdir)/generated/cshift1_16.c
377
378 in_pack_c = \
379 $(srcdir)/generated/in_pack_i4.c \
380 $(srcdir)/generated/in_pack_i8.c \
381 $(srcdir)/generated/in_pack_i16.c \
382 $(srcdir)/generated/in_pack_c4.c \
383 $(srcdir)/generated/in_pack_c8.c \
384 $(srcdir)/generated/in_pack_c10.c \
385 $(srcdir)/generated/in_pack_c16.c
386
387 in_unpack_c = \
388 $(srcdir)/generated/in_unpack_i4.c \
389 $(srcdir)/generated/in_unpack_i8.c \
390 $(srcdir)/generated/in_unpack_i16.c \
391 $(srcdir)/generated/in_unpack_c4.c \
392 $(srcdir)/generated/in_unpack_c8.c \
393 $(srcdir)/generated/in_unpack_c10.c \
394 $(srcdir)/generated/in_unpack_c16.c
395
396 i_exponent_c = \
397 $(srcdir)/generated/exponent_r4.c \
398 $(srcdir)/generated/exponent_r8.c \
399 $(srcdir)/generated/exponent_r10.c \
400 $(srcdir)/generated/exponent_r16.c
401
402 i_spacing_c = \
403 $(srcdir)/generated/spacing_r4.c \
404 $(srcdir)/generated/spacing_r8.c \
405 $(srcdir)/generated/spacing_r10.c \
406 $(srcdir)/generated/spacing_r16.c
407
408 i_rrspacing_c = \
409 $(srcdir)/generated/rrspacing_r4.c \
410 $(srcdir)/generated/rrspacing_r8.c \
411 $(srcdir)/generated/rrspacing_r10.c \
412 $(srcdir)/generated/rrspacing_r16.c
413
414 i_fraction_c = \
415 $(srcdir)/generated/fraction_r4.c \
416 $(srcdir)/generated/fraction_r8.c \
417 $(srcdir)/generated/fraction_r10.c \
418 $(srcdir)/generated/fraction_r16.c
419
420 i_nearest_c = \
421 $(srcdir)/generated/nearest_r4.c \
422 $(srcdir)/generated/nearest_r8.c \
423 $(srcdir)/generated/nearest_r10.c \
424 $(srcdir)/generated/nearest_r16.c
425
426 i_set_exponent_c = \
427 $(srcdir)/generated/set_exponent_r4.c \
428 $(srcdir)/generated/set_exponent_r8.c \
429 $(srcdir)/generated/set_exponent_r10.c \
430 $(srcdir)/generated/set_exponent_r16.c
431
432 i_pow_c = \
433 $(srcdir)/generated/pow_i4_i4.c \
434 $(srcdir)/generated/pow_i8_i4.c \
435 $(srcdir)/generated/pow_i16_i4.c \
436 $(srcdir)/generated/pow_c4_i4.c \
437 $(srcdir)/generated/pow_c8_i4.c \
438 $(srcdir)/generated/pow_c10_i4.c \
439 $(srcdir)/generated/pow_c16_i4.c \
440 $(srcdir)/generated/pow_i4_i8.c \
441 $(srcdir)/generated/pow_i8_i8.c \
442 $(srcdir)/generated/pow_i16_i8.c \
443 $(srcdir)/generated/pow_r4_i8.c \
444 $(srcdir)/generated/pow_r8_i8.c \
445 $(srcdir)/generated/pow_r10_i8.c \
446 $(srcdir)/generated/pow_r16_i8.c \
447 $(srcdir)/generated/pow_c4_i8.c \
448 $(srcdir)/generated/pow_c8_i8.c \
449 $(srcdir)/generated/pow_c10_i8.c \
450 $(srcdir)/generated/pow_c16_i8.c \
451 $(srcdir)/generated/pow_i4_i16.c \
452 $(srcdir)/generated/pow_i8_i16.c \
453 $(srcdir)/generated/pow_i16_i16.c \
454 $(srcdir)/generated/pow_r4_i16.c \
455 $(srcdir)/generated/pow_r8_i16.c \
456 $(srcdir)/generated/pow_r10_i16.c \
457 $(srcdir)/generated/pow_r16_i16.c \
458 $(srcdir)/generated/pow_c4_i16.c \
459 $(srcdir)/generated/pow_c8_i16.c \
460 $(srcdir)/generated/pow_c10_i16.c \
461 $(srcdir)/generated/pow_c16_i16.c
462
463 m4_files= m4/iparm.m4 m4/ifunction.m4 m4/iforeach.m4 m4/all.m4 \
464     m4/any.m4 m4/count.m4 m4/maxloc0.m4 m4/maxloc1.m4 m4/maxval.m4 \
465     m4/minloc0.m4 m4/minloc1.m4 m4/minval.m4 m4/product.m4 m4/sum.m4 \
466     m4/matmul.m4 m4/matmull.m4 m4/ifunction_logical.m4 \
467     m4/ctrig.m4 m4/cexp.m4 m4/chyp.m4 m4/mtype.m4 \
468     m4/specific.m4 m4/specific2.m4 m4/head.m4 m4/shape.m4 m4/reshape.m4 \
469     m4/transpose.m4 m4/eoshift1.m4 m4/eoshift3.m4 m4/exponent.m4 \
470     m4/fraction.m4 m4/nearest.m4 m4/set_exponent.m4 m4/pow.m4 \
471     m4/misc_specifics.m4 m4/rrspacing.m4 m4/spacing.m4
472
473 gfor_built_src= $(i_all_c) $(i_any_c) $(i_count_c) $(i_maxloc0_c) \
474     $(i_maxloc1_c) $(i_maxval_c) $(i_minloc0_c) $(i_minloc1_c) $(i_minval_c) \
475     $(i_product_c) $(i_sum_c) \
476     $(i_matmul_c) $(i_matmull_c) $(i_transpose_c) $(i_shape_c) $(i_eoshift1_c) \
477     $(i_eoshift3_c) $(i_cshift1_c) $(i_reshape_c) $(in_pack_c) $(in_unpack_c) \
478     $(i_exponent_c) $(i_fraction_c) $(i_nearest_c) $(i_set_exponent_c) \
479     $(i_pow_c) $(i_rrspacing_c) $(i_spacing_c) \
480     selected_int_kind.inc selected_real_kind.inc kinds.h \
481     kinds.inc c99_protos.inc fpu-target.h
482
483 # Machine generated specifics
484 gfor_built_specific_src= \
485 $(srcdir)/generated/_abs_c4.F90 \
486 $(srcdir)/generated/_abs_c8.F90 \
487 $(srcdir)/generated/_abs_c10.F90 \
488 $(srcdir)/generated/_abs_c16.F90 \
489 $(srcdir)/generated/_abs_i4.F90 \
490 $(srcdir)/generated/_abs_i8.F90 \
491 $(srcdir)/generated/_abs_i16.F90 \
492 $(srcdir)/generated/_abs_r4.F90 \
493 $(srcdir)/generated/_abs_r8.F90 \
494 $(srcdir)/generated/_abs_r10.F90 \
495 $(srcdir)/generated/_abs_r16.F90 \
496 $(srcdir)/generated/_aimag_c4.F90 \
497 $(srcdir)/generated/_aimag_c8.F90 \
498 $(srcdir)/generated/_aimag_c10.F90 \
499 $(srcdir)/generated/_aimag_c16.F90 \
500 $(srcdir)/generated/_exp_r4.F90 \
501 $(srcdir)/generated/_exp_r8.F90 \
502 $(srcdir)/generated/_exp_r10.F90 \
503 $(srcdir)/generated/_exp_r16.F90 \
504 $(srcdir)/generated/_exp_c4.F90 \
505 $(srcdir)/generated/_exp_c8.F90 \
506 $(srcdir)/generated/_exp_c10.F90 \
507 $(srcdir)/generated/_exp_c16.F90 \
508 $(srcdir)/generated/_log_r4.F90 \
509 $(srcdir)/generated/_log_r8.F90 \
510 $(srcdir)/generated/_log_r10.F90 \
511 $(srcdir)/generated/_log_r16.F90 \
512 $(srcdir)/generated/_log_c4.F90 \
513 $(srcdir)/generated/_log_c8.F90 \
514 $(srcdir)/generated/_log_c10.F90 \
515 $(srcdir)/generated/_log_c16.F90 \
516 $(srcdir)/generated/_log10_r4.F90 \
517 $(srcdir)/generated/_log10_r8.F90 \
518 $(srcdir)/generated/_log10_r10.F90 \
519 $(srcdir)/generated/_log10_r16.F90 \
520 $(srcdir)/generated/_sqrt_r4.F90 \
521 $(srcdir)/generated/_sqrt_r8.F90 \
522 $(srcdir)/generated/_sqrt_r10.F90 \
523 $(srcdir)/generated/_sqrt_r16.F90 \
524 $(srcdir)/generated/_sqrt_c4.F90 \
525 $(srcdir)/generated/_sqrt_c8.F90 \
526 $(srcdir)/generated/_sqrt_c10.F90 \
527 $(srcdir)/generated/_sqrt_c16.F90 \
528 $(srcdir)/generated/_asin_r4.F90 \
529 $(srcdir)/generated/_asin_r8.F90 \
530 $(srcdir)/generated/_asin_r10.F90 \
531 $(srcdir)/generated/_asin_r16.F90 \
532 $(srcdir)/generated/_asinh_r4.F90 \
533 $(srcdir)/generated/_asinh_r8.F90 \
534 $(srcdir)/generated/_asinh_r10.F90 \
535 $(srcdir)/generated/_asinh_r16.F90 \
536 $(srcdir)/generated/_acos_r4.F90 \
537 $(srcdir)/generated/_acos_r8.F90 \
538 $(srcdir)/generated/_acos_r10.F90 \
539 $(srcdir)/generated/_acos_r16.F90 \
540 $(srcdir)/generated/_acosh_r4.F90 \
541 $(srcdir)/generated/_acosh_r8.F90 \
542 $(srcdir)/generated/_acosh_r10.F90 \
543 $(srcdir)/generated/_acosh_r16.F90 \
544 $(srcdir)/generated/_atan_r4.F90 \
545 $(srcdir)/generated/_atan_r8.F90 \
546 $(srcdir)/generated/_atan_r10.F90 \
547 $(srcdir)/generated/_atan_r16.F90 \
548 $(srcdir)/generated/_atanh_r4.F90 \
549 $(srcdir)/generated/_atanh_r8.F90 \
550 $(srcdir)/generated/_atanh_r10.F90 \
551 $(srcdir)/generated/_atanh_r16.F90 \
552 $(srcdir)/generated/_sin_r4.F90 \
553 $(srcdir)/generated/_sin_r8.F90 \
554 $(srcdir)/generated/_sin_r10.F90 \
555 $(srcdir)/generated/_sin_r16.F90 \
556 $(srcdir)/generated/_sin_c4.F90 \
557 $(srcdir)/generated/_sin_c8.F90 \
558 $(srcdir)/generated/_sin_c10.F90 \
559 $(srcdir)/generated/_sin_c16.F90 \
560 $(srcdir)/generated/_cos_r4.F90 \
561 $(srcdir)/generated/_cos_r8.F90 \
562 $(srcdir)/generated/_cos_r10.F90 \
563 $(srcdir)/generated/_cos_r16.F90 \
564 $(srcdir)/generated/_cos_c4.F90 \
565 $(srcdir)/generated/_cos_c8.F90 \
566 $(srcdir)/generated/_cos_c10.F90 \
567 $(srcdir)/generated/_cos_c16.F90 \
568 $(srcdir)/generated/_tan_r4.F90 \
569 $(srcdir)/generated/_tan_r8.F90 \
570 $(srcdir)/generated/_tan_r10.F90 \
571 $(srcdir)/generated/_tan_r16.F90 \
572 $(srcdir)/generated/_sinh_r4.F90 \
573 $(srcdir)/generated/_sinh_r8.F90 \
574 $(srcdir)/generated/_sinh_r10.F90 \
575 $(srcdir)/generated/_sinh_r16.F90 \
576 $(srcdir)/generated/_cosh_r4.F90 \
577 $(srcdir)/generated/_cosh_r8.F90 \
578 $(srcdir)/generated/_cosh_r10.F90 \
579 $(srcdir)/generated/_cosh_r16.F90 \
580 $(srcdir)/generated/_tanh_r4.F90 \
581 $(srcdir)/generated/_tanh_r8.F90 \
582 $(srcdir)/generated/_tanh_r10.F90 \
583 $(srcdir)/generated/_tanh_r16.F90 \
584 $(srcdir)/generated/_conjg_c4.F90 \
585 $(srcdir)/generated/_conjg_c8.F90 \
586 $(srcdir)/generated/_conjg_c10.F90 \
587 $(srcdir)/generated/_conjg_c16.F90 \
588 $(srcdir)/generated/_aint_r4.F90 \
589 $(srcdir)/generated/_aint_r8.F90 \
590 $(srcdir)/generated/_aint_r10.F90 \
591 $(srcdir)/generated/_aint_r16.F90 \
592 $(srcdir)/generated/_anint_r4.F90 \
593 $(srcdir)/generated/_anint_r8.F90 \
594 $(srcdir)/generated/_anint_r10.F90 \
595 $(srcdir)/generated/_anint_r16.F90
596
597 gfor_built_specific2_src= \
598 $(srcdir)/generated/_sign_i4.F90 \
599 $(srcdir)/generated/_sign_i8.F90 \
600 $(srcdir)/generated/_sign_i16.F90 \
601 $(srcdir)/generated/_sign_r4.F90 \
602 $(srcdir)/generated/_sign_r8.F90 \
603 $(srcdir)/generated/_sign_r10.F90 \
604 $(srcdir)/generated/_sign_r16.F90 \
605 $(srcdir)/generated/_dim_i4.F90 \
606 $(srcdir)/generated/_dim_i8.F90 \
607 $(srcdir)/generated/_dim_i16.F90 \
608 $(srcdir)/generated/_dim_r4.F90 \
609 $(srcdir)/generated/_dim_r8.F90 \
610 $(srcdir)/generated/_dim_r10.F90 \
611 $(srcdir)/generated/_dim_r16.F90 \
612 $(srcdir)/generated/_atan2_r4.F90 \
613 $(srcdir)/generated/_atan2_r8.F90 \
614 $(srcdir)/generated/_atan2_r10.F90 \
615 $(srcdir)/generated/_atan2_r16.F90 \
616 $(srcdir)/generated/_mod_i4.F90 \
617 $(srcdir)/generated/_mod_i8.F90 \
618 $(srcdir)/generated/_mod_i16.F90 \
619 $(srcdir)/generated/_mod_r4.F90 \
620 $(srcdir)/generated/_mod_r8.F90 \
621 $(srcdir)/generated/_mod_r10.F90 \
622 $(srcdir)/generated/_mod_r16.F90
623
624 gfor_misc_specifics = $(srcdir)/generated/misc_specifics.F90
625
626 gfor_specific_src= \
627 $(gfor_built_specific_src) \
628 $(gfor_built_specific2_src) \
629 $(gfor_misc_specifics) \
630 intrinsics/dprod_r8.f90 \
631 intrinsics/f2c_specifics.F90
632
633 # No install-html or install-pdf support in automake yet
634 .PHONY: install-html install-pdf
635 install-html:
636 install-pdf:
637
638 # Turn on vectorization and loop unrolling for matmul.
639 $(patsubst %.c,%.lo,$(notdir $(i_matmul_c))): AM_CFLAGS += -ftree-vectorize -funroll-loops
640 # Logical matmul doesn't vectorize.
641 $(patsubst %.c,%.lo,$(notdir $(i_matmull_c))): AM_CFLAGS += -funroll-loops
642
643 # Add the -fallow-leading-underscore option when needed
644 $(patsubst %.F90,%.lo,$(patsubst %.f90,%.lo,$(notdir $(gfor_specific_src)))): AM_FCFLAGS += -fallow-leading-underscore
645 selected_real_kind.lo selected_int_kind.lo: AM_FCFLAGS += -fallow-leading-underscore
646
647 BUILT_SOURCES=$(gfor_built_src) $(gfor_built_specific_src) \
648     $(gfor_built_specific2_src) $(gfor_misc_specifics)
649
650 prereq_SRC = $(gfor_src) $(gfor_built_src) $(gfor_io_src) \
651     $(gfor_helper_src) $(gfor_io_headers) $(gfor_specific_src)
652
653 if onestep
654 # dummy sources for libtool
655 BUILT_SOURCES+=libgfortran_c.c libgfortran_f.f90
656 libgfortran_c.c libgfortran_f.f90 libgfortran_F.F90:
657         echo > $@
658 # overrides for libtool perusing the dummy sources
659 libgfortran_c.o: $(filter %.c,$(prereq_SRC))
660         $(COMPILE) -c $^ -o $@ -combine
661
662 libgfortran_c.lo: $(filter %.c,$(prereq_SRC))
663         $(LTCOMPILE) -c -o $@ $^ -combine
664
665 #libgfortran_f.o: $(filter %.f %.f90,$(prereq_SRC))
666 #       $(FCCOMPILE) -c $^ -o $@ -combine
667
668 #libgfortran_f.lo: $(filter %.f %.f90,$(prereq_SRC))
669 #       $(LTFCCOMPILE) -c -o $@ $^ -combine
670 # not currently used:
671 #libgfortran_F.o: $(filter %.F %.F90,$(prereq_SRC))
672 #       $(PPFCCOMPILE) -c $^ -o $@ -combine
673 #
674 #libgfortran_F.lo: 
675 #       $(LTPPFCCOMPILE) -c -o $@ $^ -combine
676
677 libgfortran_la_SOURCES = libgfortran_c.c $(filter-out %.c,$(prereq_SRC))
678
679 else
680 libgfortran_la_SOURCES = $(prereq_SRC)
681
682 endif
683
684 I_M4_DEPS=m4/iparm.m4
685 I_M4_DEPS0=$(I_M4_DEPS) m4/iforeach.m4
686 I_M4_DEPS1=$(I_M4_DEPS) m4/ifunction.m4
687 I_M4_DEPS2=$(I_M4_DEPS) m4/ifunction_logical.m4
688
689 kinds.h: $(srcdir)/mk-kinds-h.sh
690         $(SHELL) $(srcdir)/mk-kinds-h.sh '$(FCCOMPILE)' > $@ || rm $@
691
692 kinds.inc: kinds.h
693         grep '^#' < kinds.h > $@
694
695 c99_protos.inc: $(srcdir)/c99_protos.h
696         grep '^#' < $(srcdir)/c99_protos.h > $@
697
698 selected_int_kind.inc: $(srcdir)/mk-sik-inc.sh
699         $(SHELL) $(srcdir)/mk-sik-inc.sh '$(FCCOMPILE)' > $@ || rm $@
700
701 selected_real_kind.inc: $(srcdir)/mk-srk-inc.sh
702         $(SHELL) $(srcdir)/mk-srk-inc.sh '$(FCCOMPILE)' > $@ || rm $@
703
704 fpu-target.h: $(srcdir)/$(FPU_HOST_HEADER)
705         cp $(srcdir)/$(FPU_HOST_HEADER) $@
706
707 ## A 'normal' build shouldn't need to regenerate these
708 ## so we only include them in maintainer mode
709
710 if MAINTAINER_MODE
711 $(i_all_c): m4/all.m4 $(I_M4_DEPS2)
712         $(M4) -Dfile=$@ -I$(srcdir)/m4 all.m4 > $@
713
714 $(i_any_c): m4/any.m4 $(I_M4_DEPS2)
715         $(M4) -Dfile=$@ -I$(srcdir)/m4 any.m4 > $@
716
717 $(i_count_c): m4/count.m4 $(I_M4_DEPS2)
718         $(M4) -Dfile=$@ -I$(srcdir)/m4 count.m4 > $@
719
720 $(i_maxloc0_c): m4/maxloc0.m4 $(I_M4_DEPS0)
721         $(M4) -Dfile=$@ -I$(srcdir)/m4 maxloc0.m4 > $@
722
723 $(i_maxloc1_c): m4/maxloc1.m4 $(I_M4_DEPS1)
724         $(M4) -Dfile=$@ -I$(srcdir)/m4 maxloc1.m4 > $@
725
726 $(i_maxval_c): m4/maxval.m4 $(I_M4_DEPS1)
727         $(M4) -Dfile=$@ -I$(srcdir)/m4 maxval.m4 > $@
728
729 $(i_minloc0_c): m4/minloc0.m4 $(I_M4_DEPS0)
730         $(M4) -Dfile=$@ -I$(srcdir)/m4 minloc0.m4 > $@
731
732 $(i_minloc1_c): m4/minloc1.m4 $(I_M4_DEPS1)
733         $(M4) -Dfile=$@ -I$(srcdir)/m4 minloc1.m4 > $@
734
735 $(i_minval_c): m4/minval.m4 $(I_M4_DEPS1)
736         $(M4) -Dfile=$@ -I$(srcdir)/m4 minval.m4 > $@
737
738 $(i_product_c): m4/product.m4 $(I_M4_DEPS1)
739         $(M4) -Dfile=$@ -I$(srcdir)/m4 product.m4 > $@
740
741 $(i_sum_c): m4/sum.m4 $(I_M4_DEPS1)
742         $(M4) -Dfile=$@ -I$(srcdir)/m4 sum.m4 > $@
743
744 $(i_matmul_c): m4/matmul.m4 $(I_M4_DEPS)
745         $(M4) -Dfile=$@ -I$(srcdir)/m4 matmul.m4 > $@
746
747 $(i_matmull_c): m4/matmull.m4 $(I_M4_DEPS)
748         $(M4) -Dfile=$@ -I$(srcdir)/m4 matmull.m4 > $@
749
750 $(i_transpose_c): m4/transpose.m4 $(I_M4_DEPS)
751         $(M4) -Dfile=$@ -I$(srcdir)/m4 transpose.m4 > $@
752
753 $(i_shape_c): m4/shape.m4 $(I_M4_DEPS)
754         $(M4) -Dfile=$@ -I$(srcdir)/m4 shape.m4 > $@
755
756 $(i_reshape_c): m4/reshape.m4 $(I_M4_DEPS)
757         $(M4) -Dfile=$@ -I$(srcdir)/m4 reshape.m4 > $@
758
759 $(i_eoshift1_c): m4/eoshift1.m4 $(I_M4_DEPS)
760         $(M4) -Dfile=$@ -I$(srcdir)/m4 eoshift1.m4 > $@
761
762 $(i_eoshift3_c): m4/eoshift3.m4 $(I_M4_DEPS)
763         $(M4) -Dfile=$@ -I$(srcdir)/m4 eoshift3.m4 > $@
764
765 $(i_cshift1_c): m4/cshift1.m4 $(I_M4_DEPS)
766         $(M4) -Dfile=$@ -I$(srcdir)/m4 cshift1.m4 > $@
767
768 $(in_pack_c): m4/in_pack.m4 $(I_M4_DEPS)
769         $(M4) -Dfile=$@ -I$(srcdir)/m4 in_pack.m4 > $@
770
771 $(in_unpack_c): m4/in_unpack.m4 $(I_M4_DEPS)
772         $(M4) -Dfile=$@ -I$(srcdir)/m4 in_unpack.m4 > $@
773
774 $(i_exponent_c): m4/exponent.m4 m4/mtype.m4
775         $(M4) -Dfile=$@ -I$(srcdir)/m4 exponent.m4 > $@
776
777 $(i_rrspacing_c): m4/rrspacing.m4 m4/mtype.m4
778         $(M4) -Dfile=$@ -I$(srcdir)/m4 rrspacing.m4 > $@
779
780 $(i_spacing_c): m4/spacing.m4 m4/mtype.m4
781         $(M4) -Dfile=$@ -I$(srcdir)/m4 spacing.m4 > $@
782
783 $(i_fraction_c): m4/fraction.m4 m4/mtype.m4
784         $(M4) -Dfile=$@ -I$(srcdir)/m4 fraction.m4 > $@
785
786 $(i_nearest_c): m4/nearest.m4 m4/mtype.m4
787         $(M4) -Dfile=$@ -I$(srcdir)/m4 nearest.m4 > $@
788
789 $(i_set_exponent_c): m4/set_exponent.m4 m4/mtype.m4
790         $(M4) -Dfile=$@ -I$(srcdir)/m4 set_exponent.m4 > $@
791
792 $(i_pow_c): m4/pow.m4 $(I_M4_DEPS)
793         $(M4) -Dfile=$@ -I$(srcdir)/m4 pow.m4 > $@
794
795 $(gfor_built_specific_src): m4/specific.m4 m4/head.m4
796         $(M4) -Dfile=$@ -I$(srcdir)/m4 specific.m4 > $@
797
798 $(gfor_built_specific2_src): m4/specific2.m4 m4/head.m4
799         $(M4) -Dfile=$@ -I$(srcdir)/m4 specific2.m4 > $@
800
801 $(gfor_misc_specifics): m4/misc_specifics.m4 m4/head.m4
802         $(M4) -Dfile=$@ -I$(srcdir)/m4 misc_specifics.m4 > $@
803 ## end of maintainer mode only rules
804 endif
805
806 EXTRA_DIST = $(m4_files)