x86: Only align destination to 1x VEC_SIZE in memset 4x loop

Current code aligns to 2x VEC_SIZE. Aligning to 2x has no affect on
performance other than potentially resulting in an additional
iteration of the loop.
1x maintains aligned stores (the only reason to align in this case)
and doesn't incur any unnecessary loop iterations.
Reviewed-by: Sunil K Pandey <skpgkp2@gmail.com>
This commit is contained in:
Noah Goldstein 2023-11-01 15:30:26 -05:00
parent 3921c5b40f
commit 9469261cf1

View File

@ -293,7 +293,7 @@ L(more_2x_vec):
leaq (VEC_SIZE * 4)(%rax), %LOOP_REG leaq (VEC_SIZE * 4)(%rax), %LOOP_REG
#endif #endif
/* Align dst for loop. */ /* Align dst for loop. */
andq $(VEC_SIZE * -2), %LOOP_REG andq $(VEC_SIZE * -1), %LOOP_REG
.p2align 4 .p2align 4
L(loop): L(loop):
VMOVA %VMM(0), LOOP_4X_OFFSET(%LOOP_REG) VMOVA %VMM(0), LOOP_4X_OFFSET(%LOOP_REG)