annotate libgfortran/runtime/main.c @ 118:fd00160c1b76

ifdef TARGET_64BIT
author mir3636
date Tue, 27 Feb 2018 15:01:35 +0900
parents 04ced10e8804
children 84e7813d76e9
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* Copyright (C) 2002-2017 Free Software Foundation, Inc.
kono
parents:
diff changeset
2 Contributed by Andy Vaught and Paul Brook <paul@nowt.org>
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 This file is part of the GNU Fortran runtime library (libgfortran).
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 Libgfortran is free software; you can redistribute it and/or modify
kono
parents:
diff changeset
7 it under the terms of the GNU General Public License as published by
kono
parents:
diff changeset
8 the Free Software Foundation; either version 3, or (at your option)
kono
parents:
diff changeset
9 any later version.
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 Libgfortran is distributed in the hope that it will be useful,
kono
parents:
diff changeset
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
kono
parents:
diff changeset
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
kono
parents:
diff changeset
14 GNU General Public License for more details.
kono
parents:
diff changeset
15
kono
parents:
diff changeset
16 Under Section 7 of GPL version 3, you are granted additional
kono
parents:
diff changeset
17 permissions described in the GCC Runtime Library Exception, version
kono
parents:
diff changeset
18 3.1, as published by the Free Software Foundation.
kono
parents:
diff changeset
19
kono
parents:
diff changeset
20 You should have received a copy of the GNU General Public License and
kono
parents:
diff changeset
21 a copy of the GCC Runtime Library Exception along with this program;
kono
parents:
diff changeset
22 see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
kono
parents:
diff changeset
23 <http://www.gnu.org/licenses/>. */
kono
parents:
diff changeset
24
kono
parents:
diff changeset
25 #include "libgfortran.h"
kono
parents:
diff changeset
26
kono
parents:
diff changeset
27
kono
parents:
diff changeset
28 /* Stupid function to be sure the constructor is always linked in, even
kono
parents:
diff changeset
29 in the case of static linking. See PR libfortran/22298 for details. */
kono
parents:
diff changeset
30 void
kono
parents:
diff changeset
31 stupid_function_name_for_static_linking (void)
kono
parents:
diff changeset
32 {
kono
parents:
diff changeset
33 return;
kono
parents:
diff changeset
34 }
kono
parents:
diff changeset
35
kono
parents:
diff changeset
36 /* This will be 0 for little-endian
kono
parents:
diff changeset
37 machines and 1 for big-endian machines. */
kono
parents:
diff changeset
38 int big_endian = 0;
kono
parents:
diff changeset
39
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 /* Figure out endianness for this machine. */
kono
parents:
diff changeset
42
kono
parents:
diff changeset
43 static void
kono
parents:
diff changeset
44 determine_endianness (void)
kono
parents:
diff changeset
45 {
kono
parents:
diff changeset
46 union
kono
parents:
diff changeset
47 {
kono
parents:
diff changeset
48 GFC_LOGICAL_8 l8;
kono
parents:
diff changeset
49 GFC_LOGICAL_4 l4[2];
kono
parents:
diff changeset
50 } u;
kono
parents:
diff changeset
51
kono
parents:
diff changeset
52 u.l8 = 1;
kono
parents:
diff changeset
53 if (u.l4[0])
kono
parents:
diff changeset
54 big_endian = 0;
kono
parents:
diff changeset
55 else if (u.l4[1])
kono
parents:
diff changeset
56 big_endian = 1;
kono
parents:
diff changeset
57 else
kono
parents:
diff changeset
58 runtime_error ("Unable to determine machine endianness");
kono
parents:
diff changeset
59 }
kono
parents:
diff changeset
60
kono
parents:
diff changeset
61
kono
parents:
diff changeset
62 static int argc_save;
kono
parents:
diff changeset
63 static char **argv_save;
kono
parents:
diff changeset
64
kono
parents:
diff changeset
65
kono
parents:
diff changeset
66 /* Set the saved values of the command line arguments. */
kono
parents:
diff changeset
67
kono
parents:
diff changeset
68 void
kono
parents:
diff changeset
69 set_args (int argc, char **argv)
kono
parents:
diff changeset
70 {
kono
parents:
diff changeset
71 argc_save = argc;
kono
parents:
diff changeset
72 argv_save = argv;
kono
parents:
diff changeset
73 }
kono
parents:
diff changeset
74 iexport(set_args);
kono
parents:
diff changeset
75
kono
parents:
diff changeset
76
kono
parents:
diff changeset
77 /* Retrieve the saved values of the command line arguments. */
kono
parents:
diff changeset
78
kono
parents:
diff changeset
79 void
kono
parents:
diff changeset
80 get_args (int *argc, char ***argv)
kono
parents:
diff changeset
81 {
kono
parents:
diff changeset
82 *argc = argc_save;
kono
parents:
diff changeset
83 *argv = argv_save;
kono
parents:
diff changeset
84 }
kono
parents:
diff changeset
85
kono
parents:
diff changeset
86
kono
parents:
diff changeset
87 /* Initialize the runtime library. */
kono
parents:
diff changeset
88
kono
parents:
diff changeset
89 static void __attribute__((constructor))
kono
parents:
diff changeset
90 init (void)
kono
parents:
diff changeset
91 {
kono
parents:
diff changeset
92 /* Figure out the machine endianness. */
kono
parents:
diff changeset
93 determine_endianness ();
kono
parents:
diff changeset
94
kono
parents:
diff changeset
95 /* Must be first */
kono
parents:
diff changeset
96 init_variables ();
kono
parents:
diff changeset
97
kono
parents:
diff changeset
98 init_units ();
kono
parents:
diff changeset
99
kono
parents:
diff changeset
100 /* If (and only if) the user asked for it, set up the FPU state. */
kono
parents:
diff changeset
101 if (options.fpe != 0)
kono
parents:
diff changeset
102 set_fpu ();
kono
parents:
diff changeset
103
kono
parents:
diff changeset
104 init_compile_options ();
kono
parents:
diff changeset
105 }
kono
parents:
diff changeset
106
kono
parents:
diff changeset
107
kono
parents:
diff changeset
108 /* Cleanup the runtime library. */
kono
parents:
diff changeset
109
kono
parents:
diff changeset
110 static void __attribute__((destructor))
kono
parents:
diff changeset
111 cleanup (void)
kono
parents:
diff changeset
112 {
kono
parents:
diff changeset
113 close_units ();
kono
parents:
diff changeset
114 }