diff options
author | Stefan Liebler <stli@linux.ibm.com> | 2018-12-18 13:57:16 +0100 |
---|---|---|
committer | Stefan Liebler <stli@linux.ibm.com> | 2018-12-18 13:57:16 +0100 |
commit | 4c7b3cec113d9bb7dfc004e22c7a98e310ab9bcc (patch) | |
tree | 7d005e54610905bec43065c70af261177ae5dc2f /sysdeps/s390/multiarch/ifunc-impl-list.c | |
parent | 581a051c2e09a847332d4750f6132de0f0ad15b6 (diff) | |
download | glibc-4c7b3cec113d9bb7dfc004e22c7a98e310ab9bcc.tar.gz glibc-4c7b3cec113d9bb7dfc004e22c7a98e310ab9bcc.tar.xz glibc-4c7b3cec113d9bb7dfc004e22c7a98e310ab9bcc.zip |
S390: Refactor rawmemchr ifunc handling.
The ifunc handling for rawmemchr is adjusted in order to omit ifunc variants if those will never be used as the minimum architecture level already supports newer CPUs by default. Glibc internal calls will then also use the "newer" ifunc variant. ChangeLog: * sysdeps/s390/multiarch/Makefile (sysdep_routines): Remove rawmemchr variants. * sysdeps/s390/Makefile (sysdep_routines): Add rawmemchr variants. * sysdeps/s390/multiarch/ifunc-impl-list.c (__libc_ifunc_impl_list): Refactor ifunc handling for rawmemchr. * sysdeps/s390/multiarch/rawmemchr-c.c: Move to ... * sysdeps/s390/rawmemchr-c.c: ... here and adjust ifunc handling. * sysdeps/s390/multiarch/rawmemchr-vx.S: Move to ... * sysdeps/s390/rawmemchr-vx.S: ... here and adjust ifunc handling. * sysdeps/s390/multiarch/rawmemchr.c: Move to ... * sysdeps/s390/rawmemchr.c: ... here and adjust ifunc handling. * sysdeps/s390/ifunc-rawmemchr.h: New file.
Diffstat (limited to 'sysdeps/s390/multiarch/ifunc-impl-list.c')
-rw-r--r-- | sysdeps/s390/multiarch/ifunc-impl-list.c | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/sysdeps/s390/multiarch/ifunc-impl-list.c b/sysdeps/s390/multiarch/ifunc-impl-list.c index b4be014042..bf3b40e111 100644 --- a/sysdeps/s390/multiarch/ifunc-impl-list.c +++ b/sysdeps/s390/multiarch/ifunc-impl-list.c @@ -43,6 +43,7 @@ #include <ifunc-strpbrk.h> #include <ifunc-strcspn.h> #include <ifunc-memchr.h> +#include <ifunc-rawmemchr.h> /* Maximum number of IFUNC implementations. */ #define MAX_IFUNC 3 @@ -385,6 +386,18 @@ __libc_ifunc_impl_list (const char *name, struct libc_ifunc_impl *array, ) #endif /* HAVE_MEMCHR_IFUNC */ +#if HAVE_RAWMEMCHR_IFUNC + IFUNC_IMPL (i, name, rawmemchr, +# if HAVE_RAWMEMCHR_Z13 + IFUNC_IMPL_ADD (array, i, rawmemchr, + dl_hwcap & HWCAP_S390_VX, RAWMEMCHR_Z13) +# endif +# if HAVE_RAWMEMCHR_C + IFUNC_IMPL_ADD (array, i, rawmemchr, 1, RAWMEMCHR_C) +# endif + ) +#endif /* HAVE_RAWMEMCHR_IFUNC */ + #ifdef HAVE_S390_VX_ASM_SUPPORT # define IFUNC_VX_IMPL(FUNC) \ @@ -426,7 +439,6 @@ __libc_ifunc_impl_list (const char *name, struct libc_ifunc_impl *array, IFUNC_VX_IMPL (wcscspn); IFUNC_VX_IMPL (wmemchr); - IFUNC_VX_IMPL (rawmemchr); IFUNC_VX_IMPL (memccpy); |