summaryrefslogtreecommitdiffstats
path: root/runtime/dex_instruction.h
diff options
context:
space:
mode:
authorSebastien Hertz <shertz@google.com>2013-09-10 11:44:19 +0200
committerSebastien Hertz <shertz@google.com>2013-09-30 08:57:33 +0200
commitc61124bdeaae94f977ffc36ac69535e792c226f2 (patch)
tree41ba8619a6dea88a8c607836db21531b05a3787a /runtime/dex_instruction.h
parent7541c745e00b49983f277d6b6b18bc4c174c7e39 (diff)
downloadart-c61124bdeaae94f977ffc36ac69535e792c226f2.zip
art-c61124bdeaae94f977ffc36ac69535e792c226f2.tar.gz
art-c61124bdeaae94f977ffc36ac69535e792c226f2.tar.bz2
Cleanup invoke in interpreter.
Some cleanup in invocation stuff: - Get the number of invoke arguments from instruction (vA) rather than get it from its code item. This benefits to native invoke since we no longer need to parse the method's shorty. Also pass the low 16 bits of instructions to avoid fetching it twice when reading vA. - Remove "is_static" tests by taking advantage of invoke type template argument rather than testing method's access flags. - Ensure Instruction::GetArgs is inlined. - Check exception when initializing method's class when transitioning from interpreter to compiled code (artInterpreterToCompiledCodeBridge). - Move UnstartedRuntimeInvoke function to interpreter_common.cc and make it static as it's only used by DoInvoke and DoInvokeVirtualQuick functions. - Avoid duplicating code in ShadowFrame::Create. Performance remains the same according to benchmarks. Hopefully, this should be addressed in next CLs, especially by improving new shadow frame initialization. Bug: 10668955 Change-Id: I514b8f098d0ef3e35921ceb770383aac1a9c7902
Diffstat (limited to 'runtime/dex_instruction.h')
-rw-r--r--runtime/dex_instruction.h5
1 files changed, 4 insertions, 1 deletions
diff --git a/runtime/dex_instruction.h b/runtime/dex_instruction.h
index e8db3bc..c434cdd 100644
--- a/runtime/dex_instruction.h
+++ b/runtime/dex_instruction.h
@@ -365,7 +365,10 @@ class Instruction {
uint16_t VRegC_3rc() const;
// Fills the given array with the 'arg' array of the instruction.
- void GetArgs(uint32_t args[5]) const;
+ void GetArgs(uint32_t args[5], uint16_t inst_data) const;
+ void GetArgs(uint32_t args[5]) const {
+ return GetArgs(args, Fetch16(0));
+ }
// Returns the opcode field of the instruction. The given "inst_data" parameter must be the first
// 16 bits of instruction.