Mercurial > libavcodec.hg
diff ppc/check_altivec.c @ 5757:ace63c809071 libavcodec
Remove uses of SIGILL for CPU extension detection, that method is not acceptable
in a library.
Should not change anything for PPC, the autodetection is currently pointless due
to other code being compiled with -maltivec as well (and detection for OSX and
AmigaOS remains in place).
SPARC binaries built with VIS support can now only run on systems with VIS.
author | reimar |
---|---|
date | Tue, 02 Oct 2007 18:18:35 +0000 |
parents | 09f99af1db40 |
children | eb2e3c3b7f78 |
line wrap: on
line diff
--- a/ppc/check_altivec.c Tue Oct 02 14:35:20 2007 +0000 +++ b/ppc/check_altivec.c Tue Oct 02 18:18:35 2007 +0000 @@ -28,23 +28,6 @@ #include <exec/exec.h> #include <interfaces/exec.h> #include <proto/exec.h> -#else -#include <signal.h> -#include <setjmp.h> - -static sigjmp_buf jmpbuf; -static volatile sig_atomic_t canjump = 0; - -static void sigill_handler (int sig) -{ - if (!canjump) { - signal (sig, SIG_DFL); - raise (sig); - } - - canjump = 0; - siglongjmp (jmpbuf, 1); -} #endif /* __APPLE__ */ /** @@ -72,24 +55,9 @@ if (err == 0) return (has_vu != 0); return 0; #else -/* Do it the brute-force way, borrowed from the libmpeg2 library. */ - { - signal (SIGILL, sigill_handler); - if (sigsetjmp (jmpbuf, 1)) { - signal (SIGILL, SIG_DFL); - } else { - canjump = 1; - - asm volatile ("mtspr 256, %0\n\t" - "vand %%v0, %%v0, %%v0" - : - : "r" (-1)); - - signal (SIGILL, SIG_DFL); - return 1; - } - } - return 0; + // since we were compiled for altivec, just assume we have it + // until someone comes up with a proper way (not involving signal hacks). + return 1; #endif /* __AMIGAOS4__ */ }