8234228: AArch64: Some temp vars in string_compare intrinsics for processing the last 4 chars (LU/UL) are no use

Clean up redundant temp vars in generate_compare_long_string_different_encoding

Reviewed-by: adinn
This commit is contained in:
Patrick Zhang 2019-11-15 17:02:17 +08:00
parent 8c1efbe38b
commit 3ad9078968

View File

@ -4010,7 +4010,7 @@ class StubGenerator: public StubCodeGenerator {
// code for comparing 16 characters of strings with Latin1 and Utf16 encoding // code for comparing 16 characters of strings with Latin1 and Utf16 encoding
void compare_string_16_x_LU(Register tmpL, Register tmpU, Label &DIFF1, void compare_string_16_x_LU(Register tmpL, Register tmpU, Label &DIFF1,
Label &DIFF2) { Label &DIFF2) {
Register cnt1 = r2, tmp1 = r10, tmp2 = r11, tmp3 = r12; Register cnt1 = r2, tmp2 = r11, tmp3 = r12;
FloatRegister vtmp = v1, vtmpZ = v0, vtmp3 = v2; FloatRegister vtmp = v1, vtmpZ = v0, vtmp3 = v2;
__ ldrq(vtmp, Address(__ post(tmp2, 16))); __ ldrq(vtmp, Address(__ post(tmp2, 16)));
@ -4070,18 +4070,14 @@ class StubGenerator: public StubCodeGenerator {
__ add(str2, str2, isLU ? wordSize : wordSize/2); __ add(str2, str2, isLU ? wordSize : wordSize/2);
__ fmovd(isLU ? tmp1 : tmp2, vtmp); __ fmovd(isLU ? tmp1 : tmp2, vtmp);
__ subw(cnt2, cnt2, 8); // Already loaded 4 symbols. Last 4 is special case. __ subw(cnt2, cnt2, 8); // Already loaded 4 symbols. Last 4 is special case.
__ add(str1, str1, cnt2, __ LSL, isLU ? 0 : 1);
__ eor(rscratch2, tmp1, tmp2); __ eor(rscratch2, tmp1, tmp2);
__ add(str2, str2, cnt2, __ LSL, isLU ? 1 : 0);
__ mov(rscratch1, tmp2); __ mov(rscratch1, tmp2);
__ cbnz(rscratch2, CALCULATE_DIFFERENCE); __ cbnz(rscratch2, CALCULATE_DIFFERENCE);
Register strU = isLU ? str2 : str1, Register tmpU = isLU ? rscratch1 : tmp1, // where to keep U for comparison
strL = isLU ? str1 : str2,
tmpU = isLU ? rscratch1 : tmp1, // where to keep U for comparison
tmpL = isLU ? tmp1 : rscratch1; // where to keep L for comparison tmpL = isLU ? tmp1 : rscratch1; // where to keep L for comparison
__ push(spilled_regs, sp); __ push(spilled_regs, sp);
__ sub(tmp2, strL, cnt2); // strL pointer to load from __ mov(tmp2, isLU ? str1 : str2); // init the pointer to L next load
__ sub(cnt1, strU, cnt2, __ LSL, 1); // strU pointer to load from __ mov(cnt1, isLU ? str2 : str1); // init the pointer to U next load
__ ldr(tmp3, Address(__ post(cnt1, 8))); __ ldr(tmp3, Address(__ post(cnt1, 8)));
@ -4118,7 +4114,7 @@ class StubGenerator: public StubCodeGenerator {
__ cmn(cnt2, (u1)16); __ cmn(cnt2, (u1)16);
__ br(__ EQ, LOAD_LAST); __ br(__ EQ, LOAD_LAST);
__ bind(TAIL); // 1..15 characters left until last load (last 4 characters) __ bind(TAIL); // 1..15 characters left until last load (last 4 characters)
__ add(cnt1, cnt1, cnt2, __ LSL, 1); // Address of 8 bytes before last 4 characters in UTF-16 string __ add(cnt1, cnt1, cnt2, __ LSL, 1); // Address of 32 bytes before last 4 characters in UTF-16 string
__ add(tmp2, tmp2, cnt2); // Address of 16 bytes before last 4 characters in Latin1 string __ add(tmp2, tmp2, cnt2); // Address of 16 bytes before last 4 characters in Latin1 string
__ ldr(tmp3, Address(cnt1, -8)); __ ldr(tmp3, Address(cnt1, -8));
compare_string_16_x_LU(tmpL, tmpU, DIFF1, DIFF2); // last 16 characters before last load compare_string_16_x_LU(tmpL, tmpU, DIFF1, DIFF2); // last 16 characters before last load
@ -4134,7 +4130,8 @@ class StubGenerator: public StubCodeGenerator {
__ mov(tmpU, tmp3); __ mov(tmpU, tmp3);
__ pop(spilled_regs, sp); __ pop(spilled_regs, sp);
__ ldrs(vtmp, Address(strL)); // tmp2 points to the address of the last 4 Latin1 characters right now
__ ldrs(vtmp, Address(tmp2));
__ zip1(vtmp, __ T8B, vtmp, vtmpZ); __ zip1(vtmp, __ T8B, vtmp, vtmpZ);
__ fmovd(tmpL, vtmp); __ fmovd(tmpL, vtmp);