summaryrefslogtreecommitdiffstats
path: root/vm/compiler/codegen/arm/ArchUtility.c
diff options
context:
space:
mode:
authorBen Cheng <bccheng@android.com>2010-06-07 13:44:23 -0700
committerBen Cheng <bccheng@android.com>2010-08-02 14:52:10 -0700
commit7a2697d327936e20ef5484f7819e2e4bf91c891f (patch)
tree1a98a82d12e5aecc3c7b790abfd9963c1583b4a8 /vm/compiler/codegen/arm/ArchUtility.c
parent7b11fa96c361bf029cb465a19b23134d85267430 (diff)
downloadandroid_dalvik-7a2697d327936e20ef5484f7819e2e4bf91c891f.tar.gz
android_dalvik-7a2697d327936e20ef5484f7819e2e4bf91c891f.tar.bz2
android_dalvik-7a2697d327936e20ef5484f7819e2e4bf91c891f.zip
Implement method inlining for getters/setters
Changes include: 1) Force the trace that ends with an invoke instruction to include the next instruction if it is a move-result (because both need to be turned into no-ops if callee is inlined). 2) Interpreter entry point/trace builder changes so that return target won't automatically be considered as trace starting points (to avoid duplicate traces that include the move result instructions). 3) Codegen changes to handle getters/setters invoked from both monomorphic and polymorphic callsites. 4) Extend/fix self-verification to form identical trace regions and handle traces with inlined callees. 5) Apply touchups to the method based parsing - still not in use. Change-Id: I116b934df01bf9ada6d5a25187510e352bccd13c
Diffstat (limited to 'vm/compiler/codegen/arm/ArchUtility.c')
-rw-r--r--vm/compiler/codegen/arm/ArchUtility.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/vm/compiler/codegen/arm/ArchUtility.c b/vm/compiler/codegen/arm/ArchUtility.c
index 2daa871ca..d5acd13ef 100644
--- a/vm/compiler/codegen/arm/ArchUtility.c
+++ b/vm/compiler/codegen/arm/ArchUtility.c
@@ -277,7 +277,8 @@ void dvmDumpLIRInsn(LIR *arg, unsigned char *baseAddr)
LOGD("-------- BARRIER");
break;
case kArmPseudoExtended:
- /* intentional fallthrough */
+ LOGD("-------- %s\n", (char *) dest);
+ break;
case kArmPseudoSSARep:
DUMP_SSA_REP(LOGD("-------- %s\n", (char *) dest));
break;