devel/sdl20: correctly detect altivec
The previous patch was not correct. Already upstreamed.
This commit is contained in:
parent
52ed0237f8
commit
ece0c9bb06
2 changed files with 29 additions and 20 deletions
|
@ -1,6 +1,6 @@
|
|||
PORTNAME= sdl2
|
||||
PORTVERSION= 2.0.12
|
||||
PORTREVISION= 6
|
||||
PORTREVISION= 7
|
||||
CATEGORIES= devel
|
||||
MASTER_SITES= https://www.libsdl.org/release/
|
||||
DISTNAME= SDL2-${PORTVERSION}
|
||||
|
|
|
@ -1,24 +1,33 @@
|
|||
--- src/cpuinfo/SDL_cpuinfo.c.orig 2020-03-11 01:36:18 UTC
|
||||
+++ src/cpuinfo/SDL_cpuinfo.c
|
||||
@@ -49,7 +49,7 @@
|
||||
#endif
|
||||
#if defined(__MACOSX__) && (defined(__ppc__) || defined(__ppc64__))
|
||||
#include <sys/sysctl.h> /* For AltiVec check */
|
||||
-#elif defined(__OpenBSD__) && defined(__powerpc__)
|
||||
+#elif (defined(__OpenBSD__) || defined(__FreeBSD__)) && defined(__powerpc__)
|
||||
@@ -53,6 +53,9 @@
|
||||
#include <sys/param.h>
|
||||
#include <sys/sysctl.h> /* For AltiVec check */
|
||||
#include <machine/cpu.h>
|
||||
@@ -314,9 +314,11 @@ CPU_haveAltiVec(void)
|
||||
{
|
||||
volatile int altivec = 0;
|
||||
#ifndef SDL_CPUINFO_DISABLED
|
||||
-#if (defined(__MACOSX__) && (defined(__ppc__) || defined(__ppc64__))) || (defined(__OpenBSD__) && defined(__powerpc__))
|
||||
+#if (defined(__MACOSX__) && (defined(__ppc__) || defined(__ppc64__))) || (defined(__OpenBSD__) && defined(__powerpc__)) || (defined(__FreeBSD__) && defined(__powerpc__))
|
||||
#ifdef __OpenBSD__
|
||||
int selectors[2] = { CTL_MACHDEP, CPU_ALTIVEC };
|
||||
+#elif __FreeBSD__
|
||||
+ int selectors[2] = { CTL_HW, PPC_FEATURE_HAS_ALTIVEC };
|
||||
#else
|
||||
int selectors[2] = { CTL_HW, HW_VECTORUNIT };
|
||||
#endif
|
||||
+#elif defined(__FreeBSD__) && defined(__powerpc__)
|
||||
+#include <machine/cpu.h>
|
||||
+#include <sys/auxv.h>
|
||||
#elif SDL_ALTIVEC_BLITTERS && HAVE_SETJMP
|
||||
#include <signal.h>
|
||||
#include <setjmp.h>
|
||||
@@ -110,7 +113,7 @@
|
||||
#define CPU_HAS_AVX512F (1 << 12)
|
||||
#define CPU_HAS_ARM_SIMD (1 << 13)
|
||||
|
||||
-#if SDL_ALTIVEC_BLITTERS && HAVE_SETJMP && !__MACOSX__ && !__OpenBSD__
|
||||
+#if SDL_ALTIVEC_BLITTERS && HAVE_SETJMP && !__MACOSX__ && !__OpenBSD__ && !__FreeBSD__
|
||||
/* This is the brute force way of detecting instruction sets...
|
||||
the idea is borrowed from the libmpeg2 library - thanks!
|
||||
*/
|
||||
@@ -325,6 +328,11 @@ CPU_haveAltiVec(void)
|
||||
int error = sysctl(selectors, 2, &hasVectorUnit, &length, NULL, 0);
|
||||
if (0 == error)
|
||||
altivec = (hasVectorUnit != 0);
|
||||
+#elif defined(__FreeBSD__) && defined(__powerpc__)
|
||||
+ unsigned long cpufeatures;
|
||||
+ elf_aux_info(AT_HWCAP, &cpufeatures, sizeof(cpufeatures));
|
||||
+ altivec = cpufeatures & PPC_FEATURE_HAS_ALTIVEC;
|
||||
+ return altivec;
|
||||
#elif SDL_ALTIVEC_BLITTERS && HAVE_SETJMP
|
||||
void (*handler) (int sig);
|
||||
handler = signal(SIGILL, illegal_instruction);
|
||||
|
|
Loading…
Reference in a new issue