RFR: 8256318: AArch64: Add support for floating-point absolute difference [v3]

Dong Bo dongbo at openjdk.java.net
Mon Nov 16 03:15:23 UTC 2020


> This supports for floating-point absolute difference instructions, i.e. FABD scalar/vector.
> 
> Verified with linux-aarch64-server-release, tier1-3.
> 
> Added a JMH micro `test/micro/org/openjdk/bench/vm/compiler/FloatingScalarVectorAbsDiff.java` for performance test.
> 
> The FABD (scalar), the performance tests handle registers directly, the average latency reduces to almost half  (~57%) of the original.
> For FABD (vector), we restrict the data size (~24KB) to be less than L1 data cache size (32KB),
> so that the memory access can hit in L1, and witness 14.2% (float) and 21.2% (double) improvements.
> 
> The JMH results on Kunpeng916:
> 
> Benchmark                                            (count)  (seed)  Mode  Cnt     Score    Error  Units
> 
> # before, fsub+fabs
> FloatingScalarVectorAbsDiff.testScalarAbsDiffDouble     1024  316731  avgt   10  6038.333 ± 3.889  ns/op
> FloatingScalarVectorAbsDiff.testScalarAbsDiffFloat      1024  316731  avgt   10  6005.125 ± 3.025  ns/op
> FloatingScalarVectorAbsDiff.testVectorAbsDiffDouble     1024  316731  avgt   10   950.340 ± 9.398  ns/op
> FloatingScalarVectorAbsDiff.testVectorAbsDiffFloat      1024  316731  avgt   10   454.350 ± 1.798  ns/op
> 
> # after, fabd
> FloatingScalarVectorAbsDiff.testScalarAbsDiffDouble     1024  316731  avgt   10  3483.801 ± 1.763  ns/op
> FloatingScalarVectorAbsDiff.testScalarAbsDiffFloat      1024  316731  avgt   10  3442.412 ± 1.866  ns/op
> FloatingScalarVectorAbsDiff.testVectorAbsDiffDouble     1024  316731  avgt   10   816.301 ± 4.454  ns/op
> FloatingScalarVectorAbsDiff.testVectorAbsDiffFloat      1024  316731  avgt   10   354.710 ± 1.001  ns/op

Dong Bo has updated the pull request incrementally with one additional commit since the last revision:

  fix trailing whitespace error

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

Changes:
  - all: https://git.openjdk.java.net/jdk/pull/1215/files
  - new: https://git.openjdk.java.net/jdk/pull/1215/files/b2543841..e80d3802

Webrevs:
 - full: https://webrevs.openjdk.java.net/?repo=jdk&pr=1215&range=02
 - incr: https://webrevs.openjdk.java.net/?repo=jdk&pr=1215&range=01-02

  Stats: 1 line in 1 file changed: 0 ins; 0 del; 1 mod
  Patch: https://git.openjdk.java.net/jdk/pull/1215.diff
  Fetch: git fetch https://git.openjdk.java.net/jdk pull/1215/head:pull/1215

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


More information about the hotspot-dev mailing list