2020-09-11 01:34:37 +08:00
|
|
|
<!--===- docs/Overview.md
|
|
|
|
|
|
|
|
Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
|
|
|
|
|
|
-->
|
|
|
|
|
2019-02-12 08:33:20 +08:00
|
|
|
# Overview of Compiler Phases
|
|
|
|
|
2020-09-11 21:17:19 +08:00
|
|
|
```eval_rst
|
|
|
|
.. contents::
|
|
|
|
:local:
|
|
|
|
```
|
|
|
|
|
2019-02-15 00:40:19 +08:00
|
|
|
Each phase produces either correct output or fatal errors.
|
2019-02-12 08:33:20 +08:00
|
|
|
|
|
|
|
## Prescan and Preprocess
|
|
|
|
|
2019-02-26 02:38:55 +08:00
|
|
|
See: [Preprocessing.md](Preprocessing.md).
|
|
|
|
|
2019-02-15 00:40:19 +08:00
|
|
|
**Input:** Fortran source and header files, command line macro definitions,
|
|
|
|
set of enabled compiler directives (to be treated as directives rather than
|
|
|
|
comments).
|
2019-02-12 08:33:20 +08:00
|
|
|
|
|
|
|
**Output:**
|
|
|
|
- A "cooked" character stream: the entire program as a contiguous stream of
|
|
|
|
normalized Fortran source.
|
|
|
|
Extraneous whitespace and comments are removed (except comments that are
|
|
|
|
compiler directives that are not disabled) and case is normalized.
|
|
|
|
- Provenance information mapping each character back to the source it came from.
|
|
|
|
This is used in subsequent phases to issue errors messages that refer to source locations.
|
|
|
|
|
|
|
|
**Entry point:** `parser::Parsing::Prescan`
|
|
|
|
|
2019-02-15 00:40:19 +08:00
|
|
|
**Command:** `f18 -E src.f90` dumps the cooked character stream
|
2019-02-12 08:33:20 +08:00
|
|
|
|
|
|
|
## Parse
|
|
|
|
|
|
|
|
**Input:** Cooked character stream.
|
|
|
|
|
2019-02-13 02:40:52 +08:00
|
|
|
**Output:** A parse tree representing a syntactically correct program,
|
2019-02-12 08:33:20 +08:00
|
|
|
rooted at a `parser::Program`.
|
2019-02-26 02:38:55 +08:00
|
|
|
See: [Parsing.md](Parsing.md) and [ParserCombinators.md](ParserCombinators.md).
|
2019-02-12 08:33:20 +08:00
|
|
|
|
|
|
|
**Entry point:** `parser::Parsing::Parse`
|
|
|
|
|
|
|
|
**Command:**
|
|
|
|
- `f18 -fdebug-dump-parse-tree -fparse-only src.f90` dumps the parse tree
|
|
|
|
- `f18 -funparse src.f90` converts the parse tree to normalized Fortran
|
|
|
|
|
|
|
|
## Validate Labels and Canonicalize Do Statements
|
|
|
|
|
2019-02-15 00:40:19 +08:00
|
|
|
**Input:** Parse tree.
|
2019-02-12 08:33:20 +08:00
|
|
|
|
|
|
|
**Output:** The parse tree with label constraints and construct names checked,
|
|
|
|
and each `LabelDoStmt` converted to a `NonLabelDoStmt`.
|
|
|
|
See: [LabelResolution.md](LabelResolution.md).
|
|
|
|
|
|
|
|
**Entry points:** `semantics::ValidateLabels`, `parser::CanonicalizeDo`
|
|
|
|
|
|
|
|
## Resolve Names
|
|
|
|
|
|
|
|
**Input:** Parse tree (without `LabelDoStmt`) and `.mod` files from compilation
|
|
|
|
of USEd modules.
|
|
|
|
|
|
|
|
**Output:**
|
|
|
|
- Tree of scopes populated with symbols and types
|
|
|
|
- Parse tree with some refinements:
|
|
|
|
- each `parser::Name::symbol` field points to one of the symbols
|
|
|
|
- each `parser::TypeSpec::declTypeSpec` field points to one of the types
|
|
|
|
- array element references that were parsed as function references or
|
|
|
|
statement functions are corrected
|
|
|
|
|
|
|
|
**Entry points:** `semantics::ResolveNames`, `semantics::RewriteParseTree`
|
|
|
|
|
|
|
|
**Command:** `f18 -fdebug-dump-symbols -fparse-only src.f90` dumps the
|
2019-02-15 00:40:19 +08:00
|
|
|
tree of scopes and symbols in each scope
|
2019-02-12 08:33:20 +08:00
|
|
|
|
|
|
|
## Check DO CONCURRENT Constraints
|
|
|
|
|
|
|
|
**Input:** Parse tree with names resolved.
|
|
|
|
|
2019-02-13 02:40:52 +08:00
|
|
|
**Output:** Parse tree with semantically correct DO CONCURRENT loops.
|
2019-02-12 08:33:20 +08:00
|
|
|
|
|
|
|
## Write Module Files
|
|
|
|
|
|
|
|
**Input:** Parse tree with names resolved.
|
|
|
|
|
|
|
|
**Output:** For each module and submodule, a `.mod` file containing a minimal
|
|
|
|
Fortran representation suitable for compiling program units that depend on it.
|
2019-02-26 02:38:55 +08:00
|
|
|
See [ModFiles.md](ModFiles.md).
|
2019-02-12 08:33:20 +08:00
|
|
|
|
|
|
|
## Analyze Expressions and Assignments
|
|
|
|
|
|
|
|
**Input:** Parse tree with names resolved.
|
|
|
|
|
|
|
|
**Output:** Parse tree with `parser::Expr::typedExpr` filled in and semantic
|
|
|
|
checks performed on all expressions and assignment statements.
|
|
|
|
|
|
|
|
**Entry points**: `semantics::AnalyzeExpressions`, `semantics::AnalyzeAssignments`
|
|
|
|
|
2019-02-26 02:38:55 +08:00
|
|
|
## Produce the Intermediate Representation
|
|
|
|
|
|
|
|
**Input:** Parse tree with names and labels resolved.
|
|
|
|
|
|
|
|
**Output:** An intermediate representation of the executable program.
|
|
|
|
See [FortranIR.md](FortranIR.md).
|