mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-10 03:10:09 +00:00
Update x86-64 cpu multiarch selection header.
This commit is contained in:
parent
3d1020f0cc
commit
bbbdd77809
@ -1,3 +1,8 @@
|
|||||||
|
2010-04-13 Ulrich Drepper <drepper@redhat.com>
|
||||||
|
|
||||||
|
* sysdeps/x86_64/multiarch/init-arch.h: Pretty printing.
|
||||||
|
Add SSE 4.1 macros.
|
||||||
|
|
||||||
2010-04-10 Matt Fleming <matt@console-pimps.org>
|
2010-04-10 Matt Fleming <matt@console-pimps.org>
|
||||||
|
|
||||||
* elf/elf.h: Add SH specific ELF header flags.
|
* elf/elf.h: Add SH specific ELF header flags.
|
||||||
|
@ -20,21 +20,23 @@
|
|||||||
|
|
||||||
#ifdef __ASSEMBLER__
|
#ifdef __ASSEMBLER__
|
||||||
|
|
||||||
#include <ifunc-defines.h>
|
# include <ifunc-defines.h>
|
||||||
|
|
||||||
#define bit_SSE2 (1 << 26)
|
# define bit_SSE2 (1 << 26)
|
||||||
#define bit_SSSE3 (1 << 9)
|
# define bit_SSSE3 (1 << 9)
|
||||||
#define bit_SSE4_2 (1 << 20)
|
# define bit_SSE4_1 (1 << 19)
|
||||||
|
# define bit_SSE4_2 (1 << 20)
|
||||||
|
|
||||||
#define index_SSE2 COMMON_CPUID_INDEX_1*CPUID_SIZE+CPUID_EDX_OFFSET
|
# define index_SSE2 COMMON_CPUID_INDEX_1*CPUID_SIZE+CPUID_EDX_OFFSET
|
||||||
#define index_SSSE3 COMMON_CPUID_INDEX_1*CPUID_SIZE+CPUID_ECX_OFFSET
|
# define index_SSSE3 COMMON_CPUID_INDEX_1*CPUID_SIZE+CPUID_ECX_OFFSET
|
||||||
#define index_SSE4_2 COMMON_CPUID_INDEX_1*CPUID_SIZE+CPUID_ECX_OFFSET
|
# define index_SSE4_1 COMMON_CPUID_INDEX_1*CPUID_SIZE+CPUID_ECX_OFFSET
|
||||||
|
# define index_SSE4_2 COMMON_CPUID_INDEX_1*CPUID_SIZE+CPUID_ECX_OFFSET
|
||||||
|
|
||||||
#define index_Fast_Rep_String FEATURE_INDEX_1*FEATURE_SIZE
|
#define index_Fast_Rep_String FEATURE_INDEX_1*FEATURE_SIZE
|
||||||
|
|
||||||
#else /* __ASSEMBLER__ */
|
#else /* __ASSEMBLER__ */
|
||||||
|
|
||||||
#include <sys/param.h>
|
# include <sys/param.h>
|
||||||
|
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
@ -84,20 +86,22 @@ extern void __init_cpu_features (void) attribute_hidden;
|
|||||||
extern const struct cpu_features *__get_cpu_features (void)
|
extern const struct cpu_features *__get_cpu_features (void)
|
||||||
__attribute__ ((const));
|
__attribute__ ((const));
|
||||||
|
|
||||||
#ifndef NOT_IN_libc
|
# ifndef NOT_IN_libc
|
||||||
# define __get_cpu_features() (&__cpu_features)
|
# define __get_cpu_features() (&__cpu_features)
|
||||||
#endif
|
# endif
|
||||||
|
|
||||||
#define HAS_CPU_FEATURE(idx, reg, bit) \
|
# define HAS_CPU_FEATURE(idx, reg, bit) \
|
||||||
((__get_cpu_features ()->cpuid[idx].reg & (1 << (bit))) != 0)
|
((__get_cpu_features ()->cpuid[idx].reg & (1 << (bit))) != 0)
|
||||||
|
|
||||||
/* Following are the feature tests used throughout libc. */
|
/* Following are the feature tests used throughout libc. */
|
||||||
|
|
||||||
#define HAS_SSE2 HAS_CPU_FEATURE (COMMON_CPUID_INDEX_1, edx, 26)
|
# define HAS_SSE2 HAS_CPU_FEATURE (COMMON_CPUID_INDEX_1, edx, 26)
|
||||||
#define HAS_POPCOUNT HAS_CPU_FEATURE (COMMON_CPUID_INDEX_1, ecx, 23)
|
# define HAS_POPCOUNT HAS_CPU_FEATURE (COMMON_CPUID_INDEX_1, ecx, 23)
|
||||||
#define HAS_SSE4_2 HAS_CPU_FEATURE (COMMON_CPUID_INDEX_1, ecx, 20)
|
# define HAS_SSSE3 HAS_CPU_FEATURE (COMMON_CPUID_INDEX_1, ecx, 9)
|
||||||
#define HAS_FMA HAS_CPU_FEATURE (COMMON_CPUID_INDEX_1, ecx, 12)
|
# define HAS_SSE4_1 HAS_CPU_FEATURE (COMMON_CPUID_INDEX_1, ecx, 19)
|
||||||
|
# define HAS_SSE4_2 HAS_CPU_FEATURE (COMMON_CPUID_INDEX_1, ecx, 20)
|
||||||
|
# define HAS_FMA HAS_CPU_FEATURE (COMMON_CPUID_INDEX_1, ecx, 12)
|
||||||
|
|
||||||
#define index_Fast_Rep_String FEATURE_INDEX_1
|
# define index_Fast_Rep_String FEATURE_INDEX_1
|
||||||
|
|
||||||
#endif /* __ASSEMBLER__ */
|
#endif /* __ASSEMBLER__ */
|
||||||
|
Loading…
Reference in New Issue
Block a user