[13] RFR(S): 8224658: Unsafe access C2 compile fails with assert(flat != TypePtr::BOTTOM) failed: cannot alias-analyze an untyped ptr: adr_type = NULL

Vladimir Ivanov vladimir.x.ivanov at oracle.com
Wed Jun 12 11:46:56 UTC 2019


> http://cr.openjdk.java.net/~thartmann/8224658/webrev.02/

Looks good.

Best regards,
Vladimir Ivanov

> I've also reverted this old fix which is no longer needed because of the _bb_start < _bb_end check:
> http://hg.openjdk.java.net/jdk/jdk/rev/c974c3e10bf7
> 
> On 07.06.19 16:27, Vladimir Ivanov wrote:
>> There are existing usages of Halt for optimizing unsafe accesses (e.g., GraphKit::must_be_not_null),
>> but, as a future enhancement, it would be nice to provide more information about the root cause of
>> the crash. As an example, JDK-8219902 [1] which involved Halt execution manifested as:
>>
>>    # SIGILL (0x4) at pc=0x00007f55b4df37d6, pid=15865, tid=15869
>>    #
>>    # JRE version: OpenJDK Runtime Environment (13.0+9) (build 13-ea+9)
>>    # Java VM: OpenJDK 64-Bit Server VM (13-ea+9, mixed mode, sharing, tiered, compressed oops, g1 gc,
>> linux-amd64)
>>    # Problematic frame:
>>    # J 10152 c2
>> com.sun.tools.javac.tree.Pretty.visitLiteral(Lcom/sun/tools/javac/tree/JCTree$JCLiteral;)V
>> jdk.compiler at 13-ea (282 bytes) @ 0x00007f55b4df37d6 [0x00007f55b4df07a0+0x0000000000003036]
>>
>> Without laborous analysis of generated code, it's impossible to say whether it's a JVM bug or a
>> problem in user code. I believe JVM can do better in such situations and print meaningful error
>> message instead when crashing.
> 
> Yes, I agree that additional output would be very valuable. I'll file a RFE once this is in.
> 
> Thanks,
> Tobias
> 
> [1]
> #  Schedule BB#003 (initial)
>   25	Region	===  25  19  [[ 25  18 ]]  !jvms: Unsafe::putInt @ bci:-1 UnsafeZero::test @ bci:14
>   18	MemBarCPUOrder	===  25  0  10  0  0  [[ 17 ]]  !jvms: Unsafe::putInt @ bci:4 Unsafe::putInt @
> bci:5 UnsafeZero::test @ bci:14
>   17	MachProj	===  18  [[ 16 ]] #0/unmatched !jvms: Unsafe::putInt @ bci:4 Unsafe::putInt @ bci:5
> UnsafeZero::test @ bci:14
>   16	ShouldNotReachHere	===  17  0  0  12  0  [[ 1 ]]  !jvms: Unsafe::putInt @ bci:-1
> UnsafeZero::test @ bci:14
> 


More information about the hotspot-compiler-dev mailing list