Mercurial > libavcodec.hg
diff sparc/dsputil_vis.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 | c0f471cc871d |
| children | a73ecbffc421 |
line wrap: on
line diff
--- a/sparc/dsputil_vis.c Tue Oct 02 14:35:20 2007 +0000 +++ b/sparc/dsputil_vis.c Tue Oct 02 18:18:35 2007 +0000 @@ -26,8 +26,6 @@ #include "config.h" #include <inttypes.h> -#include <signal.h> -#include <setjmp.h> #include "dsputil.h" @@ -3987,56 +3985,13 @@ /* End of no rounding code */ -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); -} - #define ACCEL_SPARC_VIS 1 #define ACCEL_SPARC_VIS2 2 static int vis_level () { - int accel = 0; - - signal (SIGILL, sigill_handler); - if (sigsetjmp (jmpbuf, 1)) { - signal (SIGILL, SIG_DFL); - return accel; - } - - canjump = 1; - - /* pdist %f0, %f0, %f0 */ - __asm__ __volatile__(".word\t0x81b007c0"); - - canjump = 0; accel |= ACCEL_SPARC_VIS; - - if (sigsetjmp (jmpbuf, 1)) { - signal (SIGILL, SIG_DFL); - return accel; - } - - canjump = 1; - - /* edge8n %g0, %g0, %g0 */ - __asm__ __volatile__(".word\t0x81b00020"); - - canjump = 0; accel |= ACCEL_SPARC_VIS2; - - signal (SIGILL, SIG_DFL); - return accel; }
