summaryrefslogtreecommitdiff
path: root/src/compiler_llvm/method_compiler.cc
diff options
context:
space:
mode:
author TDYa127 <tdy@google.com> 2012-09-26 16:03:51 -0700
committer TDYa127 <tdy@google.com> 2012-09-26 16:05:33 -0700
commit823433dbf4afec17169d5ca738031af5b374e140 (patch)
tree74a1c19c016ce7bf63b043d161d96a56f4b71688 /src/compiler_llvm/method_compiler.cc
parent4d980b0e085ea59bc243da3eff5ea84acc7afc24 (diff)
Corresponding CL of thread flags for portable.
Change-Id: I6ad0c6159115e0d8879e0d9d674d760cd48f29c9
Diffstat (limited to 'src/compiler_llvm/method_compiler.cc')
-rw-r--r--src/compiler_llvm/method_compiler.cc11
1 files changed, 1 insertions, 10 deletions
diff --git a/src/compiler_llvm/method_compiler.cc b/src/compiler_llvm/method_compiler.cc
index 61fffbe238..ca9cbdf410 100644
--- a/src/compiler_llvm/method_compiler.cc
+++ b/src/compiler_llvm/method_compiler.cc
@@ -1257,16 +1257,7 @@ void MethodCompiler::EmitInsn_MoveException(uint32_t dex_pc,
DecodedInstruction dec_insn(insn);
- // Get thread-local exception field address
- llvm::Value* exception_object_addr =
- irb_.Runtime().EmitLoadFromThreadOffset(Thread::ExceptionOffset().Int32Value(),
- irb_.getJObjectTy(),
- kTBAAJRuntime);
-
- // Set thread-local exception field address to NULL
- irb_.Runtime().EmitStoreToThreadOffset(Thread::ExceptionOffset().Int32Value(),
- irb_.getJNull(),
- kTBAAJRuntime);
+ llvm::Value* exception_object_addr = irb_.Runtime().EmitGetAndClearException();
// Keep the exception object in the Dalvik register
EmitStoreDalvikReg(dec_insn.vA, kObject, kAccurate, exception_object_addr);