diff options
author | Carl Shapiro <cshapiro@google.com> | 2011-03-30 19:35:34 -0700 |
---|---|---|
committer | Carl Shapiro <cshapiro@google.com> | 2011-03-30 19:53:34 -0700 |
commit | ce87bfed41bbe4248b2770fb1a90f34b2518f6fa (patch) | |
tree | 8a2ca573187d322f7202df68d36a1101294f5ee5 /vm/InitRefs.c | |
parent | 6920d2c5b83f8ff0cdc8f33770cd658969dbd262 (diff) | |
download | android_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.c | 22 |
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;"); } |