diff options
author | Sebastien Hertz <shertz@google.com> | 2013-09-10 11:44:19 +0200 |
---|---|---|
committer | Sebastien Hertz <shertz@google.com> | 2013-09-30 08:57:33 +0200 |
commit | c61124bdeaae94f977ffc36ac69535e792c226f2 (patch) | |
tree | 41ba8619a6dea88a8c607836db21531b05a3787a /runtime/dex_instruction.h | |
parent | 7541c745e00b49983f277d6b6b18bc4c174c7e39 (diff) | |
download | art-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.h | 5 |
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. |