RFR 8219579: Remove redundant signature parsing from the verifier

Harold Seigel harold.seigel at oracle.com
Fri Mar 1 13:59:18 UTC 2019


Hi Lois,

Thanks for the review!

Please see comments inline.

On 2/28/2019 5:16 PM, Lois Foltan wrote:
>
> On 2/28/2019 3:57 PM, Harold Seigel wrote:
>> Hi,
>>
>> Please review this fix to remove redundant field and method signature 
>> parsing from the verifier.  The parsing is redundant because field 
>> and method signatures are already checked by ClassFileParser.
>>
>> Note that current behavior, in the odd case where a user enables 
>> local verification but disables remote verification, is that both 
>> local and remote classes get verified.  The change in arguments.cpp 
>> does not change that.
>>
>> Open Webrev: 
>> http://cr.openjdk.java.net/~hseigel/bug_8219579/webrev/index.html
>>
>> JBS Bug:  https://bugs.openjdk.java.net/browse/JDK-8219579
>>
>> The fix was regression tested by running Mach5 tiers 1 and 2 tests 
>> and builds on Linux-x64, Solaris, Windows, and Mac OS X, running 
>> tiers 3-5 tests on Linux-x64, and by running JCK-13 Lang and VM tests 
>> on Linux-x64.
>>
>> Thanks, Harold
>>
>
> Hi Harold,
>
> Looks good.  A couple of comments:
>
> - is there a way to remove the SignatureVerifier data structure since 
> it is now only used in an ASSERT situation by verifier.cpp? Could you 
> use ClassFileParser::verify_legal_method_signature and 
> ClassFileParser::verify_legal_field_signature within 
> classfile/verifier.cpp instead?
I plan to do this in a subsequent cleanup enhancement that would include 
the above and also reconciling ClassFileParser's _need_verify and 
_relax_verify flags, and adding some consistency to what is a trusted 
class loader.  For example, Verifier::should_verify_for() thinks it's 
the boot loader. ClassFileParser::relax_format_check_for() thinks it's 
the boot and platform loaders.

>
> - classfile/verifier.cpp
>   line #2114 - can you change the comment in the assert back to 
> something specific to condy like "Invalid type for dynamic constant"?
>   line #2241 & 2717 - nit the other asserts use "Invalid" instead of 
> "Bad".  My suggestion is to make them all consistently use "Invalid"

Done.

Thanks, Harold

>
> Thanks, I don't need to see another webrev.
> Lois


More information about the hotspot-runtime-dev mailing list