mirror of
https://sourceware.org/git/glibc.git
synced 2024-11-23 05:20:06 +00:00
7ebba91361
Since VZEROUPPER triggers RTM abort while VZEROALL won't, select AVX optimized string/memory functions with xtest jz 1f vzeroall ret 1: vzeroupper ret at function exit on processors with usable RTM, but without 256-bit EVEX instructions to avoid VZEROUPPER inside a transactionally executing RTM region.
13 lines
250 B
ArmAsm
13 lines
250 B
ArmAsm
#ifndef STRLEN
|
|
# define STRLEN __strlen_avx2_rtm
|
|
#endif
|
|
|
|
#define ZERO_UPPER_VEC_REGISTERS_RETURN \
|
|
ZERO_UPPER_VEC_REGISTERS_RETURN_XTEST
|
|
|
|
#define VZEROUPPER_RETURN jmp L(return_vzeroupper)
|
|
|
|
#define SECTION(p) p##.avx.rtm
|
|
|
|
#include "strlen-avx2.S"
|