Skip to content

Commit

Permalink
cpuinfo: Patched to compile on Android, Linux.
Browse files Browse the repository at this point in the history
  • Loading branch information
icculus committed Nov 17, 2016
1 parent e8f4b7c commit a298e56
Showing 1 changed file with 13 additions and 18 deletions.
31 changes: 13 additions & 18 deletions src/cpuinfo/SDL_cpuinfo.c
Expand Up @@ -50,10 +50,11 @@
#include <setjmp.h>
#endif

#if defined(__LINUX__) || defined(__ANDROID__) && defined(__ARM_ARCH)
#include <sys/auxv.h>
#if (defined(__LINUX__) || defined(__ANDROID__)) && defined(__ARM_ARCH)
#include <asm/hwcap.h>
#if !defined HAVE_GETAUXVAL
#if defined HAVE_GETAUXVAL
#include <sys/auxv.h>
#else
#include <fcntl.h>
#endif
#endif
Expand Down Expand Up @@ -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
Expand All @@ -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;
Expand Down

0 comments on commit a298e56

Please sign in to comment.