RFR: 8143219: AArch64 broken by 8141132: JEP 254: Compact Strings
Andrew Haley
aph at redhat.com
Thu Nov 19 15:13:38 UTC 2015
Hi,
On 11/19/2015 03:08 PM, Tobias Hartmann wrote:
> On 19.11.2015 12:56, Andrew Haley wrote:
>> http://cr.openjdk.java.net/~aph/8143219/
>>
>> Two things happened, one simple and one not-so-simple.
>>
>> Firstly, the string comparators now take a byte count (because it's a
>> byte array now) rather than a char count.
>
> Looks good.
>
>> Secondly, string_indexOf needs to have a guard to make sure that
>> substr.count <= string.count. This is guaranteed by
>> LibraryCallKit::inline_string_indexOf but not by
>> LibraryCallKit::inline_string_indexOfI. This is a subtle change, and
>> was quite tricky to figure out. I have fixed it here in the AArch64
>> back end.
>
> I think this check should be done in inline_string_indexOfI()
> because other intrinsics may also depend on it (see
> macroAssembler_x86.cpp). Same applies to the "substr count == 0"
> check. One could probably factor out the checks and use them for
> both inline_string_indexOf* methods.
>
> I'm moving some more runtime checks from the Java code into the
> intrinsics (see JDK-8142303 which is currently out for review on
> hotspot-compiler-dev).
>
> If you want, I can take care of these checks as well.
OK, that would be cool. In the meantime it's a bit difficult for
AArch64 because nothing works without these fixes. I wonder if I
should push this workaround and back it out later.
Andrew.
More information about the hotspot-dev
mailing list