mirror of
https://sourceware.org/git/glibc.git
synced 2024-12-28 13:31:13 +00:00
ceabdcd130
1. Add default ISA level selection in non-multiarch/rtld implementations. 2. Add ISA level build guards to different implementations. - I.e strcmp-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 (strcmp-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.
29 lines
1.1 KiB
ArmAsm
29 lines
1.1 KiB
ArmAsm
/* memrchr dispatch for RTLD and non-multiarch build
|
|
|
|
Copyright (C) 2011-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/>. */
|
|
|
|
#define MEMRCHR __memrchr
|
|
|
|
#define DEFAULT_IMPL_V1 "multiarch/memrchr-sse2.S"
|
|
#define DEFAULT_IMPL_V3 "multiarch/memrchr-avx2.S"
|
|
#define DEFAULT_IMPL_V4 "multiarch/memrchr-evex.S"
|
|
|
|
#include "isa-default-impl.h"
|
|
|
|
weak_alias (__memrchr, memrchr)
|