Check if SSE is available with HAS_CPU_FEATURE

Similar to other CPU feature checks, check if SSE is available with
HAS_CPU_FEATURE.

	* sysdeps/i386/fpu/fclrexcpt.c (__feclearexcept): Use
	HAS_CPU_FEATURE to check for SSE.
	* sysdeps/i386/fpu/fedisblxcpt.c (fedisableexcept): Likewise.
	* sysdeps/i386/fpu/feenablxcpt.c (feenableexcept): Likewise.
	* sysdeps/i386/fpu/fegetenv.c (__fegetenv): Likewise.
	* sysdeps/i386/fpu/fegetmode.c (fegetmode): Likewise.
	* sysdeps/i386/fpu/feholdexcpt.c (__feholdexcept): Likewise.
	* sysdeps/i386/fpu/fesetenv.c (__fesetenv): Likewise.
	* sysdeps/i386/fpu/fesetmode.c (fesetmode): Likewise.
	* sysdeps/i386/fpu/fesetround.c (__fesetround): Likewise.
	* sysdeps/i386/fpu/feupdateenv.c (__feupdateenv): Likewise.
	* sysdeps/i386/fpu/fgetexcptflg.c (__fegetexceptflag): Likewise.
	* sysdeps/i386/fpu/fsetexcptflg.c (__fesetexceptflag): Likewise.
	* sysdeps/i386/fpu/ftestexcept.c (fetestexcept): Likewise.
	* sysdeps/i386/setfpucw.c (__setfpucw): Likewise.
	* sysdeps/x86/cpu-features.h (bit_cpu_SSE): New.
	(index_cpu_SSE): Likewise.
	(reg_SSE): Likewise.
This commit is contained in:
H.J. Lu 2017-04-07 07:44:40 -07:00
parent 893ba3eac9
commit bf7730194f
16 changed files with 39 additions and 14 deletions

View File

@ -1,3 +1,24 @@
2017-04-07 H.J. Lu <hongjiu.lu@intel.com>
* sysdeps/i386/fpu/fclrexcpt.c (__feclearexcept): Use
HAS_CPU_FEATURE to check for SSE.
* sysdeps/i386/fpu/fedisblxcpt.c (fedisableexcept): Likewise.
* sysdeps/i386/fpu/feenablxcpt.c (feenableexcept): Likewise.
* sysdeps/i386/fpu/fegetenv.c (__fegetenv): Likewise.
* sysdeps/i386/fpu/fegetmode.c (fegetmode): Likewise.
* sysdeps/i386/fpu/feholdexcpt.c (__feholdexcept): Likewise.
* sysdeps/i386/fpu/fesetenv.c (__fesetenv): Likewise.
* sysdeps/i386/fpu/fesetmode.c (fesetmode): Likewise.
* sysdeps/i386/fpu/fesetround.c (__fesetround): Likewise.
* sysdeps/i386/fpu/feupdateenv.c (__feupdateenv): Likewise.
* sysdeps/i386/fpu/fgetexcptflg.c (__fegetexceptflag): Likewise.
* sysdeps/i386/fpu/fsetexcptflg.c (__fesetexceptflag): Likewise.
* sysdeps/i386/fpu/ftestexcept.c (fetestexcept): Likewise.
* sysdeps/i386/setfpucw.c (__setfpucw): Likewise.
* sysdeps/x86/cpu-features.h (bit_cpu_SSE): New.
(index_cpu_SSE): Likewise.
(reg_SSE): Likewise.
2017-04-07 Paul Eggert <eggert@cs.ucla.edu> 2017-04-07 Paul Eggert <eggert@cs.ucla.edu>
* posix/getopt1.c: Include <config.h>, not "config.h". * posix/getopt1.c: Include <config.h>, not "config.h".

View File

@ -41,7 +41,7 @@ __feclearexcept (int excepts)
__asm__ ("fldenv %0" : : "m" (*&temp)); __asm__ ("fldenv %0" : : "m" (*&temp));
/* If the CPU supports SSE, we clear the MXCSR as well. */ /* If the CPU supports SSE, we clear the MXCSR as well. */
if ((GLRO(dl_hwcap) & HWCAP_I386_XMM) != 0) if (HAS_CPU_FEATURE (SSE))
{ {
unsigned int xnew_exc; unsigned int xnew_exc;

View File

@ -38,7 +38,7 @@ fedisableexcept (int excepts)
__asm__ ("fldcw %0" : : "m" (*&new_exc)); __asm__ ("fldcw %0" : : "m" (*&new_exc));
/* If the CPU supports SSE we set the MXCSR as well. */ /* If the CPU supports SSE we set the MXCSR as well. */
if ((GLRO(dl_hwcap) & HWCAP_I386_XMM) != 0) if (HAS_CPU_FEATURE (SSE))
{ {
unsigned int xnew_exc; unsigned int xnew_exc;

View File

@ -38,7 +38,7 @@ feenableexcept (int excepts)
__asm__ ("fldcw %0" : : "m" (*&new_exc)); __asm__ ("fldcw %0" : : "m" (*&new_exc));
/* If the CPU supports SSE we set the MXCSR as well. */ /* If the CPU supports SSE we set the MXCSR as well. */
if ((GLRO(dl_hwcap) & HWCAP_I386_XMM) != 0) if (HAS_CPU_FEATURE (SSE))
{ {
unsigned int xnew_exc; unsigned int xnew_exc;

View File

@ -31,7 +31,7 @@ __fegetenv (fenv_t *envp)
would block all exceptions. */ would block all exceptions. */
__asm__ ("fldenv %0" : : "m" (*envp)); __asm__ ("fldenv %0" : : "m" (*envp));
if ((GLRO(dl_hwcap) & HWCAP_I386_XMM) != 0) if (HAS_CPU_FEATURE (SSE))
__asm__ ("stmxcsr %0" : "=m" (envp->__eip)); __asm__ ("stmxcsr %0" : "=m" (envp->__eip));
/* Success. */ /* Success. */

View File

@ -26,7 +26,7 @@ int
fegetmode (femode_t *modep) fegetmode (femode_t *modep)
{ {
_FPU_GETCW (modep->__control_word); _FPU_GETCW (modep->__control_word);
if ((GLRO(dl_hwcap) & HWCAP_I386_XMM) != 0) if (HAS_CPU_FEATURE (SSE))
__asm__ ("stmxcsr %0" : "=m" (modep->__mxcsr)); __asm__ ("stmxcsr %0" : "=m" (modep->__mxcsr));
return 0; return 0;
} }

View File

@ -30,7 +30,7 @@ __feholdexcept (fenv_t *envp)
__asm__ volatile ("fnstenv %0; fnclex" : "=m" (*envp)); __asm__ volatile ("fnstenv %0; fnclex" : "=m" (*envp));
/* If the CPU supports SSE we set the MXCSR as well. */ /* If the CPU supports SSE we set the MXCSR as well. */
if ((GLRO(dl_hwcap) & HWCAP_I386_XMM) != 0) if (HAS_CPU_FEATURE (SSE))
{ {
unsigned int xwork; unsigned int xwork;

View File

@ -79,7 +79,7 @@ __fesetenv (const fenv_t *envp)
__asm__ ("fldenv %0" : : "m" (temp)); __asm__ ("fldenv %0" : : "m" (temp));
if ((GLRO(dl_hwcap) & HWCAP_I386_XMM) != 0) if (HAS_CPU_FEATURE (SSE))
{ {
unsigned int mxcsr; unsigned int mxcsr;
__asm__ ("stmxcsr %0" : "=m" (mxcsr)); __asm__ ("stmxcsr %0" : "=m" (mxcsr));

View File

@ -35,7 +35,7 @@ fesetmode (const femode_t *modep)
else else
cw = modep->__control_word; cw = modep->__control_word;
_FPU_SETCW (cw); _FPU_SETCW (cw);
if ((GLRO(dl_hwcap) & HWCAP_I386_XMM) != 0) if (HAS_CPU_FEATURE (SSE))
{ {
unsigned int mxcsr; unsigned int mxcsr;
__asm__ ("stmxcsr %0" : "=m" (mxcsr)); __asm__ ("stmxcsr %0" : "=m" (mxcsr));

View File

@ -37,7 +37,7 @@ __fesetround (int round)
__asm__ ("fldcw %0" : : "m" (*&cw)); __asm__ ("fldcw %0" : : "m" (*&cw));
/* If the CPU supports SSE we set the MXCSR as well. */ /* If the CPU supports SSE we set the MXCSR as well. */
if ((GLRO(dl_hwcap) & HWCAP_I386_XMM) != 0) if (HAS_CPU_FEATURE (SSE))
{ {
unsigned int xcw; unsigned int xcw;

View File

@ -32,7 +32,7 @@ __feupdateenv (const fenv_t *envp)
__asm__ ("fnstsw %0" : "=m" (*&temp)); __asm__ ("fnstsw %0" : "=m" (*&temp));
/* If the CPU supports SSE we test the MXCSR as well. */ /* If the CPU supports SSE we test the MXCSR as well. */
if ((GLRO(dl_hwcap) & HWCAP_I386_XMM) != 0) if (HAS_CPU_FEATURE (SSE))
__asm__ ("stmxcsr %0" : "=m" (*&xtemp)); __asm__ ("stmxcsr %0" : "=m" (*&xtemp));
temp = (temp | xtemp) & FE_ALL_EXCEPT; temp = (temp | xtemp) & FE_ALL_EXCEPT;

View File

@ -34,7 +34,7 @@ __fegetexceptflag (fexcept_t *flagp, int excepts)
*flagp = temp & excepts & FE_ALL_EXCEPT; *flagp = temp & excepts & FE_ALL_EXCEPT;
/* If the CPU supports SSE, we clear the MXCSR as well. */ /* If the CPU supports SSE, we clear the MXCSR as well. */
if ((GLRO(dl_hwcap) & HWCAP_I386_XMM) != 0) if (HAS_CPU_FEATURE (SSE))
{ {
unsigned int sse_exc; unsigned int sse_exc;

View File

@ -41,7 +41,7 @@ __fesetexceptflag (const fexcept_t *flagp, int excepts)
__asm__ ("fldenv %0" : : "m" (*&temp)); __asm__ ("fldenv %0" : : "m" (*&temp));
/* If the CPU supports SSE, we set the MXCSR as well. */ /* If the CPU supports SSE, we set the MXCSR as well. */
if ((GLRO(dl_hwcap) & HWCAP_I386_XMM) != 0) if (HAS_CPU_FEATURE (SSE))
{ {
unsigned int xnew_exc; unsigned int xnew_exc;

View File

@ -32,7 +32,7 @@ fetestexcept (int excepts)
__asm__ ("fnstsw %0" : "=a" (temp)); __asm__ ("fnstsw %0" : "=a" (temp));
/* If the CPU supports SSE we test the MXCSR as well. */ /* If the CPU supports SSE we test the MXCSR as well. */
if ((GLRO(dl_hwcap) & HWCAP_I386_XMM) != 0) if (HAS_CPU_FEATURE (SSE))
__asm__ ("stmxcsr %0" : "=m" (*&xtemp)); __asm__ ("stmxcsr %0" : "=m" (*&xtemp));
return (temp | xtemp) & excepts & FE_ALL_EXCEPT; return (temp | xtemp) & excepts & FE_ALL_EXCEPT;

View File

@ -39,7 +39,7 @@ __setfpucw (fpu_control_t set)
__asm__ ("fldcw %0" : : "m" (*&cw)); __asm__ ("fldcw %0" : : "m" (*&cw));
/* If the CPU supports SSE, we set the MXCSR as well. */ /* If the CPU supports SSE, we set the MXCSR as well. */
if ((GLRO(dl_hwcap) & HWCAP_I386_XMM) != 0) if (HAS_CPU_FEATURE (SSE))
{ {
unsigned int xnew_exc; unsigned int xnew_exc;

View File

@ -45,6 +45,7 @@
/* COMMON_CPUID_INDEX_1. */ /* COMMON_CPUID_INDEX_1. */
#define bit_cpu_CX8 (1 << 8) #define bit_cpu_CX8 (1 << 8)
#define bit_cpu_CMOV (1 << 15) #define bit_cpu_CMOV (1 << 15)
#define bit_cpu_SSE (1 << 25)
#define bit_cpu_SSE2 (1 << 26) #define bit_cpu_SSE2 (1 << 26)
#define bit_cpu_SSSE3 (1 << 9) #define bit_cpu_SSSE3 (1 << 9)
#define bit_cpu_SSE4_1 (1 << 19) #define bit_cpu_SSE4_1 (1 << 19)
@ -82,6 +83,7 @@
# define index_cpu_CX8 COMMON_CPUID_INDEX_1*CPUID_SIZE+CPUID_EDX_OFFSET # define index_cpu_CX8 COMMON_CPUID_INDEX_1*CPUID_SIZE+CPUID_EDX_OFFSET
# define index_cpu_CMOV COMMON_CPUID_INDEX_1*CPUID_SIZE+CPUID_EDX_OFFSET # define index_cpu_CMOV COMMON_CPUID_INDEX_1*CPUID_SIZE+CPUID_EDX_OFFSET
# define index_cpu_SSE COMMON_CPUID_INDEX_1*CPUID_SIZE+CPUID_EDX_OFFSET
# define index_cpu_SSE2 COMMON_CPUID_INDEX_1*CPUID_SIZE+CPUID_EDX_OFFSET # define index_cpu_SSE2 COMMON_CPUID_INDEX_1*CPUID_SIZE+CPUID_EDX_OFFSET
# define index_cpu_SSSE3 COMMON_CPUID_INDEX_1*CPUID_SIZE+CPUID_ECX_OFFSET # define index_cpu_SSSE3 COMMON_CPUID_INDEX_1*CPUID_SIZE+CPUID_ECX_OFFSET
# define index_cpu_SSE4_1 COMMON_CPUID_INDEX_1*CPUID_SIZE+CPUID_ECX_OFFSET # define index_cpu_SSE4_1 COMMON_CPUID_INDEX_1*CPUID_SIZE+CPUID_ECX_OFFSET
@ -228,6 +230,7 @@ extern const struct cpu_features *__get_cpu_features (void)
# define index_cpu_CX8 COMMON_CPUID_INDEX_1 # define index_cpu_CX8 COMMON_CPUID_INDEX_1
# define index_cpu_CMOV COMMON_CPUID_INDEX_1 # define index_cpu_CMOV COMMON_CPUID_INDEX_1
# define index_cpu_SSE COMMON_CPUID_INDEX_1
# define index_cpu_SSE2 COMMON_CPUID_INDEX_1 # define index_cpu_SSE2 COMMON_CPUID_INDEX_1
# define index_cpu_SSSE3 COMMON_CPUID_INDEX_1 # define index_cpu_SSSE3 COMMON_CPUID_INDEX_1
# define index_cpu_SSE4_1 COMMON_CPUID_INDEX_1 # define index_cpu_SSE4_1 COMMON_CPUID_INDEX_1
@ -246,6 +249,7 @@ extern const struct cpu_features *__get_cpu_features (void)
# define reg_CX8 edx # define reg_CX8 edx
# define reg_CMOV edx # define reg_CMOV edx
# define reg_SSE edx
# define reg_SSE2 edx # define reg_SSE2 edx
# define reg_SSSE3 ecx # define reg_SSSE3 ecx
# define reg_SSE4_1 ecx # define reg_SSE4_1 ecx