xref: /netbsd-src/external/gpl3/gcc.old/dist/gcc/fortran/libgfortran.h (revision 4c3eb207d36f67d31994830c0a694161fc1ca39b)
1627f7eb2Smrg /* Header file to the Fortran front-end and runtime library
2*4c3eb207Smrg    Copyright (C) 2007-2020 Free Software Foundation, Inc.
3627f7eb2Smrg 
4627f7eb2Smrg This file is part of GCC.
5627f7eb2Smrg 
6627f7eb2Smrg GCC is free software; you can redistribute it and/or modify it under
7627f7eb2Smrg the terms of the GNU General Public License as published by the Free
8627f7eb2Smrg Software Foundation; either version 3, or (at your option) any later
9627f7eb2Smrg version.
10627f7eb2Smrg 
11627f7eb2Smrg GCC is distributed in the hope that it will be useful, but WITHOUT ANY
12627f7eb2Smrg WARRANTY; without even the implied warranty of MERCHANTABILITY or
13627f7eb2Smrg FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
14627f7eb2Smrg for more details.
15627f7eb2Smrg 
16627f7eb2Smrg You should have received a copy of the GNU General Public License
17627f7eb2Smrg along with GCC; see the file COPYING3.  If not see
18627f7eb2Smrg <http://www.gnu.org/licenses/>.  */
19627f7eb2Smrg 
20627f7eb2Smrg 
21627f7eb2Smrg /* Flags to specify which standard/extension contains a feature.
22627f7eb2Smrg    Note that no features were obsoleted nor deleted in F2003.
23627f7eb2Smrg    Please remember to keep those definitions in sync with
24627f7eb2Smrg    gfortran.texi.  */
25627f7eb2Smrg #define GFC_STD_F2018_DEL	(1<<11)	/* Deleted in F2018.  */
26627f7eb2Smrg #define GFC_STD_F2018_OBS	(1<<10)	/* Obsolescent in F2018.  */
27627f7eb2Smrg #define GFC_STD_F2018		(1<<9)	/* New in F2018.  */
28627f7eb2Smrg #define GFC_STD_F2008_OBS	(1<<8)	/* Obsolescent in F2008.  */
29627f7eb2Smrg #define GFC_STD_F2008		(1<<7)	/* New in F2008.  */
30627f7eb2Smrg #define GFC_STD_LEGACY		(1<<6)	/* Backward compatibility.  */
31627f7eb2Smrg #define GFC_STD_GNU		(1<<5)	/* GNU Fortran extension.  */
32627f7eb2Smrg #define GFC_STD_F2003		(1<<4)	/* New in F2003.  */
33627f7eb2Smrg #define GFC_STD_F95		(1<<3)	/* New in F95.  */
34627f7eb2Smrg #define GFC_STD_F95_DEL		(1<<2)	/* Deleted in F95.  */
35627f7eb2Smrg #define GFC_STD_F95_OBS		(1<<1)	/* Obsolescent in F95.  */
36627f7eb2Smrg #define GFC_STD_F77		(1<<0)	/* Included in F77, but not deleted or
37627f7eb2Smrg 					   obsolescent in later standards.  */
38627f7eb2Smrg 
39627f7eb2Smrg /* Combinations of the above flags that specify which classes of features
40627f7eb2Smrg  * are allowed with a certain -std option.  */
41627f7eb2Smrg #define GFC_STD_OPT_F95		(GFC_STD_F77 | GFC_STD_F95 | GFC_STD_F95_OBS  \
42627f7eb2Smrg 				| GFC_STD_F2008_OBS | GFC_STD_F2018_OBS \
43627f7eb2Smrg 				| GFC_STD_F2018_DEL)
44627f7eb2Smrg #define GFC_STD_OPT_F03		(GFC_STD_OPT_F95 | GFC_STD_F2003)
45627f7eb2Smrg #define GFC_STD_OPT_F08		(GFC_STD_OPT_F03 | GFC_STD_F2008)
46627f7eb2Smrg #define GFC_STD_OPT_F18		((GFC_STD_OPT_F08 | GFC_STD_F2018) \
47627f7eb2Smrg 				& (~GFC_STD_F2018_DEL))
48627f7eb2Smrg 
49627f7eb2Smrg /* Bitmasks for the various FPE that can be enabled.  These need to be straight integers
50627f7eb2Smrg    e.g., 8 instead of (1<<3), because they will be included in Fortran source.  */
51627f7eb2Smrg #define GFC_FPE_INVALID      1
52627f7eb2Smrg #define GFC_FPE_DENORMAL     2
53627f7eb2Smrg #define GFC_FPE_ZERO         4
54627f7eb2Smrg #define GFC_FPE_OVERFLOW     8
55627f7eb2Smrg #define GFC_FPE_UNDERFLOW   16
56627f7eb2Smrg #define GFC_FPE_INEXACT     32
57627f7eb2Smrg 
58627f7eb2Smrg /* Defines for floating-point rounding modes.  */
59627f7eb2Smrg #define GFC_FPE_DOWNWARD   1
60627f7eb2Smrg #define GFC_FPE_TONEAREST  2
61627f7eb2Smrg #define GFC_FPE_TOWARDZERO 3
62627f7eb2Smrg #define GFC_FPE_UPWARD     4
63627f7eb2Smrg 
64627f7eb2Smrg /* Size of the buffer required to store FPU state for any target.
65627f7eb2Smrg    In particular, this has to be larger than fenv_t on all glibc targets.
66627f7eb2Smrg    Currently, the winner is x86_64 with 32 bytes.  */
67627f7eb2Smrg #define GFC_FPE_STATE_BUFFER_SIZE 32
68627f7eb2Smrg 
69627f7eb2Smrg /* Bitmasks for the various runtime checks that can be enabled.  */
70627f7eb2Smrg #define GFC_RTCHECK_BOUNDS      (1<<0)
71627f7eb2Smrg #define GFC_RTCHECK_ARRAY_TEMPS (1<<1)
72627f7eb2Smrg #define GFC_RTCHECK_RECURSION   (1<<2)
73627f7eb2Smrg #define GFC_RTCHECK_DO          (1<<3)
74627f7eb2Smrg #define GFC_RTCHECK_POINTER     (1<<4)
75627f7eb2Smrg #define GFC_RTCHECK_MEM         (1<<5)
76*4c3eb207Smrg #define GFC_RTCHECK_BITS        (1<<6)
77627f7eb2Smrg #define GFC_RTCHECK_ALL        (GFC_RTCHECK_BOUNDS | GFC_RTCHECK_ARRAY_TEMPS \
78627f7eb2Smrg 				| GFC_RTCHECK_RECURSION | GFC_RTCHECK_DO \
79*4c3eb207Smrg 				| GFC_RTCHECK_POINTER | GFC_RTCHECK_MEM \
80*4c3eb207Smrg 				| GFC_RTCHECK_BITS)
81627f7eb2Smrg 
82627f7eb2Smrg /* Special unit numbers used to convey certain conditions.  Numbers -4
83627f7eb2Smrg    thru -9 available.  NEWUNIT values start at -10.  */
84627f7eb2Smrg #define GFC_INTERNAL_UNIT  -1    /* KIND=1 Internal Unit.  */
85627f7eb2Smrg #define GFC_INTERNAL_UNIT4 -2    /* KIND=4 Internal Unit.  */
86627f7eb2Smrg #define GFC_INVALID_UNIT   -3
87627f7eb2Smrg 
88627f7eb2Smrg /* Possible values for the CONVERT I/O specifier.  */
89627f7eb2Smrg /* Keep in sync with GFC_FLAG_CONVERT_* in gcc/flags.h.  */
90627f7eb2Smrg typedef enum
91627f7eb2Smrg {
92627f7eb2Smrg   GFC_CONVERT_NONE = -1,
93627f7eb2Smrg   GFC_CONVERT_NATIVE = 0,
94627f7eb2Smrg   GFC_CONVERT_SWAP,
95627f7eb2Smrg   GFC_CONVERT_BIG,
96627f7eb2Smrg   GFC_CONVERT_LITTLE
97627f7eb2Smrg }
98627f7eb2Smrg unit_convert;
99627f7eb2Smrg 
100627f7eb2Smrg 
101627f7eb2Smrg /* Runtime errors.  */
102627f7eb2Smrg typedef enum
103627f7eb2Smrg {
104627f7eb2Smrg   LIBERROR_FIRST = -3,		/* Marker for the first error.  */
105627f7eb2Smrg   LIBERROR_EOR = -2,		/* End of record, must be negative.  */
106627f7eb2Smrg   LIBERROR_END = -1,		/* End of file, must be negative.  */
107627f7eb2Smrg   LIBERROR_OK = 0,		/* Indicates success, must be zero.  */
108627f7eb2Smrg   LIBERROR_OS = 5000,		/* OS error, more info in errno.  */
109627f7eb2Smrg   LIBERROR_OPTION_CONFLICT,
110627f7eb2Smrg   LIBERROR_BAD_OPTION,
111627f7eb2Smrg   LIBERROR_MISSING_OPTION,
112627f7eb2Smrg   LIBERROR_ALREADY_OPEN,
113627f7eb2Smrg   LIBERROR_BAD_UNIT,
114627f7eb2Smrg   LIBERROR_FORMAT,
115627f7eb2Smrg   LIBERROR_BAD_ACTION,
116627f7eb2Smrg   LIBERROR_ENDFILE,
117627f7eb2Smrg   LIBERROR_BAD_US,
118627f7eb2Smrg   LIBERROR_READ_VALUE,
119627f7eb2Smrg   LIBERROR_READ_OVERFLOW,
120627f7eb2Smrg   LIBERROR_INTERNAL,
121627f7eb2Smrg   LIBERROR_INTERNAL_UNIT,
122627f7eb2Smrg   LIBERROR_ALLOCATION,
123627f7eb2Smrg   LIBERROR_DIRECT_EOR,
124627f7eb2Smrg   LIBERROR_SHORT_RECORD,
125627f7eb2Smrg   LIBERROR_CORRUPT_FILE,
126627f7eb2Smrg   LIBERROR_INQUIRE_INTERNAL_UNIT, /* Must be different from STAT_STOPPED_IMAGE.  */
127*4c3eb207Smrg   LIBERROR_BAD_WAIT_ID,
128627f7eb2Smrg   LIBERROR_LAST			/* Not a real error, the last error # + 1.  */
129627f7eb2Smrg }
130627f7eb2Smrg libgfortran_error_codes;
131627f7eb2Smrg 
132627f7eb2Smrg /* Must kept in sync with libgfortran/caf/libcaf.h.  */
133627f7eb2Smrg typedef enum
134627f7eb2Smrg {
135627f7eb2Smrg   GFC_STAT_UNLOCKED = 0,
136627f7eb2Smrg   GFC_STAT_LOCKED,
137627f7eb2Smrg   GFC_STAT_LOCKED_OTHER_IMAGE,
138627f7eb2Smrg   GFC_STAT_STOPPED_IMAGE = 6000, /* See LIBERROR_INQUIRE_INTERNAL_UNIT above. */
139627f7eb2Smrg   GFC_STAT_FAILED_IMAGE  = 6001
140627f7eb2Smrg }
141627f7eb2Smrg libgfortran_stat_codes;
142627f7eb2Smrg 
143627f7eb2Smrg typedef enum
144627f7eb2Smrg {
145627f7eb2Smrg   GFC_CAF_ATOMIC_ADD = 1,
146627f7eb2Smrg   GFC_CAF_ATOMIC_AND,
147627f7eb2Smrg   GFC_CAF_ATOMIC_OR,
148627f7eb2Smrg   GFC_CAF_ATOMIC_XOR
149627f7eb2Smrg } libcaf_atomic_codes;
150627f7eb2Smrg 
151627f7eb2Smrg 
152627f7eb2Smrg /* For CO_REDUCE.  */
153627f7eb2Smrg #define GFC_CAF_BYREF      (1<<0)
154627f7eb2Smrg #define GFC_CAF_HIDDENLEN  (1<<1)
155627f7eb2Smrg #define GFC_CAF_ARG_VALUE  (1<<2)
156627f7eb2Smrg #define GFC_CAF_ARG_DESC   (1<<3)
157627f7eb2Smrg 
158627f7eb2Smrg 
159627f7eb2Smrg /* Default unit number for preconnected standard input and output.  */
160627f7eb2Smrg #define GFC_STDIN_UNIT_NUMBER 5
161627f7eb2Smrg #define GFC_STDOUT_UNIT_NUMBER 6
162627f7eb2Smrg #define GFC_STDERR_UNIT_NUMBER 0
163627f7eb2Smrg 
164627f7eb2Smrg /* F2003 onward. For std < F2003, error caught in array.c(gfc_match_array_ref).  */
165627f7eb2Smrg #define GFC_MAX_DIMENSIONS 15
166627f7eb2Smrg 
167627f7eb2Smrg #define GFC_DTYPE_RANK_MASK 0x0F
168627f7eb2Smrg #define GFC_DTYPE_TYPE_SHIFT 4
169627f7eb2Smrg #define GFC_DTYPE_TYPE_MASK 0x70
170627f7eb2Smrg #define GFC_DTYPE_SIZE_SHIFT 7
171627f7eb2Smrg 
172627f7eb2Smrg /* Basic types.  BT_VOID is used by ISO C Binding so funcs like c_f_pointer
173627f7eb2Smrg    can take any arg with the pointer attribute as a param.  These are also
174627f7eb2Smrg    used in the run-time library for IO.  */
175627f7eb2Smrg typedef enum
176627f7eb2Smrg { BT_UNKNOWN = 0, BT_INTEGER, BT_LOGICAL, BT_REAL, BT_COMPLEX,
177627f7eb2Smrg   BT_DERIVED, BT_CHARACTER, BT_CLASS, BT_PROCEDURE, BT_HOLLERITH, BT_VOID,
178*4c3eb207Smrg   BT_ASSUMED, BT_UNION, BT_BOZ
179627f7eb2Smrg }
180627f7eb2Smrg bt;
181