RFR: 8252848: Optimize small primitive arrayCopy operations through partial inlining using AVX-512 masked instructions [v14]

Jatin Bhateja jbhateja at openjdk.java.net
Tue Nov 24 02:30:58 UTC 2020


On Sun, 22 Nov 2020 02:19:53 GMT, Vladimir Kozlov <kvn at openjdk.org> wrote:

>>> Forgot to say that failure was on Windows with only avx512f, avx512cd
>> 
>> Thanks Vladimir, I have resolved your review comments.
>
> Version 15 failed next tests on linux-x64 with  -XX:+UseParallelGC -XX:+UseNUMA flags:
> vmTestbase/metaspace/stressHierarchy/stressHierarchy015/TestDescription.java
> vmTestbase/metaspace/stressHierarchy/stressHierarchy006/TestDescription.java
> vmTestbase/metaspace/stressHierarchy/stressHierarchy005/TestDescription.java
> 
> # A fatal error has been detected by the Java Runtime Environment:
> #
> #  Internal Error (/workspace/open/src/hotspot/share/opto/macroArrayCopy.cpp:861), pid=8205, tid=8216
> #  assert(ArrayCopyNode::may_modify(dest_t, (*ctrl)->in(0)->as_MemBar(), &_igvn, ac)) failed: dependency on arraycopy lost
> #
> # Problematic frame:
> # V  [libjvm.so+0x134fbfc]  PhaseMacroExpand::generate_arraycopy(ArrayCopyNode*, AllocateArrayNode*, Node**, MergeMemNode*, Node**, TypePtr const*, BasicType, Node*, Node*, Node*, Node*, Node*, bool, bool, RegionNode*)+0x30bc
> #
> Host:  Intel(R) Xeon(R) Platinum 8167M CPU @ 2.00GHz, 8 cores, 58G, Oracle Linux Server release 7.9
> 
> Current CompileTask:
> C2:  27392 5458       4       package_level34_num50.Dummy::composeString (10 bytes)
> 
> Stack: [0x00007f4c5a024000,0x00007f4c5a125000],  sp=0x00007f4c5a120420,  free space=1009k
> Native frames: (J=compiled Java code, A=aot compiled Java code, j=interpreted, Vv=VM code, C=native code)
> V  [libjvm.so+0x134fbfc]  PhaseMacroExpand::generate_arraycopy(ArrayCopyNode*, AllocateArrayNode*, Node**, MergeMemNode*, Node**, TypePtr const*, BasicType, Node*, Node*, Node*, Node*, Node*, bool, bool, RegionNode*)+0x30bc
> V  [libjvm.so+0x1350741]  PhaseMacroExpand::expand_arraycopy_node(ArrayCopyNode*)+0x641
> V  [libjvm.so+0x1340d7b]  PhaseMacroExpand::expand_macro_nodes()+0xfdb
> V  [libjvm.so+0x9fe79b]  Compile::Optimize()+0x177b
> V  [libjvm.so+0xa00268]  Compile::Compile(ciEnv*, ciMethod*, int, bool, bool, bool, bool, DirectiveSet*)+0x17e8
> V  [libjvm.so+0x8322ae]  C2Compiler::compile_method(ciEnv*, ciMethod*, int, bool, DirectiveSet*)+0x1ce
> V  [libjvm.so+0xa103f8]  CompileBroker::invoke_compiler_on_method(CompileTask*)+0xe08
> V  [libjvm.so+0xa10f48]  CompileBroker::compiler_thread_loop()+0x5a8

Hi @vnkozlov , Kindly let me know if there are any other comments.

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

PR: https://git.openjdk.java.net/jdk/pull/302


More information about the hotspot-dev mailing list