Просмотр исходного кода

clang-interpreter: interpret instead of JITing

Fixes the build when no targets are selected, or no native target is built.

This also better matches up with the description/title of the example and
demonstrates how clang can be used to run C++ on constrained environments
without file IO or executable memory permissions (e.g. iOS apps).

A comment is added explaining how to extend the demo with JIT support as
needed.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@212083 91177308-0d34-0410-b5e6-96231b3b80d8
Alp Toker 11 лет назад
Родитель
Сommit
41b937ca28

+ 1 - 2
examples/clang-interpreter/CMakeLists.txt

@@ -1,9 +1,8 @@
 set(LLVM_LINK_COMPONENTS
 set(LLVM_LINK_COMPONENTS
   Core
   Core
   ExecutionEngine
   ExecutionEngine
-  JIT
+  Interpreter
   Support
   Support
-  nativecodegen
   )
   )
 
 
 add_clang_executable(clang-interpreter
 add_clang_executable(clang-interpreter

+ 2 - 1
examples/clang-interpreter/README.txt

@@ -10,7 +10,8 @@ It demonstrates the following features:
  3. Invoking the Clang compiler to lex, parse, syntax check, and then generate
  3. Invoking the Clang compiler to lex, parse, syntax check, and then generate
     LLVM code.
     LLVM code.
 
 
- 4. Use the LLVM JIT functionality to execute the final module.
+ 4. Use the LLVM interpreter functionality to execute the final module, with
+    guidance on how to extend the demo with JIT execution.
 
 
 The implementation has many limitations and is not designed to be a full fledged
 The implementation has many limitations and is not designed to be a full fledged
 C interpreter. It is designed to demonstrate a simple but functional use of the
 C interpreter. It is designed to demonstrate a simple but functional use of the

+ 3 - 3
examples/clang-interpreter/main.cpp

@@ -18,7 +18,6 @@
 #include "clang/Frontend/TextDiagnosticPrinter.h"
 #include "clang/Frontend/TextDiagnosticPrinter.h"
 #include "llvm/ADT/SmallString.h"
 #include "llvm/ADT/SmallString.h"
 #include "llvm/ExecutionEngine/ExecutionEngine.h"
 #include "llvm/ExecutionEngine/ExecutionEngine.h"
-#include "llvm/ExecutionEngine/JIT.h"
 #include "llvm/IR/Module.h"
 #include "llvm/IR/Module.h"
 #include "llvm/Support/FileSystem.h"
 #include "llvm/Support/FileSystem.h"
 #include "llvm/Support/Host.h"
 #include "llvm/Support/Host.h"
@@ -43,11 +42,12 @@ std::string GetExecutablePath(const char *Argv0) {
 }
 }
 
 
 static int Execute(llvm::Module *Mod, char * const *envp) {
 static int Execute(llvm::Module *Mod, char * const *envp) {
-  llvm::InitializeNativeTarget();
+  // To JIT instead of interpreting, call llvm::InitializeNativeTarget() here
+  // and pass ForceInterpreter=false to ExecutionEngine::create().
 
 
   std::string Error;
   std::string Error;
   std::unique_ptr<llvm::ExecutionEngine> EE(
   std::unique_ptr<llvm::ExecutionEngine> EE(
-      llvm::ExecutionEngine::createJIT(Mod, &Error));
+      llvm::ExecutionEngine::create(Mod, /*ForceInterpreter*/ true, &Error));
   if (!EE) {
   if (!EE) {
     llvm::errs() << "unable to make execution engine: " << Error << "\n";
     llvm::errs() << "unable to make execution engine: " << Error << "\n";
     return 255;
     return 255;