[FFmpeg-cvslog] ppc: linux: Check altivec using the auxv

Luca Barbato git at videolan.org
Sun May 31 22:19:04 CEST 2015


ffmpeg | branch: master | Luca Barbato <lu_zero at gentoo.org> | Fri Apr  3 15:31:32 2015 +0200| [baa94563fede8959a638b0fa132dd2124acd93e8] | committer: Luca Barbato

ppc: linux: Check altivec using the auxv

Should prevent trying to use altivec when it is disabled by the kernel.

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=baa94563fede8959a638b0fa132dd2124acd93e8
---

 libavutil/ppc/cpu.c |   31 +++++++++++++++++++++++++++++++
 1 file changed, 31 insertions(+)

diff --git a/libavutil/ppc/cpu.c b/libavutil/ppc/cpu.c
index 50107e1..2ceb88a 100644
--- a/libavutil/ppc/cpu.c
+++ b/libavutil/ppc/cpu.c
@@ -18,6 +18,11 @@
 
 #ifdef __APPLE__
 #include <sys/sysctl.h>
+#elif defined(__linux__)
+#include <asm/cputable.h>
+#include <linux/auxvec.h>
+#include <fcntl.h>
+#include <unistd.h>
 #elif defined(__OpenBSD__)
 #include <sys/param.h>
 #include <sys/sysctl.h>
@@ -62,6 +67,32 @@ int ff_get_cpu_flags_ppc(void)
     if (err == 0)
         return has_vu ? AV_CPU_FLAG_ALTIVEC : 0;
     return 0;
+#elif defined(__linux__)
+    // The linux kernel could have the altivec support disabled
+    // even if the cpu has it.
+    int i, ret = 0;
+    int fd = open("/proc/self/auxv", O_RDONLY);
+    unsigned long buf[64] = { 0 };
+    ssize_t count;
+
+    if (fd < 0)
+        return 0;
+
+    while ((count = read(fd, buf, sizeof(buf))) > 0) {
+        for (i = 0; i < count / sizeof(*buf); i += 2) {
+            if (buf[i] == AT_NULL)
+                goto out;
+            if (buf[i] == AT_HWCAP) {
+                if (buf[i + 1] & PPC_FEATURE_HAS_ALTIVEC)
+                    ret = AV_CPU_FLAG_ALTIVEC;
+                goto out;
+            }
+        }
+    }
+
+out:
+    close(fd);
+    return ret;
 #elif CONFIG_RUNTIME_CPUDETECT
     int proc_ver;
     // Support of mfspr PVR emulation added in Linux 2.6.17.



More information about the ffmpeg-cvslog mailing list