1 <!--===- docs/OptionComparison.md
3 Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 See https://llvm.org/LICENSE.txt for license information.
5 SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
9 # Compiler options comparison
11 This document catalogs the options processed by F18's peers/competitors. Much of the document is taken up by a set of tables that list the options categorized into different topics. Some of the table headings link to more information about the contents of the tables. For example, the table on **Standards conformance** options links to <a href=#standards">notes on Standards conformance</a>.
13 **There's also important information in the ___[Appendix section](#appendix)___ near the end of the document on how this data was gathered and what ___is___ and ___is not___ included in this document.**
15 Note that compilers may support language features without having an option for them. Such cases are frequently, but not always noted in this document.
17 ## Categorization of Options
21 <td colspan="7" ><strong><a href="#standards">Standards conformance</a></strong>
25 <td><strong>Option</strong> </td>
26 <td><strong>Cray</strong> </td>
27 <td><strong>GNU</strong> </td>
28 <td><strong>IBM</strong> </td>
29 <td><strong>Intel</strong> </td>
30 <td><strong>PGI</strong> </td>
31 <td><strong>Flang</strong> </td>
34 <td>Overall conformance </td>
39 <td>std=<em>level</em> </td>
40 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=210">qlanglvl</a>, <a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=257">qsaa</a>
42 <td><a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-stand">stand level</a>
50 <td>Compatibility with previous standards or implementations
58 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=297">qxlf77</a>,
60 <a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=299">qxlf90</a>,
62 <a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=301">qxlf2003</a>,
64 <a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=305">qxfl2008</a>,
66 <a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=245">qport</a>
68 <td><a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-f66">f66</a>,
70 <a href="https://software.intel.com/node/a8bfa478-22d5-4000-b0ac-b881804a7611">f77rtl</a>,
72 <a href="https://software.intel.com/node/647820a0-fc53-4252-a858-46feb012a281">fpscomp</a>,
74 <a href="https://software.intel.com/node/e610682a-00fe-4881-9cf7-8eee08c5f2a2">Intconstant</a>,
76 <a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-standard-realloc-lhs">nostandard-realloc-lhs</a>,
78 <a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-standard-semantics">standard-semantics</a>,
80 <a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-assume">assume nostd_intent_in</a>,
82 <a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-assume">assume nostd_value</a>,
84 <a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-assume">assume norealloc_lhs</a>
86 <td>Mallocatable=95|03
88 <td>Mallocatable=95|03
99 <td colspan="7" ><strong><a href="#source">Source format</a></strong>
103 <td><strong>Option</strong>
105 <td><strong>Cray</strong>
107 <td><strong>GNU</strong>
109 <td><strong>IBM</strong>
111 <td><strong>Intel</strong>
113 <td><strong>PGI</strong>
115 <td><strong>Flang</strong>
119 <td>Fixed or free source
129 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=179">qfree</a>,
131 <a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=169">qfixed</a>
133 <td><a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-fixed">fixed</a>,
135 <a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-free">free</a>
147 <td>Source line length
151 <td>ffixed-line-length-n,
155 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=169">qfixed=n</a>
157 <td><a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-extend-source">extend-source [size]</a>
165 <td>Column 1 comment specifier
169 <td>fd-lines-as-code,
175 <a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=161">qdlines</a>,
177 <a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=306">qxlines</a>
179 <td><a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-d-lines-qd-lines">d-lines</a>
187 <td>Don't treat CR character as a line terminator
193 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=153">qnocr</a>
203 <td>Source file naming
209 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=282">qsuffix</a>
211 <td><a href="https://software.intel.com/node/84174680-3c7d-4225-9611-6083f496aa9b">extfor</a>,
213 <a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-tf">Tf filename</a>
228 <td colspan="7" ><strong><a href="#names">Names, Literals, and other tokens</a></strong>
232 <td><strong>Option</strong>
234 <td><strong>Cray</strong>
236 <td><strong>GNU</strong>
238 <td><strong>IBM</strong>
240 <td><strong>Intel</strong>
242 <td><strong>PGI</strong>
244 <td><strong>Flang</strong>
248 <td>Max identifier length
252 <td>fmax-identifier-length=<em>n</em>
264 <td>"$" in symbol names
280 <td>Allow names with leading "_"
296 <td>Specify name format
302 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=296">U</a>
304 <td><a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-names">names=keyword</a>
312 <td>Escapes in literals
318 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=163">qescape</a>
320 <td><a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-assume">assume bscc</a>
328 <td>Allow multibyte characters in strings
334 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=223">qmbcs</a>
344 <td>Create null terminated strings
350 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=228">qnullterm</a>
360 <td>Character to use for "$"
370 <td>Mdollar,<em>char</em>
376 <td>Allow PARAMETER statements without parentheses
384 <td><a href="https://software.intel.com/node/42e8ec08-64cc-44ba-a636-20ed50c682cd">altparam</a>
397 <td colspan="7" ><strong><a href="#do">DO loop handling</a></strong>
401 <td><strong>Option</strong>
403 <td><strong>Cray</strong>
405 <td><strong>GNU</strong>
407 <td><strong>IBM</strong>
409 <td><strong>Intel</strong>
411 <td><strong>PGI</strong>
413 <td><strong>Flang</strong>
417 <td>One trip DO loops
423 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=113">1</a>,
425 <a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=231">qonetrip</a>
427 <td><a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-f66">f66</a>
435 <td>Allow branching into loops
458 <td colspan="7" ><strong><a href="#real">REAL, DOUBLE PRECISION, and COMPLEX Data</a></strong>
462 <td><strong>Option</strong>
464 <td><strong>Cray</strong>
466 <td><strong>GNU</strong>
468 <td><strong>IBM</strong>
470 <td><strong>Intel</strong>
472 <td><strong>PGI</strong>
474 <td><strong>Flang</strong>
478 <td>Default REAL size
488 <td>fdefault-real-[8|10|16]
490 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=252">qrealsize=[4|8]</a>
492 <td><a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-real-size">real-size [32|64|128]</a>
502 <td>Default DOUBLE PRECISION size
506 <td>fdefault-double-8
510 <td><a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-double-size">double-size[64|128]</a>
518 <td>Make real constants DOUBLE PRECISION
524 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=161">qdpc</a>
534 <td>Promote or demote REAL type sizes
538 <td>freal-[4|8]-real[4|8|10|16]
540 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=144">qautodbl=size</a>
558 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=190">qieee</a>
560 <td><a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-assume">assume std_minus0_rounding</a>
568 <td>Treatment of -0.0
576 <td><a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-assume">assume minus0</a>
591 <td colspan="7" ><strong><a href="#integer">INTEGER and LOGICAL Data</a></strong>
595 <td><strong>Option</strong>
597 <td><strong>Cray</strong>
599 <td><strong>GNU</strong>
601 <td><strong>IBM</strong>
603 <td><strong>Intel</strong>
605 <td><strong>PGI</strong>
607 <td><strong>Flang</strong>
611 <td>Default INTEGER size
621 <td>fdefault-integer-8
623 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=202">qintsize=[2|4|8]</a>
625 <td><a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-integer-size">integer-size [32|64|128]</a>
639 <td>Promote INTEGER sizes
643 <td>finteger-4-integer-8
655 <td>Enable 8 and 16 bit INTEGER and LOGICALS
671 <td>Change how the compiler treats LOGICAL
687 <td>Treatment of numeric constants as arguments
693 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=297">qxlf77 oldboz</a>
695 <td><a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-assume">assume old_boz</a>
703 <td>Treatment of assignment between numerics and logicals
711 <td><a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-assume">assume old_logical_assign</a>
726 <td colspan="7" ><strong>CHARACTER and Pointer Data</strong>
730 <td><strong>Option</strong>
732 <td><strong>Cray</strong>
734 <td><strong>GNU</strong>
736 <td><strong>IBM</strong>
738 <td><strong>Intel</strong>
740 <td><strong>PGI</strong>
742 <td><strong>Flang</strong>
746 <td>Use bytes for pointer arithmetic
762 <td>Use words for pointer arithmetic
778 <td>Allow character constants for typeless constants
784 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=153">qctyplss</a>
797 <td colspan="7" ><strong>Data types and allocation</strong>
801 <td><strong>Option</strong>
803 <td><strong>Cray</strong>
805 <td><strong>GNU</strong>
807 <td><strong>IBM</strong>
809 <td><strong>Intel</strong>
811 <td><strong>PGI</strong>
813 <td><strong>Flang</strong>
817 <td>Default to IMPLICIT NONE
823 <td>u, <a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=291">qundef</a>
825 <td><a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-warn">warn declarations</a>
833 <td>Enable DEC STRUCTURE extensions
837 <td><a href="https://gcc.gnu.org/onlinedocs/gfortran/STRUCTURE-and-RECORD.html">fdec-structure</a>
843 <td><a href="https://www.pgroup.com/doc/pgi15fortref.pdf#page=86">default</a>
849 <td>Enable <a href="https://support.hpe.com/hpesc/public/docDisplay?docId=a00113911en_us&docLocale=en_US&page=Types.html">Cray pointers</a>
855 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024776&aid=1#page=432">Default (near equivalent)</a>
857 <td><a href="https://www.intel.com/content/www/us/en/develop/documentation/fortran-compiler-oneapi-dev-guide-and-reference/top/language-reference/a-to-z-reference/o-to-p/pointer-integer.html">Default (near equivalent)</a>
865 <td>Allow bitwise logical operations on numeric
871 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=201">qintlog</a>
881 <td>Allow DEC STATIC and AUTOMATIC declarations
887 <td>Default, see <a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024776&aid=1#page=393">IMPLICIT STATIC</a> and <a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024776&aid=1#page=393">IMPLICIT AUTOMATIC</a>
889 <td>Default, see <a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-automatic">AUTOMATIC</a> and <a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-static-1#408BC4E6-7AA7-4475-A280-205D34AE2E4F">STATIC</a>
891 <td><a href="https://www.pgroup.com/doc/pgi15fortref.pdf#page=86">Default</a>
897 <td>Allocate variables to static storage
903 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=258">qsave</a>
905 <td><a href="https://software.intel.com/node/3ed16417-6eed-4e09-9edd-4ae03e77c6cf">save</a>,
907 <a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-auto">noauto</a>
917 <td>Compile procedures as if RECURSIVE
923 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=254">q recur</a>
925 <td><a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-assume">assume recursion</a>,
927 <a href="https://software.intel.com/node/1c3820b4-42a1-48ea-887a-2cf39a41ce53">recursive</a>
939 <td colspan="7" ><strong><a href="#arrays">Arrays</strong>
943 <td><strong>Option</strong>
945 <td><strong>Cray</strong>
947 <td><strong>GNU</strong>
949 <td><strong>IBM</strong>
951 <td><strong>Intel</strong>
953 <td><strong>PGI</strong>
955 <td><strong>Flang</strong>
964 <td>fcoarray=<em>key</em>
968 <td><a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-coarray-qcoarray">coarray[=keyword]</a>
976 <td>Contiguous array pointers
982 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=142">qassert=contig</a>
984 <td><a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-assume">assume contiguous_pointer</a>
992 <td>Contiguous assumed shape dummy arguments
994 <td>h contiguous_assumed_shape
998 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=142">qassert=contig</a>
1000 <td><a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-assume">assume contiguous_assumed_shape</a>
1014 <td colspan="7" ><strong>OpenACC, OpenMP, and CUDA</strong>
1018 <td><strong>Option</strong>
1020 <td><strong>Cray</strong>
1022 <td><strong>GNU</strong>
1024 <td><strong>IBM</strong>
1026 <td><strong>Intel</strong>
1028 <td><strong>PGI</strong>
1030 <td><strong>Flang</strong>
1036 <td> <a href="https://pubs.cray.com/content/S-3901/8.7/cray-fortran-reference-manual/program-model-specific-options">h acc</a>
1044 <td><a href="https://www.pgroup.com/resources/docs/19.1/x86/pgi-ref-guide/index.htm#acc">acc</a>
1052 <td> <a href="https://pubs.cray.com/content/S-3901/8.7/cray-fortran-reference-manual/program-model-specific-options">h omp</a>
1056 <td><a href="https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=285">qswapomp</a>
1058 <td><a href="https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-qopenmp-qopenmp">qopenmp</a>,
1060 <a href="https://software.intel.com/node/26d2aef3-9c68-4ef2-9241-bce168a48629">qopenmp-lib</a>,
1062 <a href="https://software.intel.com/node/f8d22e40-7ed0-4ec6-8e80-d4d27010ca8b">qopenmp-link</a>,
1064 <a href="https://software.intel.com/node/2cc99a64-9605-44e2-b40a-1409ba459a62">qopenmp-offload</a>,
1066 <a href="https://software.intel.com/node/02ef8658-3e66-4634-8a11-68eec60322c1">qopenmp-simd</a>,
1068 <a href="https://software.intel.com/node/088272f2-5eae-42c2-a053-20f42022343d">qopenmp-stubs</a>,
1070 <a href="https://software.intel.com/node/0ed8bee0-62b4-4266-8cbb-f25b585d4800">qopenmp-threadprivate</a>
1072 <td><a href="https://www.pgroup.com/resources/docs/19.1/x86/pgi-ref-guide/index.htm#mp">mp</a>,
1085 <td colspan="7" ><strong><a href="#miscellaneous">Miscellaneous</a></strong>
1089 <td><strong>Option</strong>
1091 <td><strong>Cray</strong>
1093 <td><strong>GNU</strong>
1095 <td><strong>IBM</strong>
1097 <td><strong>Intel</strong>
1099 <td><strong>PGI</strong>
1101 <td><strong>Flang</strong>
1105 <td>Disable compile time range checking
1121 <td>Disable call site checking
1137 <td>Warn for bad call checking
1153 <td>Set default accessibility of module entities to PRIVATE
1169 <td>Force FORALL to use temp
1173 <td>ftest-forall-temp
1190 **<a name="standards"></a>Standards conformance:**
1192 All conformance options are similar -- they issue warnings if non-standard features are used. All defaults are to allow extensions without warnings. The GNU, IBM, and Intel compilers allow multiple standard levels to be specified.
1196 * **Cray**: The capital "-eN" option specifies to issue error messages for non-compliance rather than warnings.
1197 * **GNU:** The "std=_level_" option specifies the standard to which the program is expected to conform. The default value for std is 'gnu', which specifies a superset of the latest Fortran standard that includes all of the extensions supported by GNU Fortran, although warnings will be given for obsolete extensions not recommended for use in new code. The 'legacy' value is equivalent but without the warnings for obsolete extensions. The 'f95', 'f2003', 'f2008', and 'f2018' values specify strict conformance to the respective standards. Errors are given for all extensions beyond the relevant language standard, and warnings are given for the Fortran 77 features that are permitted but obsolescent in later standards. '-std=f2008ts' allows the Fortran 2008 standard including the additions of the Technical Specification (TS) 29113 on Further Interoperability of Fortran with C and TS 18508 on Additional Parallel Features in Fortran. Values for "_level_" are f_95, f2003, f2008, f2008ts, f2018, gnu,_ and _legacy._
1199 **<a name="source"></a>Source format:**
1201 **Fixed or free source:** Cray, IBM, and Intel default the source format based on the source file suffix as follows:
1206 * **Free:** .f90, .F90, .f95, .F95, .f03, .F03, .f08, .F08, .ftn, .FTN
1207 * **Fixed:** .f, .F, .for, .FOR
1209 * **Free:** .f90, .F90, .i90
1210 * **Fixed:** .f, .for, .FOR, .ftn, .FTN, .fpp, .FPP, .i
1212 IBM Fortran's options allow the source line length to be specified with the option, e.g., "-qfixed=72". IBM bases the default on the name of the command used to invoke the compiler. IBM has 16 different commands that invoke the Fortran compiler, and the default use of free or fixed format and the line length are based on the command name. -qfixed=72 is the default for the xlf, xlf_r, f77, and fort77 commands. -qfree=f90is the default for the f90, xlf90, xlf90_r, f95, xlf95, xlf95_r, f2003, xlf2003, xlf2003_r, f2008, xlf2008, and xlf2008_r commands. The maximum line length for either source format is 132 characters.
1214 **Column 1 comment specifier:** All compilers allow "D" in column 1 to specify that the line contains a comment and have this as the default for fixed format source. IBM also supports an "X" in column 1 with the option "-qxlines".
1216 **Source line length:**
1219 * **Cray:** The "-N _col_" option specifies the line width for fixed- and free-format source lines. The value used for col specifies the maximum number of columns per line. For free form sources, col can be set to 132, 255, or 1023. For fixed form sources, col can be set to 72, 80, 132, 255, or 1023. Characters in columns beyond the col specification are ignored. By default, lines are 72 characters wide for fixed-format sources and 255 characters wide for free-form sources.
1220 * **GNU:** For both "ffixed-line-length-_n_" and "ffree-line-length-_n_" options, characters are ignored after the specified length. The default for fixed is 72. The default for free is 132. For free, you can specify 'none' as the length, which means that all characters in the line are meaningful.
1221 * **IBM:** For **fixed**, the default is 72. For **free**, there's no default, but the maximum length for either form is 132.
1222 * **Intel:** The default is 72 for **fixed** and 132 for **free**.
1224 * in free form, it is an error if the line is longer than 1000 characters
1225 * in fixed form by default, characters after column 72 are ignored
1226 * in fixed form with -Mextend, characters after column 132 are ignored
1228 **<a name="names"></a>Names, Literals, and other tokens**
1230 **Escapes in literals:**
1233 * **GNU:** The "-fbackslash" option the interpretation of backslashes in string literals from a single backslash character to "C-style" escape characters. The following combinations are expanded \a, \b, \f, \n, \r, \t, \v, \\, and \0 to the ASCII characters alert, backspace, form feed, newline, carriage return, horizontal tab, vertical tab, backslash, and NUL, respectively. Additionally, \xnn, \unnnn and \Unnnnnnnn (where each n is a hexadecimal digit) are translated into the Unicode characters corresponding to the specified code points. All other combinations of a character preceded by \ are unexpanded.
1234 * **Intel:** The option "-assume bscc" tells the compiler to treat the backslash character (\) as a C-style control (escape) character syntax in character literals. "nobscc" specifies that the backslash character is treated as a normal character in character literals. This is the default.
1236 **"$" in symbol names:** Allowing "$" in names is controlled by an option in GNU and is the default behavior in IBM and Intel. Presumably, these compilers issue warnings when standard conformance options are enabled. Dollar signs in names don't seem to be allowed in Cray, PGI, or Flang.
1238 **<a name="do"></a>DO loop handling**
1244 * **IBM:** IBM has two options that do the same thing: "-1" and "-qonetrip".
1245 * **Intel:** Intel used to support a "-onetrip" option, but it has been removed. Intel now supports a "-f66" option that ensures that DO loops are executed at least once in addition to [several other Fortran 66 semantic features](https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-f66#320D769C-7C41-4A84-AE0E-50A72296A838).
1247 **<a name="real"></a>REAL, DOUBLE PRECISION, and COMPLEX Data**
1249 These size options affect the sizes of variables, literals, and intrinsic function results.
1251 **Default REAL sizes:** These options do not affect the size of explicitly declared data (for example, REAL(KIND=4).
1255 * **Cray:** The "-s default32" and "-s default64" options affect both REAL, INTEGER, and LOGICAL types.
1257 **Default DOUBLE PRECISION:** These options allow control of the size of DOUBLE PRECISION types in conjunction with controlling REAL types.
1261 * **Cray:** The "-ep" option controls DOUBLE PRECISION. This option can only be enabled when the default data size is 64 bits ("-s default64" or "-s real64"). When "-s default64" or "-s real64" is specified, and double precision arithmetic is disabled, DOUBLE PRECISION variables and constants specified with the D exponent are converted to default real type (64-bit). If double precision is enabled ("-ep"), they are handled as a double precision type (128-bit). Similarly when the "-s default64" or" -s real64" option is used, variables declared on a DOUBLE COMPLEX statement and complex constants specified with the D exponent are mapped to the complex type in which each part has a default real type, so the complex variable is 128-bit. If double precision is enabled ("-ep"), each part has double precision type, so the double complex variable is 256-bit.
1262 * **GNU:** The "-fdefault-double-8" option sets the DOUBLE PRECISION type to an 8 byte wide type. Do nothing if this is already the default. If "-fdefault-real-8" is given, DOUBLE PRECISION would instead be promoted to 16 bytes if possible, and "-fdefault-double-8" can be used to prevent this. The kind of real constants like 1.d0 will not be changed by "-fdefault-real-8" though, so also "-fdefault-double-8" does not affect it.
1264 **Promote or demote REAL type sizes:** These options change the meaning of data types specified by declarations of the form REAL(KIND=_N_), except, perhaps for PGI.
1266 * **GNU:** The allowable combinations are "-freal-4-real-8", "-freal-4-real-10", "-freal-4-real-16", "-freal-8-real-4", "-freal-8-real-10", and "-freal-8-real-16".
1267 * **IBM:** The "-qautodbl" option is documented [here](https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=144).
1268 * **PGI:** The "-Mr8" option promotes REAL variables and constants to DOUBLE PRECISION variables and constants, respectively. DOUBLE PRECISION elements are 8 bytes in length. The "-Mr8intrinsics" option promotes the intrinsics CMPLX and REAL as DCMPLX and DBLE, respectively.
1270 **<a name="integer"></a>INTEGER and LOGICAL Data**
1272 These size options affect the sizes of variables, literals, and intrinsic function results.
1274 **Default INTEGER sizes:** For all compilers, these options affect both INTEGER and LOGICAL types.
1276 **Enable 8 and 16 bit INTEGER and LOGICAL:** This Cray option ("-eh") enables support for 8-bit and 16-bit INTEGER and LOGICAL types that use explicit kind or star values. By default ("-eh"), data objects declared as INTEGER(kind=1) or LOGICAL(kind=1) are 8 bits long, and objects declared as INTEGER(kind=2) or LOGICAL(kind=2) are 16 bits long. When this option is disabled ("-dh"), data objects declared as INTEGER(kind=1), INTEGER(kind=2), LOGICAL(kind=1), or LOGICAL(kind=2) are 32 bits long.
1278 **Intrinsic functions**
1280 GNU is the only compiler with options governing the use of non-standard intrinsics. For more information on the GNU options, see [here](https://gcc.gnu.org/onlinedocs/gcc-8.3.0/gfortran/Fortran-Dialect-Options.html#Fortran-Dialect-Options). All compilers implement non-standard intrinsics but don't have options that affect access to them.
1282 **<a name="arrays"></a>Arrays**
1284 **Contiguous array pointers:** All vendors that implement this option (Cray, IBM, and Intel) seem to have apply to all pointer targets. Assuming that the arrays that are targeted by the pointers allows greater optimization.
1286 **Contiguous assumed shape dummy arguments:** Cray and Intel have a separate argument that's specific to assumed shape dummy arguments.
1288 **<a name="miscellaneous"></a>Miscellaneous**
1290 **Disable call site checking:** This Cray option ("-dC") disables some types of standard call site checking. The current Fortran standard requires that the number and types of arguments must agree between the caller and callee. These constraints are enforced in cases where the compiler can detect them, however, specifying "-dC" disables some of this error checking, which may be necessary in order to get some older Fortran codes to compile. If error checking is disabled, unexpected compile-time or run time results may occur. The compiler by default attempts to detect situations in which an interface block should be specified but is not. Specifying "-dC" disables this type of checking as well.
1292 **Warn for bad call checking**: This Cray option ("-eb") issues a warning message rather than an error message when the compiler detects a call to a procedure with one or more dummy arguments having the TARGET, VOLATILE or ASYNCHRONOUS attribute and there is not an explicit interface definition.
1298 ### What is and is not included
1300 This document focuses on options relevant to the Fortran language definition. This includes some features (such as recursion) that are only indirectly related to the Fortran language definition. Options related to the following areas are not included:
1306 * Alternate library definition or linking
1307 * Choosing file locations for compiler input or output
1309 * Warning and error messages and listing output
1310 * Data initialization
1313 * Specification of operating system
1314 * Target architecture
1315 * Assembler generation
1316 * Threads or parallelization
1317 * Profiling and code coverage
1321 Here's the list of compilers surveyed, hot linked to the source of data on it. Note that this is the only mention of the Oracle and NAG compilers in this document.
1324 * [Cray Fortran Reference Manual version 8.7](https://pubs.cray.com/content/S-3901/8.7/cray-fortran-reference-manual/compiler-command-line-options)
1325 * IBM (XLF) version 14.1 -- [Compiler Referenc](https://www-01.ibm.com/support/docview.wss?uid=swg27024803&aid=1#page=93)e, [Language Reference](https://www-01.ibm.com/support/docview.wss?uid=swg27024776&aid=1)
1326 * [Intel Fortran version 19.0](https://software.intel.com/en-us/fortran-compiler-developer-guide-and-reference-alphabetical-list-of-compiler-options)
1327 * [GNU Fortran Compiler version 8.3.0](https://gcc.gnu.org/onlinedocs/gcc-8.3.0/gfortran/Option-Summary.html)
1328 * [NAG Fortran Release 6.2](https://www.nag.co.uk/nagware/np/r62_doc/manual/compiler_2_4.html)
1329 * [Oracle Fortran version 819-0492-10](https://docs.oracle.com/cd/E19059-01/stud.10/819-0492/3_options.html)
1330 * PGI -- [Compiler Reference version 19.1](https://www.pgroup.com/resources/docs/19.1/x86/pgi-ref-guide/index.htm#cmdln-options-ref), [Fortran Reference Guide version 17](https://www.pgroup.com/doc/pgi17fortref.pdf)
1331 * [Flang](https://github.com/flang-compiler/flang/wiki/Using-Flang) -- information from GitHub
1333 This document has been kept relatively small by providing links to much of the information about options rather than duplicating that information. For IBM, Intel, and some PGI options, there are direct links. But direct links were not possible for Cray, GNU and some PGI options.
1335 Many compilers have options that can either be enabled or disabled. Some compilers indicate this by the presence or absence of the letters "no" in the option name (IBM, Intel, and PGI) while Cray precedes many options with either "e" for enabled or "d" for disabled. This document only includes the enabled version of the option specification.
1337 Deprecated options were generally ignored, even though they were documented.