summaryrefslogtreecommitdiffstats
path: root/vm/InitRefs.c
diff options
context:
space:
mode:
authorCarl Shapiro <cshapiro@google.com>2011-03-30 19:35:34 -0700
committerCarl Shapiro <cshapiro@google.com>2011-03-30 19:53:34 -0700
commitce87bfed41bbe4248b2770fb1a90f34b2518f6fa (patch)
tree8a2ca573187d322f7202df68d36a1101294f5ee5 /vm/InitRefs.c
parent6920d2c5b83f8ff0cdc8f33770cd658969dbd262 (diff)
downloadandroid_dalvik-ce87bfed41bbe4248b2770fb1a90f34b2518f6fa.tar.gz
android_dalvik-ce87bfed41bbe4248b2770fb1a90f34b2518f6fa.tar.bz2
android_dalvik-ce87bfed41bbe4248b2770fb1a90f34b2518f6fa.zip
Delegate the queuing of cleared references to managed code.
Previously, the garbage collector would pass each cleared reference to the heap worker thread for queuing. The heap worker thread would then perform a callback into managed code for each cleared reference which assigned the reference to its reference queue. With this change, the garbage collector instead links together all of the cleared references and calls back into managed code exactly once to hand off the references for processing. This change makes the heap worker thread and its data structures obsolete. Change-Id: I28e02638f0877a7fd2ac96b9c3f5597a38541ebb
Diffstat (limited to 'vm/InitRefs.c')
-rw-r--r--vm/InitRefs.c22
1 files changed, 10 insertions, 12 deletions
diff --git a/vm/InitRefs.c b/vm/InitRefs.c
index b5b75266d..5a9ba2ad5 100644
--- a/vm/InitRefs.c
+++ b/vm/InitRefs.c
@@ -320,6 +320,11 @@ static bool initFieldOffsets(void) {
{ NULL, NULL, NULL }
};
+ static struct FieldInfo infoFinalizerReference[] = {
+ { &gDvm.offJavaLangRefFinalizerReference_zombie, "zombie", "Ljava/lang/Object;" },
+ { NULL, NULL, NULL }
+ };
+
static struct FieldInfo infoConstructor[] = {
{ &gDvm.offJavaLangReflectConstructor_slot, "slot", "I" },
{ &gDvm.offJavaLangReflectConstructor_declClass, "declaringClass", "Ljava/lang/Class;" },
@@ -357,6 +362,7 @@ static bool initFieldOffsets(void) {
{ "Ljava/lang/ThreadGroup;", infoThreadGroup },
{ "Ljava/lang/Throwable;", infoThrowable },
{ "Ljava/lang/VMThread;", infoVMThread },
+ { "Ljava/lang/ref/FinalizerReference;", infoFinalizerReference },
{ "Ljava/lang/reflect/Constructor;", infoConstructor },
{ "Ljava/lang/reflect/Field;", infoField },
{ "Ljava/lang/reflect/Method;", infoMethod },
@@ -468,6 +474,8 @@ static bool initDirectMethodReferences(void) {
"Lorg/apache/harmony/dalvik/ddmc/DdmServer;", "dispatch", "(I[BII)Lorg/apache/harmony/dalvik/ddmc/Chunk;" },
{ &gDvm.methDalvikDdmcServer_broadcast,
"Lorg/apache/harmony/dalvik/ddmc/DdmServer;", "broadcast", "(I)V" },
+ { &gDvm.methJavaLangRefReferenceQueueAdd,
+ "Ljava/lang/ref/ReferenceQueue;", "add", "(Ljava/lang/ref/Reference;)V" },
{ NULL, NULL, NULL, NULL }
};
@@ -587,26 +595,16 @@ bool dvmFindRequiredClassesAndMembers(void) {
/* (documented in header) */
bool dvmFindReferenceMembers(ClassObject* classReference) {
- if (gDvm.methJavaLangRefReference_enqueueInternal != NULL) {
- LOGE("Attempt to set up class Reference more than once\n");
- return false;
- }
-
if (strcmp(classReference->descriptor, "Ljava/lang/ref/Reference;") != 0) {
LOGE("Attempt to set up the wrong class as Reference\n");
return false;
}
-
- /* Note: enqueueInternal() is private and thus a direct method. */
-
return initFieldOffset(classReference, &gDvm.offJavaLangRefReference_pendingNext,
- "pendingNext", "Ljava/lang/Object;")
+ "pendingNext", "Ljava/lang/ref/Reference;")
&& initFieldOffset(classReference, &gDvm.offJavaLangRefReference_queue,
"queue", "Ljava/lang/ref/ReferenceQueue;")
&& initFieldOffset(classReference, &gDvm.offJavaLangRefReference_queueNext,
"queueNext", "Ljava/lang/ref/Reference;")
&& initFieldOffset(classReference, &gDvm.offJavaLangRefReference_referent,
- "referent", "Ljava/lang/Object;")
- && initDirectMethodReferenceByClass(&gDvm.methJavaLangRefReference_enqueueInternal,
- classReference, "enqueueInternal", "()Z");
+ "referent", "Ljava/lang/Object;");
}