| ============================================================================= | 
 | Building a JIT: Remote-JITing -- Process Isolation and Laziness at a Distance | 
 | ============================================================================= | 
 |  | 
 | .. 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 5 Introduction | 
 | ====================== | 
 |  | 
 | Welcome to Chapter 5 of the "Building an ORC-based JIT in LLVM" tutorial. This | 
 | chapter introduces the ORC RemoteJIT Client/Server APIs and shows how to use | 
 | them to build a JIT stack that will execute its code via a communications | 
 | channel with a different process. This can be a separate process on the same | 
 | machine, a process on a different machine, or even a process on a different | 
 | platform/architecture. The code builds on top of the lazy-AST-compiling JIT | 
 | stack from `Chapter 4 <BuildingAJIT3.html>`_. | 
 |  | 
 | **To be done -- this is going to be a long one:** | 
 |  | 
 | **(1) Introduce channels, RPC, RemoteJIT Client and Server APIs** | 
 |  | 
 | **(2) Describe the client code in greater detail. Discuss modifications of the | 
 | KaleidoscopeJIT class, and the REPL itself.** | 
 |  | 
 | **(3) Describe the server code.** | 
 |  | 
 | **(4) Describe how to run the demo.** | 
 |  | 
 | 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 | 
 |     clang++ -g Server/server.cpp `llvm-config --cxxflags --ldflags --system-libs --libs core orcjit native` -O3 -o toy-server | 
 |     # Run | 
 |     ./toy-server & | 
 |     ./toy | 
 |  | 
 | Here is the code for the modified KaleidoscopeJIT: | 
 |  | 
 | .. literalinclude:: ../../examples/Kaleidoscope/BuildingAJIT/Chapter5/KaleidoscopeJIT.h | 
 |    :language: c++ | 
 |  | 
 | And the code for the JIT server: | 
 |  | 
 | .. literalinclude:: ../../examples/Kaleidoscope/BuildingAJIT/Chapter5/Server/server.cpp | 
 |    :language: c++ |