mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-06 01:21:08 +00:00
c69f960b01
The changes for these functions are different than the others because the best implementation (sse4_2) requires the generic implementation as a fallback to be built as well. Changes are: 1. Add non-multiarch functions for str{c|p}{brk|spn}.c to statically select the best implementation based on the configured ISA build level. 2. Add stubs for str{c|p}{brk|spn}-generic and varshift.c to in the sysdeps/x86_64 directory so that the the sse4 implementation will have all of its dependencies for the non-multiarch / rtld build when ISA level >= 2. 3. Add new multiarch/rtld-strcspn.c that just include the non-multiarch strcspn.c which will in turn select the best implementation based on the compiled ISA level. 4. 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.
41 lines
1.6 KiB
C
41 lines
1.6 KiB
C
/* Common definition for ifunc selections optimized with SSE2 and SSE4.2.
|
|
All versions must be listed in ifunc-impl-list.c.
|
|
Copyright (C) 2017-2022 Free Software Foundation, Inc.
|
|
This file is part of the GNU C Library.
|
|
|
|
The GNU C Library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public
|
|
License as published by the Free Software Foundation; either
|
|
version 2.1 of the License, or (at your option) any later version.
|
|
|
|
The GNU C Library is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Lesser General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
License along with the GNU C Library; if not, see
|
|
<https://www.gnu.org/licenses/>. */
|
|
|
|
#include <init-arch.h>
|
|
|
|
extern __typeof (REDIRECT_NAME) OPTIMIZE (generic) attribute_hidden;
|
|
extern __typeof (REDIRECT_NAME) OPTIMIZE (sse42) attribute_hidden;
|
|
|
|
static inline void *
|
|
IFUNC_SELECTOR (void)
|
|
{
|
|
const struct cpu_features* cpu_features = __get_cpu_features ();
|
|
|
|
/* This function uses the `pcmpstri` sse4.2 instruction which can be
|
|
slow on some CPUs. This normally would be guarded by a
|
|
Slow_SSE4_2 check, but since there is no other optimized
|
|
implementation its best to keep it regardless. If an optimized
|
|
fallback is added add a X86_ISA_CPU_FEATURE_ARCH_P (cpu_features,
|
|
Slow_SSE4_2) check. */
|
|
if (X86_ISA_CPU_FEATURE_USABLE_P (cpu_features, SSE4_2))
|
|
return OPTIMIZE (sse42);
|
|
|
|
return OPTIMIZE (generic);
|
|
}
|