GHC Commentary: The Compiler
The compiler itself is written entirely in Haskell, and lives in the many sub-directories of the compiler directory.
- Compiler Module Dependencies (deals with the arcane mutual recursions among GHC's many data types)
- Coding guidelines
- Compiling one module: HscMain
- Overview gives the big picture.
- Some details of the parser
- Some details of the renamer
- Some details of the typechecker
- Some details of the simplifier
- Some details of the code generator converts STG to Cmm
- Backends convert Cmm to native code:
- A guide to the generated assembly code
- Key data types
- The source language: HsSyn
- RdrNames, Modules, and OccNames
- ModIface, ModDetails, ModGuts
- Names
- Entities: variables (Var), type constructors (TyCon), data constructors (DataCon), and classes (Class).
- Tying the knot: how we build the circular data structure representing entities
- Types:
- The core language
- The STG language
- The Cmm language
- Back end types
- Compiling more than one module at once
- How data type declarations are compiled
- The GHC API
- Symbol names and the Z-encoding
- Template Haskell
- Wired-in and known-key things
- Packages
- Recompilation Avoidance
Case studies:
Overall Structure
Here is a block diagram of its top-level structure:
The part called HscMain deals with compiling a single module. On top of this is built the compilation manager (in blue) that manages the compilation of multiple modules. It exports an interface called the GHC API. On top of this API are four small front ends:
- GHCi, the interactive environment, is implemented in ghc/InteractiveUI.hs and compiler/main/InteractiveEval.hs. It sits squarely on top of the GHC API.
- --make is almost a trivial client of the GHC API, and is implemented in compiler/main/GhcMake.hs.
- -M, the Makefile dependency generator, is also a client of the GHC API and is implemented in compiler/main/DriverMkDepend.hs.
- The "one-shot" mode, where GHC compiles each file on the command line separately (eg. ghc -c Foo.hs). This mode bypasses the GHC API, and is implemented directly on top of HscMain, since it compiles only one file at a time. In fact, this is all that GHC consisted of prior to version 5.00 when GHCi and --make were introduced.
GHC is packaged as a single binary in which all of these front-ends are present, selected by the command-line flags indicated above. There is a single command-line interface implemented in ghc/Main.hs.
In addition, GHC is compiled, without its front ends, as a library which can be imported by any Haskell program; see the GHC API.
Attachments (1)
- ghc-top.png (35.8 KB) - added by simonmar 10 years ago.
Download all attachments as: .zip