mirror of
git://sourceware.org/git/glibc.git
synced 2024-12-15 04:20:28 +08: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 MEMCHR
|
|
# define MEMCHR __memchr_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 "memchr-avx2.S"
|