RFR: 8291459: JVM crash with GenerateOopMap::error_work(char const*, __va_list_tag*) [v2]

David Holmes dholmes at openjdk.org
Fri Aug 5 04:00:48 UTC 2022


On Thu, 4 Aug 2022 17:18:16 GMT, Harold Seigel <hseigel at openjdk.org> wrote:

>> The JVM fails when generating oop maps for method getAlphanumericCode(int) in bug_file/com/google/zxing/qrcode/encoder/Encoder.javap because the last bytecode in the method is an unreachable conditional branch at byecode index 11131:
>> 
>>       11124: ireturn
>>       11125: iinc          41, 1
>>       11128: iload         41
>>       11130: iconst_2
>>       11131: if_icmple     291
>> 
>> The class file (Encoder.class) containing getAlphanumericCode(int) has a class file version of 49.  So it is verified by the old verifier, which allows methods to end in a conditional branch provided that the conditional branch is unreachable during method execution.
>> 
>> This fix changes GenerateOopMap::jump_targets_do() to handle such methods.
>> 
>> The fix was tested by running the user's failing program, the new regression test, Mach5 tiers 1-2 on Linux, Mac OS, and Windows, Mach5 tiers 3-5 on Linu x64, and the JC Lang,VM, and API tests locally on Linux x64.
>> 
>> Please review.
>> Thanks, Harold
>
> Harold Seigel has updated the pull request incrementally with one additional commit since the last revision:
> 
>   remove CreateCodedumpOnCrash option

Seems reasonable. One query on the test but nothing important.

Surprised this has not been detected in the past.

Thanks.

test/hotspot/jtreg/runtime/GenerateOopMap/TestGenerateOopMapCrash.java line 34:

> 32:  */
> 33: 
> 34: package compiler.linkage;

Why a package, and why this package for a runtime test ??

-------------

Marked as reviewed by dholmes (Reviewer).

PR: https://git.openjdk.org/jdk/pull/9745


More information about the hotspot-dev mailing list