RFR: 8220366: Optimize Symbol handling in ClassVerifier and SignatureStream

Lois Foltan lois.foltan at oracle.com
Thu Mar 14 17:09:17 UTC 2019


On 3/14/2019 12:15 PM, Claes Redestad wrote:
> On 2019-03-14 16:47, Lois Foltan wrote:
>>
>> Hi Claes,
>>
>> Looks like a good improvement! 
>
> Thanks!
>
>> A couple of comments:
>>
>> - src/hotspot/share/oops/symbol.cpp - new method 
>> Symbol::make_permanent()
>>    I have a concern that the while (true) loop could be infinite, can 
>> you have Coleen ok this part of the change since she is the expert in 
>> regards to Symbol refcounts?
>
> I've checked this with Coleen. The race handling logic here mimics that
> of increment_ and decrement_refcount. A live lock condition where two or
> more threads keep trying to update a refcount indefinitely should be
> extremely rare, in practice they should always resolve within a few
> iterations.
>
>>
>> - src/hotspot/share/runtime/signature.cpp
>>    The removal of SignatureVerifier::invalid_name_char(char c) method 
>> seems fine except that the new switch at line #496 does not include 
>> the ';' case, why?
>
> Note that the ';' case is handled above the switch. Admittedly, this
> expression can be simplified a bit:
>
> diff -r 89b091544fd0 src/hotspot/share/runtime/signature.cpp
> --- a/src/hotspot/share/runtime/signature.cpp    Thu Mar 14 16:50:03 
> 2019 +0100
> +++ b/src/hotspot/share/runtime/signature.cpp    Thu Mar 14 17:09:35 
> 2019 +0100
> @@ -479,10 +479,9 @@
>      case 'L':
>        for (index = index + 1; index < limit; ++index) {
>          char c = type[index];
> -        if (c == ';') {
> -          return index + 1;
> -        }
>          switch (c) {
> +          case ';':
> +            return index + 1;
>            case '\0': case '.': case '[':
>              return -1;
>            default: ; // fall through
>
> Maybe that's clearer? Seeing that the code is ASSERT-only since
> JDK-8219579 the changes in this area are mostly cosmetic.

Thanks for the explanation, I missed the earlier check for ';' in the 
if.  I like having it moved into the switch statement.  And I see Coleen 
reviewed at the same time I did, so I think this change looks good.  I 
don't need to see another webrev.
Lois

>
>> - copyrights need to be updated in various files
>
> Sure.
>
> /Claes



More information about the hotspot-runtime-dev mailing list