|  | =========================================================================== | 
|  | Building a JIT: Extreme Laziness - Using Compile Callbacks to JIT from ASTs | 
|  | =========================================================================== | 
|  |  | 
|  | .. contents:: | 
|  | :local: | 
|  |  | 
|  | **This tutorial is under active development. It is incomplete and details may | 
|  | change frequently.** Nonetheless we invite you to try it out as it stands, and | 
|  | we welcome any feedback. | 
|  |  | 
|  | Chapter 4 Introduction | 
|  | ====================== | 
|  |  | 
|  | Welcome to Chapter 4 of the "Building an ORC-based JIT in LLVM" tutorial. This | 
|  | chapter introduces the Compile Callbacks and Indirect Stubs APIs and shows how | 
|  | they can be used to replace the CompileOnDemand layer from | 
|  | `Chapter 3 <BuildingAJIT3.html>`_ with a custom lazy-JITing scheme that JITs | 
|  | directly from Kaleidoscope ASTs. | 
|  |  | 
|  | **To be done:** | 
|  |  | 
|  | **(1) Describe the drawbacks of JITing from IR (have to compile to IR first, | 
|  | which reduces the benefits of laziness).** | 
|  |  | 
|  | **(2) Describe CompileCallbackManagers and IndirectStubManagers in detail.** | 
|  |  | 
|  | **(3) Run through the implementation of addFunctionAST.** | 
|  |  | 
|  | Full Code Listing | 
|  | ================= | 
|  |  | 
|  | Here is the complete code listing for our running example that JITs lazily from | 
|  | Kaleidoscope ASTS. To build this example, use: | 
|  |  | 
|  | .. code-block:: bash | 
|  |  | 
|  | # Compile | 
|  | clang++ -g toy.cpp `llvm-config --cxxflags --ldflags --system-libs --libs core orcjit native` -O3 -o toy | 
|  | # Run | 
|  | ./toy | 
|  |  | 
|  | Here is the code: | 
|  |  | 
|  | .. literalinclude:: ../../examples/Kaleidoscope/BuildingAJIT/Chapter4/KaleidoscopeJIT.h | 
|  | :language: c++ | 
|  |  | 
|  | `Next: Remote-JITing -- Process-isolation and laziness-at-a-distance <BuildingAJIT5.html>`_ |