RFR: 8321308: AArch64: Fix matching predication for cbz/cbnz [v2]
Fei Gao
fgao at openjdk.org
Thu Jun 6 14:39:51 UTC 2024
On Thu, 6 Jun 2024 14:35:29 GMT, Fei Gao <fgao at openjdk.org> wrote:
>> For array length check like:
>>
>> if (a.length > 0) {
>> [Block 1]
>> } else {
>> [Block 2]
>> }
>>
>>
>> Since `a.length` is unsigned, it's semantically equivalent to:
>>
>> if (a.length != 0) {
>> [Block 1]
>> } else {
>> [Block 2]
>> }
>>
>>
>> On aarch64 port, we can do the conversion like above, during c2 compiler instruction matching, for certain unsigned integral comparisons.
>>
>> For example,
>>
>> cmpw w11, #0 # unsigned
>> bls label # unsigned
>> [Block 1]
>>
>> label:
>> [Block 2]
>>
>>
>> can be converted to:
>>
>> cbz w11, label
>> [Block 1]
>>
>> label:
>> [Block 2]
>>
>>
>> Currently, we have some matching rules to do the conversion [[1]](https://github.com/openjdk/jdk/blob/master/src/hotspot/cpu/aarch64/aarch64.ad#L16179). But the predicate here [[2]](https://github.com/openjdk/jdk/blob/master/src/hotspot/cpu/aarch64/aarch64.ad#L6140) matches wrong `BoolTest` masks, so these rules fail to convert. I guess it's a typo introduced in [JDK-8160006](https://bugs.openjdk.org/browse/JDK-8160006). The patch fixes it.
>
> Fei Gao has updated the pull request with a new target base due to a merge or a rebase. The incremental webrev excludes the unrelated changes brought in by the merge/rebase. The pull request contains three additional commits since the last revision:
>
> - Redefine the interface for cmpOpUEqNeLeGt
> - Merge branch 'master' into fg8321308
> - 8321308: AArch64: Fix matching predication for cbz/cbnz
>
> For array length check like:
> ```
> if (a.length > 0) {
> [Block 1]
> } else {
> [Block 2]
> }
> ```
>
> Since `a.length` is unsigned, it's semantically equivalent to:
> ```
> if (a.length != 0) {
> [Block 1]
> } else {
> [Block 2]
> }
> ```
>
> On aarch64 port, we can do the conversion like above, during c2
> compiler instruction matching, for certain unsigned integral
> comparisons.
>
> For example,
> ```
> cmpw w11, #0 # unsigned
> bls label # unsigned
> [Block 1]
>
> label:
> [Block 2]
> ```
>
> can be converted to:
> ```
> cbz w11, label
> [Block 1]
>
> label:
> [Block 2]
> ```
>
> Currently, we have some matching rules to do the conversion[1].
> But the predicate here[2] matches wrong `BoolTest` masks,
> so these rules fail to convert. I guess it's a typo introduced
> in JDK-8160006. The patch fixes it.
>
> [1] https://github.com/openjdk/jdk/blob/master/src/hotspot/cpu/aarch64/aarch64.ad#L16179
> [2] https://github.com/openjdk/jdk/blob/master/src/hotspot/cpu/aarch64/aarch64.ad#L6140
Thanks for all your comments.
> @fg1417 Regarding the rework, see my response to @dean-long which explains how the interface for `cmpOpUEqNeLeGt` should be redefined (also how the rules can be retained as currently defined).
In the new commit, I redefined the interface for `cmpOpUEqNeLeGt` and also kept the rules besides adding assertion lines. Thanks @adinn .
-------------
PR Comment: https://git.openjdk.org/jdk/pull/16989#issuecomment-2152703543
More information about the hotspot-compiler-dev
mailing list