diff --git a/src/cpuinfo/SDL_cpuinfo.c b/src/cpuinfo/SDL_cpuinfo.c index 5366fbb6d..b241cb51b 100644 --- a/src/cpuinfo/SDL_cpuinfo.c +++ b/src/cpuinfo/SDL_cpuinfo.c @@ -50,10 +50,11 @@ #include #endif -#if defined(__LINUX__) || defined(__ANDROID__) && defined(__ARM_ARCH) -#include +#if (defined(__LINUX__) || defined(__ANDROID__)) && defined(__ARM_ARCH) #include -#if !defined HAVE_GETAUXVAL +#if defined HAVE_GETAUXVAL +#include +#else #include #endif #endif @@ -297,27 +298,22 @@ CPU_haveAltiVec(void) return altivec; } -#if (defined(__LINUX__) || defined(__ANDROID__)) && !defined(HAVE_GETAUXVAL) +#if (defined(__LINUX__) || defined(__ANDROID__)) && defined(__ARM_ARCH) && !defined(HAVE_GETAUXVAL) static int readProcAuxvForNeon(void) { int neon = 0; int kv[2]; const int fd = open("/proc/self/auxv", O_RDONLY); - - if (fd == -1) { - return 0; - } - - while (read(fd, kv, sizeof (kv)) == sizeof (kv)) { - if (kv[0] == AT_HWCAP) { - neon = ((kv[1] & HWCAP_NEON) == HWCAP_NEON); - break; + if (fd != -1) { + while (read(fd, kv, sizeof (kv)) == sizeof (kv)) { + if (kv[0] == AT_HWCAP) { + neon = ((kv[1] & HWCAP_NEON) == HWCAP_NEON); + break; + } } + close(fd); } - - close(fd); - return neon; } #endif @@ -338,11 +334,10 @@ CPU_haveNEON(void) size_t length = sizeof (neon); const int error = sysctlbyname("hw.optional.neon", &neon, &length, NULL, 0); return (!error) && (neon != 0); -/* Android offers a static library for this but all it does is parse /proc/cpuinfo */ #elif (defined(__LINUX__) || defined(__ANDROID__)) && defined(HAVE_GETAUXVAL) return ((getauxval(AT_HWCAP) & HWCAP_NEON) == HWCAP_NEON) #elif (defined(__LINUX__) || defined(__ANDROID__)) - return readProcAuxvForNeon(); + return readProcAuxvForNeon(); /* Android offers a static library for this, but it just parses /proc/self/auxv */ #elif (defined(__WINDOWS__) || defined(__WINRT__)) && defined(_M_ARM) /* All WinRT ARM devices are required to support NEON, but just in case. */ return IsProcessorFeaturePresent(PF_ARM_NEON_INSTRUCTIONS_AVAILABLE) != 0;