diff options
| author | 2012-04-21 22:15:31 -0700 | |
|---|---|---|
| committer | 2012-04-22 01:34:46 -0700 | |
| commit | 853cd09d6ffc87a270d0d531f84f246d534b8c82 (patch) | |
| tree | f66b7329f1c6c0d370cd9eeb78ff6a0e86751653 /src/compiler_llvm/method_compiler.cc | |
| parent | ce154726f34ebfbdce905da008b6359bea9ae50a (diff) | |
Fix llvm runtime support bug.
Change-Id: I7c023e861cb8738ade67ef66155a318c8bd5735a
Diffstat (limited to 'src/compiler_llvm/method_compiler.cc')
| -rw-r--r-- | src/compiler_llvm/method_compiler.cc | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/src/compiler_llvm/method_compiler.cc b/src/compiler_llvm/method_compiler.cc index 5bd1695ea1..8e592fe778 100644 --- a/src/compiler_llvm/method_compiler.cc +++ b/src/compiler_llvm/method_compiler.cc @@ -35,7 +35,6 @@ #include <iomanip> -#include <llvm/Analysis/Verifier.h> #include <llvm/BasicBlock.h> #include <llvm/Function.h> #include <llvm/GlobalVariable.h> @@ -3687,7 +3686,7 @@ CompiledMethod *MethodCompiler::Compile() { EmitPrologueLastBranch(); // Verify the generated bitcode - llvm::verifyFunction(*func_, llvm::PrintMessageAction); + VERIFY_LLVM_FUNCTION(*func_); // Add the memory usage approximation of the compilation unit cunit_->AddMemUsageApproximation(code_item_->insns_size_in_code_units_ * 900); @@ -3738,8 +3737,12 @@ void MethodCompiler::EmitGuard_ExceptionLandingPad(uint32_t dex_pc) { void MethodCompiler::EmitGuard_GarbageCollectionSuspend(uint32_t dex_pc) { llvm::Value* runtime_func = irb_.GetRuntime(TestSuspend); + + llvm::Value* thread_object_addr = irb_.CreateCall(irb_.GetRuntime(GetCurrentThread)); + EmitUpdateDexPC(dex_pc); - irb_.CreateCall(runtime_func); + + irb_.CreateCall(runtime_func, thread_object_addr); EmitGuard_ExceptionLandingPad(dex_pc); } |