RFR: 8273317: crash in cmovP_cmpP_zero_zeroNode::bottom_type()
Vladimir Kozlov
kvn at openjdk.java.net
Mon Oct 18 15:27:50 UTC 2021
On Sat, 4 Sep 2021 02:58:56 GMT, SUN Guoyun <duke at openjdk.java.net> wrote:
> Hi all,
>
> When I implement a new instruct in adfile for match CMoveP with Cmp node,like this:
>
> match(Set dst (CMoveP (Binary cop (CmpP op1 zero)) (Binary dst zero)));
>
> this means right child of CmpP is immediate zero and right child of CmovP also is immediate zero, then an exception will occur:
>
> <pre><code class="shell">
> #
> # A fatal error has been detected by the Java Runtime Environment:
> #
> # SIGSEGV (0xb) at pc=0x000000fff410fcc4, pid=11130, tid=11146
> #
> # JRE version: OpenJDK Runtime Environment (17.0) (build 17-internal+0-jenkins-slave-20210821140615-jdk-ls-a526852e137)
> # Java VM: OpenJDK 64-Bit Server VM (17-internal+0-jenkins-slave-20210821140615-jdk-ls-a526852e137, compiled mode, compressed oops, compressed class ptrs, g1 gc, linux-loongarch64)
> # Problematic frame:
> # V [libjvm.so+0x21fcc4] cmovP_cmpP_zero_zeroNode::bottom_type() const+0x44
> #
> # No core dump will be written. Core dumps have been disabled. To enable core dumping, try "ulimit -c unlimited" before starting Java again
> #
> # If you would like to submit a bug report, please visit:
> # https://bugreport.java.com/bugreport/crash.jsp
> #
> </code></pre>
>
> In this case, cmovP_ cmpP_ zero_ zeroNode only has three input nodes, so an exception is triggered. This is a patch to fix this problem. Please help review it
>
> Thanks,
> Sun Guoyun
Thank you for running testing, Tobias.
I have few cosmetic comments.
src/hotspot/share/adlc/output_h.cpp line 1947:
> 1945: // Special special hack to see if the Cmp? has been incorporated in the conditional move
> 1946: MatchNode *rl = instr->_matrule->_rChild->_lChild;
> 1947: if( rl && !strcmp(rl->_opType, "Binary") && rl->_rChild && strncmp(rl->_rChild->_opType, "Cmp", 3) == 0) {
Code style. Use `if (rl &&`.
src/hotspot/share/adlc/output_h.cpp line 1958:
> 1956: }
> 1957: else if( instr->_matrule && instr->_matrule->_rChild && !strcmp(instr->_matrule->_rChild->_opType,"CMoveN") ) {
> 1958: int offset = 1;
The following code, AFAIS, matches `CMoveP` code. The only difference is comment: `// CMoveN` vs `// CMoveP` unless I am missing something.
Consider factoring code into separate function and path node's name as string.
-------------
PR: https://git.openjdk.java.net/jdk/pull/5369
More information about the hotspot-compiler-dev
mailing list