Request for review: 8000797: NPG: is_pseudo_string_at() doesn't work
John Rose
john.r.rose at oracle.com
Wed Feb 20 11:51:06 PST 2013
On Feb 20, 2013, at 10:20 AM, Coleen Phillimore <coleen.phillimore at oracle.com> wrote:
> Summary: Add JVM_CONSTANT_PseudoString in place of JVM_CONSTANT_Object and use this tag to distinguish patched pseudo strings. The original string is retained if it was present.
This is reasonable; it is a good cleanup. If you can propose a name better than "PseudoString" I'm all ears.
Consider getting rid of set_has_pseudo_string. That flag was present (IIRC) only to tell the GC that there might be non-perm oops in the constant pool. Do we still need that?
> I'm not sure how class file reconstitution for pseudo-strings is going to work, but I thought it was prudent to leave the Symbol* in the slot for the patched string.
If you really wanted to reconstitute a class file for an anonymous class, and if that class has oop patching (pseudo-strings), you would need either to (a) reconstitute the patches array handed to Unsafe.defineAnonymousClass, or (b) accept whatever odd strings were there first, as an approximation. The "odd strings" are totally insignificant, and are typically something like "CONSTANT_PLACEHOLDER_42" (see InvokerBytecodeGenerator::constantPlaceholder).
— John
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://mail.openjdk.java.net/pipermail/serviceability-dev/attachments/20130220/396d46df/attachment.html
More information about the serviceability-dev
mailing list