summaryrefslogtreecommitdiff
path: root/sysdeps/x86_64/multiarch/stpncpy-avx2.S
diff options
context:
space:
mode:
authorNoah Goldstein <goldstein.w.n@gmail.com>2022-07-13 16:33:01 -0700
committerNoah Goldstein <goldstein.w.n@gmail.com>2022-07-16 03:07:59 -0700
commit49889fb256a7f9b894b2d16fea23de1ac25b65e2 (patch)
tree923f7a6a2eb94e4baf9141783b19df06ed9ee747 /sysdeps/x86_64/multiarch/stpncpy-avx2.S
parent192979ee351315b84ff4277d0985f26243717cd7 (diff)
downloadglibc-49889fb256a7f9b894b2d16fea23de1ac25b65e2.tar
glibc-49889fb256a7f9b894b2d16fea23de1ac25b65e2.tar.gz
glibc-49889fb256a7f9b894b2d16fea23de1ac25b65e2.tar.bz2
glibc-49889fb256a7f9b894b2d16fea23de1ac25b65e2.zip
x86: Add support to build st{p|r}{n}{cpy|cat} with explicit ISA level
1. Add default ISA level selection in non-multiarch/rtld implementations. 2. Add ISA level build guards to different implementations. - I.e strcpy-avx2.S which is ISA level 3 will only build if compiled ISA level <= 3. Otherwise there is no reason to include it as we will always use one of the ISA level 4 implementations (strcpy-evex.S). 3. Refactor the ifunc selector and ifunc implementation list to use the ISA level aware wrapper macros that allow functions below the compiled ISA level (with a guranteed replacement) to be skipped. Tested with and without multiarch on x86_64 for ISA levels: {generic, x86-64-v2, x86-64-v3, x86-64-v4} And m32 with and without multiarch.
Diffstat (limited to 'sysdeps/x86_64/multiarch/stpncpy-avx2.S')
-rw-r--r--sysdeps/x86_64/multiarch/stpncpy-avx2.S6
1 files changed, 5 insertions, 1 deletions
diff --git a/sysdeps/x86_64/multiarch/stpncpy-avx2.S b/sysdeps/x86_64/multiarch/stpncpy-avx2.S
index 032b0407d0..b2f8c19143 100644
--- a/sysdeps/x86_64/multiarch/stpncpy-avx2.S
+++ b/sysdeps/x86_64/multiarch/stpncpy-avx2.S
@@ -1,4 +1,8 @@
+#ifndef STPNCPY
+# define STPNCPY __stpncpy_avx2
+#endif
+
#define USE_AS_STPCPY
#define USE_AS_STRNCPY
-#define STRCPY __stpncpy_avx2
+#define STRCPY STPNCPY
#include "strcpy-avx2.S"