[aarch64-port-dev ] [10] RFR: 8187472 - AARCH64: array_equals intrinsic doesn't use prefetch for large arrays

Andrew Haley aph at redhat.com
Wed Nov 15 10:34:21 UTC 2017


On 15/11/17 08:34, Ningsheng Jian wrote:
> Hi Dmitrij,
> 
> I can see regressions on some hardware with your patch.
> 
> Could you please try the micro-benchmark below on your systems?
> 
> http://people.linaro.org/~ningsheng.jian/test/StringOps.java
> 
> $ java -jar ./target/benchmarks.jar "StringEqualsLarge" -wi 10 -f 3 -i 10
> 
> Seems that your patch affects the inlining.

Before the patch:

StringOps.jmhTimeStringEqualsIgnoreCaseLarge         avgt   10  2984.638 ? 12.899  ns/op
StringOps.jmhTimeStringEqualsIgnoreCaseSmall         avgt   10   319.434 ?  0.434  ns/op
StringOps.jmhTimeStringEqualsLarge                   avgt   10   146.122 ?  0.638  ns/op
StringOps.jmhTimeStringEqualsSmall                   avgt   10    45.998 ?  0.444  ns/op

After:
                                     Mode  Cnt     Score   Error  Units
StringOps.jmhTimeStringEqualsIgnoreCaseLarge  avgt   10  2982.222 ? 3.683  ns/op
StringOps.jmhTimeStringEqualsIgnoreCaseSmall  avgt   10   319.671 ? 0.902  ns/op
StringOps.jmhTimeStringEqualsLarge            avgt   10  1137.348 ? 1.088  ns/op
StringOps.jmhTimeStringEqualsSmall            avgt   10   194.698 ? 0.857  ns/op

Gosh.  I think that's a very bad patch.

-- 
Andrew Haley
Java Platform Lead Engineer
Red Hat UK Ltd. <https://www.redhat.com>
EAC8 43EB D3EF DB98 CC77 2FAD A5CD 6035 332F A671


More information about the hotspot-compiler-dev mailing list