RFR: 8283726: x86_64 intrinsics for compareUnsigned method in Integer and Long
Sandhya Viswanathan
sviswanathan at openjdk.java.net
Fri Jun 10 00:09:00 UTC 2022
On Wed, 8 Jun 2022 09:39:04 GMT, Quan Anh Mai <duke at openjdk.java.net> wrote:
>> Hi,
>>
>> This patch implements intrinsics for `Integer/Long::compareUnsigned` using the same approach as the JVM does for long and floating-point comparisons. This allows efficient and reliable usage of unsigned comparison in Java, which is a basic operation and is important for range checks such as discussed in #8620 .
>>
>> Thank you very much.
>
> I have added a benchmark for the intrinsic. The result is as follows, thanks a lot:
>
> Before After
> Benchmark (size) Mode Cnt Score Error Score Error Units
> Integers.compareUnsigned 500 avgt 15 0.527 ± 0.002 0.498 ± 0.011 us/op
> Longs.compareUnsigned 500 avgt 15 0.677 ± 0.014 0.561 ± 0.006 us/op
@merykitty Could you please also add the micro benchmark where compareUnsigned result is stored directly in an integer and show the performance of that?
-------------
PR: https://git.openjdk.org/jdk/pull/9068
More information about the hotspot-dev
mailing list