mirror of
https://sourceware.org/git/glibc.git
synced 2024-12-25 20:21:07 +00:00
6aa3e97e25
index_* and bit_* macros are used to access cpuid and feature arrays o struct cpu_features. It is very easy to use bits and indices of cpuid array on feature array, especially in assembly codes. For example, sysdeps/i386/i686/multiarch/bcopy.S has HAS_CPU_FEATURE (Fast_Rep_String) which should be HAS_ARCH_FEATURE (Fast_Rep_String) We change index_* and bit_* to index_cpu_*/index_arch_* and bit_cpu_*/bit_arch_* so that we can catch such error at build time. [BZ #19762] * sysdeps/unix/sysv/linux/x86_64/64/dl-librecon.h (EXTRA_LD_ENVVARS): Add _arch_ to index_*/bit_*. * sysdeps/x86/cpu-features.c (init_cpu_features): Likewise. * sysdeps/x86/cpu-features.h (bit_*): Renamed to ... (bit_arch_*): This for feature array. (bit_*): Renamed to ... (bit_cpu_*): This for cpu array. (index_*): Renamed to ... (index_arch_*): This for feature array. (index_*): Renamed to ... (index_cpu_*): This for cpu array. [__ASSEMBLER__] (HAS_FEATURE): Add and use field. [__ASSEMBLER__] (HAS_CPU_FEATURE)): Pass cpu to HAS_FEATURE. [__ASSEMBLER__] (HAS_ARCH_FEATURE)): Pass arch to HAS_FEATURE. [!__ASSEMBLER__] (HAS_CPU_FEATURE): Replace index_##name and bit_##name with index_cpu_##name and bit_cpu_##name. [!__ASSEMBLER__] (HAS_ARCH_FEATURE): Replace index_##name and bit_##name with index_arch_##name and bit_arch_##name.
45 lines
2.0 KiB
C
45 lines
2.0 KiB
C
/* Optional code to distinguish library flavours. x86-64 version.
|
|
Copyright (C) 2015-2016 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
|
|
<http://www.gnu.org/licenses/>. */
|
|
|
|
#ifndef _DL_LIBRECON_H
|
|
|
|
#include <sysdeps/unix/sysv/linux/dl-librecon.h>
|
|
|
|
/* Recognizing extra environment variables. For 64-bit applications,
|
|
branch prediction performance may be negatively impacted when the
|
|
target of a branch is more than 4GB away from the branch. Add the
|
|
Prefer_MAP_32BIT_EXEC bit so that mmap will try to map executable
|
|
pages with MAP_32BIT first. NB: MAP_32BIT will map to lower 2GB,
|
|
not lower 4GB, address. Prefer_MAP_32BIT_EXEC reduces bits available
|
|
for address space layout randomization (ASLR). Prefer_MAP_32BIT_EXEC
|
|
is always disabled for SUID programs and can be enabled by setting
|
|
environment variable, LD_PREFER_MAP_32BIT_EXEC. */
|
|
#define EXTRA_LD_ENVVARS \
|
|
case 21: \
|
|
if (memcmp (envline, "PREFER_MAP_32BIT_EXEC", 21) == 0) \
|
|
GLRO(dl_x86_cpu_features).feature[index_arch_Prefer_MAP_32BIT_EXEC] \
|
|
|= bit_arch_Prefer_MAP_32BIT_EXEC; \
|
|
break;
|
|
|
|
/* Extra unsecure variables. The names are all stuffed in a single
|
|
string which means they have to be terminated with a '\0' explicitly. */
|
|
#define EXTRA_UNSECURE_ENVVARS \
|
|
"LD_PREFER_MAP_32BIT_EXEC\0"
|
|
|
|
#endif /* dl-librecon.h */
|