Added serviceability-dev@... since this affects SA code...


On 3/29/2011 11:58 AM, Tom Rodriguez wrote:
http://cr.openjdk.java.net/~never/7031614

Please update copyright years as needed.

I could be wrong here but some of what you've uncovered here
appears to be applicable to older SA (pre-static field move).
In particular the oop sizing stuff and static field visitation
during mirror processing.

Did you also get a chance to run the nsk.sajdi subsuite?

Thumbs up.

Dan


agent/src/share/classes/sun/jvm/hotspot/oops/ObjectHeap.java
   No comments.

agent/src/share/classes/sun/jvm/hotspot/oops/Instance.java
   No comments.

agent/src/share/classes/sun/jvm/hotspot/oops/InstanceKlass.java
   line 478 - delete blank line?

agent/src/share/classes/sun/jvm/hotspot/oops/InstanceMirrorKlass.java
   No comments.

agent/src/share/classes/sun/jvm/hotspot/jdi/ClassObjectReferenceImpl.java
   No comments.

agent/src/share/classes/sun/jvm/hotspot/oops/Oop.java
   No comments.

agent/src/share/classes/sun/jvm/hotspot/oops/OopUtilities.java
   No comments.

agent/src/share/classes/sun/jvm/hotspot/oops/java_lang_Class.java
   No comments.

agent/src/share/classes/sun/jvm/hotspot/runtime/VM.java
   No comments.

agent/src/share/classes/sun/jvm/hotspot/tools/FinalizerInfo.java
   No comments.

agent/src/share/classes/sun/jvm/hotspot/utilities/HeapGXLWriter.java
   No comments.

agent/src/share/classes/sun/jvm/hotspot/utilities/HeapHprofBinWriter.java
   No comments.

agent/src/share/classes/sun/jvm/hotspot/utilities/ReversePtrsAnalysis.java
   No comments.

agent/src/share/classes/sun/jvm/hotspot/utilities/soql/JSJavaFactoryImpl.java
   No comments.

src/share/vm/oops/instanceMirrorKlass.hpp
   No comments.

src/share/vm/runtime/vmStructs.cpp
   No comments.


7031614: jmap -permstat fails with java.lang.InternalError in 
sun.jvm.hotspot.oops.OopField.getValue
Reviewed-by:

There were some places that were finding static fields by iterating
over the InstanceKlass object which I missed in my original changes.
I added an iterateStaticFields that hides the owner the static fields
and uses the OopVisitor.getObj to return the proper object.  I
inspected all the iterateFields call sites to make sure I didn't miss
any.  Additionally iteration of the mirror wasn't visiting the static
fields so some roots might be missed by the reverse pointers analysis.
There is heap iteration code in the SA and the InstanceMirrorKlass
wasn't plugged into the the oop sizing logic in the SA which caused
some searches to fail.  I needed to add access to oop_size so I moved
the java_lang_Class style utilities into their own class and made them
like normal SA style classes.  Tested with the full tmtools suite that
showed these issues plus some other which don't appear to have been
reported.

Reply via email to