1 /* Header file to the Fortran front-end and runtime library
2    Copyright (C) 2007-2018 Free Software Foundation, Inc.
3 
4 This file is part of GCC.
5 
6 GCC is free software; you can redistribute it and/or modify it under
7 the terms of the GNU General Public License as published by the Free
8 Software Foundation; either version 3, or (at your option) any later
9 version.
10 
11 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
12 WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
14 for more details.
15 
16 You should have received a copy of the GNU General Public License
17 along with GCC; see the file COPYING3.  If not see
18 <http://www.gnu.org/licenses/>.  */
19 
20 
21 /* Flags to specify which standard/extension contains a feature.
22    Note that no features were obsoleted nor deleted in F2003.
23    Please remember to keep those definitions in sync with
24    gfortran.texi.  */
25 #define GFC_STD_F2018_DEL      (1<<12)  /* Deleted in F2018.  */
26 #define GFC_STD_F2018_OBS      (1<<11)  /* Obsolescent in F2018.  */
27 #define GFC_STD_F2018          (1<<10)  /* New in F2018.  */
28 #define GFC_STD_F2008_TS	(1<<9)	/* POST-F2008 technical reports.  */
29 #define GFC_STD_F2008_OBS	(1<<8)	/* Obsolescent in F2008.  */
30 #define GFC_STD_F2008		(1<<7)	/* New in F2008.  */
31 #define GFC_STD_LEGACY		(1<<6)	/* Backward compatibility.  */
32 #define GFC_STD_GNU		(1<<5)	/* GNU Fortran extension.  */
33 #define GFC_STD_F2003		(1<<4)	/* New in F2003.  */
34 #define GFC_STD_F95		(1<<3)	/* New in F95.  */
35 #define GFC_STD_F95_DEL		(1<<2)	/* Deleted in F95.  */
36 #define GFC_STD_F95_OBS		(1<<1)	/* Obsolescent in F95.  */
37 #define GFC_STD_F77		(1<<0)	/* Included in F77, but not deleted or
38 					   obsolescent in later standards.  */
39 
40 
41 /* Bitmasks for the various FPE that can be enabled.  These need to be straight integers
42    e.g., 8 instead of (1<<3), because they will be included in Fortran source.  */
43 #define GFC_FPE_INVALID      1
44 #define GFC_FPE_DENORMAL     2
45 #define GFC_FPE_ZERO         4
46 #define GFC_FPE_OVERFLOW     8
47 #define GFC_FPE_UNDERFLOW   16
48 #define GFC_FPE_INEXACT     32
49 
50 /* Defines for floating-point rounding modes.  */
51 #define GFC_FPE_DOWNWARD   1
52 #define GFC_FPE_TONEAREST  2
53 #define GFC_FPE_TOWARDZERO 3
54 #define GFC_FPE_UPWARD     4
55 
56 /* Size of the buffer required to store FPU state for any target.
57    In particular, this has to be larger than fenv_t on all glibc targets.
58    Currently, the winner is x86_64 with 32 bytes.  */
59 #define GFC_FPE_STATE_BUFFER_SIZE 32
60 
61 /* Bitmasks for the various runtime checks that can be enabled.  */
62 #define GFC_RTCHECK_BOUNDS      (1<<0)
63 #define GFC_RTCHECK_ARRAY_TEMPS (1<<1)
64 #define GFC_RTCHECK_RECURSION   (1<<2)
65 #define GFC_RTCHECK_DO          (1<<3)
66 #define GFC_RTCHECK_POINTER     (1<<4)
67 #define GFC_RTCHECK_MEM         (1<<5)
68 #define GFC_RTCHECK_ALL        (GFC_RTCHECK_BOUNDS | GFC_RTCHECK_ARRAY_TEMPS \
69 				| GFC_RTCHECK_RECURSION | GFC_RTCHECK_DO \
70 				| GFC_RTCHECK_POINTER | GFC_RTCHECK_MEM)
71 
72 /* Special unit numbers used to convey certain conditions.  Numbers -4
73    thru -9 available.  NEWUNIT values start at -10.  */
74 #define GFC_INTERNAL_UNIT  -1    /* KIND=1 Internal Unit.  */
75 #define GFC_INTERNAL_UNIT4 -2    /* KIND=4 Internal Unit.  */
76 #define GFC_INVALID_UNIT   -3
77 
78 /* Possible values for the CONVERT I/O specifier.  */
79 /* Keep in sync with GFC_FLAG_CONVERT_* in gcc/flags.h.  */
80 typedef enum
81 {
82   GFC_CONVERT_NONE = -1,
83   GFC_CONVERT_NATIVE = 0,
84   GFC_CONVERT_SWAP,
85   GFC_CONVERT_BIG,
86   GFC_CONVERT_LITTLE
87 }
88 unit_convert;
89 
90 
91 /* Runtime errors.  */
92 typedef enum
93 {
94   LIBERROR_FIRST = -3,		/* Marker for the first error.  */
95   LIBERROR_EOR = -2,		/* End of record, must be negative.  */
96   LIBERROR_END = -1,		/* End of file, must be negative.  */
97   LIBERROR_OK = 0,		/* Indicates success, must be zero.  */
98   LIBERROR_OS = 5000,		/* OS error, more info in errno.  */
99   LIBERROR_OPTION_CONFLICT,
100   LIBERROR_BAD_OPTION,
101   LIBERROR_MISSING_OPTION,
102   LIBERROR_ALREADY_OPEN,
103   LIBERROR_BAD_UNIT,
104   LIBERROR_FORMAT,
105   LIBERROR_BAD_ACTION,
106   LIBERROR_ENDFILE,
107   LIBERROR_BAD_US,
108   LIBERROR_READ_VALUE,
109   LIBERROR_READ_OVERFLOW,
110   LIBERROR_INTERNAL,
111   LIBERROR_INTERNAL_UNIT,
112   LIBERROR_ALLOCATION,
113   LIBERROR_DIRECT_EOR,
114   LIBERROR_SHORT_RECORD,
115   LIBERROR_CORRUPT_FILE,
116   LIBERROR_INQUIRE_INTERNAL_UNIT, /* Must be different from STAT_STOPPED_IMAGE.  */
117   LIBERROR_LAST			/* Not a real error, the last error # + 1.  */
118 }
119 libgfortran_error_codes;
120 
121 /* Must kept in sync with libgfortran/caf/libcaf.h.  */
122 typedef enum
123 {
124   GFC_STAT_UNLOCKED = 0,
125   GFC_STAT_LOCKED,
126   GFC_STAT_LOCKED_OTHER_IMAGE,
127   GFC_STAT_STOPPED_IMAGE = 6000, /* See LIBERROR_INQUIRE_INTERNAL_UNIT above. */
128   GFC_STAT_FAILED_IMAGE  = 6001
129 }
130 libgfortran_stat_codes;
131 
132 typedef enum
133 {
134   GFC_CAF_ATOMIC_ADD = 1,
135   GFC_CAF_ATOMIC_AND,
136   GFC_CAF_ATOMIC_OR,
137   GFC_CAF_ATOMIC_XOR
138 } libcaf_atomic_codes;
139 
140 
141 /* For CO_REDUCE.  */
142 #define GFC_CAF_BYREF      (1<<0)
143 #define GFC_CAF_HIDDENLEN  (1<<1)
144 #define GFC_CAF_ARG_VALUE  (1<<2)
145 #define GFC_CAF_ARG_DESC   (1<<3)
146 
147 
148 /* Default unit number for preconnected standard input and output.  */
149 #define GFC_STDIN_UNIT_NUMBER 5
150 #define GFC_STDOUT_UNIT_NUMBER 6
151 #define GFC_STDERR_UNIT_NUMBER 0
152 
153 /* F2003 onward. For std < F2003, error caught in array.c(gfc_match_array_ref).  */
154 #define GFC_MAX_DIMENSIONS 15
155 
156 #define GFC_DTYPE_RANK_MASK 0x0F
157 #define GFC_DTYPE_TYPE_SHIFT 4
158 #define GFC_DTYPE_TYPE_MASK 0x70
159 #define GFC_DTYPE_SIZE_SHIFT 7
160 
161 /* Basic types.  BT_VOID is used by ISO C Binding so funcs like c_f_pointer
162    can take any arg with the pointer attribute as a param.  These are also
163    used in the run-time library for IO.  */
164 typedef enum
165 { BT_UNKNOWN = 0, BT_INTEGER, BT_LOGICAL, BT_REAL, BT_COMPLEX,
166   BT_DERIVED, BT_CHARACTER, BT_CLASS, BT_PROCEDURE, BT_HOLLERITH, BT_VOID,
167   BT_ASSUMED, BT_UNION
168 }
169 bt;
170